

16

# R9A02G015

## User's Manual: Hardware

## ASSP (USB Power Delivery Controller)

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

Renesas Electronics www.renesas.com

Rev.1.00 Mar 2019

#### 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 or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information.
- Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving 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, including but not limited to, the product data, drawings, charts, programs, algorithms, and application examples.
- 3. 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 shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering.
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended 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; industrial robots; etc.

"High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc.

Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or 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 damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document.

- 6. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified ranges.
- 7. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury, injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, 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 and impractical, you are responsible for evaluating 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. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 9. Renesas Electronics products and technologies shall 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 shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions.
- 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third party in advance of the contents and conditions set forth in this document.
- 11. This document shall not be reprinted, 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.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

## 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. Precaution against Electrostatic Discharge (ESD)

A strong electrical field, when exposed to a CMOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop the generation of static electricity as much as possible, and quickly dissipate it when it occurs. Environmental control must be adequate. When it is dry, a humidifier should be used. This is recommended to avoid using insulators that can 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 must be grounded. The operator must also be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions must be taken for printed circuit boards with mounted semiconductor devices.

2. Processing at power-on

The state of the product is undefined at the time when power is supplied. The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the time 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 time 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 time when power is supplied until the power is supplied until the power is supplied until the power reaches the level at which resetting is specified.

3. Input of signal during power-off state

Do not input signals or an I/O pull-up power supply while the device is powered off. 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. Follow the guideline for input signal during power-off state as described in your product documentation.

4. Handling of unused pins

Handle unused pins in accordance with the directions given under handling of unused pins in the manual. 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 the 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.

5. Clock signals

After applying a reset, only release the reset line after the operating clock signal becomes stable. When switching the clock signal during program execution, wait until the target clock signal is 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. Additionally, 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.
6. 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  $V_{IL}$  (Max.) and  $V_{IH}$  (Min.) due to noise, for example, 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  $V_{IL}$  (Max.) and  $V_{IH}$  (Min.).

7. Prohibition of access to reserved addresses

Access to reserved addresses is prohibited. The reserved addresses are provided for possible future expansion of functions. Do not access these addresses as the correct operation of the LSI is not guaranteed.

8. Differences between products

Before changing from one product to another, for example to a product with a different part number, confirm that the change will not lead to problems. The characteristics of a microprocessing unit or microcontroller unit products in the same group but having a different part number might differ in terms of 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.

## How to Use This Manual

ReadersThis manual is intended for user engineers who wish to understand the functions of the<br/>R9A02G015 and design and develop application systems and programs for these devices.<br/>The target products are as follows.

• 32-pin: R9A02G0150/R9A02G0151

 Purpose
 This manual is intended to give users an understanding of the functions described in the

 Organization below.

OrganizationThe R9A02G015 manual is separated into three parts: this manual, Data Sheet, and the<br/>software edition (common to the RL78 family).

#### R9A02G015 User's Manual: Hardware (This Manual)

Pin functions

Internal block functions

Interrupts

· Other on-chip peripheral functions

#### RL78 Family User's Manual: Software

- CPU functions
- Instruction set
- Explanation of each instruction

R9A02G015 Data Sheet

- Electrical specifications
- Package drawings

How to Read This Manual It is assumed that the readers of this manual have general knowledge of electrical engineering, logic circuits, and microcontrollers.

- To gain a general understanding of functions:
  - $\rightarrow$  Read this manual in the order of the **CONTENTS**.
- How to interpret the register format:
  - → For a bit number enclosed in angle brackets, the bit name is defined as a reserved word in the assembler, and is defined as an sfr variable using the #pragma sfr directive in the compiler.
- To know details of the R9A02G015 (built in RL78 CPU core) instructions:
- → Refer to the separate document RL78 Family User's Manual Software (R01US0015E).

| Conventions | Data significance:          | Higher digits on the left and lower digits on the right                        |
|-------------|-----------------------------|--------------------------------------------------------------------------------|
|             | Active low representations: | $\overline{\times \times \times}$ (overscore over pin and signal name) or xxxB |
|             | Note:                       | Footnote for item marked with Note in the text                                 |
|             | Caution:                    | Information requiring particular attention                                     |
|             | Remark:                     | Supplementary information                                                      |
|             | Numerical representations:  | Binary×××× or ××××B                                                            |
|             |                             | Decimal××××                                                                    |
|             |                             | Hexadecimal××××H                                                               |
|             |                             |                                                                                |

Related Documents
 The related documents indicated in this publication may include preliminary versions.

 However, preliminary versions are not marked as such.
 However, preliminary versions are not marked as such.

#### **Documents Related to Devices**

| Document Name                       | Document No. |
|-------------------------------------|--------------|
| R9A02G015 User's Manual: Hardware   | This manual  |
| R9A02G015 Data Sheet                | R19DS0101E   |
| RL78 Family User's Manual: Software | R01US0015E   |

#### Documents Related to Flash Memory Programming (User's Manual)

| Document Name                                                            | Document No. |
|--------------------------------------------------------------------------|--------------|
| PG-FP6 Flash Memory Programmer User's Manual                             | R20UT4025E   |
| E1 Emulator R0E000010KCE00 E20 Emulator R0E000200KCT00 User's Manual     | R20UT0398E   |
| E2 Emulator RTE0T00020KCE00000R User's Manual                            | R20UT3538E   |
| E2 Emulator Lite RTE0T0002LKCE00000R User's Manual                       | R20UT3240E   |
| Renesas Flash Programmer Flash Memory Programming Software User's Manual | R20UT4066E   |
| Renesas Flash Development Toolkit User's Manual                          | R20UT0508E   |

## Caution The related documents listed above are subject to change without notice. Be sure to use the latest version of each document when designing.

#### **Other Documents**

| Document Name                        | Document No. |
|--------------------------------------|--------------|
| Renesas Microcontrollers RL78 Family | R01CP0003E   |
| Semiconductor Package Mount Manual   | R50ZZ0003E   |
| Semiconductor Reliability Handbook   | R51ZZ0001E   |

## Caution The related documents listed above are subject to change without notice. Be sure to use the latest version of each document when designing.

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

EEPROM is a trademark of Renesas Electronics Corporation.

SuperFlash is a registered trademark of Silicon Storage Technology, Inc. in several countries including the United States and Japan.

Caution: This product uses SuperFlash® technology licensed from Silicon Storage Technology, Inc.

## CONTENTS

| 1. OL  | ITLINE                                                                           | 17 |
|--------|----------------------------------------------------------------------------------|----|
| 1.1    | Features                                                                         | 17 |
| 1.2    | Ordering Information                                                             | 19 |
| 1.3    | Pin Configuration (Top View)                                                     | 20 |
| 1.3.1  | 32-pin product (with USB)                                                        | 20 |
| 1.3.2  | 32-pin product (without USB)                                                     | 21 |
| 1.4    | Pin Identification                                                               | 22 |
| 1.5    | Block Diagram                                                                    | 23 |
| 1.5.1  | 32-pin products                                                                  | 23 |
| 1.6    | Outline of Functions                                                             | 24 |
| 2. PIN | N FUNCTIONS                                                                      | 26 |
| 2.1    | Port Functions                                                                   | 26 |
| 2.1.1  | 32-pin Products                                                                  | 26 |
| 2.2    | Functions other than port pins                                                   | 28 |
| 2.3    | Connection of Unused Pins                                                        |    |
| 2.4    | Pin Block Diagrams                                                               |    |
|        |                                                                                  |    |
| 3. CP  | U ARCHITECTURE                                                                   | 42 |
| 3.1    | Memory Space                                                                     | 43 |
| 3.1.1  | Internal program memory space                                                    | 45 |
| 3.1.2  | Mirror area                                                                      | 47 |
| 3.1.3  | Internal data memory space                                                       | 48 |
| 3.1.4  | Special function register (SFR) area                                             | 49 |
| 3.1.5  | Extended special function register (2nd SFR: 2nd Special Function Register) area | 49 |
| 3.1.6  | Data memory addressing                                                           | 50 |
| 3.2    | Processor Registers                                                              | 51 |
| 3.2.1  | Control registers                                                                | 51 |
| 3.2.2  | General-purpose registers                                                        | 53 |
| 3.2.3  | ES and CS registers                                                              | 54 |
| 3.2.4  | Special function registers (SFRs)                                                | 55 |
| 3.2.5  | Extended special function registers (2nd SFRs: 2nd Special Function Registers)   | 59 |
| 3.3    | Instruction Address Addressing                                                   | 66 |
| 3.3.1  | Relative addressing                                                              | 66 |
| 3.3.2  | Immediate addressing                                                             | 66 |
| 3.3.3  | Table indirect addressing                                                        | 67 |
| 3.3.4  | Register indirect addressing                                                     | 67 |
| 3.4    | Addressing for Processing Data Addresses                                         | 68 |
| 3.4.1  | Implied addressing                                                               |    |
| 3.4.2  | Register addressing                                                              | 68 |
| 3.4.3  | Direct addressing                                                                | 69 |
| 3.4.4  | Short direct addressing                                                          | 70 |
| 3.4.5  | SFR addressing                                                                   | 71 |
| 3.4.6  | Register indirect addressing                                                     | 72 |
| 3.4.7  | Based addressing                                                                 | 73 |

| 3.4.8          | Based indexed addressing                                                   |     |
|----------------|----------------------------------------------------------------------------|-----|
| 3.4.9          | Stack addressing                                                           | 77  |
|                |                                                                            |     |
|                | DRT FUNCTIONS                                                              |     |
| 4.1            | Port Functions                                                             |     |
| 4.2            | Port Configuration                                                         |     |
| 4.2.1          | Port 0                                                                     |     |
| 4.2.2          |                                                                            |     |
| 4.2.3          | Port 4                                                                     |     |
| 4.2.4<br>4.2.5 |                                                                            | -   |
| 4.2.5<br>4.2.6 |                                                                            |     |
| 4.2.0          | Port 7<br>Port 12                                                          |     |
| 4.2.7          |                                                                            |     |
| 4.2.0          | Registers Controlling Port Function                                        |     |
| 4.3.1          | Port mode registers (PMxx)                                                 |     |
| 4.3.2          |                                                                            |     |
| 4.3.3          | Pull-up resistor option registers (PUxx)                                   |     |
| 4.3.4          |                                                                            |     |
| 4.3.5          |                                                                            |     |
| 4.3.6          | Port mode control registers (PMCxx)                                        |     |
| 4.4            | Port Function Operations                                                   |     |
| 4.4.1          | Writing to I/O port                                                        |     |
| 4.4.2          |                                                                            |     |
| 4.4.3          | Operations on I/O port                                                     | 89  |
| 4.4.4          | Handling different potential (1.8 V, 2.5 V) by using I/O buffers           |     |
| 4.5            | Register Settings When Using Alternate Function                            |     |
| 4.5.1          | Basic concept when using alternate function                                |     |
| 4.5.2          | Register settings for alternate function whose output function is not used | 93  |
| 4.5.3          | Register setting examples for used port and alternate functions            |     |
| 4.6            | Cautions When Using Port Function                                          |     |
| 4.6.1          | Cautions on 1-Bit Manipulation Instruction for Port Register n (Pn)        |     |
| 4.6.2          | Notes on specifying the pin settings                                       | 100 |
| F ()           |                                                                            | 101 |
|                | OCK GENERATOR Functions of Clock Generator                                 |     |
| 5.1<br>5.2     | Configuration of Clock Generator                                           |     |
| 5.2<br>5.3     | Registers Controlling Clock Generator                                      |     |
| 5.3.1          | Clock operation mode control register (CMC)                                |     |
| 5.3.2          |                                                                            |     |
| 5.3.3          |                                                                            |     |
| 5.3.4          |                                                                            |     |
| 5.3.5          |                                                                            |     |
| 5.3.6          |                                                                            |     |
| 5.3.7          |                                                                            |     |
| 5.3.8          |                                                                            |     |
| 5.3.9          |                                                                            |     |
| 5.3.1          |                                                                            |     |
| 5.3.1          | 1 Main clock control register (MCKC)                                       | 120 |

| 5.3.12 | USB clock selection register (UCKSEL)                                       | 121 |
|--------|-----------------------------------------------------------------------------|-----|
| 5.4    | System Clock Oscillator                                                     | 122 |
| 5.4.1  | X1 oscillator                                                               | 122 |
| 5.4.2  | High-speed on-chip oscillator                                               | 125 |
| 5.4.3  | Low-speed on-chip oscillator                                                | 125 |
| 5.4.4  | PLL (Phase Locked Loop)                                                     | 125 |
| 5.5    | Clock Generator Operation                                                   | 126 |
| 5.6    | Controlling Clock                                                           | 128 |
| 5.6.1  | Example of setting high-speed on-chip oscillator                            | 128 |
| 5.6.2  | Example of setting X1 oscillation clock                                     | 130 |
| 5.6.3  | Example of setting PLL circuit                                              | 131 |
| 5.6.4  | CPU clock status transition diagram                                         | 133 |
| 5.6.5  | Condition before changing CPU clock and processing after changing CPU clock | 138 |
| 5.6.6  | Time required for switchover of CPU clock and system clock                  | 140 |
| 5.6.7  | Conditions before clock oscillation is stopped                              | 141 |
| 5.7    | Resonator and Oscillator Constants                                          | 142 |
|        |                                                                             |     |
| 6. TIM | ER ARRAY UNIT                                                               | 145 |
| 6.1    | Functions of Timer Array Unit                                               | 146 |
| 6.1.1  | Independent channel operation function                                      | 146 |
| 6.1.2  | Simultaneous channel operation function                                     | 147 |
| 6.1.3  | 8-bit timer operation function (channels 1 and 3 only)                      | 148 |
| 6.2    | Configuration of Timer Array Unit                                           | 149 |
| 6.2.1  | Timer count register mn (TCRmn)                                             | 155 |
| 6.2.2  | Timer data register mn (TDRmn)                                              | 157 |
| 6.3    | Registers Controlling Timer Array Unit                                      | 158 |
| 6.3.1  | Peripheral enable register 0 (PER0)                                         | 159 |
| 6.3.2  | Timer clock select register m (TPSm)                                        | 160 |
| 6.3.3  | Timer mode register mn (TMRmn)                                              | 163 |
| 6.3.4  | Timer status register mn (TSRmn)                                            | 168 |
| 6.3.5  | Timer channel enable status register m (TEm)                                | 169 |
| 6.3.6  | Timer channel start register m (TSm)                                        | 170 |
| 6.3.7  | Timer channel stop register m (TTm)                                         | 171 |
| 6.3.8  | Timer input select register 0 (TIS0)                                        | 172 |
| 6.3.9  | Timer output enable register m (TOEm)                                       | 173 |
| 6.3.10 |                                                                             |     |
| 6.3.11 | Timer output level register m (TOLm)                                        |     |
| 6.3.12 |                                                                             |     |
| 6.3.13 | 5 ( )                                                                       |     |
| 6.3.14 |                                                                             |     |
| 6.4    | Basic Rules of Timer Array Unit                                             |     |
| 6.4.1  | Basic rules of simultaneous channel operation function                      |     |
| 6.4.2  | Basic rules of 8-bit timer operation function (channels 1 and 3 only)       |     |
| 6.5    | Operation of Counter                                                        |     |
| 6.5.1  | Count clock (fTCLK)                                                         |     |
| 6.5.2  | Start timing of counter                                                     |     |
| 6.5.3  | Operation of counter                                                        |     |
| 6.6    | Channel Output (TOmn pin) Control                                           |     |
| 6.6.1  | TOmn pin output circuit configuration                                       | 191 |

| 6.6.2      | TOmn Pin Output Setting                                                                                      | 192   |
|------------|--------------------------------------------------------------------------------------------------------------|-------|
| 6.6.3      | Cautions on Channel Output Operation                                                                         | 193   |
| 6.6.4      | Collective manipulation of TOmn bit                                                                          | 198   |
| 6.6.5      | Timer Interrupt and TOmn Pin Output at Operation Start                                                       | 199   |
| 6.7        | Timer Input (TImn) Control                                                                                   | 200   |
| 6.7.1      | TImn input circuit configuration                                                                             | 200   |
| 6.7.2      | Noise filter                                                                                                 | 200   |
| 6.7.3      | Cautions on channel input operation                                                                          | 201   |
| 6.8        | Independent Channel Operation Function of Timer Array Unit                                                   | 202   |
| 6.8.1      | Operation as interval timer/square wave output                                                               | 202   |
| 6.8.2      | Operation as external event counter                                                                          |       |
| 6.8.3      | Operation as input pulse interval measurement                                                                | . 211 |
| 6.8.4      | Operation as input signal high-/low-level width measurement                                                  | . 215 |
| 6.8.5      | Operation as delay counter                                                                                   |       |
| 6.9        | Simultaneous Channel Operation Function of Timer Array Unit                                                  | 223   |
| 6.9.1      | Operation as one-shot pulse output function                                                                  | 223   |
| 6.9.2      | Operation as PWM function                                                                                    | 230   |
| 6.9.3      | Operation as multiple PWM output function                                                                    | 237   |
| 6.10       | Cautions When Using Timer Array Unit                                                                         |       |
| 6.10.1     | 1 Cautions When Using Timer output                                                                           | 245   |
|            |                                                                                                              |       |
| 7. 12-     | BIT INTERVAL TIMER                                                                                           | 246   |
| 7.1        | Functions of 12-bit Interval Timer                                                                           |       |
| 7.2        | Configuration of 12-bit Interval Timer                                                                       |       |
| 7.3        | Registers Controlling 12-bit Interval Timer                                                                  |       |
| 7.3.1      | Peripheral enable register 2 (PER2)                                                                          |       |
| 7.3.2      | Peripheral reset control register 2 (PRR2)                                                                   |       |
| 7.3.3      | Subsystem clock supply mode control register (OSMC)                                                          |       |
| 7.3.4      | 12-bit interval timer control register (ITMC)                                                                |       |
| 7.4        | 12-bit Interval Timer Operation                                                                              |       |
| 7.4.1      | 12-bit interval timer operation timing                                                                       | 250   |
| 7.4.2      | Start of count operation and re-enter to HALT/STOP mode after returned from                                  | 054   |
|            | HALT/STOP mode                                                                                               | . 251 |
| 8. CL      | OCK OUTPUT/BUZZER OUTPUT CONTROLLER                                                                          | 252   |
| 8.1        |                                                                                                              |       |
|            | Functions of Clock Output/Buzzer Output Controller<br>Configuration of Clock Output/Buzzer Output Controller |       |
| 8.2<br>8.3 | Registers Controlling Clock Output/Buzzer Output Controller                                                  |       |
| 8.3.1      | Clock output select registers n (CKSn)                                                                       |       |
| 8.3.1      | Registers controlling port functions of pins to be used for clock or buzzer output                           |       |
| 8.4        | Operations of Clock Output/Buzzer Output Controller                                                          |       |
| 8.4.1      | Operation as output pin                                                                                      |       |
| 8.5        | Cautions of clock output/buzzer output controller                                                            |       |
| 0.0        |                                                                                                              | 201   |
| 9. WA      | ATCHDOG TIMER                                                                                                | 258   |
| 9.1        | Functions of Watchdog Timer                                                                                  | 258   |
| 9.2        | Configuration of Watchdog Timer                                                                              |       |
| 9.3        | Register Controlling Watchdog Timer                                                                          |       |
| 9.3.1      | Watchdog timer enable register (WDTE)                                                                        |       |
|            |                                                                                                              |       |

| 9.4     | Operation of Watchdog Timer                                             | . 261 |
|---------|-------------------------------------------------------------------------|-------|
| 9.4.1   | Controlling operation of watchdog timer                                 | . 261 |
| 9.4.2   | Setting overflow time of watchdog timer                                 | . 262 |
| 9.4.3   | Setting window open period of watchdog timer                            | . 263 |
| 9.4.4   | Setting watchdog timer interval interrupt                               | . 264 |
|         |                                                                         |       |
| 10. A/E | OONVERTER                                                               | . 265 |
| 10.1    | Function of A/D Converter                                               | . 265 |
| 10.2    | Configuration of A/D Converter                                          | . 268 |
| 10.3    | Registers Controlling A/D Converter                                     | . 270 |
| 10.3.1  | Peripheral enable register 0 (PER0)                                     | . 271 |
| 10.3.2  | A/D converter mode register 0 (ADM0)                                    | . 272 |
| 10.3.3  | A/D converter mode register 1 (ADM1)                                    | . 278 |
| 10.3.4  | A/D converter mode register 2 (ADM2)                                    | . 279 |
| 10.3.5  | 5 10-bit A/D conversion result register (ADCR)                          | . 281 |
| 10.3.6  | 8-bit A/D conversion result register (ADCRH)                            | . 282 |
| 10.3.7  | Analog input channel specification register (ADS)                       | . 283 |
| 10.3.8  | Conversion result comparison upper limit setting register (ADUL)        | . 285 |
| 10.3.9  | O Conversion result comparison lower limit setting register (ADLL)      | . 285 |
| 10.3.1  | 0 A/D test register (ADTES)                                             | . 286 |
| 10.3.1  | 1 Registers controlling port function of analog input pins              | . 286 |
| 10.4    | A/D Converter Conversion Operations                                     | . 287 |
| 10.5    | Input Voltage and Conversion Results                                    | . 289 |
| 10.6    | A/D Converter Operation Modes                                           | . 290 |
| 10.6.1  | Software trigger mode (select mode, sequential conversion mode)         | . 290 |
| 10.6.2  | 2 Software trigger mode (select mode, one-shot conversion mode)         | . 291 |
| 10.6.3  | Software trigger mode (scan mode, sequential conversion mode)           | . 292 |
| 10.6.4  | Software trigger mode (scan mode, one-shot conversion mode)             | . 293 |
| 10.6.5  | Hardware trigger no-wait mode (select mode, sequential conversion mode) | . 294 |
| 10.6.6  | B Hardware trigger no-wait mode (select mode, one-shot conversion mode) | . 295 |
| 10.6.7  | ' Hardware trigger no-wait mode (scan mode, sequential conversion mode) | 296   |
| 10.6.8  | B Hardware trigger no-wait mode (scan mode, one-shot conversion mode)   | . 297 |
| 10.6.9  | Hardware trigger wait mode (select mode, sequential conversion mode)    | . 298 |
| 10.6.1  | 0 Hardware trigger wait mode (select mode, one-shot conversion mode)    | 299   |
| 10.6.1  | 1 Hardware trigger wait mode (scan mode, sequential conversion mode)    | . 300 |
| 10.6.1  | 2 Hardware trigger wait mode (scan mode, one-shot conversion mode)      | . 301 |
| 10.7    | A/D Converter Setup Flowchart                                           | . 302 |
| 10.7.1  | Setting up software trigger mode                                        | . 302 |
| 10.7.2  | 2 Setting up hardware trigger no-wait mode                              | . 303 |
| 10.7.3  | Setting up hardware trigger wait mode                                   | . 304 |
| 10.7.4  | Setup when using temperature sensor                                     |       |
|         | (example for software trigger mode and one-shot conversion mode)        | 305   |
| 10.7.5  | 5 Setting up test mode                                                  | . 306 |
| 10.8    | SNOOZE Mode Function                                                    | . 307 |
| 10.9    | How to Read A/D Converter Characteristics Table                         | 311   |
| 10.10   | Cautions for A/D Converter                                              | . 314 |
|         |                                                                         |       |
| 11. SE  | RIAL ARRAY UNIT                                                         |       |
| 11.1    | Functions of Serial Array Unit                                          | . 319 |
|         |                                                                         |       |

| 11.1.1  | 3-wire serial I/O (CSI00, CSI01)                                                      | 319 |
|---------|---------------------------------------------------------------------------------------|-----|
| 11.1.2  | UART (UART0)                                                                          | 320 |
| 11.1.3  | Simplified I <sup>2</sup> C (IIC00, IIC01)                                            | 321 |
| 11.2 C  | onfiguration of Serial Array Unit                                                     | 322 |
| 11.2.1  | Shift register                                                                        | 325 |
| 11.2.2  | Lower 8/9 bits of the serial data register mn (SDRmn)                                 | 325 |
| 11.3 R  | egisters Controlling Serial Array Unit                                                |     |
| 11.3.1  | Peripheral enable register 0 (PER0)                                                   | 328 |
| 11.3.2  | Peripheral reset control register 0 (PRR0)                                            | 329 |
| 11.3.3  | Serial clock select register m (SPSm)                                                 | 330 |
| 11.3.4  | Serial mode register mn (SMRmn)                                                       | 332 |
| 11.3.5  | Serial communication operation setting register mn (SCRmn)                            | 333 |
| 11.3.6  | Serial data register mn (SDRmn)                                                       | 336 |
| 11.3.7  | Serial flag clear trigger register mn (SIRmn)                                         | 337 |
| 11.3.8  | Serial status register mn (SSRmn)                                                     |     |
| 11.3.9  | Serial channel start register m (SSm)                                                 |     |
| 11.3.10 | Serial channel stop register m (STm)                                                  | 341 |
| 11.3.11 | Serial channel enable status register m (SEm)                                         | 342 |
| 11.3.12 | Serial output enable register m (SOEm)                                                | 343 |
| 11.3.13 | Serial output register m (SOm)                                                        | 344 |
|         | Serial output level register m (SOLm)                                                 |     |
|         | Serial standby control register m (SSCm)                                              |     |
|         | Noise filter enable register 0 (NFEN0)                                                |     |
|         | Registers controlling port functions of serial input/output pins                      |     |
|         | peration Stop Mode                                                                    |     |
| 11.4.1  | Stopping the operation by units                                                       | 351 |
| 11.4.2  | Stopping the operation by channels                                                    | 352 |
| 11.5 C  | peration of 3-Wire Serial I/O (CSI00, CSI01) Communication                            |     |
| 11.5.1  | Master transmission                                                                   |     |
| 11.5.2  | Master reception                                                                      | 363 |
| 11.5.3  | Master transmission/reception                                                         | 371 |
| 11.5.4  | Slave transmission                                                                    | 379 |
| 11.5.5  | Slave reception                                                                       | 387 |
| 11.5.6  | Slave transmission/reception                                                          | 393 |
| 11.5.7  | SNOOZE mode function                                                                  | 401 |
| 11.5.8  | Calculating transfer clock frequency                                                  | 405 |
| 11.5.9  | Procedure for processing errors that occurred during 3-wire serial I/O (CSI00, CSI01) |     |
|         | communication                                                                         |     |
| 11.6 C  | peration of UART (UART0) Communication                                                |     |
| 11.6.1  | UART transmission                                                                     | 410 |
| 11.6.2  | UART reception                                                                        | 419 |
| 11.6.3  | SNOOZE mode function                                                                  | 426 |
| 11.6.4  | Calculating baud rate                                                                 |     |
| 11.6.5  | Procedure for processing errors that occurred during UART (UART0) communication       |     |
|         | peration of Simplified I <sup>2</sup> C (IIC00, IIC01) Communication                  |     |
| 11.7.1  | Address field transmission                                                            | 441 |
| 11.7.2  | Data transmission                                                                     |     |
| 11.7.3  | Data reception                                                                        |     |
| 11.7.4  | Stop condition generation                                                             | 453 |

| 11.7.5  | 8                                                                                                             | 454   |
|---------|---------------------------------------------------------------------------------------------------------------|-------|
| 11.7.6  | Procedure for processing errors that occurred during simplified I <sup>2</sup> C (IIC00, IIC01) communication | . 456 |
| 12. SEI | RIAL INTERFACE IICA                                                                                           | 457   |
| 12.1    | Functions of Serial Interface IICA                                                                            |       |
| 12.2    | Configuration of Serial Interface IICA                                                                        |       |
| 12.3    | Registers Controlling Serial Interface IICA                                                                   |       |
| 12.3.1  |                                                                                                               |       |
| 12.3.2  |                                                                                                               |       |
| 12.3.3  | IICA status register n (IICSn)                                                                                | 469   |
| 12.3.4  | IICA flag register n (IICFn)                                                                                  | 471   |
| 12.3.5  | IICA control register n1 (IICCTLn1)                                                                           | 473   |
| 12.3.6  | IICA low-level width setting register n (IICWLn)                                                              | 475   |
| 12.3.7  | IICA high-level width setting register n (IICWHn)                                                             | 475   |
| 12.3.8  | Port mode registers 6, 7 (PM6, PM7)                                                                           | 476   |
| 12.4    | I <sup>2</sup> C Bus Mode Functions                                                                           | 477   |
| 12.4.1  | Pin configuration                                                                                             | 477   |
| 12.4.2  | Setting transfer clock by using IICWLn and IICWHn registers                                                   | 478   |
| 12.5    | I <sup>2</sup> C Bus Definitions and Control Methods                                                          | 480   |
| 12.5.1  | Start conditions                                                                                              | 480   |
| 12.5.2  | Addresses                                                                                                     | 481   |
| 12.5.3  | Transfer direction specification                                                                              | 481   |
| 12.5.4  | Acknowledge (ACK)                                                                                             | 482   |
| 12.5.5  | Stop condition                                                                                                | 483   |
| 12.5.6  | Wait                                                                                                          | 484   |
| 12.5.7  | Canceling wait                                                                                                | 486   |
| 12.5.8  | Interrupt request (INTIICAn) generation timing and wait control                                               | 487   |
| 12.5.9  |                                                                                                               |       |
| 12.5.1  | 0 Error detection                                                                                             | 488   |
| 12.5.1  | 1 Extension code                                                                                              | 489   |
| 12.5.1  | 2 Arbitration                                                                                                 | 490   |
| 12.5.1  | 3 Wakeup function                                                                                             | 492   |
| 12.5.1  | 4 Communication reservation                                                                                   | 495   |
| 12.5.1  | 5 Cautions                                                                                                    | 499   |
| 12.5.1  | 6 Communication operations                                                                                    | 500   |
| 12.5.1  | 7 Timing of I <sup>2</sup> C interrupt request (INTIICAn) occurrence                                          | 508   |
| 12.6    | Timing Charts                                                                                                 | 529   |
| 13. US  | B 2.0 HOST/FUNCTION MODULE (USB)                                                                              | 544   |
| 13.1    | Functions of USB 2.0 Host/Function Module                                                                     | 544   |
| 13.2    | Configuration of USB 2.0 Host/Function Module                                                                 |       |
| 13.3    | Registers Used in USB 2.0 Host/Function Module                                                                |       |
| 13.3.1  | •                                                                                                             |       |
|         | system configuration control register 1 (SYSCFG1)                                                             | . 551 |
| 13.3.2  | System configuration status register n (SYSSTSn) (n = 0, 1)                                                   | 554   |
| 13.3.3  | Device state control register n (DVSTCTRn) (n = 0, 1)                                                         | 555   |
| 13.3.4  | CFIFO port register (CFIFOM), DnFIFO port register (DnFIFOM) (n = 0, 1)                                       | 560   |

| 13.3.5  | CFIFO port select register (CFIFOSEL), DnFIFO port select register (DnFIFOSEL) (n = 0, 1)      | 562 |
|---------|------------------------------------------------------------------------------------------------|-----|
| 13.3.6  | CFIFO port control register (CFIFOCTR), DnFIFO port control register (DnFIFOCTR)<br>(n = 0, 1) |     |
| 13.3.7  | Interrupt enable register 0 (INTENB0)                                                          |     |
| 13.3.8  | Interrupt enable register n (INTENBn) (n = 1, 2)                                               |     |
| 13.3.9  | BRDY interrupt enable register (BRDYENB)                                                       |     |
|         | NRDY interrupt enable register (NRDYENB)                                                       |     |
|         | BEMP interrupt enable register (BEMPENB)                                                       |     |
|         | SOF output configuration register (SOFCFG)                                                     |     |
|         | Interrupt status register 0 (INTSTS0)                                                          |     |
|         | Interrupt status register 0 (INTSTS0) (n = 1, 2)                                               |     |
|         | BRDY interrupt status register (BRDYSTS)                                                       |     |
|         | NRDY interrupt status register (NRDYSTS)                                                       |     |
|         | BEMP interrupt status register (BEMPSTS)                                                       |     |
|         |                                                                                                |     |
|         | Frame number register (FRMNUM)                                                                 |     |
|         | USB address register (USBADDR)                                                                 |     |
|         | USB request type register (USBREQ)                                                             |     |
|         | USB request value register (USBVAL)                                                            |     |
|         | USB request index register (USBINDX)                                                           |     |
|         | USB request length register (USBLENG)                                                          |     |
|         | DCP configuration register (DCPCFG)                                                            |     |
|         | DCP maximum packet size register (DCPMAXP)                                                     |     |
|         | DCP control register (DCPCTR)                                                                  |     |
|         | Pipe window select register (PIPESEL)                                                          |     |
|         | Pipe configuration register (PIPECFG)                                                          |     |
|         | Pipe maximum packet size register (PIPEMAXP)                                                   |     |
|         | Pipe cycle control register (PIPEPERI)                                                         |     |
|         | PIPEn control registers (PIPEnCTR) (n = 4 to 7)                                                |     |
| 13.3.32 | PIPEn transaction counter enable registers (PIPEnTRE) (n = 4, 5)                               | 608 |
| 13.3.33 | PIPEn transaction counter registers (PIPEnTRN) (n = 4, 5)                                      | 609 |
| 13.3.34 | BC control register n (USBBCCTRLn) (n = 0, 1)                                                  | 610 |
| 13.3.35 | BC option control register n (USBBCOPTn) (n = 0, 1)                                            | 614 |
| 13.3.36 | USB clock selection register (UCKSEL)                                                          | 618 |
| 13.3.37 | USB module control register (USBMC)                                                            | 619 |
| 13.3.38 | Device address n configuration registers (DEVADDn) (n = 0 to 5)                                | 620 |
| 13.4 O  | peration                                                                                       | 621 |
| 13.4.1  | System control                                                                                 | 621 |
| 13.4.2  | Interrupt sources                                                                              | 626 |
| 13.4.3  | Interrupts                                                                                     | 630 |
| 13.4.4  | Pipe control                                                                                   |     |
| 13.4.5  | FIFO buffer memory                                                                             |     |
| 13.4.6  | Control transfers (DCP)                                                                        |     |
| 13.4.7  | Bulk transfers (PIPE4, PIPE5)                                                                  |     |
| 13.4.8  | Interrupt transfers (PIPE6, PIPE7)                                                             |     |
| 13.4.9  | SOF interpolation function                                                                     |     |
|         | Pipe schedule                                                                                  |     |
|         | Controlling battery charging detection                                                         |     |
|         | Battery charging connection detection optional functions                                       |     |
| 10.7.12 |                                                                                                | 000 |

| 13.4.13 Battery charging detection processing                                                                              | . 661 |
|----------------------------------------------------------------------------------------------------------------------------|-------|
| 14. INTERRUPT FUNCTIONS                                                                                                    | . 666 |
| 14.1 Interrupt Function Types                                                                                              | . 666 |
| 14.2 Interrupt Sources and Configuration                                                                                   |       |
| 14.3 Registers Controlling Interrupt Functions                                                                             |       |
| 14.3.1 Interrupt request flag registers (IF0L, IF0H, IF1L, IF1H, IF2L, IF2H)                                               |       |
| 14.3.2 Interrupt mask flag registers (MK0L, MK0H, MK1L, MK1H, MK2L, MK2H)                                                  |       |
| 14.3.3 Priority specification flag registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) |       |
| 14.3.4 External interrupt rising edge enable register (EGP0, EGP1),                                                        | -     |
| external interrupt falling edge enable register (EGN0, EGN1)                                                               | 679   |
| 14.3.5 Program status word (PSW)                                                                                           | . 681 |
| 14.4 Interrupt Servicing Operations                                                                                        |       |
| 14.4.1 Maskable interrupt request acknowledgment                                                                           | . 682 |
| 14.4.2 Software interrupt request acknowledgment                                                                           | . 685 |
| 14.4.3 Multiple interrupt servicing                                                                                        | . 685 |
| 14.4.4 Interrupt servicing during division instruction                                                                     | . 689 |
| 14.4.5 Interrupt request hold                                                                                              | . 691 |
| 15. STANDBY FUNCTION                                                                                                       | . 692 |
| 15.1 Standby Function                                                                                                      | . 692 |
| 15.2 Registers controlling standby function                                                                                | . 693 |
| 15.3 Standby Function Operation                                                                                            |       |
| 15.3.1 HALT mode                                                                                                           | . 694 |
| 15.3.2 STOP mode                                                                                                           | . 698 |
| 15.3.3 SNOOZE mode                                                                                                         | . 703 |
| 16. RESET FUNCTION                                                                                                         | . 706 |
| 16.1 Timing of Reset Operation                                                                                             | . 708 |
| 16.2 Register for Confirming Reset Source                                                                                  |       |
| 16.2.1 Reset control flag register (RESF)                                                                                  |       |
| 16.2.2 Peripheral reset control register 0 (PRR0)                                                                          |       |
| 16.2.3 Peripheral reset control register 2 (PRR2)                                                                          |       |
| 17. POWER-ON-RESET CIRCUIT                                                                                                 | . 717 |
| 17.1 Functions of Power-on-reset Circuit                                                                                   |       |
| 17.2 Configuration of Power-on-reset Circuit                                                                               |       |
| 17.3     Operation of Power-on-reset Circuit                                                                               |       |
| 18. VOLTAGE DETECTOR                                                                                                       | . 722 |
| 18.1 Functions of Voltage Detector                                                                                         |       |
| 18.2 Configuration of Voltage Detector                                                                                     |       |
| 18.3 Registers Controlling Voltage Detector                                                                                |       |
| 18.3.1 Voltage detection register (LVIM)                                                                                   |       |
| 18.3.2 Voltage detection level register (LVIS)                                                                             |       |
| 18.4 Operation of Voltage Detector                                                                                         |       |
| 18.4.1 When used as reset mode                                                                                             |       |
| 18.4.2 When used as interrupt mode                                                                                         |       |
|                                                                                                                            |       |

| 734   |
|-------|
| 739   |
| 740   |
| . 741 |
| 743   |
|       |
| 745   |
| 745   |
| 746   |
| 746   |
| 746   |
| 750   |
| 753   |
| 755   |
| 756   |
| 757   |
| 759   |
| 761   |
| 763   |
| 704   |
| 764   |
| 764   |
| 765   |
| 765   |
| 765   |
| 766   |
| 767   |
| 774   |
| 775   |
|       |
| 776   |
| 777   |
| 779   |
| 779   |
| 780   |
| 780   |
| 781   |
| 782   |
| 782   |
| 782   |
| 783   |
| 783   |
| 783   |
| 783   |
| 784   |
| 784   |
| 785   |
| 787   |
|       |

| 22.4.4      | Communication commands                                                | 788 |
|-------------|-----------------------------------------------------------------------|-----|
| 22.5 Pro    | cessing Time for Each Command When PG-FP6 Is in Use (Reference Value) | 790 |
| 22.6 Self   | f-Programming                                                         | 791 |
| 22.6.1 S    | Self-programming procedure                                            | 792 |
| 22.6.2 E    | Boot swap function                                                    | 793 |
| 22.6.3 F    | -lash shield window function                                          | 795 |
| 22.7 Sec    | curity Settings                                                       | 796 |
| 22.8 Dat    | a Flash                                                               | 798 |
| 22.8.1 C    | Data flash overview                                                   | 798 |
| 22.8.2 F    | Register controlling data flash memory                                | 799 |
| 22.8.3 F    | Procedure for accessing data flash memory                             | 800 |
| 23. ON-CH   | IP DEBUG FUNCTION                                                     | 801 |
| 23.1 Cor    | nnecting E1 On-chip Debugging Emulator                                | 801 |
| 23.2 On-    | Chip Debug Security ID                                                | 802 |
| 23.3 Sec    | curing of User Resources                                              | 802 |
| 24. BCD C   | ORRECTION CIRCUIT                                                     | 804 |
| 24.1 BCI    | D Correction Circuit Function                                         | 804 |
| 24.2 Reg    | gisters Used by BCD Correction Circuit                                | 804 |
| 24.2.1 E    | BCD correction result register (BCDADJ)                               | 804 |
| 24.3 BCI    | D Correction Circuit Operation                                        | 805 |
| 25. INSTRI  | JCTION SET                                                            | 807 |
| 25.1 Cor    | nventions Used in Operation List                                      | 807 |
|             | Dperand identifiers and specification methods                         |     |
|             | Description of operation column                                       |     |
|             | Description of flag operation column                                  |     |
|             | PREFIX instruction                                                    |     |
|             | eration List                                                          |     |
| 26. ELECT   | RICAL SPECIFICATIONS                                                  | 823 |
| 27. PACKA   | GE DRAWINGS                                                           | 824 |
| REVISION HI | STORY                                                                 | 825 |

## RENESAS

## R9A02G015

ASSP (USB Power Delivery Controller)

R19UH0112EJ0100 Rev.1.00 Mar 29, 2019

## **CHAPTER 1 OUTLINE**

### 1.1 Features

Ultra-low power consumption technology

- VDD = single power supply voltage of 2.7 to 5.5 V
- HALT mode
- STOP mode
- SNOOZE mode

#### RL78 CPU core

- CISC architecture with 3-stage pipeline
- Minimum instruction execution time: 0.04167 µs: @ 24 MHz operation with high-speed on-chip oscillator
- Multiply/divide/multiply & accumulate instructions are supported.
- Address space: 1 MB
- General-purpose registers: (8-bit register × 8) × 4 banks
- On-chip RAM: 7 KB

#### Code flash memory

- Code flash memory: 128 KB
- Block size: 1 KB
- Prohibition of block erase and rewriting (security function)
- On-chip debug function
- Self-programming (with boot swap function/flash shield window function)

#### Data flash memory

- Data flash memory: 2 KB
- Back ground operation (BGO): Instructions can be executed from the program memory while rewriting the data flash memory.
- Number of rewrites: 1,000,000 times (TYP.)
- Voltage of rewrites: VDD = 2.7 to 5.5 V

#### High-speed on-chip oscillator

- Select from 48 MHz, 24 MHz, 16 MHz, 12 MHz, 8 MHz, 6 MHz, 4 MHz, 3 MHz, 2 MHz, and 1 MHz
- High accuracy: ±1.0% (VDD = 2.7 to 5.5 V, TA = -20 to +85°C)

#### Operating ambient temperature

• TA = -40 to +85°C (A: Consumer applications)



Power management and reset function

- On-chip power-on-reset (POR) circuit
- On-chip voltage detector (LVD) (Select reset from 6 levels)

#### USB

- Complying with USB Specification Revision 2.0, incorporating host/function controller
- Corresponding to full-speed transfer (12 Mbps) and low-speed (1.5 Mbps)
- Complying with Battery Charging Specification Revision 1.2
- Compliant with the 2.1 A/1.0 A charging mode.

#### Serial interfaces

- CSI: 2 channels
- UART: 1 channel
- Simplified I<sup>2</sup>C: 2 channels
- I<sup>2</sup>C: 2 or 3 channels

#### Timers

- 16-bit timer: 8 channels
- 12-bit interval timer: 1 channel
- Watchdog timer: 1 channel

#### A/D converter

- 8/10-bit resolution A/D converter (VDD = 2.7 to 5.5 V)
- Analog input: 8 channels
- Internal reference voltage (1.45 V) and temperature sensor

#### I/O ports

- I/O port: 23 or 28 (N-ch open drain I/O [withstand voltage of 6 V]: 5, N-ch open drain I/O [VDD withstand voltage]: 8 or 13)
- Can be set to N-ch open drain, TTL input buffer, and on-chip pull-up resistor
- On-chip clock output/buzzer output controller

#### Others

• On-chip BCD (binary-coded decimal) correction circuit

**Remark** The functions mounted depend on the product. See **1.6 Outline of Functions**.

#### $\bigcirc$ ROM, RAM capacities

| Flash ROM | Data flash       | RAM       | R9A02              | 2G015                 |
|-----------|------------------|-----------|--------------------|-----------------------|
| Flash ROW | Data ilasin KAwi |           | 32 pins (with USB) | 32 pins (without USB) |
| 128 KB    | 2 KB             | 7 KB Note | R9A02G0150         | R9A02G0151            |

**Note** The flash library uses RAM in self-programming and rewriting of the data flash memory.

The target products and start address of the RAM areas used by the flash library are shown below.

R9A02G0150/R9A02G0151: Start address FE300H



## 1.2 Ordering Information

#### Figure 1 - 1 Part Number and Package of R9A02G015

| Pin count | Package                  | Ordering Part Number | Remarks                          |
|-----------|--------------------------|----------------------|----------------------------------|
| 32 pins   | 32-pin QFN               | R9A02G015020GNP#AC0  | Product with USB (R9A02G0150)    |
|           | (4 × 4 mm, 0.4 mm pitch) | R9A02G015120GNP#AC0  | Product without USB (R9A02G0151) |

Caution The ordering part numbers represent the numbers at the time of publication. For the latest ordering part numbers, refer to the target product page of the Renesas Electronics website.



### **1.3 Pin Configuration (Top View)**

#### 1.3.1 32-pin product (with USB)

• 32-pin QFN (4 × 4 mm, 0.4 mm pitch)



Caution 1. Connect the exposed die pad (Vss) to ground.

Caution 2. Connect the REGC pin to Vss via a capacitor (0.47 to 1  $\mu F).$ 

Remark For pin identification, see 1.4 Pin Identification.



### 1.3.2 32-pin product (without USB)

• 32-pin QFN (4 × 4 mm, 0.4 mm pitch)



Caution 1. Connect the exposed die pad (Vss) to ground. Caution 2. Connect the REGC pin to Vss via a capacitor (0.47 to 1  $\mu$ F).

Remark For pin identification, see 1.4 Pin Identification.



## 1.4 Pin Identification

| ANI0 to ANI5, ANI16, ANI17:   | Analog input                                     |
|-------------------------------|--------------------------------------------------|
| AVREFM:                       | A/D converter reference potential (- side) input |
| AVREFP:                       | A/D converter reference potential (+ side) input |
| EXCLK:                        | External clock input (main system clock)         |
| INTP0 to INTP15:              | External interrupt input                         |
| P00, P01:                     | Port 0                                           |
| P20 to P25:                   | Port 2                                           |
| P40:                          | Port 4                                           |
| P50 to P55:                   | Port 5                                           |
| P60 to P64:                   | Port 6                                           |
| P70 to P74:                   | Port 7                                           |
| P121, P122:                   | Port 12                                          |
| P137:                         | Port 13                                          |
| PCLBUZ0:                      | Programmable clock output/buzzer output          |
| REGC:                         | Regulator capacitance                            |
| RESETB:                       | Reset                                            |
| RxD0:                         | Receive data                                     |
| SCK00, SCK01:                 | Serial clock input/output                        |
| SCLA0 to SCLA2, SCL00, SCL01: | Serial clock input/output                        |
| SDAA0 to SDAA2, SDA00, SDA01: | Serial data input/output                         |
| SI00, SI01:                   | Serial data input                                |
| SO00, SO01:                   | Serial data output                               |
| TI00 to TI07:                 | Timer input                                      |
| TO00 to TO07:                 | Timer output                                     |
| TOOL0:                        | Data input/output for tool                       |
| TOOLRXD, TOOLTXD:             | Data input/output for external device            |
| TxD0:                         | Transmit data                                    |
| UDM0, UDM1, UDP0, UDP1:       | USB Input/Output                                 |
| UOVRCUR0, UOVRCUR1:           | USB Input                                        |
| UVBUSEN0, UVBUSEN1:           | USB Output                                       |
| UVDD:                         | USB Power Supply/USB Regulator Capacitance       |
| UVBUS:                        | USB Input/USB Power Supply (USB Optional BC)     |
| VDD:                          | Power supply                                     |
| Vss:                          | Ground                                           |
| X1, X2:                       | Crystal oscillator (main system clock)           |
|                               |                                                  |



## 1.5 Block Diagram

### 1.5.1 32-pin products





(1/2)

## 1.6 Outline of Functions

|                       |                                          | 32-pin (with USB)                                                                                                                                                                                                                                                                         | 32-pin (without USB)                                                   |  |
|-----------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--|
| Item -                |                                          | R9A02G0150                                                                                                                                                                                                                                                                                | R9A02G0151                                                             |  |
|                       |                                          | 128 KB                                                                                                                                                                                                                                                                                    | 10/10200101                                                            |  |
| <b>, , ,</b>          |                                          | 2 KB                                                                                                                                                                                                                                                                                      |                                                                        |  |
| RAM                   |                                          | 7KB Note 1                                                                                                                                                                                                                                                                                |                                                                        |  |
| Address space         |                                          | 1 MB                                                                                                                                                                                                                                                                                      |                                                                        |  |
| Main system clock     | High-speed system clock (fMX)            |                                                                                                                                                                                                                                                                                           | in system clock input (EXCLK)                                          |  |
| Main system clock     | High-speed on-chip oscillator clock      | X1 (crystal/ceramic) oscillation, external main system clock input (EXCLK)<br>HS (High-speed main) mode: 1 to 20 MHz (VDD = 2.7 to 5.5 V)<br>HS (High-speed main) mode: 1 to 24 MHz (VDD = 2.7 to 5.5 V)                                                                                  |                                                                        |  |
|                       | (fiH) Max: 24 MHz                        |                                                                                                                                                                                                                                                                                           |                                                                        |  |
|                       | PLL clock                                | 6, 12, 24 MHz <sup>Note 2</sup> : VDD = 2.7 to 5.5 V                                                                                                                                                                                                                                      |                                                                        |  |
| Subsystem clock       | Low-speed on-chip oscillator clock (fiL) | 15 kHz (TYP.): VDD = 2.7 to 5.5 V                                                                                                                                                                                                                                                         |                                                                        |  |
| General-purpose reg   | gister                                   | 8 bits × 32 registers (8 bits × 8 registers × 4                                                                                                                                                                                                                                           | banks)                                                                 |  |
| Minimum instruction   | execution time                           | 0.04167 µs (High-speed on-chip oscillator cl                                                                                                                                                                                                                                              | ock: fHOCO = 48MHz/fiH = 24 MHz operation)                             |  |
|                       |                                          | 0.04167 µs (PLL clock: fPLL = 48 MHz/fiH = 2                                                                                                                                                                                                                                              | 24 MHz <sup>Note 2</sup> operation)                                    |  |
|                       |                                          | 0.05 μs (High-speed system clock: fмx = 20                                                                                                                                                                                                                                                | MHz operation)                                                         |  |
| Instruction set       |                                          | <ul> <li>Data transfer (8/16 bits)</li> <li>Adder and subtractor/logical operation (8/</li> <li>Multiplication (8 bits × 8 bits, 16 bits × 16 t<br/>bits)</li> <li>Multiplication and Accumulation (16 bits ×</li> <li>Rotate, barrel shift, and bit manipulation (\$</li> </ul>          | bits), Division (16 bits + 16 bits, 32 bits + 32<br>16 bits + 32 bits) |  |
| I/O port              | Total                                    | 23                                                                                                                                                                                                                                                                                        | 28                                                                     |  |
|                       | CMOS I/O                                 | 15                                                                                                                                                                                                                                                                                        | 20                                                                     |  |
|                       | CMOS input                               | 3                                                                                                                                                                                                                                                                                         |                                                                        |  |
|                       | N-ch open-drain I/O<br>(6 V tolerance)   | 5                                                                                                                                                                                                                                                                                         |                                                                        |  |
| Timer                 | 16-bit timer                             | 8 channels                                                                                                                                                                                                                                                                                |                                                                        |  |
|                       | Watchdog timer                           | 1 channel                                                                                                                                                                                                                                                                                 |                                                                        |  |
|                       | 12-bit interval timer                    | 1 channel                                                                                                                                                                                                                                                                                 |                                                                        |  |
|                       | Timer output                             | 7                                                                                                                                                                                                                                                                                         | 8                                                                      |  |
| Clock output/buzzer   | L<br>output                              | 1<br>2.93 kHz, 5.86 kHz, 11.7 kHz, 1.5 MHz, 3 M<br>(Main system clock: fMAIN = 24 MHz operation                                                                                                                                                                                           |                                                                        |  |
| 10-bit resolution A/D | converter                                | 8 channels                                                                                                                                                                                                                                                                                |                                                                        |  |
| Serial interface      |                                          | CSI: 2 channels/UART: 1 channel/simplified                                                                                                                                                                                                                                                | I <sup>2</sup> C: 2 channels                                           |  |
|                       | I <sup>2</sup> C bus                     | 2 channels                                                                                                                                                                                                                                                                                | 3 channels                                                             |  |
| USB                   | Host controller                          | 2 channels                                                                                                                                                                                                                                                                                | 1_                                                                     |  |
|                       | Function controller                      | 1channel                                                                                                                                                                                                                                                                                  |                                                                        |  |
| Vectored interrupt    | Internal                                 | 22                                                                                                                                                                                                                                                                                        | 21                                                                     |  |
| sources               | External                                 | 14                                                                                                                                                                                                                                                                                        | 16                                                                     |  |
| Reset                 |                                          | Reset by RESETB pin     Internal reset by watchdog timer     Internal reset by power-on-reset     Internal reset by voltage detector     Internal reset by illegal instruction execution <sup>Note 3</sup> Internal reset by RAM parity error     Internal reset by illegal-memory access |                                                                        |  |
| Power-on-reset circu  | lit                                      | <ul> <li>Power-on-reset: 1.51 ± 0.04 V (TA = -40 to +85°C)</li> <li>Power-down-reset: 1.50 ± 0.04 V (TA = -40 to +85°C)</li> </ul>                                                                                                                                                        |                                                                        |  |
| Voltage detector      | Power on                                 | 2.81 V to 4.06 V (6 stages)                                                                                                                                                                                                                                                               |                                                                        |  |
|                       | Power down                               | 2.75 V to 3.98 V (6 stages)                                                                                                                                                                                                                                                               |                                                                        |  |
| On-chip debug funct   | ion                                      | Provided (Enable to tracing)                                                                                                                                                                                                                                                              |                                                                        |  |



(2/2)

| Item                          | 32-pin (with USB)              | 32-pin (without USB) |
|-------------------------------|--------------------------------|----------------------|
| nem                           | R9A02G0150                     | R9A02G0151           |
| Power supply voltage          | V <sub>DD</sub> = 2.7 to 5.5 V |                      |
| Operating ambient temperature | TA = -40 to +85°C              |                      |

Note 1.The flash library uses RAM in self-programming and rewriting of the data flash memory.The target products and start address of the RAM areas used by the flash library are shown below.

R9A02G0150/R9A02G0151: Start address FE300H

**Note 2.** In the PLL clock 48 MHz operation, the system clock is 2/4/8 dividing ratio.

Note 3. The illegal instruction is generated when instruction code FFH is executed. Reset by the illegal instruction execution is not issued by emulation with the in-circuit emulator or on-chip debug emulator.



## **CHAPTER 2 PIN FUNCTIONS**

### 2.1 Port Functions

Pin I/O buffer power supplies are shown below.

#### Table 2 - 1 Pin I/O Buffer Power Supplies

| Power Supply | Corresponding Pins                             |
|--------------|------------------------------------------------|
| VDD          | All pins other than UDP0, UDM0, UDP1, and UDM1 |
| UVdd         | UDP0, UDM0, UDP1, UDM1                         |

Set in each port I/O, buffer, pull-up resistor is also valid for alternate functions.

## 2.1.1 32-pin Products

| Function<br>Name | Pin Type | I/O | After Reset<br>Release | Alternate Function                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|----------|-----|------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P00              | 8-3-4    | I/O | Analog input port      | INTP12/TI05/TO05/ANI16/PCLBUZ0                        | Port 0.                                                                                                                                                                                                                                                                                                                                                                                                 |
| P01              |          |     |                        | INTP13/TI06/TO06/ANI17                                | <ul> <li>2-bit I/O port.</li> <li>Input/output can be specified in 1-bit units.</li> <li>Use of an on-chip pull-up resistor can be specified by a software setting at input port.</li> <li>Input of P00 and P01 can be set to TTL input buffer.</li> <li>Output of P00 and P01 can be set to N-ch open-drain output (VDD tolerance).</li> <li>P00 and P01 can be set to analog input. Note 1</li> </ul> |
| P20              | 4-3-5    | I/O | Analog input port      | ANI0/AVREFP                                           | Port 2.                                                                                                                                                                                                                                                                                                                                                                                                 |
| P21              |          |     |                        | ANI1/AVREFM                                           | 5-bit I/O port.<br>Input/output can be specified in 1-bit units.                                                                                                                                                                                                                                                                                                                                        |
| P22              |          |     |                        | ANI2                                                  | Can be set to analog input. <sup>Note 1</sup>                                                                                                                                                                                                                                                                                                                                                           |
| P23              |          |     |                        | ANI3                                                  |                                                                                                                                                                                                                                                                                                                                                                                                         |
| P24              |          |     |                        | ANI4                                                  |                                                                                                                                                                                                                                                                                                                                                                                                         |
| P25              |          |     |                        | ANI5                                                  |                                                                                                                                                                                                                                                                                                                                                                                                         |
| P40              | 7-1-3    | I/O | Input port             | TOOL0                                                 | Port 4.<br>1-bit I/O port.<br>Input/output can be specified.<br>Use of an on-chip pull-up resistor can be specified by a<br>software setting.                                                                                                                                                                                                                                                           |
| P50              | 8-1-4    | I/O | Input port             | INTP6/SCL00/SCK00                                     | Port 5.                                                                                                                                                                                                                                                                                                                                                                                                 |
| P51              |          |     |                        | INTP7/TI00/TO00/SDA00/SI00/<br>RXD0/TOOLRXD           | 6-bit I/O port.<br>Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a                                                                                                                                                                                                                                                                            |
| P52              |          |     |                        | INTP8/TI01/TO01/SO00/TXD0/<br>TOOLTXD/UVBUSEN1 Note 2 | software setting at input port.<br>Input of P50 to P55 can be set to TTL input buffer.                                                                                                                                                                                                                                                                                                                  |
| P53              |          |     |                        | INTP9/TI02/TO02/SCL01/SCK01/<br>UOVRCUR1 Note 2       | Output of P50 to P55 can be set to N-ch open-drain output (VDD tolerance).                                                                                                                                                                                                                                                                                                                              |
| P54              |          |     |                        | INTP10/TI03/TO03/SDA01/SI01/<br>UVBUSEN0 Note 2       |                                                                                                                                                                                                                                                                                                                                                                                                         |
| P55              |          |     |                        | INTP11/TI04/TO04/SO01/<br>UOVRCUR0 Note 2             |                                                                                                                                                                                                                                                                                                                                                                                                         |

(1/2)



| - 14 | <b>n</b> / | n | ۱ |
|------|------------|---|---|
|      | 21         | 1 | 1 |
|      |            |   |   |

| Function<br>Name | Pin Type | I/O   | After Reset<br>Release | Alternate Function | Function                                                                                                                                                                                             |
|------------------|----------|-------|------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P60              | 12-1-3   | I/O   | Input port             | INTP1/SCLA0        | Port 6.                                                                                                                                                                                              |
| P61              |          |       |                        | INTP2/SDAA0        | 5-bit I/O port.<br>Input/output can be specified in 1-bit units.                                                                                                                                     |
| P62              |          |       |                        | INTP3/SCLA1        | Output can be set to N-ch open-drain output (6 V tolerance).                                                                                                                                         |
| P63              |          |       |                        | INTP4/SDAA1        |                                                                                                                                                                                                      |
| P64              | 12-1-2   |       |                        | INTP5              |                                                                                                                                                                                                      |
| P70<br>Note 3    | 8-1-4    | I/O   | Input port             | SCLA2              | Port 7.<br>5-bit I/O port.                                                                                                                                                                           |
| P71<br>Note 3    |          |       |                        | SDAA2              | Input/output can be specified in 1-bit units.<br>Use of an on-chip pull-up resistor can be specified by a<br>software setting at input port.                                                         |
| P72<br>Note 3    |          |       |                        | INTP14             | Input of P70 to P74 can be set to TTL input buffer.<br>Output of P70 to P74 can be set to N-ch open-drain output                                                                                     |
| P73<br>Note 3    |          |       |                        | INTP15             | (VDD tolerance).                                                                                                                                                                                     |
| P74<br>Note 3    |          |       |                        | TI07/TO07          |                                                                                                                                                                                                      |
| P121             | 2-2-1    | Input | Input port             | X1                 | Port 12.                                                                                                                                                                                             |
| P122             |          |       |                        | X2/EXCLK           | 2-bit input-only port.                                                                                                                                                                               |
| P137             | 2-1-2    | Input | Input port             | INTP0              | Port 13.<br>1-bit input-only port.                                                                                                                                                                   |
| RESETB           | 2-1-1    | Input | _                      | _                  | Input-only pin for external reset.<br>Connect to VDD directly or via a resistor when external reset<br>is not used.                                                                                  |
| UDP0<br>Note 2   | 18-11-1  | I/O   | _                      | —                  | D+ I/O pin of USB port 0.<br>This pin should be connected to the D+ pin of the USB bus.                                                                                                              |
| UDM0<br>Note 2   | 18-11-1  | I/O   | _                      | -                  | D- I/O pin of USB port 0.<br>This pin should be connected to the D- pin of the USB bus.                                                                                                              |
| UVBUS<br>Note 2  | 17-11-1  | Input | _                      | _                  | USB cable connection monitor pin.<br>This pin should be connected to VBUS of the USB bus.<br>Whether VBUS is connected or disconnected can be<br>detected during operation as a function controller. |
| UDP1<br>Note 2   | 18-11-1  | I/O   | _                      | -                  | D+ I/O pin of USB port 1.<br>This pin should be connected to the D+ pin of the USB bus.                                                                                                              |
| UDM1<br>Note 2   | 18-11-1  | I/O   | _                      | -                  | D- I/O pin of USB port 1.<br>This pin should be connected to the D- pin of the USB bus.                                                                                                              |

Note 1. Digital or analog for each pin can be selected with the port mode control register x (PMCx) (can be set in 1-bit unit).

Note 2. This function has not been mounted in the R9A02G0151 product.

Note 3. This function has not been mounted in the R9A02G0150 product.



## 2.2 Functions other than port pins

| Function Name |        |                                                                                                                                                                                                                                                     | Product with USB                      | Product without USB                   |
|---------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------------------|
|               | I/O    | Function                                                                                                                                                                                                                                            | 32-pin                                | 32-pin                                |
| ANI0          | Input  | A/D converter analog input                                                                                                                                                                                                                          | · · · · · · · · · · · · · · · · · · · | · · · · · · · · · · · · · · · · · · · |
| ANI1          |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| ANI2          |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| ANI3          |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | √                                     |
| ANI4          |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| ANI5          |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | √                                     |
| ANI16         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ✓                                     |
| ANI17         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | $\checkmark$                          |
| EXCLK         | Input  | External clock input for main system clock                                                                                                                                                                                                          | $\checkmark$                          | $\checkmark$                          |
| INTP0         | Input  | External interrupt request input pin for which the valid edge (rising edge, falling edge, or both rising and falling edges) can be specified.                                                                                                       | $\checkmark$                          | ✓                                     |
| INTP1         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| INTP2         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| INTP3         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | $\checkmark$                          |
| INTP4         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| INTP5         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | $\checkmark$                          |
| INTP6         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| INTP8         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| INTP9         |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| INTP10        |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | $\checkmark$                          |
| INTP11        |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | $\checkmark$                          |
| INTP12        |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| INTP13        |        |                                                                                                                                                                                                                                                     | $\checkmark$                          | $\checkmark$                          |
| INTP14        |        |                                                                                                                                                                                                                                                     | _                                     | $\checkmark$                          |
| INTP15        |        |                                                                                                                                                                                                                                                     | _                                     | ✓                                     |
| PCLBUZ0       | Output | Clock output/buzzer output                                                                                                                                                                                                                          | $\checkmark$                          | ✓                                     |
| REGC          | _      | Pin for connecting regulator output stabilization capacitance for internal operation. Connect this pin to Vss via a capacitor (0.47 to 1 $\mu$ F). Also, use a capacitor with good characteristics, since it is used to stabilize internal voltage. | ~                                     | ~                                     |
| RESETB        | Input  | This is the active-low system reset input pin. When the external reset pin is not used, connect this pin directly or via a resistor to VDD.                                                                                                         | $\checkmark$                          | ~                                     |
| RxD0          | Input  | Serial data input pins of serial interface UART0                                                                                                                                                                                                    | $\checkmark$                          | $\checkmark$                          |
| TxD0          | Output | Serial data output pins of serial interface UART0                                                                                                                                                                                                   | $\checkmark$                          | $\checkmark$                          |
| SCK00         | I/O    | Clock input/output for CSI00, CSI01 Clock input/output for IICA0, IICA1, IICA2                                                                                                                                                                      | $\checkmark$                          | ✓                                     |
| SCK01         | 1      |                                                                                                                                                                                                                                                     | ~                                     | ✓                                     |
| SCLA0         | I/O    |                                                                                                                                                                                                                                                     | $\checkmark$                          | ~                                     |
| SCLA1         |        |                                                                                                                                                                                                                                                     | ~                                     | ~                                     |
| SCLA2         |        |                                                                                                                                                                                                                                                     |                                       | ~                                     |
| SCL00         | Output | Ut Clock output for IIC00, IIC01                                                                                                                                                                                                                    | 1                                     | ~                                     |
| SCL01         |        |                                                                                                                                                                                                                                                     | √                                     | ~                                     |
| SDAA0         | I/O    | Serial data I/O for IICA0, IICA1, IICA2                                                                                                                                                                                                             | √                                     | ~                                     |
| SDAA1         |        |                                                                                                                                                                                                                                                     | √                                     | ~                                     |
| SDAA2         |        |                                                                                                                                                                                                                                                     | _                                     | $\checkmark$                          |
| SDA00         | I/O    | Serial data I/O for IIC00, IIC01                                                                                                                                                                                                                    | $\checkmark$                          | $\checkmark$                          |



SI00

SI01 SO00

SO01 TI00

TI01 TI02 TI03 TI04 TI05 TI06 TI07 TO00

TO01 TO02 TO03 TO04 TO05 TO06 TO07 X1

X2 VDD

AVREFP

**AVREFM** 

TOOLRxD

TOOLTxD

TOOL0

UVdd

UVBUS

UDP0

UDM0

UDP1

UDM1

UVBUSEN0

UOVRCUR0

UVBUSEN1

UOVRCUR1

Vss

Function Name

I/O

Input

Output

Input

Output

\_

Input

Input

Input

Output

I/O

Input

I/O

I/O

I/O

I/O

Output

Input

Output

Input

flash memory programming

Power supply for USB

VBUS input

Data I/O for flash memory programmer/debugger

USB data input/output (+ side) (USB port 0)

USB data input/output (- side) (USB port 0)

USB data input/output (+ side) (USB port 1)

USB data input/output (- side) (USB port 1)

VBUS supply permit output (for USB port 0)

Overcurrent detection input (for USB port 0)

VBUS supply permit output (for USB port 1)

Overcurrent detection input (for USB port 1)

|                                                                                            |                  | (2/2                |  |
|--------------------------------------------------------------------------------------------|------------------|---------------------|--|
| Function                                                                                   | Product with USB | Product without USB |  |
| Function                                                                                   | 32-pin           | 32-pin              |  |
| Serial data input to CSI00, CSI01                                                          | ~                | $\checkmark$        |  |
|                                                                                            | $\checkmark$     | $\checkmark$        |  |
| Serial data output from CSI00, CSI01                                                       | ~                | $\checkmark$        |  |
|                                                                                            | ~                | $\checkmark$        |  |
| he pins for inputting an external count clock/capture trigger to 16-bit                    | ~                | $\checkmark$        |  |
| mers 00 to 07                                                                              | ~                | $\checkmark$        |  |
|                                                                                            | $\checkmark$     | $\checkmark$        |  |
|                                                                                            | ~                | ~                   |  |
|                                                                                            | —                | $\checkmark$        |  |
| imer output pins of 16-bit timers 00 to 07                                                 | ~                | $\checkmark$        |  |
|                                                                                            | $\checkmark$     | $\checkmark$        |  |
|                                                                                            | ~                | $\checkmark$        |  |
|                                                                                            | ~                | $\checkmark$        |  |
|                                                                                            | $\checkmark$     | $\checkmark$        |  |
|                                                                                            | $\checkmark$     | $\checkmark$        |  |
|                                                                                            | $\checkmark$     | $\checkmark$        |  |
|                                                                                            | _                | $\checkmark$        |  |
| Resonator connection for main system clock                                                 | ✓                | $\checkmark$        |  |
|                                                                                            | $\checkmark$     | $\checkmark$        |  |
| ositive power supply for pins other than USB data pins                                     | ~                | ~                   |  |
| /D converter reference potential (+ side) input                                            | ~                | ~                   |  |
| /D converter reference potential (- side) input                                            | ~                | ~                   |  |
| Ground potential for all pins                                                              | ~                | ~                   |  |
| JART reception pin for the external device connection used during flash nemory programming | ✓                | $\checkmark$        |  |

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

~

1

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

 $\checkmark$ 

\_

\_

\_

\_

\_

\_

Caution After reset release, the relationships between P40/TOOL0 and the operating mode are as follows.

UART transmission pin for the external device connection used during



| P40/TOOL0 | Operating mode                |
|-----------|-------------------------------|
| VDD       | Normal operation mode         |
| 0 V       | Flash memory programming mode |

#### Table 2 - 2 Relationships Between P40/TOOL0 and Operation Mode After Reset Release

For details, see 22.4 Programming Method.

Remark Use bypass capacitors (about 0.1 µF) as noise and latch up countermeasures with relatively thick wires at the shortest distance to VDD to Vss lines.



### 2.3 Connection of Unused Pins

Table 2 - 3 shows the Connection of Unused Pins.

Remark The mounted pins depend on the product. Refer to 1.3 Pin Configuration (Top View) and 2.1 Port Functions.

| Pin Name             | I/O                              | Recommended Connection of Unused Pins                                                                                                                                                                                                   |  |
|----------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| P00, P01             | I/O                              | Input: Independently connect to VDD or VSS via a resistor.<br>Output: Leave open.                                                                                                                                                       |  |
| P20 to P25           | I/O                              | Input: Independently connect to VDD or VSS via a resistor.<br>Output: Leave open.                                                                                                                                                       |  |
| P40/TOOL0            | I/O                              | Input: Independently connect to VDD or VSS via a resistor.<br>Output: Leave open.                                                                                                                                                       |  |
| P50 to P55           | I/O                              | Input: Independently connect to VDD or VSS via a resistor.<br>Output: Leave open.                                                                                                                                                       |  |
| P60 to P64           | I/O                              | Input: Independently connect to VDD or VSS via a resistor.<br>Output: Set the port's output latch to 0 and leave the pins open, or set the port's output latch to<br>1 and independently connect the pins to VDD or VSS via a resistor. |  |
| P70 to P74           | I/O                              | Input: Independently connect to VDD or VSS via a resistor.<br>Output: Leave open.                                                                                                                                                       |  |
| P121, P122           | Input                            | Independently connect to VDD or VSS via a resistor.                                                                                                                                                                                     |  |
| P137                 | Input                            | Independently connect to VDD or VSS via a resistor.                                                                                                                                                                                     |  |
| RESETB               | Input                            | Connect directly or via a resistor to VDD.                                                                                                                                                                                              |  |
| REGC                 | —                                | Connect to Vss via capacitor (0.47 to 1 µF).                                                                                                                                                                                            |  |
| UVDD                 | _                                | <ul> <li>When the USB power supply is not used, connect directly to VDD, or draw power from an external 3.3 V supply.</li> <li>When the USB power is generated in the chip, connect to Vss via capacitor (0.33 μF).</li> </ul>          |  |
| UVBUS Note           | Input                            | Independently connect to Vss via a resistor.                                                                                                                                                                                            |  |
| UDM0 Note, UDP0 Note | I/O                              | Input: Independently connect to UVDD or Vss via a resistor.                                                                                                                                                                             |  |
| UDM1 Note, UDP1 Note | DP1 Note I/O Output: Leave open. |                                                                                                                                                                                                                                         |  |

| Table 2 - 3 Connection of Unused Pins | Table | 2 - 3 | Connection | of Unused | l Pins |
|---------------------------------------|-------|-------|------------|-----------|--------|
|---------------------------------------|-------|-------|------------|-----------|--------|

Note This function is not mounted in the R9A02G0151 product.



### 2.4 Pin Block Diagrams

For the pin types listed in 2.1.1 32-pin Products, pin block diagrams are shown in Figures 2 - 1 to 2 - 11.

#### Figure 2 - 1 Pin Block Diagram of Pin Type 2-1-1



Figure 2 - 2 Pin Block Diagram of Pin Type 2-1-2



**Remark** Refer to 2.1 Port Functions for alternate functions.





Figure 2 - 3 Pin Block Diagram of Pin Type 2-2-1

**Remark** Refer to **2.1 Port Functions** for alternate functions.





Figure 2 - 4 Pin Block Diagram of Pin Type 4-3-5





Figure 2 - 5 Pin Block Diagram of Pin Type 7-1-3

Remark 1. Refer to 2.1 Port Functions for alternate functions.Remark 2. SAU: Serial array unit





Figure 2 - 6 Pin Block Diagram of Pin Type 8-1-4

Remark 1. Refer to 2.1 Port Functions for alternate functions.Remark 2. SAU: Serial array unit





Figure 2 - 7 Pin Block Diagram of Pin Type 8-3-4

Remark 1. Refer to 2.1 Port Functions for alternate functions.Remark 2. SAU: Serial array unit





Figure 2 - 8 Pin Block Diagram of Pin Type 12-1-2

Remark 1. Refer to 2.1 Port Functions for alternate functions.Remark 2. SAU: Serial array unit





Figure 2 - 9 Pin Block Diagram of Pin Type 12-1-3

Remark 1. Refer to 2.1 Port Functions for alternate functions.Remark 2. SAU: Serial array unit





Figure 2 - 10 Pin Block Diagram of Pin Type 17-11-1





Figure 2 - 11 Pin Block Diagram of Pin Type 18-11-1



# **CHAPTER 3 CPU ARCHITECTURE**

The R9A02G015 has the RL78-S3 CPU core.

The CPU core in the RL78-S3 employs the Harvard architecture which has independent instruction fetch bus, address bus and data bus. In addition, through the adoption of three-stage pipeline control of fetch, decode, and memory access, the operation efficiency is remarkably improved over the conventional CPU core. The CPU core features high performance and highly functional instruction processing, and can be suited for use in various applications that require high speed and highly functional processing.

- 3-stage pipeline CISC architecture
- Address space: 1 Mbyte
- Minimum instruction execution time: One instruction per clock cycle
- General-purpose registers: Eight 8-bit registers
- Type of instruction: 81

The following multiply/divide instructions are available only in the RL78-S3 CPU core. MULHU (unsigned 16-bit multiplication) MULH (signed 16-bit multiplication) DIVHU (unsigned 16-bit division) DIVWU (unsigned 32-bit division)

MACHU (unsigned multiplication/accumulation (16 bits × 16 bits) + 32 bits) MACH (signed multiplication/accumulation (16 bits × 16 bits) + 32 bits)

Data allocation: Little endian

The R9A02G015 supports an OCD trace function.



# 3.1 Memory Space

Products in the R9A02G015 can access a 1 MB address space. Figures 3 - 1 shows the memory maps.



Figure 3 - 1 Memory Map

- Note 1. Do not allocate the stack area, data buffers, branch destinations in the processing of vectored interrupts to the area from FFE20H to FFEDFH when performing self-programming or rewriting of the data flash memory.
- **Note 2.** Instructions can be executed from the RAM area excluding the general-purpose register area.
- Note 3. When boot swap is not used:Set the option bytes to 000C0H to 000C3H, and the on-chip debug security IDs to 000C4H to 000CDH.

When boot swap is used: Set the option bytes to 000C0H to 000C3H and 010C0H to 010C3H, and the on-chip debug security IDs to 000C4H to 000CDH and 010C4H to 010CDH.

- Note 4. Writing boot cluster 0 can be prohibited depending on the setting of security (see 22.7 Security Settings).
- Caution While RAM parity error resets are enabled (RPERDIS = 0), be sure to initialize RAM areas where data access is to proceed and the RAM area + 10 bytes when instructions are fetched from RAM areas, respectively. Reset signal generation sets RAM parity error resets to enabled (RPERDIS = 0). For details, see 19.3.3 RAM parity error detection function.

 Remark
 The flash memory is divided into blocks (one block = 1 KB). For the address values and block numbers, see Table 3 - 1

 Correspondence Between Address Values and Block Numbers in Flash Memory.



Correspondence between the address values and block numbers in the flash memory are shown below.

| Address Value    | Block<br>Number |
|------------------|-----------------|------------------|-----------------|------------------|-----------------|------------------|-----------------|
| 00000H to 003FFH | 00H             | 08000H to 083FFH | 20H             | 10000H to 103FFH | 40H             | 18000H to 183FFH | 60H             |
| 00400H to 007FFH | 01H             | 08400H to 087FFH | 21H             | 10400H to 107FFH | 41H             | 18400H to 187FFH | 61H             |
| 00800H to 00BFFH | 02H             | 08800H to 07BFFH | 22H             | 10800H to 10BFFH | 42H             | 18800H to 17BFFH | 62H             |
| 00C00H to 00FFFH | 03H             | 08C00H to 08FFFH | 23H             | 10C00H to 10FFFH | 43H             | 18C00H to 18FFFH | 63H             |
| 01000H to 013FFH | 04H             | 09000H to 093FFH | 24H             | 11000H to 113FFH | 44H             | 19000H to 193FFH | 64H             |
| 01400H to 017FFH | 05H             | 09400H to 097FFH | 25H             | 11400H to 117FFH | 45H             | 19400H to 197FFH | 65H             |
| 01800H to 01BFFH | 06H             | 09800H to 09BFFH | 26H             | 11800H to 11BFFH | 46H             | 19800H to 19BFFH | 66H             |
| 01C00H to 01FFFH | 07H             | 09C00H to 09FFFH | 27H             | 11C00H to 11FFFH | 47H             | 19C00H to 19FFFH | 67H             |
| 02000H to 023FFH | 08H             | 0A000H to 0A3FFH | 28H             | 12000H to 123FFH | 48H             | 1A000H to 1A3FFH | 68H             |
| 02400H to 027FFH | 09H             | 0A400H to 0A7FFH | 29H             | 12400H to 127FFH | 49H             | 1A400H to 1A7FFH | 69H             |
| 02800H to 02BFFH | 0AH             | 0A800H to 0ABFFH | 2AH             | 12800H to 12BFFH | 4AH             | 1A800H to 1ABFFH | 6AH             |
| 02C00H to 02FFFH | 0BH             | 0AC00H to 0AFFFH | 2BH             | 12C00H to 12FFFH | 4BH             | 1AC00H to 1AFFFH | 6BH             |
| 03000H to 033FFH | 0CH             | 0B000H to 0B3FFH | 2CH             | 13000H to 133FFH | 4CH             | 1B000H to 1B3FFH | 6CH             |
| 03400H to 037FFH | 0DH             | 0B400H to 0B7FFH | 2DH             | 13400H to 137FFH | 4DH             | 1B400H to 1B7FFH | 6DH             |
| 03800H to 03BFFH | 0EH             | 0B800H to 0BBFFH | 2EH             | 13800H to 13BFFH | 4EH             | 1B800H to 1BBFFH | 6EH             |
| 03C00H to 03FFFH | 0FH             | 0BC00H to 0BFFFH | 2FH             | 13C00H to 13FFFH | 4FH             | 1BC00H to 1BFFFH | 6FH             |
| 04000H to 043FFH | 10H             | 0C000H to 0C3FFH | 30H             | 14000H to 143FFH | 50H             | 1C000H to 1C3FFH | 70H             |
| 04400H to 047FFH | 11H             | 0C400H to 0C7FFH | 31H             | 14400H to 147FFH | 51H             | 1C400H to 1C7FFH | 71H             |
| 04800H to 04BFFH | 12H             | 0C800H to 0CBFFH | 32H             | 14800H to 14BFFH | 52H             | 1C800H to 1CBFFH | 72H             |
| 04C00H to 04FFFH | 13H             | 0CC00H to 0CFFFH | 33H             | 14C00H to 14FFFH | 53H             | 1CC00H to 1CFFFH | 73H             |
| 05000H to 053FFH | 14H             | 0D000H to 0D3FFH | 34H             | 15000H to 153FFH | 54H             | 1D000H to 1D3FFH | 74H             |
| 05400H to 057FFH | 15H             | 0D400H to 0D7FFH | 35H             | 15400H to 157FFH | 55H             | 1D400H to 1D7FFH | 75H             |
| 05800H to 05BFFH | 16H             | 0D800H to 0DBFFH | 36H             | 15800H to 15BFFH | 56H             | 1D800H to 1DBFFH | 76H             |
| 05C00H to 05FFFH | 17H             | 0DC00H to 0DFFFH | 37H             | 15C00H to 15FFFH | 57H             | 1DC00H to 1DFFFH | 77H             |
| 06000H to 063FFH | 18H             | 0E000H to 0E3FFH | 38H             | 16000H to 163FFH | 58H             | 1E000H to 1E3FFH | 78H             |
| 06400H to 067FFH | 19H             | 0E400H to 0E7FFH | 39H             | 16400H to 167FFH | 59H             | 1E400H to 1E7FFH | 79H             |
| 06800H to 06BFFH | 1AH             | 0E800H to 0EBFFH | 3AH             | 16800H to 16BFFH | 5AH             | 1E800H to 1EBFFH | 7AH             |
| 06C00H to 06FFFH | 1BH             | 0EC00H to 0EFFFH | 3BH             | 16C00H to 16FFFH | 5BH             | 1EC00H to 1EFFFH | 7BH             |
| 07000H to 073FFH | 1CH             | 0F000H to 0F3FFH | 3CH             | 17000H to 173FFH | 5CH             | 1F000H to 1F3FFH | 7CH             |
| 07400H to 077FFH | 1DH             | 0F400H to 0F7FFH | 3DH             | 17400H to 177FFH | 5DH             | 1F400H to 1F7FFH | 7DH             |
| 07800H to 07BFFH | 1EH             | 0F800H to 0FBFFH | 3EH             | 17800H to 17BFFH | 5EH             | 1F800H to 1FBFFH | 7EH             |
| 07C00H to 07FFFH | 1FH             | 0FC00H to 0FFFFH | 3FH             | 17C00H to 17FFFH | 5FH             | 1FC00H to 1FFFFH | 7FH             |

Table 3 - 1 Correspondence Between Address Values and Block Numbers in Flash Memory



### 3.1.1 Internal program memory space

The internal program memory space stores the program and table data.

The R9A02G015 products incorporate internal ROM (flash memory), as shown below.

| Part Number   | Interna      | al ROM                             |
|---------------|--------------|------------------------------------|
| Fait Nulliber | Structure    | Capacity                           |
| R9A02G0150    | Flash memory | 131072 × 8 bits (00000H to 1FFFFH) |
| R9A02G0151    |              |                                    |

The internal program memory space is divided into the following areas.

(1) Vector table area

The 128-byte area 00000H to 0007FH is reserved as a vector table area. The program start addresses for branch upon reset or generation of each interrupt request are stored in the vector table area. Furthermore, the interrupt jump address is a 64 K address of 00000H to 0FFFFH, because the vector code is assumed to be 2 bytes.

Of the 16-bit address, the lower 8 bits are stored at even addresses and the higher 8 bits are stored at odd addresses.

To use the boot swap function, set a vector table also at 01000H to 0107FH.

Table 3 - 3 lists the vector table. " $\sqrt{}$ " indicates an interrupt source which is supported. "—" indicates an interrupt source which is not supported.

| Vector Table Address | Interrupt Source                     | With USB     | Without USB  |  |
|----------------------|--------------------------------------|--------------|--------------|--|
|                      |                                      | 32-pin       | 32-pin       |  |
| 00000H               | RESET, POR, LVD, WDT, TRAP, IAW, RPE | $\checkmark$ | $\checkmark$ |  |
| 00004H               | INTWDT1                              | $\checkmark$ | $\checkmark$ |  |
| 00006H               | INTLVI                               | $\checkmark$ | $\checkmark$ |  |
| 00008H               | INTP0                                | $\checkmark$ | $\checkmark$ |  |
| 0000AH               | INTP1                                | $\checkmark$ | $\checkmark$ |  |
| 0000CH               | INTP2                                | $\checkmark$ | $\checkmark$ |  |
| 0000EH               | INTP3                                | $\checkmark$ | $\checkmark$ |  |
| 00010H               | INTP4                                | $\checkmark$ | $\checkmark$ |  |
| 00012H               | INTP5                                | $\checkmark$ | $\checkmark$ |  |
| 00014H               | INTP6                                | $\checkmark$ | $\checkmark$ |  |
| 00016H               | INTST0/INTCSI00/INTIIC00             | $\checkmark$ | $\checkmark$ |  |
| 00018H               | INTSR0/INTCSI01/INTIIC01             | $\checkmark$ | $\checkmark$ |  |
| 0001EH               | INTSRE0                              | $\checkmark$ | $\checkmark$ |  |
| 00020H               | INTTM00                              | $\checkmark$ | $\checkmark$ |  |
| 00026H               | INTTM01H                             | $\checkmark$ | $\checkmark$ |  |
| 00028H               | INTTM03H                             | $\checkmark$ | $\checkmark$ |  |
| 0002AH               | INTTM01                              | $\checkmark$ | $\checkmark$ |  |
| 0002CH               | INTTM02                              | $\checkmark$ | $\checkmark$ |  |
| 0002EH               | INTTM03                              | √            | $\checkmark$ |  |
| 00030H               | INTIICA0                             | √            | $\checkmark$ |  |
| 00032H               | INTIICA1                             | √            | $\checkmark$ |  |
| 00034H               | INTAD                                | √            | $\checkmark$ |  |
|                      |                                      |              |              |  |

#### Table 3 - 3 Vector Table (1/2)



| Vector Table Address | Interrupt Source | With USB     | Without USB  |
|----------------------|------------------|--------------|--------------|
|                      |                  | 32-pin       | 32-pin       |
| 00038H               | INTIT            | $\checkmark$ | $\checkmark$ |
| 0003CH               | INTUSB           | $\checkmark$ | $\checkmark$ |
| 0003EH               | INTRSUM          | $\checkmark$ | $\checkmark$ |
| 00040H               | INTIICA2         | —            | $\checkmark$ |
| 00044H               | INTTM04          | $\checkmark$ | $\checkmark$ |
| 00046H               | INTTM05          | $\checkmark$ | $\checkmark$ |
| 00048H               | INTTM06          | $\checkmark$ | $\checkmark$ |
| 0004AH               | INTTM07          | $\checkmark$ | $\checkmark$ |
| 0004CH               | INTP7            | $\checkmark$ | $\checkmark$ |
| 0004EH               | INTP8            | $\checkmark$ | $\checkmark$ |
| 00050H               | INTP9            | $\checkmark$ | $\checkmark$ |
| 00052H               | INTP10           | $\checkmark$ | $\checkmark$ |
| 00054H               | INTP11           | $\checkmark$ | $\checkmark$ |
| 00056H               | INTP12           | $\checkmark$ | $\checkmark$ |
| 00058H               | INTP13           | $\checkmark$ | $\checkmark$ |
| 0005AH               | INTP14           | —            | $\checkmark$ |
| 0005CH               | INTP15           | —            | $\checkmark$ |
| 00062H               | INTFL            | √            | $\checkmark$ |
| 0007EH               | BRK              | $\checkmark$ | $\checkmark$ |

| Table | 3. | - 3 | Vector | Table | (2/2) |
|-------|----|-----|--------|-------|-------|
|-------|----|-----|--------|-------|-------|

#### (2) CALLT instruction table area

The 64-byte area 00080H to 000BFH can store the subroutine entry address of a 2-byte call instruction (CALLT). Set the subroutine entry address to a value in a range of 00000H to 0FFFFH (because an address code is 2 bytes).

To use the boot swap function, set a CALLT instruction table also at 01080H to 010BFH.

(3) Option byte area

A 4-byte area of 000C0H to 000C3H can be used as an option byte area. Set the option byte at 010C0H to 010C3H when the boot swap is used. For details, see **CHAPTER 21 OPTION BYTE**.

(4) On-chip debug security ID setting area

A 10-byte area of 000C4H to 000CDH and 010C4H to 010CDH can be used as an on-chip debug security ID setting area. Set the on-chip debug security ID of 10 bytes at 000C4H to 000CDH when the boot swap is not used and at 000C4H to 000CDH and at 010C4H to 010CDH when the boot swap is used. For details, see **CHAPTER 23 ON-CHIP DEBUG FUNCTION**.



### 3.1.2 Mirror area

The R9A02G015 mirrors the code flash area of 00000H to 0FFFFH, to F0000H to FFFFFH (the code flash area to be mirrored is set by the processor mode control register (PMC)).

By reading data from F0000H to FFFFFH, an instruction that does not have the ES register as an operand can be used, and thus the contents of the code flash can be read with the shorter code. However, the code flash area is not mirrored to the special function register (SFR), extended special function register (2nd SFR), RAM, data flash memory, and use prohibited areas.

See 3.1 Memory Space for the mirror area of each product.

The mirror area can only be read and no instruction can be fetched from this area.

The following show examples.

#### Example



The PMC register is described below.



Processor mode control register (PMC)
 This register sets the flash memory space for mirroring to area from F0000H to FFFFFH.
 The PMC register can be set by a 1-bit or 8-bit memory manipulation instruction.
 Reset signal generation sets this register to 00H.

#### Figure 3 - 2 Format of Configuration of Processor mode control register (PMC) Address: FFFFEH After reset: 00H R/W Symbol 7 6 5 4 3 2 1 <0> PMC 0 0 0 0 0 0 0 MAA

| MAA | Selection of flash memory space for mirroring to area from F0000H to FFFFH |
|-----|----------------------------------------------------------------------------|
| 0   | 00000H to 0FFFFH is mirrored to F0000H to FFFFH                            |
| 1   | Setting prohibited                                                         |

Caution 1. Be sure to clear bit 0 (MAA) of this register to 0 (default value).

Caution 2. After setting the PMC register, wait for at least one instruction and access the mirror area.

# 3.1.3 Internal data memory space

The R9A02G015 products incorporate the following RAMs.

#### Table 3 - 4 Internal RAM Capacity

| Part Number | Internal RAM                     |  |  |  |  |  |
|-------------|----------------------------------|--|--|--|--|--|
| R9A02G0150  | 7168 × 8 bits (FE300H to FFEFFH) |  |  |  |  |  |
| R9A02G0151  | 7168 × 8 bits (FE300H to FFEFFH) |  |  |  |  |  |

The internal RAM can be used as a data area and a program area where instructions are fetched (it is prohibited to use the general-purpose register area for fetching instructions). Four general-purpose register banks consisting of eight 8-bit registers per bank are assigned to the 32-byte area of FFEE0H to FFEFFH of the internal RAM area.

The internal RAM is used as stack memory.

- Caution 1. It is prohibited to use the general-purpose register (FFEE0H to FFEFFH) space for fetching instructions or as a stack area.
- Caution 2. Do not allocate the stack area, data buffers, branch destinations in the processing of vectored interrupts to the area from FFE20H to FFEDFH when performing self-programming or rewriting of the data flash memory.
- Caution 3. The flash library uses RAM in self-programming and rewriting of the data flash memory. The target products and start address of the RAM areas used by the flash library are shown below.

R9A02G0150/R9A02G0151: Start address FE300H

Caution 4. The internal RAM area in the following products cannot be used as stack memory when using the on-chip debugging trace function. R9A02G0150/R9A02G0151: FE300H to FEAFFH



# 3.1.4 Special function register (SFR) area

On-chip peripheral hardware special function registers (SFRs) are allocated in the area FFF00H to FFFFH (see **Tables 3 - 5** in **3.2.4 Special function registers (SFRs)**).

Caution Do not access addresses to which SFRs are not assigned.

# 3.1.5 Extended special function register (2nd SFR: 2nd Special Function Register) area

On-chip peripheral hardware special function registers (2nd SFRs) are allocated in the area F0000H to F07FFH (see Tables 3 - 6 in 3.2.5 Extended special function registers (2nd SFRs: 2nd Special Function Registers)).

Caution Do not access addresses to which extended SFRs are not assigned.



# 3.1.6 Data memory addressing

Addressing refers to the method of specifying the address of the instruction to be executed next or the address of the register or memory relevant to the execution of instructions.

Several addressing modes are provided for addressing the memory relevant to the execution of instructions for the R9A02G015, based on operability and other considerations. For areas containing data memory in particular, special addressing methods designed for the functions of the special function registers (SFR) and general-purpose registers are available for use. Figure 3 - 3 shows correspondence between data memory and addressing. For details of each addressing, see **3.4 Addressing for Processing Data Addresses**.







# 3.2 **Processor Registers**

The R9A02G015 products incorporate the following processor registers.

# 3.2.1 Control registers

The control registers control the program sequence, statuses and stack memory. The control registers consist of a program counter (PC), a program status word (PSW) and a stack pointer (SP).

(1) Program counter (PC)

The program counter is a 20-bit register that holds the address information of the next program to be executed.

In normal operation, PC is automatically incremented according to the number of bytes of the instruction to be fetched. When a branch instruction is executed, immediate data and register contents are set. Reset signal generation sets the reset vector table values at addresses 0000H and 0001H to the program counter.

#### Figure 3 - 4 Format of Program Counter



(2) Program status word (PSW)

The program status word is an 8-bit register consisting of various flags set/reset by instruction execution. Program status word contents are stored in the stack area upon vectored interrupt request is acknowledged or PUSH PSW instruction execution and are restored upon execution of the RETB, RETI and POP PSW instructions. Reset signal generation sets the PSW register to 06H.

#### Figure 3 - 5 Format of Program Status Word

|     | 7  |   |      |    |      |      |      | 0  |  |
|-----|----|---|------|----|------|------|------|----|--|
| PSW | IE | Z | RBS1 | AC | RBS0 | ISP1 | ISP0 | CY |  |

(a) Interrupt enable flag (IE)

This flag controls the interrupt request acknowledge operations of the CPU.

When 0, the IE flag is set to the interrupt disabled (DI) state, and all maskable interrupt requests are disabled.

When 1, the IE flag is set to the interrupt enabled (EI) state and interrupt request acknowledgment is controlled with an in-service priority flag (ISP1, ISP0), an interrupt mask flag for various interrupt sources, and a priority specification flag.

The IE flag is reset (0) upon DI instruction execution or interrupt acknowledgment and is set (1) upon EI instruction execution.

(b) Zero flag (Z)

When the operation result is zero, this flag is set (1). It is reset (0) in all other cases.

(c) Register bank select flags (RBS0, RBS1)
 These are 2-bit flags to select one of the four register banks.
 In these flags, the 2-bit information that indicates the register bank selected by SEL RBn instruction execution is stored.

- (d) Auxiliary carry flag (AC)
   If the operation result has a carry from bit 3 or a borrow at bit 3, this flag is set (1). It is reset (0) in all other cases.
- (e) In-service priority flags (ISP1, ISP0)

This flag manages the priority of acknowledgeable maskable vectored interrupts. Vectored interrupt requests specified lower than the value of ISP0 and ISP1 flags by the priority specification flag registers (PRn0L, PRn0H, PRn1L, PRn1H, PRn2L, PRn2H) (see **14.3.3**) can not be acknowledged. Actual request acknowledgment is controlled by the interrupt enable flag (IE).

**Remark** n = 0, 1

(f) Carry flag (CY)

This flag stores overflow and underflow upon add/subtract instruction execution. It stores the shift-out value upon rotate instruction execution and functions as a bit accumulator during bit operation instruction execution.

(3) Stack pointer (SP)

This is a 16-bit register to hold the start address of the memory stack area. Only the internal RAM area can be set as the stack area.

#### Figure 3 - 6 Format of Stack Pointer

|    | 15   |      |      |      |      |      |     |     |     |     |     |     |     |     |     | 0 |
|----|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|---|
| SP | SP15 | SP14 | SP13 | SP12 | SP11 | SP10 | SP9 | SP8 | SP7 | SP6 | SP5 | SP4 | SP3 | SP2 | SP1 | 0 |

In stack addressing through a stack pointer, the SP is decremented ahead of write (save) to the stack memory and is incremented after read (restore) from the stack memory.

- Caution 1. Since reset signal generation makes the SP contents undefined, be sure to initialize the SP before using the stack.
- Caution 2. It is prohibited to use the general-purpose register (FFEE0H to FFEFFH) space for fetching instructions or as a stack area.
- Caution 3. Do not allocate RAM addresses which are used as a stack area, a data buffer, a branch destination of vector interrupt processing to the area FFE20H to FFEDFH when performing self-programming and rewriting the data flash memory.
- Caution 4. Use of the RAM areas of the following products is prohibited when performing selfprogramming and rewriting the data flash memory, because these areas are used for each library.

R9A02G0150/R9A02G0151: FE300H to FE709H

Caution 5. The internal RAM area in the following products cannot be used as stack memory when using the on-chip debugging trace function. R9A02G0150/R9A02G0151: FE300H to FEAFFH



# 3.2.2 General-purpose registers

General-purpose registers are mapped at particular addresses (FFEE0H to FFEFFH) of the data memory. The general-purpose registers consists of 4 banks, each bank consisting of eight 8-bit registers (X, A, C, B, E, D, L, and H).

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

Register banks to be used for instruction execution are set by the CPU control instruction (SEL RBn). Because of the 4-register bank configuration, an efficient program can be created by switching between a register for normal processing and a register for interrupt processing for each bank.

# Caution It is prohibited to use the general-purpose register (FFEE0H to FFEFFH) space for fetching instructions or as a stack area.



#### (a) Function name

Figure 3 - 7 Configuration of General-Purpose Registers



# 3.2.3 ES and CS registers

The ES register and CS register are used to specify the higher address for data access and when a branch instruction is executed (register direct addressing), respectively.

The default value of the ES register after reset is 0FH, and that of the CS register is 00H.



#### Figure 3 - 8 Configuration of ES and CS Registers

Though the data area which can be accessed with 16-bit addresses is the 64 Kbytes from F0000H to FFFFFH, using the ES register as well extends this to the 1 Mbyte from 00000H to FFFFFH.





# 3.2.4 Special function registers (SFRs)

Unlike a general-purpose register, each SFR has a special function. SFRs are allocated to the FFF00H to FFFFH area. SFRs can be manipulated like general-purpose registers, using operation, transfer, and bit manipulation instructions. The manipulable bit units, 1, 8, and 16, depend on the SFR type. Each manipulation bit unit can be specified as follows.

1-bit manipulation

Describe as follows for the 1-bit manipulation instruction operand (sfr.bit).

When the bit name is defined: <Bit name>

When the bit name is not defined: <Register name>, <Bit number> or <Address>, <Bit number>

8-bit manipulation

Describe the symbol defined by the assembler for the 8-bit manipulation instruction operand (sfr). This manipulation can also be specified with an address.

• 16-bit manipulation

Describe the symbol defined by the assembler for the 16-bit manipulation instruction operand (sfrp). When specifying an address, describe an even address.

Tables 3 - 5 gives lists of the SFRs. The meanings of items in the table are as follows.

Symbol

This item indicates the address of a special function register. It is a reserved word in the assembler, and is defined as an sfr variable using the #pragma sfr directive in the compiler. When using the assembler, debugger, and simulator, symbols can be written as an instruction operand.

• R/W

This item indicates whether the corresponding SFR can be read or written.

- R/W: Read/write enable
- R: Read only

W: Write only

Manipulable bit units

"√" indicates the manipulable bit unit (1, 8, or 16). "—" indicates a bit unit for which manipulation is not possible.

After reset

This item indicates each register status upon reset signal generation.

Caution Do not access addresses to which SFRs are not assigned.

Remark For extended SFRs (2nd SFRs), see 3.2.5 Extended special function registers (2nd SFRs: 2nd Special Function Registers).



| Address | Special Function Register (SFR) Name                 | Syr            | mbol  | R/W | Mani         | pulable Bit R | ange   | After Reset |
|---------|------------------------------------------------------|----------------|-------|-----|--------------|---------------|--------|-------------|
|         |                                                      |                |       |     | 1-bit        | 8-bit         | 16-bit |             |
| FFF00H  | Port register 0                                      | P0             |       | R/W | $\checkmark$ | ~             | _      | 00H         |
| FFF02H  | Port register 2                                      | P2             |       | R/W | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF04H  | Port register 4                                      | P4             |       | R/W | $\checkmark$ | $\checkmark$  | —      | 00H         |
| FFF05H  | Port register 5                                      | P5             |       | R/W | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF06H  | Port register 6                                      | P6             |       | R/W | $\checkmark$ | $\checkmark$  | —      | 00H         |
| FFF07H  | Port register 7 Note 1                               | P7             |       | R/W | $\checkmark$ | ~             | —      | 00H         |
| FFF0CH  | Port register 12                                     | P12            |       | R/W | $\checkmark$ | $\checkmark$  | _      | Undefined   |
| FFF0DH  | Port register 13                                     | P13            |       | R/W | $\checkmark$ | $\checkmark$  | —      | Undefined   |
| FFF10H  | Serial data register 00                              | TXD0/<br>SIO00 | SDR00 | R/W | _            | ~             | ~      | 0000H       |
| FFF11H  | -                                                    | _              | -     |     | _            | _             | -      |             |
| FFF12H  | Serial data register 01                              | RXD0/<br>SIO01 | SDR01 | R/W | -            | $\checkmark$  | ~      | 0000H       |
| FFF13H  |                                                      | _              |       |     | _            | _             |        |             |
| FFF18H  | Timer data register 00                               | TDR00          |       | R/W | —            | _             | √      | 0000H       |
| FFF19H  |                                                      |                |       |     |              |               |        |             |
| FFF1AH  | Timer data register 01                               | TDR01L         | TDR01 | R/W | _            | $\checkmark$  | ~      | 00H         |
| FFF1BH  |                                                      | TDR01H         |       |     | —            | ~             |        | 00H         |
| FFF1EH  | 10-bit A/D conversion result register                | ADCR           |       | R   | _            | _             | ~      | 0000H       |
| FFF1FH  | 8-bit A/D conversion result register                 | ADCRH          |       | R   | _            | $\checkmark$  | —      | 00H         |
| FFF20H  | Port mode register 0                                 | PM0            |       | R/W | $\checkmark$ | $\checkmark$  | —      | FFH         |
| FFF22H  | Port mode register 2                                 | PM2            |       | R/W | $\checkmark$ | $\checkmark$  | —      | FFH         |
| FFF24H  | Port mode register 4                                 | PM4            |       | R/W | $\checkmark$ | $\checkmark$  | —      | FFH         |
| FFF25H  | Port mode register 5                                 | PM5            |       | R/W | $\checkmark$ | $\checkmark$  | _      | FFH         |
| FFF26H  | Port mode register 6                                 | PM6            |       | R/W | $\checkmark$ | $\checkmark$  | —      | FFH         |
| FFF27H  | Port mode register 7 Note 1                          | PM7            |       | R/W | $\checkmark$ | $\checkmark$  | —      | FFH         |
| FFF30H  | A/D converter mode register 0                        | ADM0           |       | R/W | $\checkmark$ | ~             | _      | 00H         |
| FFF31H  | Analog input channel specification register          | ADS            |       | R/W | $\checkmark$ | ~             | _      | 00H         |
| FFF32H  | A/D converter mode register 1                        | ADM1           |       | R/W | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF38H  | External interrupt rising edge enable register 0     | EGP0           |       | R/W | $\checkmark$ | $\checkmark$  | -      | 00H         |
| FFF39H  | External interrupt falling edge enable register 0    | EGN0           |       | R/W | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF3AH  | External interrupt rising edge enable register 1     | EGP1           |       | R/W | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF3BH  | External interrupt falling edge enable<br>register 1 | EGN1           |       | R/W | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF50H  | IICA shift register 0                                | IICA0          |       | R/W | _            | ~             | —      | 00H         |
| FFF51H  | IICA status register 0                               | IICS0          |       | R   | $\checkmark$ | ~             | —      | 00H         |
| FFF52H  | IICA flag register 0                                 | IICF0          |       | R/W | $\checkmark$ | $\checkmark$  | -      | 00H         |
| FFF54H  | IICA shift register 1                                | IICA1          |       | R/W | _            | ~             | —      | 00H         |
| FFF55H  | IICA status register 1                               | IICS1          |       | R   | $\checkmark$ | ~             | —      | 00H         |
| FFF56H  | IICA flag register 1                                 | IICF1          |       | R/W | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF60H  | IICA shift register 2 Note 1                         | IICA2          |       | R/W | _            | $\checkmark$  | —      | 00H         |
| FFF61H  | IICA status register 2 Note 1                        | IICS2          |       | R   | $\checkmark$ | $\checkmark$  | _      | 00H         |
| FFF62H  | IICA flag register 2 <sup>Note 1</sup>               | IICF2          |       | R/W | $\checkmark$ | ~             | _      | 00H         |

Table 3 - 5 Special Function Register (SFR) List (1/3)



| Address | Special Function Register (SFR) Name                   | Sy     | mbol  | R/W | Man          | ipulable Bit R | ange         | After Reset      |
|---------|--------------------------------------------------------|--------|-------|-----|--------------|----------------|--------------|------------------|
|         |                                                        |        |       | -   | 1-bit        | 8-bit          | 16-bit       |                  |
| FFF64H  | Timer data register 02                                 | TDR02  | TDR02 |     | _            | _              | ~            | 0000H            |
| FFF65H  | 1                                                      |        |       |     |              |                |              |                  |
| FFF66H  | Timer data register 03                                 | TDR03L | TDR03 | R/W | —            | ~              | ~            | 00H              |
| FFF67H  |                                                        | TDR03H |       |     | —            | ~              |              | 00H              |
| FFF68H  | Timer data register 04                                 | TDR04  | •     | R/W | _            | —              | ~            | 0000H            |
| FFF69H  |                                                        |        |       |     |              |                |              |                  |
| FFF6AH  | Timer data register 05                                 | TDR05  |       | R/W | _            | —              | ~            | 0000H            |
| FFF6BH  |                                                        |        |       |     |              |                |              |                  |
| FFF6CH  | Timer data register 06                                 | TDR06  |       | R/W | —            | —              | $\checkmark$ | 0000H            |
| FFF6DH  |                                                        |        |       |     |              |                |              |                  |
| FFF6EH  | Timer data register 07                                 | TDR07  |       | R/W | —            | —              | $\checkmark$ | 0000H            |
| FFF6FH  |                                                        |        |       |     |              |                |              |                  |
| FFF90H  | 12-bit interval timer control register                 | ITMC   |       | R/W | —            | —              | $\checkmark$ | 0FFFH            |
| FFF91H  |                                                        |        |       |     |              |                |              |                  |
| FFFA0H  | Clock operation mode control register                  | CMC    |       | R/W | _            | ~              | —            | 00H              |
| FFFA1H  | Clock operation status control register                | CSC    |       | R/W | $\checkmark$ | ~              | —            | C0H              |
| FFFA2H  | Oscillation stabilization time counter status register | OSTC   |       | R   | $\checkmark$ | ~              | _            | 00H              |
| FFFA3H  | Oscillation stabilization time select register         | OSTS   |       | R/W | —            | ~              | —            | 07H              |
| FFFA4H  | System clock control register                          | СКС    |       | R/W | $\checkmark$ | $\checkmark$   | —            | 00H              |
| FFFA5H  | Clock output select register 0                         | CKS0   |       | R/W | $\checkmark$ | ~              | —            | 00H              |
| FFFA8H  | Reset control flag register                            | RESF   |       | R   | —            | ~              | —            | Undefined Note 2 |
| FFFA9H  | Voltage detection register                             | LVIM   |       | R/W | $\checkmark$ | ~              | —            | 00H Note 2       |
| FFFAAH  | Voltage detection level register                       | LVIS   |       | R/W | $\checkmark$ | ~              | —            | Note 4           |
| FFFABH  | Watchdog timer enable register                         | WDTE   |       | R/W | _            | ~              | —            | 1AH/9AH Note 3   |
| FFFACH  | CRC input register                                     | CRCIN  |       | R/W | —            | ~              | —            | 00H              |
| FFFD0H  | Interrupt request flag register 2                      | IF2L   | IF2   | R/W | $\checkmark$ | ~              | —            | 00H              |
| FFFD1H  |                                                        | IF2H   |       | R/W | $\checkmark$ | ~              | —            | 00H              |
| FFFD4H  | Interrupt mask flag register 2                         | MK2L   | MK2   | R/W | $\checkmark$ | ~              | —            | FFH              |
| FFFD5H  |                                                        | MK2H   |       | R/W | $\checkmark$ | ~              | —            | FFH              |
| FFFD8H  | Priority specification flag register 02                | PR02L  | PR02  | R/W | $\checkmark$ | ~              | —            | FFH              |
| FFFD9H  |                                                        | PR02H  |       | R/W | $\checkmark$ | ~              | —            | FFH              |
| FFFDCH  | Priority specification flag register 12                | PR12L  | PR12  | R/W | $\checkmark$ | ~              | —            | FFH              |
| FFFDDH  |                                                        | PR12H  |       | R/W | $\checkmark$ | ~              | —            | FFH              |
| FFFE0H  | Interrupt request flag register 0                      | IF0L   | IF0   | R/W | $\checkmark$ | $\checkmark$   | $\checkmark$ | 00H              |
| FFFE1H  |                                                        | IF0H   |       | R/W | $\checkmark$ | ~              |              | 00H              |
| FFFE2H  | Interrupt request flag register 1                      | IF1L   | IF1   | R/W | $\checkmark$ | ~              | ~            | 00H              |
| FFFE3H  |                                                        | IF1H   |       | R/W | $\checkmark$ | ~              |              | 00H              |
| FFFE4H  | Interrupt mask flag register 0                         | MK0L   | MK0   | R/W | $\checkmark$ | ~              | ~            | FFH              |
| FFFE5H  |                                                        | MK0H   |       | R/W | $\checkmark$ | ~              |              | FFH              |
| FFFE6H  | Interrupt mask flag register 1                         | MK1L   | MK1   | R/W | $\checkmark$ | ~              | ~            | FFH              |
| FFFE7H  |                                                        | MK1H   |       | R/W | $\checkmark$ | ~              |              | FFH              |
| FFFE8H  | Priority specification flag register 00                | PR00L  | PR00  | R/W | $\checkmark$ | ~              | ~            | FFH              |
| FFFE9H  |                                                        | PR00H  |       | R/W | $\checkmark$ | ~              |              | FFH              |
| FFFEAH  | Priority specification flag register 01                | PR01L  | PR01  | R/W | $\checkmark$ | ~              | ~            | FFH              |
| FFFEBH  |                                                        | PR01H  |       | R/W | $\checkmark$ | ~              |              | FFH              |

# Table 3 - 5 Special Function Register (SFR) List (2/3)



|         | · · · · · · ·                           |       |        |     |              |               |              |             |  |
|---------|-----------------------------------------|-------|--------|-----|--------------|---------------|--------------|-------------|--|
| Address | Special Function Register (SFR) Name    | Sy    | Symbol |     | Mani         | pulable Bit R | ange         | After Reset |  |
|         |                                         |       |        |     | 1-bit        | 8-bit         | 16-bit       |             |  |
| FFFECH  | Priority specification flag register 10 | PR10L | PR10   | R/W | $\checkmark$ | $\checkmark$  | ~            | FFH         |  |
| FFFEDH  | ]                                       | PR10H |        | R/W | $\checkmark$ | $\checkmark$  |              | FFH         |  |
| FFFEEH  | Priority specification flag register 11 | PR11L | PR11   | R/W | $\checkmark$ | $\checkmark$  | $\checkmark$ | FFH         |  |
| FFFEFH  |                                         | PR11L |        | R/W | $\checkmark$ | ~             |              | FFH         |  |
| FFFF0H  | Multiply and accumulation register (L)  | MACRL |        | R/W | $\checkmark$ | $\checkmark$  | ~            | 0000H       |  |
| FFFF1H  |                                         |       |        |     |              |               |              |             |  |
| FFFF2H  | Multiply and accumulation register (H)  | MACRH |        | R/W | —            | _             | ~            | 0000H       |  |
| FFFF3H  |                                         |       |        |     |              |               |              |             |  |
| FFFFEH  | Processor mode control register         | PMC   |        | R/W | $\checkmark$ | $\checkmark$  | —            | 00H         |  |

### Table 3 - 5 Special Function Register (SFR) List (3/3)

Note 1. This register is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.

#### Note 2. These values vary depending on the reset source.

| Registe | Reset Source | RESET Input | Reset by POR | Reset by Execution of Illegal Instruction | Reset by WDT | Reset by RAM parity error | Reset by illegal-<br>memory access | Reset by LVD |  |
|---------|--------------|-------------|--------------|-------------------------------------------|--------------|---------------------------|------------------------------------|--------------|--|
| RESF    | TRAP         | Cleared (0) |              | Set (1)                                   | Held         |                           |                                    | Held         |  |
|         | WDTRF        |             |              | Held                                      | Set (1)      | Held                      | eld                                |              |  |
|         | RPERF        |             |              | Held                                      |              | Set (1)                   | Held                               |              |  |
|         | IAWRF        |             |              | Held                                      |              |                           | Set (1)                            |              |  |
|         | LVIRF        |             |              | Held                                      |              |                           | •                                  | Set (1)      |  |
| LVIM    | LVISEN       | Cleared (0) |              |                                           |              |                           |                                    | Held         |  |
|         | LVIOMSK      | Held        |              |                                           |              |                           |                                    |              |  |
|         | LVIF         |             |              |                                           |              |                           |                                    |              |  |

Note 3. The reset value of the WDTE register is determined by the setting of the option byte.

Note 4. The reset value of the LVIS register is determined by the setting of the option byte.

Remark For extended SFRs (2nd SFRs), see Tables 3 - 6 Extended Special Function Register (2nd SFR) List.



# 3.2.5 Extended special function registers (2nd SFRs: 2nd Special Function Registers)

Unlike a general-purpose register, each extended SFR (2<sup>nd</sup> SFR) has a special function. Extended SFRs are allocated to the F0000H to F07FFH area. SFRs other than those in the SFR area (FFF00H to FFFFFH) are allocated to this area. An instruction that accesses the extended SFR area, however, is 1 byte longer than an instruction that accesses the SFR area.

Extended SFRs can be manipulated like general-purpose registers, using operation, transfer, and bit manipulation instructions. The manipulable bit units, 1, 8, and 16, depend on the SFR type. Each manipulation bit unit can be specified as follows.

• 1-bit manipulation

Describe as follows for the 1-bit manipulation instruction operand (!addr16.bit)

When the bit name is defined: <Bit name>

When the bit name is not defined: <Register name>, <Bit number> or <Address>, <Bit number>

8-bit manipulation

Describe the symbol defined by the assembler for the 8-bit manipulation instruction operand (!addr16). This manipulation can also be specified with an address.

• 16-bit manipulation

Describe the symbol defined by the assembler for the 16-bit manipulation instruction operand (!addr16). When specifying an address, describe an even address.

Tables 3 - 6 gives lists of the extended SFRs. The meanings of items in the table are as follows.

Symbol

This item indicates the address of an extended SFR. It is a reserved word in the assembler, and is defined as an sfr variable using the #pragma sfr directive in the compiler. When using the assembler, debugger, and simulator, symbols can be written as an instruction operand.

• R/W

This item indicates whether the corresponding extended SFR can be read or written.

R/W:Read/write enable

R:Read only

W:Write only

Manipulable bit units

"√" indicates the manipulable bit unit (1, 8, or 16). "—" indicates a bit unit for which manipulation is not possible. • After reset

This item indicates each register status upon reset signal generation.

#### Caution Do not access addresses to which extended SFRs are not assigned.

Remark For SFRs in the SFR area, see 3.2.4 Special function registers (SFRs).



| Address | Extended Special Function Register                        | Symt    | ool   | R/W | Manipulable Bit F |              | Range  | After Reset         |
|---------|-----------------------------------------------------------|---------|-------|-----|-------------------|--------------|--------|---------------------|
|         | (2nd SFR) Name                                            |         |       |     | 1-bit             | 8-bit        | 16-bit |                     |
| F0010H  | A/D converter mode register 2                             | ADM2    |       | R/W | $\checkmark$      | ~            | _      | 00H                 |
| F0011H  | Conversion result comparison upper limit setting register | ADUL    |       | R/W | _                 | $\checkmark$ | _      | FFH                 |
| F0012H  | Conversion result comparison lower limit setting register | ADLL    |       | R/W | _                 | $\checkmark$ | _      | 00H                 |
| F0013H  | A/D test register                                         | ADTES   |       | R/W | _                 | ~            | _      | 00H                 |
| F0030H  | Pull-up resistor option register 0                        | PU0     |       | R/W | $\checkmark$      | ~            | _      | 00H                 |
| F0034H  | Pull-up resistor option register 4                        | PU4     |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0035H  | Pull-up resistor option register 5                        | PU5     |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0037H  | Pull-up resistor option register 7 Note 1                 | PU7     |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0040H  | Port input mode register 0                                | PIM0    |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0045H  | Port input mode register 5                                | PIM5    |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0047H  | Port input mode register 7 Note 1                         | PIM7    |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0050H  | Port output mode register 0                               | POM0    |       | R/W | $\checkmark$      | ~            | _      | 00H                 |
| F0055H  | Port output mode register 5                               | POM5    |       | R/W | ~                 | ~            | _      | 00H                 |
| F0057H  | Port output mode register 7 Note 1                        | POM7    |       | R/W | $\checkmark$      | ~            | _      | 00H                 |
| F0060H  | Port mode control register 0                              | PMC0    |       | R/W | $\checkmark$      | $\checkmark$ | _      | FFH                 |
| F0062H  | Port mode control register 2                              | PMC2    |       | R/W | $\checkmark$      | $\checkmark$ | _      | FFH                 |
| F0070H  | Noise filter enable register 0                            | NFEN0   |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0071H  | Noise filter enable register 1                            | NFEN1   |       | R/W | $\checkmark$      | $\checkmark$ | _      | 00H                 |
| F0074H  | Timer input select register 0                             | TIS0    |       | R/W | _                 | ~            | _      | 00H                 |
| F0077H  | Invalid memory access detection control register          | IAWCTL  |       | R/W | _                 | ~            | _      | 00H                 |
| F007BH  | Port mode selection register                              | PMS     |       | R/W | $\checkmark$      | ~            | _      | 00H                 |
| F0090H  | Data flash control register                               | DFLCTL  |       | R/W | $\checkmark$      | ~            | _      | 00H                 |
| F00A8H  | High-speed on-chip oscillator frequency select register   | HOCODIV |       | R/W | _                 | ~            | —      | Undefined<br>Note 2 |
| F00F0H  | Peripheral enable register 0                              | PER0    |       | R/W | $\checkmark$      | ~            | _      | 00H                 |
| F00F1H  | Peripheral reset control register 0                       | PRR0    |       | R/W | $\checkmark$      | ~            | -      | 00H                 |
| F00F3H  | Subsystem clock supply mode control register              | OSMC    |       | R/W | $\checkmark$      | ~            | -      | 00H                 |
| F00F5H  | RAM parity error control register                         | RPECTL  |       | R/W | $\checkmark$      | $\checkmark$ | —      | 00H                 |
| F00FCH  | Peripheral enable register 2                              | PER2    |       | R/W | $\checkmark$      | $\checkmark$ | -      | 00H                 |
| F00FDH  | Peripheral reset control register 2                       | PRR2    |       | R/W | $\checkmark$      | $\checkmark$ | -      | 00H                 |
| F00FEH  | BCD adjust result register                                | BCDADJ  |       | R   |                   | ~            | —      | Undefined           |
| F0100H  | Serial status register 00                                 | SSR00L  | SSR00 | R   |                   | ~            | ~      | 0000H               |
| F0101H  |                                                           | _       |       | R   |                   | —            |        |                     |
| F0102H  | Serial status register 01                                 | SSR01L  | SSR01 | R   |                   | ~            | ~      | 0000H               |
| F0103H  |                                                           | _       |       | R   | _                 | —            |        |                     |
| F0108H  | Serial flag clear trigger register 00                     | SIR00L  | SIR00 | R/W | _                 | $\checkmark$ | ~      | 0000H               |
| F0109H  |                                                           | _       |       |     | I                 | —            |        |                     |
| F010AH  | Serial flag clear trigger register 01                     | SIR01L  | SIR01 | R/W | -                 | $\checkmark$ | ~      | 0000H               |
| F010BH  |                                                           | _       |       |     |                   | _            |        |                     |
| F0110H  | Serial mode register 00                                   | SMR00   |       | R/W | —                 | _            | ~      | 0020H               |
| F0111H  |                                                           |         |       |     |                   |              |        |                     |
| F0112H  | Serial mode register 01                                   | SMR01   |       | R/W | —                 | _            | ~      | 0020H               |
| F0113H  |                                                           |         |       |     |                   |              |        |                     |
| F0118H  | Serial communication operation setting register 00        | SCR00   |       | R/W | _                 | _            | ~      | 0087H               |
| F0119H  |                                                           |         |       |     |                   |              |        |                     |

Table 3 - 6 Extended Special Function Register (2nd SFR) List (1/6)



| Address          | Extended Special Function Register                 | Syr     | nbol | R/W    | Manip            | ulable Bit | Range  | After Reset |
|------------------|----------------------------------------------------|---------|------|--------|------------------|------------|--------|-------------|
|                  | (2nd SFR) Name                                     |         |      |        | 1-bit 8-bit 16-b |            | 16-bit |             |
| F011AH           | Serial communication operation setting register 01 | SCR01   |      | R/W    | _                | _          | ~      | 0087H       |
| F011BH           |                                                    |         |      |        |                  |            |        |             |
| F0120H           | Serial channel enable status register 0            | SE0L    | SE0  | R      | ~                | ~          | ~      | 0000H       |
| F0121H           |                                                    | —       |      |        | _                | —          |        |             |
| F0122H           | Serial channel start register 0                    | SSOL    | SS0  | R/W    | ~                | ~          | ✓      | 0000H       |
| F0123H           |                                                    | —       |      |        | _                | -          |        |             |
| F0124H           | Serial channel stop register 0                     | STOL    | ST0  | R/W    | $\checkmark$     | ~          | ~      | 0000H       |
| F0125H           |                                                    | —       |      |        | _                | —          |        |             |
| F0126H           | Serial clock select register 0                     | SPS0L   | SPS0 | R/W    | _                | ~          | ~      | 0000H       |
| F0127H           |                                                    | —       |      |        | —                | —          |        |             |
| F0128H           | Serial output register 0                           | SO0     |      | R/W    | —                | —          | ~      | 0303H       |
| F0129H           |                                                    |         |      |        |                  |            |        |             |
| F012AH           | Serial output enable register 0                    | SOE0L   | SOE0 | R/W    | ~                | ~          | ~      | 0000H       |
| F012BH           |                                                    | —       |      |        | _                | —          |        |             |
| F0134H           | Serial output level register 0                     | SOL0L   | SOL0 | R/W    | _                | ~          | ~      | 0000H       |
| F0135H           |                                                    | —       |      |        | _                | —          |        |             |
| F0138H           | Serial standby control register 0                  | SSCOL   | SSC0 | R/W    |                  | ~          | ~      | 0000H       |
| F0139H           |                                                    | —       |      |        | —                | —          |        |             |
| F0180H           | Timer counter register 00                          | TCR00   |      | R      | _                | -          | ~      | FFFFH       |
| F0181H           |                                                    |         |      |        |                  |            |        |             |
| F0182H           | Timer counter register 01                          | TCR01   |      | R      | —                | —          | ~      | FFFFH       |
| F0183H           |                                                    |         |      |        |                  |            |        |             |
| F0184H           | Timer counter register 02                          | TCR02   |      | R      | —                | —          | ~      | FFFFH       |
| F0185H           |                                                    |         |      |        |                  |            |        |             |
| F0186H           | Timer counter register 03                          | TCR03   |      | R      | —                | -          | ~      | FFFFH       |
| F0187H           |                                                    |         |      |        |                  |            |        |             |
| F0188H           | Timer counter register 04                          | TCR04   |      | R      | —                | -          | ~      | FFFFH       |
| F0189H           |                                                    |         |      |        |                  |            |        |             |
| F018AH           | Timer counter register 05                          | TCR05   |      | R      | —                | -          | ~      | FFFFH       |
| F018BH           |                                                    |         |      |        |                  |            |        |             |
| F018CH           | Timer counter register 06                          | TCR06   |      | R      | —                | -          | ~      | FFFFH       |
| F018DH           |                                                    |         |      |        |                  |            |        |             |
| F018EH           | Timer counter register 07                          | TCR07   |      | R      | —                | _          | ~      | FFFFH       |
| F018FH           |                                                    |         |      |        |                  |            |        |             |
| F0190H           | Timer mode register 00                             | TMR00   |      | R/W    | _                | _          | ~      | 0000H       |
| F0191H           | <b>T</b>                                           | THEAT   |      | DAA    |                  |            |        | 000011      |
| F0192H           | Timer mode register 01                             | TMR01   |      | R/W    | _                | -          | ~      | 0000H       |
| F0193H           |                                                    | TMD00   |      | DAA    |                  |            |        | 000011      |
| F0194H           | Timer mode register 02                             | TMR02   |      | R/W    | _                | _          | ~      | 0000H       |
| F0195H           | Timer mode register 02                             | TMD02   |      |        |                  |            |        | 000011      |
| F0196H           | Timer mode register 03                             | TMR03   |      | R/W    | _                | _          | ~      | 0000H       |
| F0197H<br>F0198H | Timer mode register 04                             | TMR04   |      | R/W    |                  |            | ~      | 0000H       |
|                  |                                                    | TIVINU4 |      | rt/ VV | _                | _          | ľ      | 0000        |
| F0199H           | Timer mode register 05                             | TMP05   |      | R/W    |                  |            | ~      | 0000        |
| F019AH<br>F019BH |                                                    | TMR05   |      | rt/ VV | _                | _          | Ň      | 0000H       |
| IUISDU           |                                                    |         |      |        |                  |            |        |             |

Table 3 - 6 Extended Special Function Register (2nd SFR) List (2/6)



| Address | Extended Special Function Register       | Sym      | lod   | R/W | Manip        | ulable Bit   | Range        | After Reset |
|---------|------------------------------------------|----------|-------|-----|--------------|--------------|--------------|-------------|
|         | (2nd SFR) Name                           |          |       |     | 1-bit        | 8-bit        | 16-bit       |             |
| F019CH  | Timer mode register 06                   | TMR06    |       | R/W | _            | _            | $\checkmark$ | 0000H       |
| F019DH  | 1                                        |          |       |     |              |              |              |             |
| F019EH  | Timer mode register 07                   | TMR07    |       | R/W | _            | —            | ~            | 0000H       |
| F019FH  |                                          |          |       |     |              |              |              |             |
| F01A0H  | Timer status register 00                 | TSR00L   | TSR00 | R   | —            | ~            | ~            | 0000H       |
| F01A1H  |                                          | —        |       |     | _            |              |              |             |
| F01A2H  | Timer status register 01                 | TSR01L   | TSR01 | R   | —            | ~            | ~            | 0000H       |
| F01A3H  |                                          | —        |       |     | _            | _            |              |             |
| F01A4H  | Timer status register 02                 | TSR02L   | TSR02 | R   | _            | ~            | ~            | 0000H       |
| F01A5H  |                                          | —        |       |     | _            | _            |              |             |
| F01A6H  | Timer status register 03                 | TSR03L   | TSR03 | R   | _            | $\checkmark$ | ~            | 0000H       |
| F01A7H  |                                          | —        |       |     | —            | —            |              |             |
| F01A8H  | Timer status register 04                 | TSR04L   | TSR04 | R   |              | $\checkmark$ | ~            | 0000H       |
| F01A9H  |                                          | _        |       |     | —            | —            |              |             |
| F01AAH  | Timer status register 05                 | TSR05L   | TSR05 | R   | _            | ~            | ~            | 0000H       |
| F01ABH  |                                          | —        |       |     | _            | _            |              |             |
| F01ACH  | Timer status register 06                 | TSR06L   | TSR06 | R   | _            | $\checkmark$ | ~            | 0000H       |
| F01ADH  |                                          | —        |       |     | —            | —            |              |             |
| F01AEH  | Timer status register 07                 | TSR07L   | TSR07 | R   | _            | ~            | ~            | 0000H       |
| F01AFH  |                                          | —        |       |     | _            | _            |              |             |
| F01B0H  | Timer channel enable status register 0   | TEOL     | TE0   | R   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 0000H       |
| F01B1H  |                                          | —        |       |     | _            | _            |              |             |
| F01B2H  | Timer channel start register 0           | TSOL     | TS0   | R/W | $\checkmark$ | $\checkmark$ | ~            | 0000H       |
| F01B3H  |                                          | —        |       |     | —            | —            |              |             |
| F01B4H  | IICCTL01                                 | TTOL     | TT0   | R/W | $\checkmark$ | $\checkmark$ | ~            | 0000H       |
| F01B5H  |                                          | _        |       |     | —            | —            |              |             |
| F01B6H  | Timer clock select register 0            | TPS0     |       | R/W | —            | —            | $\checkmark$ | 0000H       |
| F01B7H  |                                          |          |       |     |              |              |              |             |
| F01B8H  | Timer output register 0                  | TOOL     | ТО0   | R/W | _            | $\checkmark$ | ~            | 0000H       |
| F01B9H  |                                          | SYSCFG1  |       |     | —            | _            |              |             |
| F01BAH  | Timer output enable register 0           | TOE0L    | TOE0  | R/W | ~            | $\checkmark$ | ~            | 0000H       |
| F01BBH  |                                          | —        |       |     | —            | —            |              |             |
| F01BCH  | Timer output level register 0            | TOLOL    | TOL0  | R/W | —            | $\checkmark$ | ~            | 0000H       |
| F01BDH  |                                          | —        |       |     | _            | —            |              |             |
| F01BEH  | Timer output mode register 0             | TOMOL    | TOM0  | R/W | _            | $\checkmark$ | ~            | 0000H       |
| F01BFH  |                                          | —        |       |     | —            | —            |              |             |
| F0230H  | IICA control register 00                 | IICCTL00 |       | R/W | $\checkmark$ | $\checkmark$ | —            | 00H         |
| F0231H  | IICA control register 01                 | IICCTL01 |       | R/W | $\checkmark$ | $\checkmark$ | —            | 00H         |
| F0232H  | IICA low-level width setting register 0  | IICWL0   |       | R/W | —            | $\checkmark$ | —            | FFH         |
| F0233H  | IICA high-level width setting register 0 | IICWH0   |       | R/W | _            | $\checkmark$ | _            | FFH         |
| F0234H  | Slave address register 0                 | SVA0     |       | R/W | —            | $\checkmark$ | —            | 00H         |
| F0238H  | IICA control register 10                 | IICCTL10 |       | R/W | ~            | ~            | —            | 00H         |
| F0239H  | IICA control register 11                 | IICCTL11 |       | R/W | ~            | ~            | —            | 00H         |
| F023AH  | IICA low-level width setting register 1  | IICWL1   |       | R/W | _            | ~            | _            | FFH         |
| F023BH  | IICA high-level width setting register 1 | IICWH1   |       | R/W | —            | ~            | —            | FFH         |
| F023CH  | Slave address register 1                 | SVA1     |       | R/W | —            | ~            | —            | 00H         |

Table 3 - 6 Extended Special Function Register (2nd SFR) List (3/6)



| Address          | Extended Special Function Register              | Sym       | bol     | R/W     | Manip        | ulable Bit   | After Reset  |        |
|------------------|-------------------------------------------------|-----------|---------|---------|--------------|--------------|--------------|--------|
|                  | (2nd SFR) Name                                  |           |         |         | 1-bit        | 8-bit        | 16-bit       |        |
| F0240H           | IICA control register 20 Note 1                 | IICCTL20  |         | R/W     | ~            | ~            | _            | 00H    |
| F0241H           | IICA control register 21 Note 1                 | IICCTL21  |         | R/W     | ~            | ~            | -            | 00H    |
| F0242H           | IICA low-level width setting register 2 Note 1  | IICWL2    |         | R/W     | _            | ~            | _            | FFH    |
| F0243H           | IICA high-level width setting register 2 Note 1 | IICWH2    |         | R/W     | _            | ~            | _            | FFH    |
| F0244H           | Slave address register 2 Note 1                 | SVA2      |         | R/W     | _            | ~            | _            | 00H    |
| F02E5H           | PLL control register                            | DSCCTL    |         | R/W     | ~            | ~            | _            | 00H    |
| F02E6H           | Main clock control register                     | МСКС      |         | R/W     | $\checkmark$ | ~            | -            | 00H    |
| F02F0H           | Flash memory CRC control register               | CRC0CTL   |         | R/W     | $\checkmark$ | ~            | -            | 00H    |
| F02F2H           | Flash memory CRC operation result register      | PGCRCL    |         | R/W     | _            |              | ~            | 0000H  |
| F02F3H           | 7                                               |           |         |         |              |              |              |        |
| F02FAH           | CRC data register                               | CRCD      |         | R/W     | —            | —            | ~            | 0000H  |
| F02FBH           | 7                                               |           |         |         |              |              |              |        |
| F0400H           | System configuration control register Note 3    | SYSCFG    |         | R/W     | _            | _            | ~            | 0000H  |
| F0401H           |                                                 |           |         |         |              |              |              |        |
| F0402H           | System configuration control register 1 Note 3  | SYSCFG1   |         | R/W     | _            | _            | ~            | 0000H  |
| F0403H           |                                                 |           |         |         |              |              |              |        |
| F0404H           | System configuration status register 0 Note 3   | SYSSTS0   |         | R       | —            | —            | ~            | 0000H  |
| F0405H           |                                                 |           |         |         |              |              |              |        |
| F0406H           | System configuration status register 1 Note 3   | SYSSTS1   |         | R       | —            | —            | $\checkmark$ | 0000H  |
| F0407H           |                                                 |           |         |         |              |              |              |        |
| F0408H           | Device state control register 0 Note 3          | DVSTCTR0  |         | R/W     | —            | —            | ~            | 0000H  |
| F0409H           |                                                 |           |         |         |              |              |              |        |
| F040AH           | Device state control register 1 Note 3          | DVSTCTR1  |         | R/W     | —            | —            | ~            | 0000H  |
| F040BH           |                                                 |           |         |         |              |              |              |        |
| F0414H           | CFIFO port register Note 3                      | CFIFOML   | CFIFOM  | R/W     | _            | ~            | ~            | 0000H  |
| F0415H           |                                                 | —         |         |         | _            | —            |              |        |
| F0418H           | D0FIFO port register Note 3                     | D0FIFOML  | D0FIFOM | R/W     | _            | $\checkmark$ | ~            | 0000H  |
| F0419H           |                                                 |           |         |         | _            | _            |              |        |
| F041CH           | D1FIFO port register Note 3                     | D1FIFOML  | D1FIFOM | R/W     | _            | ~            | ~            | 0000H  |
| F041DH           |                                                 |           |         |         | _            | _            |              |        |
| F0420H           | CFIFO port selection register Note 3            | CFIFOSEL  |         | R/W     | _            | _            | ~            | 0000H  |
| F0421H           |                                                 |           |         | DAA     |              |              |              | 000011 |
| F0422H           | CFIFO port control register Note 3              | CFIFOCTR  |         | R/W     | _            |              | ~            | 0000H  |
| F0423H           |                                                 | DOFIEOSEI |         | R/W     |              |              | ~            | 0000   |
| F0428H<br>F0429H | D0FIFO port selection register Note 3           | D0FIFOSEL |         | FK/ VV  | _            | _            | v            | 0000H  |
| F0429H           | D0FIFO port control register Note 3             | D0FIFOCTR |         | R/W     |              |              | ~            | 0000H  |
| F042AH           |                                                 |           |         | 11/11   |              |              | ľ            | 0000   |
| F042CH           | D1FIFO port selection register Note 3           | D1FIFOSEL |         | R/W     |              |              | ~            | 0000H  |
| F042DH           |                                                 |           |         | 1.7.4.4 |              |              |              | 000011 |
| F042EH           | D1FIFO port control register Note 3             | D1FIFOCTR |         | R/W     |              |              | √            | 0000H  |
| F042FH           |                                                 |           |         |         |              |              |              | 500011 |
| F0430H           | Interrupt enable register 0 Note 3              | INTENB0   |         | R/W     |              |              | √            | 0000H  |
| F0431H           |                                                 |           |         |         |              |              |              | 500011 |
| F0432H           | Interrupt enable register 1 Note 3              | INTENB1   |         | R/W     |              |              | ~            | 0000H  |
|                  |                                                 |           |         |         |              |              | 1            |        |

Table 3 - 6 Extended Special Function Register (2nd SFR) List (4/6)



| Address | Extended Special Function Register           | Symbol   | R/W    | Manipulable Bit Range |   |   | After Reset |
|---------|----------------------------------------------|----------|--------|-----------------------|---|---|-------------|
|         | (2nd SFR) Name                               |          |        | 1-bit 8-bit 16-bit    |   |   | ĺ           |
| F0434H  | Interrupt enable register 2 Note 3           | INTENB2  | R/W    | —                     | - | ~ | 0000H       |
| F0435H  | 7                                            |          |        |                       |   |   |             |
| F0436H  | BRDY interrupt enable register Note 3        | BRDYENB  | R/W    | —                     | — | ~ | 0000H       |
| F0437H  |                                              |          |        |                       |   |   |             |
| F0438H  | NRDY interrupt enable register Note 3        | NRDYENB  | R/W    | —                     | — | ~ | 0000H       |
| F0439H  |                                              |          |        |                       |   |   |             |
| F043AH  | BEMP interrupt register Note 3               | BEMPENB  | R/W    | _                     | — | ~ | 0000H       |
| F043BH  |                                              |          |        |                       |   |   |             |
| F043CH  | SOF output configuration register Note 3     | SOFCFG   | R/W    | _                     | — | ~ | 0000H       |
| F043DH  |                                              |          |        |                       |   |   |             |
| F0440H  | Interrupt status register 0 Note 3           | INTSTS0  | R/W    | _                     | — | ~ | 00000000    |
| F0441H  |                                              |          |        |                       |   |   | X000000B    |
| F0442H  | Interrupt status register 1 Note 3           | INTSTS1  | R/W    | _                     | — | ~ | XX0X0000    |
| F0443H  |                                              |          |        |                       |   |   | 0000000B    |
| F0444H  | Interrupt status register 2 Note 3           | INTSTS2  | R/W    | —                     | — | ~ | X00X0000    |
| F0445H  |                                              |          |        |                       |   |   | 0000000B    |
| F0446H  | BRDY interrupt status register Note 3        | BRDYSTS  | R/W    | _                     | — | ~ | 0000H       |
| F0447H  |                                              |          |        |                       |   |   |             |
| F0448H  | NRDY Interrupt status register Note 3        | NRDYSTS  | R/W    | _                     | — | ~ | 0000H       |
| F0449H  |                                              |          |        |                       |   |   |             |
| F044AH  | BEMP interrupt status register Note 3        | BEMPSTS  | R/W    | _                     | — | ~ | 0000H       |
| F044BH  |                                              |          |        |                       |   |   |             |
| F044CH  | Frame number register Note 3                 | FRMNUM   | R/W    | _                     | — | ~ | 0000H       |
| F044DH  |                                              |          |        |                       |   |   |             |
| F0450H  | USB address register Note 3                  | USBADDR  | R      | —                     | — | ~ | 0000H       |
| F0451H  |                                              |          |        |                       |   |   |             |
| F0454H  | USB request type register Note 3             | USBREQ   | Note 4 | _                     | — | ~ | 0000H       |
| F0455H  |                                              |          |        |                       |   |   |             |
| F0456H  | USB request value register Note 3            | USBVAL   | Note 4 | _                     | - | ~ | 0000H       |
| F0457H  |                                              |          |        |                       |   |   |             |
| F0458H  | USB request index register Note 3            | USBINDX  | Note 4 | _                     | - | ~ | 0000H       |
| F0459H  |                                              |          |        |                       |   |   |             |
| F045AH  | USB request length register Note 3           | USBLENG  | Note 4 | _                     | - | ~ | 0000H       |
| F045BH  |                                              |          |        |                       |   |   |             |
| F045CH  | DCP configuration register <sup>Note 3</sup> | DCPCFG   | R/W    | —                     | - | ~ | 0000H       |
| F045DH  |                                              |          |        |                       |   |   |             |
| F045EH  | DCP maximum packet size register Note 3      | DCPMAXP  | R/W    | —                     | — | ~ | 0000H       |
| F045FH  |                                              |          |        |                       |   |   |             |
| F0460H  | DCP control register Note 3                  | DCPCTR   | R/W    | —                     | - | ~ | 0000H       |
| F0461H  |                                              |          |        |                       |   |   |             |
| F0464H  | Pipe window selection register Note 3        | PIPESEL  | R/W    | —                     | - | ~ | 0000H       |
| F0465H  |                                              |          |        |                       |   |   |             |
| F0468H  | Pipe configuration register Note 3           | PIPECFG  | R/W    | —                     | - | ~ | 0000H       |
| F0469H  |                                              |          |        |                       |   |   |             |
| F046CH  | Pipe maximum packet size register Note 3     | PIPEMAXP | R/W    | —                     | - | ~ | 0000H/      |
| F046DH  |                                              |          |        |                       |   |   | 0040H       |

Table 3 - 6 Extended Special Function Register (2nd SFR) List (5/6)



| Address | Extended Special Function Register                | Symbol                      | R/W        | Manip              | After Reset |              |        |
|---------|---------------------------------------------------|-----------------------------|------------|--------------------|-------------|--------------|--------|
|         | (2nd SFR) Name                                    |                             |            | 1-bit 8-bit 16-bit |             |              |        |
| F046EH  | Pipe interval control register Note 3             | PIPEPERI                    | R/W        | _                  | _           | $\checkmark$ | 0000H  |
| F046FH  | 1                                                 |                             |            |                    |             |              |        |
| F0476H  | Pipe 4 control register Note 3                    | PIPE4CTR                    | R/W        | _                  | _           | ~            | 0000H  |
| F0477H  |                                                   |                             |            |                    |             |              |        |
| F0478H  | Pipe 5 control register Note 3                    | PIPE5CTR                    | R/W        | _                  | _           | ~            | 0000H  |
| F0479H  | 1                                                 |                             |            |                    |             |              |        |
| F047AH  | Pipe 6 control register Note 3                    | PIPE6CTR                    | R/W        | _                  |             | ~            | 0000H  |
| F047BH  | 1                                                 |                             |            |                    |             |              |        |
| F047CH  | Pipe 7 control register Note 3                    | PIPE7CTR                    | R/W        | _                  | _           | ~            | 0000H  |
| F047DH  |                                                   |                             |            |                    |             |              |        |
| F049CH  | Pipe 4 transaction counter enable register Note 3 | PIPE4TRE                    | R/W        | _                  | _           | ~            | 0000H  |
| F049DH  |                                                   |                             |            |                    |             |              |        |
| F049EH  | Pipe 4 transaction counter register Note 3        | PIPE4TRN                    | R/W        | _                  | _           | ~            | 0000H  |
| F049FH  |                                                   |                             |            |                    |             |              |        |
| F04A0H  | Pipe 5 transaction counter enable register Note 3 | PIPE5TRE                    | R/W        | _                  | _           | ~            | 0000H  |
| F04A1H  | -<br>-                                            |                             |            |                    |             |              |        |
| F04A2H  | Pipe 5 transaction counter register Note 3        | PIPE5TRN                    | R/W        | _                  | _           | ~            | 0000H  |
| F04A3H  |                                                   |                             |            |                    |             |              |        |
| F04B0H  | BC control register 0 Note 3                      | USBBCCTRL0                  | R/W        | _                  | _           | √            | 0000H  |
| F04B1H  |                                                   |                             |            |                    |             |              |        |
| F04B4H  | BC control register 1 Note 3                      | USBBCCTRL1                  | R/W        | _                  |             | ~            | 0000H  |
| F04B5H  |                                                   |                             |            |                    |             |              |        |
| F04B8H  | BC option control register 0 Note 3               | USBBCOPT0                   | R/W        | _                  | _           | ~            | 0000H  |
| F04B9H  |                                                   |                             |            |                    |             |              |        |
| F04BCH  | BC option control register 1 Note 3               | USBBCOPT1                   | R/W        | _                  | _           | ~            | 0000H  |
| F04BDH  |                                                   |                             |            |                    |             |              |        |
| F04C4H  | USB clock selection register Note 3               | UCKSEL                      | R/W        | _                  |             | ~            | 0000H  |
| F04C5H  |                                                   |                             |            |                    |             |              |        |
| F04CCH  | USB module control register Note 3                | USBMC                       | R/W        | _                  | _           | ~            | 0000H  |
| F04CDH  |                                                   |                             |            |                    |             |              |        |
| F04D0H  | Device address 0 configuration register Note 3    | DEVADD0                     | R/W        | _                  |             | √            | 0000H  |
| F04D1H  |                                                   |                             |            |                    |             |              |        |
| F04D2H  | Device address 1 configuration register Note 3    | DEVADD1                     | R/W        | _                  |             | √            | 0000H  |
| F04D3H  |                                                   |                             |            |                    |             |              |        |
| F04D4H  | Device address 2 configuration register Note 3    | DEVADD2                     | R/W        | _                  |             | √            | 0000H  |
| F04D5H  |                                                   |                             |            |                    |             |              |        |
| F04D6H  | Device address 3 configuration register Note 3    | DEVADD3                     | R/W        | _                  | _           | ~            | 0000H  |
| F04D7H  |                                                   | -                           |            |                    |             |              |        |
| F04D8H  | Device address 4 configuration register Note 3    | DEVADD4                     | R/W        |                    |             | √            | 0000H  |
| F04D9H  |                                                   |                             |            |                    |             |              |        |
| F04DAH  | Device address 5 configuration register Note 3    | DEVADD5                     | R/W        |                    |             | √            | 0000H  |
| F04DBH  | Serve address & configuration register root a     | 5200000                     | 1          |                    | _           |              | 000011 |
| Note 1. | This register is incorporated with R9A02G015      | 1 but is not incorporated v | vith R9402 | G0150              |             |              |        |
| Note 2. | The value after a reset is a value set in FRQS    |                             |            |                    |             |              |        |
| Note 3. | This register is incorporated with R9A02G015      |                             | -          |                    |             |              |        |
|         | When the function controller is selected, the re  |                             |            |                    |             |              |        |

| Table 3 - 6 Extended Special | Function Register  | (2nd SFR) List (6/6) |
|------------------------------|--------------------|----------------------|
|                              | i anotion regiotor |                      |

**Remark** For SFRs in the SFR area, see **Tables 3 - 5 Special Function Register (SFR) List**.

# 3.3 Instruction Address Addressing

# 3.3.1 Relative addressing

#### [Function]

Relative addressing stores in the program counter (PC) the result of adding a displacement value included in the instruction word (signed complement data: -128 to +127 or -32768 to +32767) to the program counter (PC)'s value (the start address of the next instruction), and specifies the program address to be used as the branch destination. Relative addressing is applied only to branch instructions.

Figure 3 - 10 Outline of Relative Addressing



# 3.3.2 Immediate addressing

#### [Function]

Immediate addressing stores immediate data of the instruction word in the program counter, and specifies the program address to be used as the branch destination.

For immediate addressing, CALL !!addr20 or BR !!addr20 is used to specify 20-bit addresses and CALL !addr16 or BR !addr16 is used to specify 16-bit addresses. 0000 is set to the higher 4 bits when specifying 16-bit addresses.

Figure 3 - 11 Example of CALL !!addr20/BR !!addr20



#### Figure 3 - 12 Example of CALL !addr16/BR !addr16





# 3.3.3 Table indirect addressing

#### [Function]

Table indirect addressing specifies a table address in the CALLT table area (0080H to 00BFH) with the 5-bit immediate data in the instruction word, stores the contents at that table address and the next address in the program counter (PC) as 16-bit data, and specifies the program address. Table indirect addressing is applied only for CALLT instructions.

In the R9A02G015, branching is enabled only to the 64 KB space from 00000H to 0FFFFH.



#### Figure 3 - 13 Outline of Table Indirect Addressing

# 3.3.4 Register indirect addressing

#### [Function]

Register direct addressing stores in the program counter (PC) the contents of a general-purpose register pair (AX/BC/DE/HL) and CS register of the current register bank specified with the instruction word as 20-bit data, and specifies the program address. Register indirect addressing can be applied only to the CALL AX, BC, DE, HL, and BR AX instructions.







# 3.4 Addressing for Processing Data Addresses

# 3.4.1 Implied addressing

#### [Function]

Instructions for accessing registers (such as accumulators) that have special functions are directly specified with the instruction word, without using any register specification field in the instruction word.

#### [Operand format]

Implied addressing can be applied only to MULU X.





Memory (register area)

# 3.4.2 Register addressing

#### [Function]

Register addressing accesses a general-purpose register as an operand. The instruction word of 3-bit long is used to select an 8-bit register and the instruction word of 2-bit long is used to select a 16-bit register.

#### [Operand format]

| Identifier | Description            |
|------------|------------------------|
| r          | X, A, C, B, E, D, L, H |
| rp         | AX, BC, DE, HL         |

#### Figure 3 - 16 Outline of Register Addressing





## 3.4.3 Direct addressing

#### [Function]

Direct addressing uses immediate data in the instruction word as an operand address to directly specify the target address.

[Operand format]

| Identifier Description |                                                                                          |
|------------------------|------------------------------------------------------------------------------------------|
| !addr16                | Label or 16-bit immediate data (only the space from F0000H to FFFFFH is specifiable)     |
| ES:laddr16             | Label or 16-bit immediate data (higher 4-bit addresses are specified by the ES register) |









 A 16-bit address <2> in the area from X0000H to XFFFFH and the ES register <1> specify the target location; this is used for access to fixed data other than that in mirrored areas.



# 3.4.4 Short direct addressing

#### [Function]

Short direct addressing directly specifies the target addresses using 8-bit data in the instruction word. This type of addressing is applied only to the space from FFE20H to FFF1FH.

[Operand format]

| Identifier | Description                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| SADDR      | Label, FFE20H to FFF1FH immediate data, or 0FE20H to 0FF1FH immediate data (only the space from FFE20H to FFF1FH is specifiable)                     |
| SADDRP     | Label, FFE20H to FFF1FH immediate data, or 0FE20H to 0FF1FH immediate data (even address only) (only the space from FFE20H to FFF1FH is specifiable) |





**Remark** SADDR and SADDRP are used to describe the values of addresses FE20H to FF1FH with 16-bit immediate data (higher 4 bits of actual address are omitted), and the values of addresses FFE20H to FFF1FH with 20-bit immediate data.

Regardless of whether SADDR or SADDRP is used, addresses within the space from FFE20H to FFF1FH are specified for the memory.



# 3.4.5 SFR addressing

#### [Function]

SFR addressing directly specifies the target SFR addresses using 8-bit data in the instruction word. This type of addressing is applied only to the space from FFF00H to FFFFFH.

[Operand format]

| Identifier | Description                                  |
|------------|----------------------------------------------|
| SFR        | SFR name                                     |
| SFRP       | 16-bit-manipulatable SFR name (even address) |



### Figure 3 - 20 Outline of SFR Addressing



## 3.4.6 Register indirect addressing

#### [Function]

Register indirect addressing directly specifies the target addresses using the contents of the register pair specified with the instruction word as an operand address.

#### [Operand format]

| Identifier | Description                                                                |
|------------|----------------------------------------------------------------------------|
| —          | [DE], [HL] (only the space from F0000H to FFFFFH is specifiable)           |
| —          | ES:[DE], ES:[HL] (higher 4-bit addresses are specified by the ES register) |









• Either pair of registers <2> and the ES register <1> specify the target location in the area from X0000H to XFFFFH.



### 3.4.7 Based addressing

#### [Function]

Based addressing uses the contents of a register pair specified with the instruction word or 16-bit immediate data as a base address, and 8-bit immediate data or 16-bit immediate data as offset data. The sum of these values is used to specify the target address.

#### [Operand format]

| Identifier | Description                                                                                 |
|------------|---------------------------------------------------------------------------------------------|
| _          | [HL + byte], [DE + byte], [SP + byte] (only the space from F0000H to FFFFFH is specifiable) |
| —          | word[B], word[C] (only the space from F0000H to FFFFFH is specifiable)                      |
| —          | word[BC] (only the space from F0000H to FFFFFH is specifiable)                              |
| —          | ES:[HL + byte], ES:[DE + byte] (higher 4-bit addresses are specified by the ES register)    |
| —          | ES:word[B], ES:word[C] (higher 4-bit addresses are specified by the ES register)            |
| —          | ES:word[BC] (higher 4-bit addresses are specified by the ES register)                       |

Figure 3 - 23 Example of [SP+byte]



Figure 3 - 24 Example of [HL + byte], [DE + byte]]





Figure 3 - 25 Example of word [B], word [C]



Figure 3 - 26 Example of word [BC]







<sup>• &</sup>quot;byte" <3> specifies an offset within the array to the target location in memory.



#### Figure 3 - 28 Example of word [B], word [C]

- "word" <2> specifies the address where the target array of word-sized data starts in the 64-Kbyte area specified in the ES register <1>.
- Either register <3> specifies an offset within the array to the target location in memory.





- word-sized data starts in the 64-Kbyte area specified in the ES register <1>.
- A pair of registers <3> specifies an offset within the array to the target location in memory.



### 3.4.8 Based indexed addressing

#### [Function]

Based indexed addressing uses the contents of a register pair specified with the instruction word as the base address, and the content of the B register or C register similarly specified with the instruction word as offset address. The sum of these values is used to specify the target address.

#### [Operand format]

| Identifier | Description                                                                    |
|------------|--------------------------------------------------------------------------------|
| —          | [HL+B], [HL+C] (only the space from F0000H to FFFFFH is specifiable)           |
| —          | ES:[HL+B], ES:[HL+C] (higher 4-bit addresses are specified by the ES register) |



#### Figure 3 - 30 Example of [HL + B], [HL + C]





- the address range.
  A pair of registers <2> specifies the address where the target array of data starts in the 64-Kbyte area specified
- target array of data starts in the 64-Kbyte area specified in the ES register <1>.
  Either register <3> specifies an offset within the array to
- Either register <3> specifies an offset within the array to the target location in memory.



### 3.4.9 Stack addressing

#### [Function]

The stack area is indirectly addressed with the stack pointer (SP) values. This addressing is automatically employed when the PUSH, POP, subroutine call, and return instructions are executed or the register is saved/restored upon generation of an interrupt request.

Only the internal RAM area can be set as the stack area.

#### [Operand format]

| Identifier | Description                                                             |
|------------|-------------------------------------------------------------------------|
| _          | PUSH PSW AX/BC/DE/HL<br>POP PSW AX/BC/DE/HL<br>CALL/CALLT<br>RET<br>BRK |
|            | RETB<br>(Interrupt request generated)<br>RETI                           |

The data to be saved/restored by each stack operation is shown in Figures 3 - 32 to 3 - 37.



#### Figure 3 - 32 Example of PUSH rp



Figure 3 - 33 Example of POP



Figure 3 - 34 Example of CALL, CALLT



<sup>•</sup> The value of the SP <3> is decreased by 4.





Figure 3 - 36 Example of Interrupt, BRK



- The values of the PSW, PC bits 19 to 16, 15 to 8, and 7 to 0 are stored in addresses SP-1, SP-2, SP-3, and SP-4, respectively <2>.
- The value of the SP <3> is decreased by 4.

Figure 3 - 37 Example of RETI, RETB



• The value of SP <3> is increased by four.



## **CHAPTER 4 PORT FUNCTIONS**

### 4.1 Port Functions

The R9A02G015 is provided with digital I/O ports, which enable variety of control operations. In addition to the function as digital I/O ports, these ports have several alternate functions. For details of the alternate functions, see **CHAPTER 2 PIN FUNCTIONS**.

### 4.2 Port Configuration

Ports include the following hardware.

| Item              | Configuration                                                                                                                                           |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Control registers | Port mode registers (PM0, PM2, PM4 to PM7)                                                                                                              |
|                   | Port registers (P0, P2, P4 to 7, P12, P13)                                                                                                              |
|                   | Pull-up resistor option registers (PU0, PU4, PU5, PU7)                                                                                                  |
|                   | Port input mode registers (PIM0, PIM5, PIM7)                                                                                                            |
|                   | Port output mode registers (POM0, POM5, POM7)                                                                                                           |
|                   | Port mode control registers (PMC0, PMC2)                                                                                                                |
| Port              | <ul> <li>32-pin product (with USB)<br/>Total: 23 (CMOS I/O: 15, CMOS input: 3, N-ch open drain I/O: 5)</li> <li>32-pin product (without USB)</li> </ul> |
|                   | Total: 28 (CMOS I/O: 20, CMOS input: 3, N-ch open drain I/O: 5)                                                                                         |
| Pull-up resistor  | <ul> <li>32-pin product (with USB) : 9</li> <li>32-pin product (without USB): 14</li> </ul>                                                             |

| Table | 4 - | - 1 | Port | Configuration |
|-------|-----|-----|------|---------------|
|-------|-----|-----|------|---------------|

### 4.2.1 Port 0

Port 0 is an I/O port with an output latch. Port 0 can be set to the input mode or output mode in 1-bit units using port mode register 0 (PM0). When the P00 and P01 are used as an input port, use of an on-chip pull-up resistor can be specified in 1-bit units by pull-up resistor option register 0 (PU0).

To use P00 and P01 as digital input/output pins, set them in the digital I/O mode by using port mode control register 0 (PMC0) (can be specified in 1-bit units).

This port can also be used for external interrupt request input, timer I/O, A/D converter analog input, and buzzer output.

Reset signal generation sets port 0 to analog input port.

### 4.2.2 Port 2

Port 2 is an I/O port with an output latch. Port 2 can be set to the input mode or output mode in 1-bit units using port mode register 2 (PM2).

This port can also be used for A/D converter analog input.

To use P20 to P25 as analog input pins, set them to analog input using port mode control register 2 (PMC2) (can be specified in 1-bit units).

Reset signal generation sets port 2 to analog input port.

### 4.2.3 Port 4

Port 4 is an I/O port with an output latch. Port 4 can be set to the input mode or output mode in 1-bit units using port mode register 4 (PM4). When the P40 pin is used as an input port, use of an on-chip pull-up resistor can be specified in 1-bit units by pull-up resistor option register 4 (PU4).

This port can also be used for data I/O for a flash memory programmer/debugger.

Reset signal generation sets port 4 to input port.

### 4.2.4 Port 5

Port 5 is an I/O port with an output latch. Port 5 can be set to the input mode or output mode in 1-bit units using port mode register 5 (PM5). When the P50 to P55 pins are used as an input port, use of an on-chip pull-up resistor can be specified in 1-bit units by pull-up resistor option register 5 (PU5).

Input to the P50 to P55 pin can be specified through a normal input buffer or a TTL input buffer in 1-bit units using port input mode register 5 (PIM5).

Output from the P50 to P55 pins can be specified as N-ch open-drain output (VDD tolerance) in 1-bit units using port output mode register 5 (POM5).

This port can also be used for external interrupt request input, serial interface data I/O, clock I/O, programming UART transmission/reception, timer I/O, and interface with USB connector.

Reset signal generation sets port 5 to input port.

### 4.2.5 Port 6

Port 6 is an I/O port with an output latch. Port 6 can be set to the input mode or output mode in 1-bit units using port mode register 6 (PM6).

The output of the P60 to P64 pins is N-ch open-drain output (6 V tolerance).

This port can also be used for external interrupt request input, serial interface data I/O, and clock I/O. Reset signal generation sets port 6 to input port.

### 4.2.6 Port 7

Port 7 is an I/O port with an output latch. Port 7 can be set to the input mode or output mode in 1-bit units using port mode register 7 (PM7). When the P70 to P74 pins are used as an input port, use of an on-chip pull-up resistor can be specified in 1-bit units by pull-up resistor option register 7 (PU7).

Input to the P70 to P74 pin can be specified through a normal input buffer or a TTL input buffer in 1-bit units using port input mode register 7 (PIM7).

Output from the P70 to P74 pins can be specified as N-ch open-drain output (VDD tolerance) in 1-bit units using port output mode register 7 (POM7).

This port can also be used for external interrupt request input, timer I/O, serial interface data I/O, and clock I/O. Reset signal generation sets port 7 to input port.

### 4.2.7 Port 12

P121 and P122 are 2-bit input ports.

This port can also be used for connecting a resonator for the main system clock and external clock input for the main system clock.

Reset signal generation sets P121 and P122 to input port.



### 4.2.8 Port 13

P137 is a 1-bit input-only port.

P137 is fixed an input ports.

This port can also be used for external interrupt request input.



### 4.3 Registers Controlling Port Function

Port functions are controlled by the following registers.

- Port mode registers (PMxx)
- Port registers (Pxx)
- Pull-up resistor option registers (PUxx)
- Port input mode registers (PIMxx)
- Port output mode registers (POMxx)
- Port mode control registers (PMCxx)

# Caution Which registers and bits are included depends on the product. For registers and bits mounted on each product, see Tables 4 - 2. Be sure to set bits that are not mounted to their initial values.

#### Table 4 - 2 PMxx, Pxx, PUxx, PIMxx, POMxx, PMCxx registers and the bits mounted on each product (1/2)

|        |   |                  |                 | Bit N            | Product with USB  | Product without USB |                   |              |              |
|--------|---|------------------|-----------------|------------------|-------------------|---------------------|-------------------|--------------|--------------|
| Port   |   | PMxx<br>register | Pxx<br>register | PUxx<br>register | PIMxx<br>register | POMxx<br>register   | PMCxx<br>register | 32-pin       | 32-pin       |
| Port 0 | 0 | PM00             | P00             | PU00             | PIM00             | POM00               | PMC00             | $\checkmark$ | ~            |
|        | 1 | PM01             | P01             | PU01             | PIM01             | POM01               | PMC01             | $\checkmark$ | ~            |
|        | 2 | _                | —               | —                | _                 | —                   | —                 | —            | —            |
|        | 3 |                  | —               | —                | _                 | —                   | —                 | —            | —            |
|        | 4 |                  | —               | —                | _                 | —                   | —                 | —            | —            |
|        | 5 |                  | —               | —                | _                 | —                   | —                 | —            | —            |
|        | 6 | _                | —               | —                | _                 | —                   | —                 | —            | —            |
|        | 7 | _                | —               | —                | _                 | —                   | —                 | —            | —            |
| Port 2 | 0 | PM20             | P20             | _                | _                 | —                   | PMC20             | $\checkmark$ | $\checkmark$ |
|        | 1 | PM21             | P21             | —                | _                 | —                   | PMC21             | $\checkmark$ | $\checkmark$ |
|        | 2 | PM22             | P22             | —                | _                 | —                   | PMC22             | $\checkmark$ | $\checkmark$ |
|        | 3 | PM23             | P23             | —                | _                 | —                   | PMC23             | $\checkmark$ | $\checkmark$ |
|        | 4 | PM24             | P24             | —                | _                 | —                   | PMC24             | $\checkmark$ | $\checkmark$ |
|        | 5 | PM25             | P25             | —                | _                 | —                   | PMC25             | $\checkmark$ | $\checkmark$ |
|        | 6 | _                | —               | —                | _                 | —                   | —                 | —            | —            |
|        | 7 | _                | —               | —                | _                 | —                   | —                 | —            | —            |
| Port 4 | 0 | PM40             | P40             | PU40             | _                 | —                   | —                 | $\checkmark$ | $\checkmark$ |
|        | 1 | —                | —               | —                | _                 | —                   | —                 | —            | —            |
|        | 2 |                  | —               | _                | —                 | —                   | —                 | —            | —            |
|        | 3 |                  | —               | —                |                   | —                   | —                 | —            | —            |
|        | 4 |                  | —               | —                |                   | —                   | —                 | —            | —            |
|        | 5 |                  | —               | —                |                   | —                   | —                 | —            | —            |
|        | 6 | —                | —               | _                |                   | —                   | —                 | —            | —            |
|        | 7 | _                | —               | —                | _                 | —                   | —                 |              | —            |

|         |   |                  |                 | Bit N            | Product with USB  | Product without USB |                   |              |              |
|---------|---|------------------|-----------------|------------------|-------------------|---------------------|-------------------|--------------|--------------|
| Port    |   | PMxx<br>register | Pxx<br>register | PUxx<br>register | PIMxx<br>register | POMxx<br>register   | PMCxx<br>register | 32-pin       | 32-pin       |
| Port 5  | 0 | PM50             | P50             | PU50             | PIM50             | POM50               | —                 | $\checkmark$ | $\checkmark$ |
|         | 1 | PM51             | P51             | PU51             | PIM51             | POM51               | —                 | $\checkmark$ | $\checkmark$ |
|         | 2 | PM52             | P52             | PU52             | PIM52             | POM52               | —                 | $\checkmark$ | $\checkmark$ |
|         | 3 | PM53             | P53             | PU53             | PIM53             | POM53               | _                 | $\checkmark$ | $\checkmark$ |
|         | 4 | PM54             | P54             | PU54             | PIM54             | POM54               | —                 | $\checkmark$ | $\checkmark$ |
|         | 5 | PM55             | P55             | PU55             | PIM55             | POM55               | —                 | $\checkmark$ | $\checkmark$ |
|         | 6 |                  | _               | —                | —                 | —                   | —                 | —            | —            |
|         | 7 |                  | _               | —                | —                 | —                   | —                 | —            | —            |
| Port 6  | 0 | PM60             | P60             | —                | —                 | —                   | —                 | $\checkmark$ | $\checkmark$ |
|         | 1 | PM61             | P61             | —                | —                 | —                   | —                 | $\checkmark$ | $\checkmark$ |
|         | 2 | PM62             | P62             | —                | —                 | —                   | —                 | $\checkmark$ | $\checkmark$ |
|         | 3 | PM63             | P63             | —                | —                 | —                   | —                 | $\checkmark$ | $\checkmark$ |
|         | 4 | PM64             | P64             | _                | —                 | —                   | _                 | $\checkmark$ | $\checkmark$ |
|         | 5 | _                | _               | _                | —                 | —                   | _                 | _            | —            |
|         | 6 | _                | _               | _                | —                 | —                   | _                 | _            | —            |
|         | 7 | _                | _               | _                | —                 | —                   | _                 | _            | —            |
| Port 7  | 0 | PM70             | P70             | PU70             | PIM70             | POM70               | —                 |              | $\checkmark$ |
|         | 1 | PM71             | P71             | PU71             | PIM71             | POM71               | _                 | _            | $\checkmark$ |
|         | 2 | PM72             | P72             | PU72             | PIM72             | POM72               | _                 | _            | $\checkmark$ |
|         | 3 | PM73             | P73             | PU73             | PIM73             | POM73               | _                 | _            | $\checkmark$ |
|         | 4 | PM74             | P74             | PU74             | PIM74             | POM74               | —                 |              | $\checkmark$ |
|         | 5 | _                | _               | —                | —                 | —                   | —                 |              | —            |
|         | 6 | _                | _               | —                | —                 | —                   | —                 |              | —            |
|         | 7 | _                | —               | —                | —                 | —                   | —                 | —            | —            |
| Port 12 | 0 | _                | _               | —                | —                 | —                   | —                 |              | —            |
|         | 1 | _                | P121            | —                | —                 | —                   | —                 | $\checkmark$ | $\checkmark$ |
|         | 2 | _                | P122            | —                | —                 | —                   | —                 | $\checkmark$ | $\checkmark$ |
|         | 3 |                  | —               | —                | —                 | —                   | —                 | —            | —            |
|         | 4 | _                | —               | —                | —                 | —                   | —                 | —            | —            |
|         | 5 | _                | —               | —                | —                 | —                   | —                 | —            | —            |
|         | 6 |                  | —               | —                | —                 | —                   | —                 | —            | —            |
|         | 7 | _                | —               | —                | —                 | —                   | —                 | —            | —            |
| Port 13 | 0 | —                | —               | —                | —                 | —                   | —                 | —            | —            |
|         | 1 | _                | _               | —                | —                 | —                   | —                 |              | —            |
|         | 2 |                  | —               | _                | —                 | —                   | _                 | —            | —            |
|         | 3 |                  | —               | _                | —                 | —                   | _                 | —            | —            |
|         | 4 | —                | —               | —                | —                 | —                   | —                 |              | —            |
|         | 5 | —                | —               | —                | —                 | —                   | —                 |              | —            |
|         | 6 | _                | —               | —                | —                 | —                   | —                 | —            | _            |
|         | 7 |                  | P137            | _                | _                 | _                   | _                 | $\checkmark$ | $\checkmark$ |

Table 4 - 2 PMxx, Pxx, PUxx, PIMxx, POMxx, PMCxx registers and the bits mounted on each product (2/2)



### 4.3.1 Port mode registers (PMxx)

These registers specify input or output mode for the port in 1-bit units.

These registers can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation sets these registers to FFH.

When port pins are used as alternate-function pins, set the port mode register by referencing **4.5 Register Settings When Using Alternate Function**.

| Symbol | 7    | 6       | 5                                                         | 4          | 3         | 2         | 1        | 0          | Address    | After reset | R/W |
|--------|------|---------|-----------------------------------------------------------|------------|-----------|-----------|----------|------------|------------|-------------|-----|
| PM0    | 1    | 1       | 1                                                         | 1          | 1         | 1         | PM01     | PM00       | FFF20H     | FFH         | R/W |
| PM2    | 1    | 1       | PM25                                                      | PM24       | PM23      | PM22      | PM21     | PM20       | FFF22H     | FFH         | R/W |
| PM4    | 1    | 1       | 1                                                         | 1          | 1         | 1         | 1        | PM40       | FFF24H     | FFH         | R/W |
| PM5    | 1    | 1       | PM55                                                      | PM54       | PM53      | PM52      | PM51     | PM50       | FFF25H     | FFH         | R/W |
| PM6    | 1    | 1       | 1                                                         | PM64       | PM63      | PM62      | PM61     | PM60       | FFF26H     | FFH         | R/W |
| PM7    | 1    | 1       | 1                                                         | PM74       | PM73      | PM72      | PM71     | PM70       | FFF27H     | FFH         | R/W |
|        | •    |         |                                                           |            | 1 111 0   |           |          | 1 111 0    |            |             |     |
|        | PMmn |         | Pmn pin I/O mode selection (m = 0, 2, 4 to 7; n = 0 to 5) |            |           |           |          |            |            |             |     |
|        | 0    | Output  | mode (th                                                  | ne pin fui | nctions a | is an out | put port | (output b  | uffer on)) |             |     |
|        | 1    | Input m | node (the                                                 | pin func   | tions as  | an input  | port (ou | tput buffe | er off))   |             |     |
|        |      |         |                                                           |            |           |           |          |            |            |             |     |

#### Figure 4 - 1 Format of Port mode register



### 4.3.2 Port registers (Pxx)

These registers set the output latch value of a port.

If the data is read in the input mode, the pin level is read. If it is read in the output mode, the output latch value is read <sup>Note</sup>.

These registers can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears these registers to 00H.

**Note** When P00, P01, and P20 to P25 are set to the analog function, if a port is read in input mode, the read value is always 0, not the pin level.

| Symbol | 7    | 6 | 5   | 4   | 3   | 2    | 1    | 0   | Address       | After reset        | R/W        |
|--------|------|---|-----|-----|-----|------|------|-----|---------------|--------------------|------------|
| P0     | 0    | 0 | 0   | 0   | 0   | 0    | P01  | P00 | FFF00H        | 00H (output latch) | R/W        |
| P2     | 0    | 0 | P25 | P24 | P23 | P22  | P21  | P20 | FFF02H        | 00H (output latch) | R/W        |
| P4     | 0    | 0 | 0   | 0   | 0   | 0    | 0    | P40 | FFF04H        | 00H (output latch) | R/W        |
| P5     | 0    | 0 | P55 | P54 | P53 | P52  | P51  | P50 | FFF05H        | 00H (output latch) | R/W        |
| P6     | 0    | 0 | 0   | P64 | P63 | P62  | P61  | P60 | FFF06H        | 00H (output latch) | R/W        |
| P7     | 0    | 0 | 0   | P74 | P73 | P72  | P71  | P70 | FFF07H        | 00H (output latch) | R/W        |
| P12    | 0    | 0 | 0   | 0   | 0   | P122 | P121 | 0   | FFF0CH        | Undefined          | R/W Note 1 |
| P13    | P137 | 0 | 0   | 0   | 0   | 0    | 0    | 0   | <b>FFF0DH</b> | Note 2             | R/W Note 1 |
|        |      |   |     |     |     |      |      |     |               |                    |            |

#### Figure 4 - 2 Format of Port register

| Pmn | m = 0, 2, 4 to 7, 12, 13; n = 0 to 7 |                                 |  |  |  |  |  |  |
|-----|--------------------------------------|---------------------------------|--|--|--|--|--|--|
|     | Output data control (in output mode) | Input data read (in input mode) |  |  |  |  |  |  |
| 0   | Output 0                             | Input low level                 |  |  |  |  |  |  |
| 1   | Output 1                             | Input high level                |  |  |  |  |  |  |

Note 1. P121, P122, and P137 are read-only.

Note 2. P137: Undefined



### 4.3.3 Pull-up resistor option registers (PUxx)

These registers specify whether the on-chip pull-up resistors are to be used or not. On-chip pull-up resistors can be used in 1-bit units only for the bits set to input mode (PMmn = 1 and POMmn = 0) for the pins to which the use of an on-chip pull-up resistor has been specified in these registers. On-chip pull-up resistors cannot be connected to bits set to output mode and bits used as alternate-function output pins, regardless of the settings of these registers. Similarly, on-chip pull-up resistors cannot be connected to the pins used as alternate-function output pins and the pins set to the analog function.

These registers can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears these registers to 00H (Only PU4 is set to 01H).



#### Figure 4 - 3 Format of Pull-up resistor option register

Caution Be sure to set bits that are not mounted to their initial values.

### 4.3.4 Port input mode registers (PIMxx)

These registers set the input buffer in 1-bit units.

TTL input buffer can be selected during serial communication with an external device of the different potential. Port input mode registers can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears these registers to 00H.



#### Figure 4 - 4 Format of Port input mode register

### 4.3.5 Port output mode registers (POMxx)

These registers set the output mode in 1-bit units.

N-ch open-drain output (VDD tolerance) mode can be selected during serial communication with an external device of the different potential, and for the SDA00 and SDA01 pins during simplified I<sup>2</sup>C communication with an external device of the same potential.

In addition, POMxx register is set with PUxx register, whether or not to use the on-chip pull-up resistor. These registers can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears these registers to 00H.

# Caution An on-chip pull-up resistor is not connected to a bit for which N-ch open drain output (VDD tolerance) mode is set.



#### Figure 4 - 5 Format of Port output mode register

Caution Be sure to set bits that are not mounted to their initial values.

### 4.3.6 Port mode control registers (PMCxx)

These registers set the P00, P01, P20 to P25 digital I/O/analog input in 1-bit units. These registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears these registers to FFH.



#### Figure 4 - 6 Format of Port mode control register

### 4.4 Port Function Operations

Port operations differ depending on whether the input or output mode is set, as shown below.

### 4.4.1 Writing to I/O port

(1) Output mode

A value is written to the output latch by a transfer instruction, and the output latch contents are output from the pin.

Once data is written to the output latch, it is retained until data is written to the output latch again. The data of the output latch is cleared when a reset signal is generated.

(2) Input mode

A value is written to the output latch by a transfer instruction, but since the output buffer is off, the pin status does not change.

Once data is written to the output latch, it is retained until data is written to the output latch again. The data of the output latch is cleared when a reset signal is generated.

### 4.4.2 Reading from I/O port

(1) Output mode

The output latch contents are read by a transfer instruction. The output latch contents do not change.

(2) Input mode

The pin status is read by a transfer instruction. The output latch contents do not change.

### 4.4.3 Operations on I/O port

(1) Output mode

An operation is performed on the output latch contents, and the result is written to the output latch. The output latch contents are output from the pins.

Once data is written to the output latch, it is retained until data is written to the output latch again. The data of the output latch is cleared when a reset signal is generated.

(2) Input mode

The pin level is read and an operation is performed on its contents. The result of the operation is written to the output latch, but since the output buffer is off, the pin status does not change. Therefore, byte data can be written to the ports used for both input and output.

The data of the output latch is cleared when a reset signal is generated.



### 4.4.4 Handling different potential (1.8 V, 2.5 V) by using I/O buffers

It is possible to connect an external device operating on a different potential (1.8 V, 2.5 V) by switching I/O buffers with the port input mode register (PIMxx) and port output mode register (POMxx). When receiving input from an external device with a different potential (1.8 V, 2.5 V), set the port input mode registers 0, 5, and 7 (PIM0, PIM5, and PIM7) on a bit-by-bit basis to enable normal input (CMOS)/TTL input buffer switching.

When outputting data to an external device with a different potential (1.8 V, 2.5 V), set the port output mode registers 0, 5, and 7 (POM0, POM5, and POM7) on a bit-by-bit basis to enable normal output (CMOS)/N-ch open drain (VDD tolerance) switching.

The connection of a serial interface is described in the following.

(1) Setting procedure when using input pins of UART0, CSI00, and CSI01 functions for the TTL input buffer

| In case of UART0: | P51      |
|-------------------|----------|
| In case of CSI00: | P50, P51 |
| In case of CSI01: | P53, P54 |

- <1> Using an external resistor, pull up externally the pin to be used to the power supply of the target device (on-chip pull-up resistor cannot be used).
- <2> Set the corresponding bit of the PIM0, PIM5, and PIM7 registers to 1 to switch to the TTL input buffer. For VIH and VIL, refer to the DC characteristics when the TTL input buffer is selected.
- <3> Enable the operation of the serial array unit and set the mode to the UART/CSI mode.
- (2) Setting procedure when using output pins of UART0, CSI00, and CSI01 functions in N-ch open-drain output mode

| In case of UART0: | P52      |
|-------------------|----------|
| In case of CSI00: | P50, P52 |
| In case of CSI01: | P53, P55 |

- <1> Using an external resistor, pull up externally the pin to be used to the power supply of the target device (on-chip pull-up resistor cannot be used).
- <2> After reset release, the port mode is the input mode (Hi-Z).
- <3> Set the output latch of the corresponding port to 1.
- <4> Set the corresponding bit of the POM0, POM5, and POM7 registers to 1 to set the N-ch open drain output (VDD tolerance) mode.
- <5> Enable the operation of the serial array unit and set the mode to the UART/CSI mode.
- <6> Set the corresponding bit of the PM0, PM5, and PM7 registers to the output mode. At this time, the output data is high level, so the pin is in the Hi-Z state.



(3) Setting procedure when using I/O pins of IIC00 and IIC01 functions with a different potential (1.8 V, 2.5 V)

In case of simplified IIC00: P50, P51 In case of simplified IIC01: P53, P54

- <1> Using an external resistor, pull up externally the pin to be used to the power supply of the target device (on-chip pull-up resistor cannot be used).
- <2> After reset release, the port mode is the input mode (Hi-Z).
- <3> Set the output latch of the corresponding port to 1.
- <4> Set the corresponding bit of the POM0, POM5 and POM7 registers to 1 to set the N-ch open drain output (VDD tolerance) mode.
- <5> Set the corresponding bit of the PIM0, PIM5 and PIM7 registers to 1 to switch to the TTL input buffer. For VIH and VIL, refer to the DC characteristics when the TTL input buffer is selected.
- <6> Enable the operation of the serial array unit and set the mode to the simplified I<sup>2</sup>C mode.
- <7> Set the corresponding bit of the PM0, PM5 and PM7 registers to the output mode (data I/O is possible in the output mode). At this time, the output data is high level, so the pin is in the Hi-Z state.



### 4.5 Register Settings When Using Alternate Function

### 4.5.1 Basic concept when using alternate function

In the beginning, for a pin also assigned to be used for analog function, use the port mode control register (PMCxx) to specify whether to use the pin for analog function or digital input/output.

Figure 4 - 7 shows the basic configuration of an output circuit for pins used for digital input/output. The output of the output latch for the port and the output of the alternate SAU function are input to an AND gate. The output of the AND gate is input to an OR gate. The output of an alternate function other than SAU (Timer, clock/buzzer output, etc.) is connected to the other input pin of the OR gate. When such kind of pins are used by the port function or an alternate function, the unused alternate function must not hinder the output of the function to be used. An idea of basic settings for this kind of case is shown in Table 4 - 3.



Figure 4 - 7 Basic Configuration of Output Circuit for Pins

Note 1. When there is no POM register, this signal should be considered to be low level (0).

Note 2. When there is no alternate function, this signal should be considered to be high level (1).

**Note 3.** When there is no alternate function, this signal should be considered to be low level (0).

| Output Function of Used Pin        | Output Settings of Unused Alternate Function |                         |                                    |  |  |  |  |  |
|------------------------------------|----------------------------------------------|-------------------------|------------------------------------|--|--|--|--|--|
| Output Function of Osed Fin        | Output Function for Port                     | Output Function for SAU | Output Function for other than SAU |  |  |  |  |  |
| Output function for port           | _                                            | Output is high (1)      | Output is low (0)                  |  |  |  |  |  |
| Output function for SAU            | High (1)                                     | _                       | Output is low (0)                  |  |  |  |  |  |
| Output function for other than SAU | Low (0)                                      | Output is high (1)      | Output is low (0) <sup>Note</sup>  |  |  |  |  |  |

Note Since more than one output function other than SAU may be assigned to a single pin, the output of an unused alternate function must be set to low level (0). For details on the setting method, see **4.5.2 Register settings for alternate function whose output function is not used**.

### 4.5.2 Register settings for alternate function whose output function is not used

When the output of an alternate function of the pin is not used, the following settings should be made.

- (1) SOp = 1, TxDq = 1 (settings when the serial output (SOp/TxDq) of SAU is not used) When the serial output (SOp/TxDq) is not used, such as, a case in which only the serial input of SAU is used, set the bit in serial output enable register m (SOEm) which corresponds to the unused output to 0
- (output disabled) and set the SOmn bit in serial output register m (SOm) to 1 (high). These are the same settings as the initial state.
  (2) SCKp = 1, SDAr = 1, SCLr = 1 (settings when channel n in SAU is not used)
- When SAU is not used, set bit n (SEmn) in serial channel enable status register m (SEm) to 0 (operation stopped state), set the bit in serial output enable register m (SOEm) which corresponds to the unused output to 0 (output disabled), and set the SOmn and CKOmn bits in serial output register m (SOm) to 1 (high). These are the same settings as the initial state.
- (3) TOmn = 0 (settings when the output of channel n in TAU is not used) When the TOmn output of TAU is not used, set the bit in timer output enable register 0 (TOE0) which corresponds to the unused output to 0 (output disabled) and set the bit in timer output register 0 (TO0) to 0 (low). These are the same settings as the initial state.
- SDAAn = 0, SCLAn = 0 (setting when IICA is not used)
   When IICA is not used, set the IICEn bit in IICA control register n0 (IICCTLn0) to 0 (operation stopped). This is the same setting as the initial state.
- PCLBUZ0 = 0 (setting when clock/buzzer output is not used)
   When the clock/buzzer output is not used, set the PCLOEn bit in clock output select register n (CKSn) to 0 (output disabled). This is the same setting as the initial state.



### 4.5.3 Register setting examples for used port and alternate functions

Register setting examples for used port and alternate functions are shown in Tables 4 - 4 to 4 - 11. The registers used to control the port functions should be set as shown in Tables 4 - 4 to 4 - 11. See the following remark for legends used in Tables 4 - 4 to 4 - 11.

| Remark | :      | Not supported              |
|--------|--------|----------------------------|
|        | ×:     | Don't care                 |
|        | POMxx: | Port output mode register  |
|        | PMCxx: | Port mode control register |
|        | PMxx:  | Port mode register         |
|        | Pxx:   | Port output latch          |

| Pin  | Used             | Function       |       |       |      |     | Alternate Fu           | Inction Output | 32-          | pin            |
|------|------------------|----------------|-------|-------|------|-----|------------------------|----------------|--------------|----------------|
| Name | Function<br>Name | I/O            | POMxx | PMCxx | PMxx | Pxx | SAU Output<br>Function | Other than SAU | with USB     | without<br>USB |
| P00  | P00              | Input          | ×     | 0     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      |                  | Output         | 0     | 0     | 0    | 0/1 | —                      | TO05 = 0       |              |                |
|      |                  | N ch-OD Output | 1     | 0     | 0    | 0/1 | —                      | PCLBUZ0 = 0    |              |                |
|      | INTP12           | Input          | ×     | 0     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      | TI05             | Input          | ×     | 0     | 1    | ×   | —                      | ×              | ✓            | ✓              |
|      | TO05             | Output         | 0     | 0     | 0    | 0   | —                      | PCLBUZ0 = 0    | $\checkmark$ | $\checkmark$   |
|      | ANI16            | Analog input   | ×     | 1     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      | PCLBUZ0          | Output         | ×     | 0     | 0    | 0/1 | _                      | TO05 = 0       | √            | $\checkmark$   |
| P01  | P01              | Input          | ×     | 0     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      |                  | Output         | 0     | 0     | 0    | 0/1 | —                      | TO06 = 0       |              |                |
|      |                  | N ch-OD Output | 1     | 0     | 0    | 0/1 | —                      |                |              |                |
|      | INTP13           | Input          | ×     | 0     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      | TI06             | Input          | ×     | 0     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      | TO06             | Output         | 0     | 0     | 0    | 0   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      | ANI17            | Analog input   | ×     | 1     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |

#### Table 4 - 4 Setting Examples of Registers When Using P00 to P01 Pin Function



| Pin  | Used             | Function               |                       |       |       |      |     | Alternate Fur          | nction Output     | 32-      | pin            |
|------|------------------|------------------------|-----------------------|-------|-------|------|-----|------------------------|-------------------|----------|----------------|
| Name | Function<br>Name | I/O                    | ADM2                  | POMxx | PMCxx | PMxx | Pxx | SAU Output<br>Function | Other than<br>SAU | with USB | without<br>USB |
| P20  | P20              | Input                  | ×                     | —     | 0     | 1    | ×   | —                      | —                 | ~        | $\checkmark$   |
|      |                  | Output                 | ×                     | —     | 0     | 0    | 0/1 | —                      | _                 |          |                |
|      | ANI0             | Analog input           | 00x0xx0x,<br>10x0xx0x | —     | 1     | 1    | ×   | -                      | _                 | ~        | ~              |
|      | AVREFP           | Reference power supply | 01x0xx0x              | —     | 1     | 1    | ×   | -                      | _                 | ~        | $\checkmark$   |
| P21  | P21              | Input                  | ×                     | —     | 0     | 1    | ×   | —                      | _                 | ~        | $\checkmark$   |
|      |                  | Output                 | ×                     | —     | 0     | 0    | 0/1 | —                      |                   |          |                |
|      | ANI1             | Analog input           | xx00xx0x              | —     | 1     | 1    | ×   | —                      | _                 | ~        | $\checkmark$   |
|      | AVREFM           | Reference power supply | xx10xx0x              | —     | 1     | 1    | ×   | -                      | _                 | ~        | $\checkmark$   |
| P22  | P22              | Input                  | _                     | —     | 0     | 1    | ×   | —                      |                   | ~        | $\checkmark$   |
|      |                  | Output                 | _                     | —     | 0     | 0    | 0/1 | —                      | _                 |          |                |
|      | ANI2             | Analog input           | _                     | —     | 1     | 1    | ×   | —                      | _                 | ~        | $\checkmark$   |
| P23  | P23              | Input                  | _                     | —     | 0     | 1    | ×   | _                      | _                 | ~        | $\checkmark$   |
|      |                  | Output                 | _                     | —     | 0     | 0    | 0/1 | —                      | _                 |          |                |
|      | ANI3             | Analog input           | _                     | —     | 1     | 1    | ×   | —                      | _                 | ~        | $\checkmark$   |
| P24  | P24              | Input                  | _                     | —     | 0     | 1    | ×   | —                      | _                 | ~        | $\checkmark$   |
|      |                  | Output                 | _                     | —     | 0     | 0    | 0/1 | —                      | _                 |          |                |
|      | ANI4             | Analog input           | _                     | —     | 1     | 1    | ×   | _                      | _                 | ~        | $\checkmark$   |
| P25  | P25              | Input                  |                       | —     | 0     | 1    | ×   | _                      |                   | ~        | $\checkmark$   |
|      |                  | Output                 |                       | _     | 0     | 0    | 0/1 | _                      |                   |          |                |
|      | ANI5             | Analog input           | _                     | —     | 1     | 1    | ×   | _                      | _                 | ~        | $\checkmark$   |

Table 4 - 5 Setting Examples of Registers When Using P20 to 25 Pin Function

Table 4 - 6 Setting Examples of Registers When Using P40 Pin Function

| Pin  | Used F           | unction |       |       |      |     | Alternate Fu           | nction Output  | 32-          | pin            |
|------|------------------|---------|-------|-------|------|-----|------------------------|----------------|--------------|----------------|
| Name | Function<br>Name | I/O     | POMxx | PMCxx | PMxx | Рхх | SAU Output<br>Function | Other than SAU | with USB     | without<br>USB |
| P40  | P40              | Input   | —     | —     | 1    | ×   | —                      | —              | $\checkmark$ | $\checkmark$   |
|      |                  | Output  | _     |       | 0    | 0/1 |                        | _              |              |                |



|             | Used             | Function       |        |       |      |     | Alternate Fun          | ction Output             | 32-                                   | pin            |
|-------------|------------------|----------------|--------|-------|------|-----|------------------------|--------------------------|---------------------------------------|----------------|
| Pin<br>Name | Function<br>Name | I/O            | POMxx  | PMCxx | PMxx | Рхх | SAU Output<br>Function | Other than SAU           | with USB                              | without<br>USB |
| P50         | P50              | Input          | 0      | —     | 1    | ×   | ×                      | _                        | $\checkmark$                          | $\checkmark$   |
|             |                  | Output         | 0      | _     | 0    | 0/1 | SCK00/SCL00 = 1        | _                        |                                       |                |
|             |                  | N ch-OD output | 1      | _     | 0    | 0/1 |                        | _                        |                                       |                |
|             | INTP6            | Input          | ×      | _     | 1    | ×   | ×                      | _                        | ~                                     | $\checkmark$   |
|             | SCL00            | Output         | 0/1    | _     | 0    | 1   | ×                      | _                        | ~                                     | $\checkmark$   |
|             | SCK00            | Input          | ×      | _     | 1    | ×   | ×                      | _                        | ~                                     | $\checkmark$   |
|             |                  | Output         | 0/1    | _     | 0    | 1   | ×                      | _                        |                                       |                |
| P51         | P51              | Input          | 0      | _     | 1    | ×   | ×                      | ×                        | ~                                     | $\checkmark$   |
|             |                  | Output         | 0      | _     | 0    | 0/1 | SDA00 = 1              | TO00 = 0                 |                                       |                |
|             |                  | N ch-OD output | 1      | _     | 0    | 0/1 |                        |                          |                                       |                |
|             | INTP7            | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ~                                     | ~              |
|             | TI00             | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ~                                     | $\checkmark$   |
|             | ТО00             | Output         | 0      | _     | 0    | 0   | SDA00 = 1              | ×                        | ~                                     | $\checkmark$   |
|             | SDA00            | I/O            | 1      | _     | 0    | 1   | ×                      | TO00 = 0                 | ~                                     | $\checkmark$   |
|             | SI00             | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ✓                                     | ~              |
|             | RXD0             | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ✓                                     | $\checkmark$   |
| P52         | P52              | Input          | 0      | _     | 1    | ×   | ×                      | ×                        | ✓                                     | $\checkmark$   |
|             |                  | Output         | 0      | _     | 0    | 0/1 | SO00 = 1               | TO01 = 0                 |                                       |                |
|             |                  | N ch-OD output | 1      | _     | 0    | 0/1 | TXD0 = 1               | UVBUSEN1 = 0             |                                       |                |
|             | INTP8            | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ~                                     | ~              |
| -           | TI01             | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ✓                                     | ~              |
|             | TO01             | Output         | 0      | _     | 0    | 0   | SO00 = 1               | ×                        | ✓                                     | ~              |
|             | SO00             | Output         | 0/1    | _     | 0    | 1   | ×                      | TO01 = 0                 | ~                                     | $\checkmark$   |
|             | TXD0             | Output         | 0/1    | _     | 0    | 1   | SO00 = 1               | UVBUSEN1 = 0             | √                                     | ~              |
|             | UVBUSEN1         | Output         | _      | _     | 1    | ×   |                        | TO01 = 0                 | ~                                     | ×              |
| P53         | P53              | Input          | 0      | _     | 1    | ×   | ×                      | ×                        | ~                                     | ~              |
|             |                  | Output         | 0      | _     | 0    | 0/1 | SCK01/SCL01 = 1        | TO02 = 0                 |                                       |                |
|             |                  | N ch-OD output | 1      | _     | 0    | 0/1 |                        |                          |                                       |                |
|             | INTP9            | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ✓                                     | ~              |
|             | TI02             | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ~                                     | √              |
|             | TO02             | Output         | 0      | _     | 0    | 0   | SCK01/SCL01 = 1        | ×                        | ✓                                     | ~              |
|             | SCL01            | Output         | 0/1    | _     | 0    | 1   | ×                      | TO02 = 0                 | ~                                     | √              |
|             | SCK01            | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ~                                     | √              |
|             |                  | Output         | 0/1    | _     | 0    | 1   | ×                      | TO02 = 0                 |                                       |                |
|             | UVOVRCUR1        | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ~                                     | ×              |
| P54         | P54              | Input          | 0      |       | 1    | ×   | ×                      | ×                        | · · · · · · · · · · · · · · · · · · · | ~<br>~         |
|             |                  | Output         | 0      | _     | 0    | 0/1 | SDA01 = 1              | TO03 = 0                 |                                       |                |
|             |                  | N ch-OD output | 1      | _     | 0    | 0/1 |                        | UVBUSEN0 = 0             |                                       |                |
|             | INTP10           | Input          | ×      |       | 1    | ×   | ×                      | ×                        | ✓                                     | √              |
|             | TI03             | Input          | ×      |       | 1    | ×   | ×                      | ×                        | · ·                                   | ·<br>√         |
|             | T003             | Output         | ^<br>0 |       | 0    | 0   | ^<br>SDA01 = 1         | vvbuseno = 0             | ▼<br>✓                                | v<br>√         |
|             | SDA01            | I/O            | 1      |       | 0    | 1   | x                      | TO03 = 0<br>UVBUSEN0 = 0 | ✓<br>✓                                | ✓<br>✓         |
|             | SI01             | Input          | ×      | _     | 1    | ×   | ×                      | ×                        | ~                                     | ✓              |
|             | UVBUSEN0         | Output         | _      | _     | 1    | ×   | SDA01 = 1              | TO03 = 0                 | ✓                                     | ×              |

Table 4 - 7 Setting Examples of Registers When Using P50 to P55 Pin Function (1/2)



| Pin  | Used             | Function       |       | 5140  |      |     | Alternate Fun          | ction Output   | 32-          | pin            |
|------|------------------|----------------|-------|-------|------|-----|------------------------|----------------|--------------|----------------|
| Name | Function<br>Name | I/O            | POMxx | PMCxx | PMxx | Pxx | SAU Output<br>Function | Other than SAU | with USB     | without<br>USB |
| P55  | P55              | Input          | 0     | —     | 1    | ×   | ×                      | ×              | ~            | $\checkmark$   |
|      |                  | Output         | 0     | —     | 0    | 0/1 | SO01 = 1               | TO04 = 0       |              |                |
|      |                  | N ch-OD output | 1     | —     | 0    | 0/1 |                        |                |              |                |
|      | INTP11           | Input          | ×     | —     | 1    | ×   | ×                      | ×              | $\checkmark$ | $\checkmark$   |
|      | TI04             | Input          | ×     | —     | 1    | ×   | ×                      | ×              | $\checkmark$ | $\checkmark$   |
|      | TO04             | Output         | 0     | —     | 0    | 0   | SO01 = 1               | ×              | $\checkmark$ | $\checkmark$   |
|      | SO01             | Output         | 0/1   | —     | 0    | 1   | ×                      | TO04 = 0       | $\checkmark$ | $\checkmark$   |
|      | UVOVRCUR0        | Input          | ×     | —     | 1    | ×   | SO01 = 1               | ×              | $\checkmark$ | ×              |

Table 4 - 7 Setting Examples of Registers When Using P50 to P55 Pin Function (2/2)

Table 4 - 8 Setting Examples of Registers When Using P60 to P64 Pin Function

| Pin  | Used             | Function |       |       |      |     | Alternate Fur          | ction Output   | 32-          | pin            |
|------|------------------|----------|-------|-------|------|-----|------------------------|----------------|--------------|----------------|
| Name | Function<br>Name | I/O      | POMxx | PMCxx | PMxx | Pxx | SAU Output<br>Function | Other than SAU | with USB     | without<br>USB |
| P60  | P60              | Input    | —     | —     | 1    | ×   | —                      | ×              | $\checkmark$ | $\checkmark$   |
|      |                  | Output   | —     | _     | 0    | 0/1 | _                      | SCLA0 = 0      |              |                |
|      | INTP1            | Input    | —     | -     | 1    | ×   | _                      | ×              | $\checkmark$ | $\checkmark$   |
|      | SCLA0            | I/O      | —     | _     | 0    | 0   | _                      | ×              | $\checkmark$ | $\checkmark$   |
| P61  | P61              | Input    | —     | —     | 1    | ×   | _                      | ×              | $\checkmark$ | $\checkmark$   |
|      |                  | Output   | —     | _     | 0    | 0/1 | _                      | SDAA0 = 0      |              |                |
|      | INTP2            | Input    | —     | _     | 1    | ×   | _                      | ×              | $\checkmark$ | $\checkmark$   |
|      | SDAA0            | I/O      | —     | —     | 0    | 0   | _                      | ×              | $\checkmark$ | $\checkmark$   |
| P62  | P62              | Input    | —     | _     | 1    | ×   | _                      | ×              | $\checkmark$ | $\checkmark$   |
|      |                  | Output   | —     | _     | 0    | 0/1 | _                      | SCLA1 = 0      |              |                |
|      | INTP3            | Input    | _     | _     | 1    | ×   | _                      | ×              | $\checkmark$ | $\checkmark$   |
|      | SCLA1            | I/O      | —     | _     | 0    | 0   | _                      | ×              | $\checkmark$ | $\checkmark$   |
| P63  | P63              | Input    | —     | —     | 1    | ×   | _                      | ×              | $\checkmark$ | $\checkmark$   |
|      |                  | Output   | _     | _     | 0    | 0/1 | _                      | SDAA1 = 0      |              |                |
|      | INTP4            | Input    | —     | _     | 1    | ×   | _                      | ×              | $\checkmark$ | $\checkmark$   |
|      | SDAA1            | I/O      | —     | -     | 0    | 0   | _                      | ×              | $\checkmark$ | $\checkmark$   |
| P64  | P64              | Input    | —     | —     | 1    | ×   | _                      | _              | $\checkmark$ | $\checkmark$   |
|      |                  | Output   | —     | -     | 0    | 0/1 | _                      | _              |              |                |
|      | INTP5            | Input    | —     | —     | 1    | ×   | -                      | _              | $\checkmark$ | ~              |

| Pin  | Use              | d Function     |       |       |      |     | Alternate Fun          | ction Output   | 32-      | pin            |
|------|------------------|----------------|-------|-------|------|-----|------------------------|----------------|----------|----------------|
| Name | Function<br>Name | I/O            | POMxx | PMCxx | PMxx | Pxx | SAU Output<br>Function | Other than SAU | with USB | without<br>USB |
| P70  | P70              | Input          | ×     | —     | 1    | ×   | —                      | ×              | ×        | $\checkmark$   |
|      |                  | Output         | 0     | —     | 0    | 0/1 | _                      | SCLA2 = 0      |          |                |
|      |                  | N ch-OD output | 1     | —     | 0    | 0/1 | _                      |                |          |                |
|      | SCLA2            | I/O            | 1     | —     | 0    | 0   | _                      | ×              | ×        | $\checkmark$   |
| P71  | P71              | Input          | ×     | —     | 1    | ×   | _                      | ×              | ×        | $\checkmark$   |
|      |                  | Output         | 0     | —     | 0    | 0/1 | _                      | SDAA2 = 0      |          |                |
|      |                  | N ch-OD output | 1     | —     | 0    | 0/1 | _                      |                |          |                |
|      | SDAA2            | I/O            | 1     | —     | 0    | 0   | _                      | ×              | ×        | ~              |
| P72  | P72              | Input          | ×     | —     | 1    | ×   | _                      | —              | ×        | ~              |
|      |                  | Output         | 0     | —     | 0    | 0/1 | _                      | —              |          |                |
|      |                  | N ch-OD output | 1     | —     | 0    | 0/1 | _                      | —              |          |                |
|      | INTP14           | Input          | ×     | —     | 1    | ×   | _                      | —              | ×        | $\checkmark$   |
| P73  | P73              | Input          | ×     | —     | 1    | ×   | _                      | —              | ×        | $\checkmark$   |
|      |                  | Output         | 0     | —     | 0    | 0/1 | _                      | —              |          |                |
|      |                  | N ch-OD output | 1     | —     | 0    | 0/1 | _                      | —              |          |                |
|      | INTP15           | Input          | ×     | —     | 1    | ×   |                        | —              | ×        | $\checkmark$   |
| P74  | P74              | Input          | ×     | -     | 1    | ×   | —                      | ×              | ×        | $\checkmark$   |
|      |                  | Output         | 0     | —     | 0    | 0/1 | _                      | TO07 = 0       |          |                |
|      |                  | N ch-OD output | 1     | —     | 0    | 0/1 | _                      | ]              |          |                |
|      | TI07             | Input          | ×     | _     | 1    | ×   | _                      | ×              | ×        | $\checkmark$   |
|      | TO07             | Output         | 0     | —     | 0    | 0   | _                      | ×              | ×        | $\checkmark$   |

Table 4 - 9 Setting Examples of Registers When Using P70 to P74 Pin Function

#### Table 4 - 10 Setting Examples of Registers When Using P121 to P122 Pin Function

| Pin  | Used F        | unction | СМС             | Pxx | 32-pin       |              |  |
|------|---------------|---------|-----------------|-----|--------------|--------------|--|
| Name | Function Name | I/O     | (EXCLK, OSCSEL) | FXX | with USB     | without USB  |  |
| P121 | P121          | Input   | 00/10/11        | ×   | $\checkmark$ | $\checkmark$ |  |
|      | X1            | —       | 01              | —   | $\checkmark$ | ✓            |  |
| P122 | P122          | Input   | 00/10           | ×   | $\checkmark$ | ✓            |  |
|      | X2            | —       | 01              | —   | $\checkmark$ | ✓            |  |
|      | EXCLK         | Input   | 11              | ×   | $\checkmark$ | ~            |  |

Table 4 - 11 Setting Examples of Registers When Using P137 Pin Function

| Pin  | Used             | Function |       |       |      |     | Alternate Fun          | ction Output   | 32-pin       |                |
|------|------------------|----------|-------|-------|------|-----|------------------------|----------------|--------------|----------------|
| Name | Function<br>Name | I/O      | POMxx | PMCxx | PMxx | Pxx | SAU Output<br>Function | Other than SAU | with USB     | without<br>USB |
| P137 | P137             | Input    | —     | _     | —    | ×   | _                      | _              | $\checkmark$ | $\checkmark$   |
|      | INTP0            | Input    | _     | _     | _    | ×   | —                      | —              | $\checkmark$ | $\checkmark$   |

### 4.6 Cautions When Using Port Function

### 4.6.1 Cautions on 1-Bit Manipulation Instruction for Port Register n (Pn)

When a 1-bit manipulation instruction is executed on a port that provides both input and output functions, the output latch value of an input port that is not subject to manipulation may be written in addition to the targeted bit. Therefore, it is recommended to rewrite the output latch when switching a port from input mode to output mode.

- <Example> When P20 is an output port, P21 to P25 are input ports (all pin statuses are high level), and the port latch value of port 1 is 00H, if the output of output port P20 is changed from low level to high level via a 1-bit manipulation instruction, the output latch value of port 1 is 3FH.
- Explanation: The targets of writing to and reading from the Pn register of a port whose PMnm bit is 1 are the output latch and pin status, respectively.

A 1-bit manipulation instruction is executed in the following order in the R9A02G015.

- <1> The Pn register is read in 8-bit units.
- <2> The targeted one bit is manipulated.

<3> The Pn register is written in 8-bit units.

In step <1>, the output latch value (0) of P20, which is an output port, is read, while the pin statuses of P21 to P25, which are input ports, are read. If the pin statuses of P21 to P25 are high level at this time, the read value is 3EH.

The value is changed to 3FH by the manipulation in <2>.

3FH is written to the output latch by the manipulation in <3>.

#### Figure 4 - 8 Bit Manipulation Instruction (P20)





### 4.6.2 Notes on specifying the pin settings

For an output pin to which multiple functions are assigned, the output of the unused alternate functions must be set to its initial state so as to prevent conflicting outputs. For details about the alternate function output, see **4.5 Register Settings When Using Alternate Function**.

No specific setting is required for input pins because the output of their alternate functions is disabled (the buffer output is Hi-Z).

Disabling the unused functions, including blocks that are only used for input or do not have I/O, is recommended for lower power consumption.



## **CHAPTER 5 CLOCK GENERATOR**

### 5.1 Functions of Clock Generator

The clock generator generates the clock to be supplied to the CPU and peripheral hardware. The following two kinds of system clocks and clock oscillators are selectable.

#### (1) Main system clock

#### <1> X1 oscillator

This circuit oscillates a clock of fx = 1 to 20 MHz by connecting a resonator to X1 and X2 pins. Oscillation can be stopped by executing the STOP instruction or setting of the MSTOP bit (bit 7 of the clock operation status control register (CSC)).

#### <2> High-speed on-chip oscillator

The frequency at which to oscillate can be selected from amoung fHOCO = 48, 24, 16, 12, 8, 6, 4, 3, 2 or 1MHz (TYP.) by using the option byte (000C2H). When selecting 48MHz for the high-speed on-chip oscillator clock fHOCO (FRQSEL4 = 1 in the option byte (000C2H)) and the CKSELR bit (bit 0 of the MCKC register) is set to 0, a clock generated by dividing the fHOCO frequency by 2, 4, or 8 (divided by 2 is the default) by setting the RDIV0 and RDIV1 bits (bits 1 and 2 of the MCKC register) is selected as the main system clock source (fiH). After a reset release, the CPU always starts operating with this high-speed on-chip oscillator clock.

When selecting the high-speed on-chip oscillator as the USB clock (this setting is only available when using the USB function controller), be sure to select 48 MHz as the fHOCO frequency and then select the main system clock source (fIH) with fHOCO divided as the main system clock (fMAIN).

Oscillation can be stopped by executing the STOP instruction or setting the HIOSTOP bit (bit 0 of the CSC register).

The frequency specified by using an option byte can be changed by using the high-speed on-chip oscillator frequency select register (HOCODIV). For details about the frequency, see **Figure 5 - 10 Format of High-speed on-chip oscillator frequency select register (HOCODIV)**.

# <3> High-speed system clock multiplication function using PLL (phase locked loop)

This clock function is mainly used for clock supply to the USB host/function controller. Set the DSCCTL register so that the PLL oscillation frequency (fPLL) is 48 MHz. When the CKSELR bit is set to 1, a clock generated by dividing the fPLL frequency by 2, 4, or 8 by setting the RDIV0 and RDIV1 bits is selected as the main system clock source (fiH). When selecting the PLL clock as the USB source clock, be sure to select the main system clock source (fiH) with fPLL divided as the main system clock (fMAIN).

The PLL can be operated or stopped by setting the DSCON bit (bit 0 in the DSCCTL register). For details on PLL settings and the connection with the USB clock, see **Figure 5 - 13** and **Table 5 - 3**.

An external main system clock (fEx = 1 to 20 MHz) can also be supplied from the EXCLK/X2/P122 pin. An external main system clock input can be disabled by executing the STOP instruction or setting of the MSTOP bit.

As the main system clock, a high-speed system clock (X1 clock or external main system clock) or high-speed on-chip oscillator clock or PLL clock can be selected by setting of the MCM0 bit (bit 4 of the system clock control register (CKC)).



#### (2) Low-speed on-chip oscillator clock (Low-speed on-chip oscillator)

This circuit oscillates a clock of fiL = 15 kHz (TYP.).

The low-speed on-chip oscillator clock cannot be used as the CPU clock.

Only the following peripheral hardware runs on the low-speed on-chip oscillator clock.

- Watchdog timer
- 12-bit interval timer

This clock operates when bit 4 (WDTON) of the option byte (000C0H), bit 4 (WUTMMCK0) of the subsystem clock supply mode control register (OSMC), or both are set to 1.

However, when WDTON = 1, WUTMMCK0 = 0, and bit 0 (WDSTBYON) of the option byte (000C0H) is 0, oscillation of the low-speed on-chip oscillator stops if the HALT or STOP instruction is executed.

#### Remark fx: X1 clock oscillation frequency

- fIH: Main system clock source frequency divided by 2, 4, or 8 when the high-speed on-chip oscillator clock or the PLL clock is selected (24 MHz max.)
- fHOCO: High-speed on-chip oscillator clock frequency (48 MHz max.)
- fEX: External main system clock frequency
- fIL: Low-speed on-chip oscillator clock frequency
- fPLL: PLL oscillation frequency



### 5.2 Configuration of Clock Generator

The clock generator includes the following hardware.

| Table 5 - 1 | Configuration | of Clock Generator |
|-------------|---------------|--------------------|
|-------------|---------------|--------------------|

| Item              | Configuration                                                     |  |
|-------------------|-------------------------------------------------------------------|--|
| Control registers | Clock operation mode control register (CMC)                       |  |
|                   | System clock control register (CKC)                               |  |
|                   | Clock operation status control register (CSC)                     |  |
|                   | Oscillation stabilization time counter status register (OSTC)     |  |
|                   | Oscillation stabilization time select register (OSTS)             |  |
|                   | Peripheral enable registers 0, 2 (PER0, PER2)                     |  |
|                   | Subsystem clock supply mode control register (OSMC)               |  |
|                   | High-speed on-chip oscillator frequency select register (HOCODIV) |  |
|                   | High-speed on-chip oscillator trimming register (HIOTRM)          |  |
|                   | PLL control register (DSCCTL)                                     |  |
|                   | Main clock control register (MCKC)                                |  |
|                   | USB clock selection register (UCKSEL)                             |  |
| Oscillators       | X1 oscillator                                                     |  |
|                   | High-speed on-chip oscillator                                     |  |
|                   | Low-speed on-chip oscillator                                      |  |
|                   | PLL oscillator                                                    |  |





Figure 5 - 1 Block Diagram of Clock Generator

(Note and Remark are listed on the next page.)

| Note   | Be sure to select fin when using the USB host/function controller. |                                                                                               |  |  |  |  |
|--------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|
| Remark | fx:                                                                | X1 clock oscillation frequency                                                                |  |  |  |  |
|        | fін:                                                               | Main system clock source frequency when the high-speed on-chip oscillator clock divided 1, 2, |  |  |  |  |
|        |                                                                    | 4, or 8, or the PLL clock divided by 2, 4, or 8 is selected (24 MHz max.)                     |  |  |  |  |
|        | fHOCO:                                                             | High-speed on-chip oscillator clock frequency (48 MHz max.)                                   |  |  |  |  |
|        | fEX:                                                               | External main system clock frequency                                                          |  |  |  |  |
|        | fMX:                                                               | High-speed system clock frequency                                                             |  |  |  |  |
|        | fmain:                                                             | Main system clock frequency                                                                   |  |  |  |  |
|        | fclk:                                                              | CPU/peripheral hardware clock frequency                                                       |  |  |  |  |
|        | fı∟:                                                               | Low-speed on-chip oscillator clock frequency                                                  |  |  |  |  |
|        | fPLL:                                                              | PLL oscillation frequency                                                                     |  |  |  |  |
|        | fUSB:                                                              | USB clock frequency                                                                           |  |  |  |  |

### 5.3 Registers Controlling Clock Generator

The following registers are used to control the clock generator.

- Clock operation mode control register (CMC)
- System clock control register (CKC)
- Clock operation status control register (CSC)
- Oscillation stabilization time counter status register (OSTC)
- Oscillation stabilization time select register (OSTS)
- Peripheral enable registers 0, 2 (PER0, PER2)
- Subsystem clock supply mode control register (OSMC)
- High-speed on-chip oscillator frequency select register (HOCODIV)
- High-speed on-chip oscillator trimming register (HIOTRM)
- PLL control register (DSCCTL)
- Main clock control register (MCKC)
- USB clock selection register (UCKSEL)



### 5.3.1 Clock operation mode control register (CMC)

This register is used to set the operation mode of the X1/P121, X2/EXCLK/P122 pins, and to select a gain of the oscillator.

The CMC register can be written only once by an 8-bit memory manipulation instruction after reset release. This register can be read by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

| Address: | FFFA0H | After reset: 00                           | H R/W                                         |   |                                 |                                      |         |                   |  |
|----------|--------|-------------------------------------------|-----------------------------------------------|---|---------------------------------|--------------------------------------|---------|-------------------|--|
| Symbol   | 7      | 6                                         | 5                                             | 4 | 3                               | 2                                    | 1       | 0                 |  |
| СМС      | EXCLK  | OSCSEL                                    | 0                                             | 0 | 0                               | 0                                    | 0       | AMPH              |  |
|          |        |                                           |                                               |   |                                 |                                      |         |                   |  |
| ſ        | EXCLK  | OSCSEL                                    | High-speed system clock<br>pin operation mode |   | X1/P121 pin                     |                                      | X2/EXCL | X2/EXCLK/P122 pin |  |
|          | 0      | 0                                         | Input port mode                               |   | Input port                      |                                      |         |                   |  |
| -        | 0      | 1                                         | X1 oscillation mode                           |   | Crystal/ceram                   | Crystal/ceramic resonator connection |         |                   |  |
| -        | 1      | 0                                         | Input port mode                               |   | Input port                      |                                      |         |                   |  |
|          | 1      | 1                                         | External clock input mode                     |   | Input port External clock input |                                      | input   |                   |  |
|          |        | •                                         | •                                             |   |                                 |                                      | •       |                   |  |
| Γ        | AMPH   | Control of X1 clock oscillation frequency |                                               |   |                                 |                                      |         |                   |  |

| Figure 5 - 2 Format of Clock Operation | n Mode Control Register (CMC) |
|----------------------------------------|-------------------------------|
|----------------------------------------|-------------------------------|

| AMPH | Control of X1 clock oscillation frequency |
|------|-------------------------------------------|
| 0    | $1 \text{ MHz} \le fX \le 10 \text{ MHz}$ |
| 1    | 10 MHz < fX ≤ 20 MHz                      |

- Caution 1. The CMC register can be written only once after reset release, by an 8-bit memory manipulation instruction. When using the CMC register with its initial value (00H), be sure to set the register to 00H after a reset ends in order to prevent malfunction due to a program loop. Such a malfunction becomes unrecoverable when a value other than 00H is mistakenly written.
- Caution 2. After reset release, set the CMC register before X1 oscillation is started as set by the clock operation status control register (CSC).
- Caution 3. Be sure to set the AMPH bit to 1 if the X1 clock oscillation frequency exceeds 10 MHz.
- Caution 4. Specify the settings for the AMPH bit while fill is selected as fCLK after a reset ends (before fCLK is switched to fMX).
- Caution 5. Although the maximum system clock frequency is 24 MHz, the maximum frequency of the X1 oscillator is 20 MHz.

**Remark** fX: X1 clock frequency



### 5.3.2 System clock control register (CKC)

This register is used to select a CPU/peripheral hardware clock and a main system clock. The CKC register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation sets this register to 00H.

#### Figure 5 - 3 Format of System Clock Control Register (CKC)

| Address                                                                                                                                                                                       | : FFFA4H                                                                                                                                                                                           |       | After reset: 00                              | H R/W No                                                                                                                  | ote 1             |                  |                   |               |   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------|------------------|-------------------|---------------|---|
| Symbol                                                                                                                                                                                        | 7                                                                                                                                                                                                  |       | 6                                            | <5>                                                                                                                       | <4>               | 3                | 2                 | 1             | 0 |
| CKC                                                                                                                                                                                           | 0                                                                                                                                                                                                  |       | 0                                            | MCS                                                                                                                       | MCM0              | 0                | 0                 | 0             | 0 |
| MCS Status of Main system clock (fMAIN)                                                                                                                                                       |                                                                                                                                                                                                    |       |                                              |                                                                                                                           |                   |                  |                   |               |   |
|                                                                                                                                                                                               | 0                                                                                                                                                                                                  |       | High-speed o                                 | n-chip oscillator                                                                                                         | clock (fHOCO)     |                  |                   |               |   |
|                                                                                                                                                                                               | 1                                                                                                                                                                                                  |       | High-speed sy                                | ystem clock (fm)                                                                                                          | ×)                |                  |                   |               |   |
|                                                                                                                                                                                               |                                                                                                                                                                                                    | nte 2 |                                              |                                                                                                                           | Main system (     | lock (fMAINI) or | poration control  |               |   |
|                                                                                                                                                                                               |                                                                                                                                                                                                    |       | 0 1 4 4 1                                    | Main system clock (fMAIN) operation control<br>gh-speed on-chip oscillator clock (fHOCO) as the main system clock (fMAIN) |                   |                  |                   |               |   |
|                                                                                                                                                                                               | 0                                                                                                                                                                                                  |       | Selects the hi                               | gh-speed on-ch                                                                                                            | ip oscillator clo | ck (fHOCO) as    | the main system   | clock (fMAIN) |   |
|                                                                                                                                                                                               | 1                                                                                                                                                                                                  |       | Selects the hi                               | gh-speed syste                                                                                                            | m clock (fMX) a   | s the main sys   | tem clock (fMAIN) | )             |   |
|                                                                                                                                                                                               | <ul> <li>Note 1. Bit 5 is read-only.</li> <li>Note 2. Don't set the MCM0 bit to 1 while the FRQSEL4 bit of the option byte (000C2H) or the CKSELR bit of the MCKC register is set to 1.</li> </ul> |       |                                              |                                                                                                                           |                   |                  | SELR bit of the   |               |   |
|                                                                                                                                                                                               | Caution                                                                                                                                                                                            | Be    | sure to clear bit7, bit6 and bit3 to 0 to 0. |                                                                                                                           |                   |                  |                   |               |   |
| Remarkfill:Main system clock source frequency divided by 2, 4, or 8<br>clock or the PLL clock is selected (24 MHz max.)fMX:High-speed system clock frequencyfMAIN:Main system clock frequency |                                                                                                                                                                                                    |       | 1, or 8 when the                             | high-speed or                                                                                                             | n-chip oscillator |                  |                   |               |   |
|                                                                                                                                                                                               |                                                                                                                                                                                                    |       | 5                                            | ·                                                                                                                         | ,                 |                  |                   |               |   |



### 5.3.3 Clock operation status control register (CSC)

This register is used to control the operations of the high-speed system clock and high-speed on-chip oscillator. The CSC register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation sets this register to C0H.

#### Figure 5 - 4 Format of Clock Operation Status Control Register (CSC)

| Address: I | FFFA1H | After reset: C0 | H R/W |   |   |   |   |         |
|------------|--------|-----------------|-------|---|---|---|---|---------|
| Symbol     | <7>    | 6               | 5     | 4 | 3 | 2 | 1 | <0>     |
| csc        | MSTOP  | 1               | 0     | 0 | 0 | 0 | 0 | HIOSTOP |

| MSTOP | High-speed system clock operation control |                                          |                 |  |  |  |
|-------|-------------------------------------------|------------------------------------------|-----------------|--|--|--|
| MSTOP | X1 oscillation mode                       | External clock input mode                | Input port mode |  |  |  |
| 0     | X1 oscillator operating                   | External clock from EXCLK pin is valid   | Input port      |  |  |  |
| 1     | X1 oscillator stopped                     | External clock from EXCLK pin is invalid |                 |  |  |  |

| HIOSTOP | High-speed on-chip oscillator clock operation control |
|---------|-------------------------------------------------------|
| 0       | High-speed on-chip oscillator operating               |
| 1       | High-speed on-chip oscillator stopped                 |

- Caution 1. After reset release, set the clock operation mode control register (CMC) before setting the CSC register.
- Caution 2. Set the oscillation stabilization time select register (OSTS) before setting the MSTOP bit to 0 after releasing reset. Note that if the OSTS register is being used with its default settings, the OSTS register is not required to be set here.
- Caution 3. To start X1 oscillation as set by the MSTOP bit, check the oscillation stabilization time of the X1 clock by using the oscillation stabilization time counter status register (OSTC).
- Caution 4. Do not stop the clock selected for the CPU peripheral hardware clock (fcLK) with the OSC register.
- Caution 5. The setting of the flags of the register to stop clock oscillation (invalidate the external clock input) and the condition before clock oscillation is to be stopped are as Table 5 - 2. Before stopping the clock oscillation, check the conditions before the clock oscillation is stopped.

| Clock                                  | Condition Before Stopping Clock<br>(Invalidating External Clock Input)                                                      | Setting of CSC<br>Register Flags |
|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| X1 clock                               | CPU and peripheral hardware clocks operate with a clock                                                                     | MSTOP = 1                        |
| External main system<br>clock          | other than the high-speed system clock.<br>(MCS = 0)                                                                        |                                  |
| High-speed on-chip<br>oscillator clock | CPU and peripheral hardware clocks operate with a clock<br>other than the high-speed on-chip oscillator clock.<br>(MCS = 1) | HIOSTOP = 1                      |

#### Table 5 - 2 Stopping Clock Method



## 5.3.4 Oscillation stabilization time counter status register (OSTC)

This is the register that indicates the count status of the X1 clock oscillation stabilization time counter. The X1 clock oscillation stabilization time can be checked in the following case,

• If the X1 clock starts oscillation while the high-speed on-chip oscillator clock is being used as the CPU clock.

• If the STOP mode is entered and then released while the high-speed on-chip oscillator clock is being used as the CPU clock with the X1 clock oscillating.

The OSTC register can be read by a 1-bit or 8-bit memory manipulation instruction. When reset signal is generated, the STOP instruction and MSTOP (bit 7 of clock operation status control register (CSC)) = 1 clear the OSTC register to 00H.

Remark The oscillation stabilization time counter starts counting in the following cases.

- When oscillation of the X1 clock starts (EXCLK, OSCSEL = 0, 1  $\rightarrow$  MSTOP = 0)
- When the STOP mode is released



| Address            | : FFFA2I | H A   | fter rese | t: 00H | R    |      |      |      |                          |                        |              |
|--------------------|----------|-------|-----------|--------|------|------|------|------|--------------------------|------------------------|--------------|
| Symbol             | 7        | 6     | 5         | 4      | 3    | 2    | 1    | 0    |                          |                        |              |
| OSTC               | MOSTR    | MOST9 | MOST      | MOST   | MOST | MOST | MOST | MOST |                          |                        |              |
| 0010               | 10010    | 10010 | 10        | 11     | 13   | 15   | 17   | 18   |                          |                        |              |
| MOST MOST MOST MOS |          |       |           | MOST   | MOST | MOST | MOST | MOST | Oscilla                  | tion stabilization tir | me status    |
|                    | 8        | 9     | 10        | 11     | 13   | 15   | 17   | 18   | Cooma                    | fx = 10  MHz           | fx = 20  MHz |
|                    | 0        | Ŭ     | 10        |        | 10   | 10   |      | 10   |                          |                        |              |
|                    | 0        | 0     | 0         | 0      | 0    | 0    | 0    | 0    | 2 <sup>8</sup> /fx max.  | 25.6 µs max.           | 12.8 µs max. |
|                    | 1        | 0     | 0         | 0      | 0    | 0    | 0    | 0    | 2 <sup>8</sup> /fx min.  | 25.6 µs min.           | 12.8 µs min. |
|                    | 1        | 1     | 0         | 0      | 0    | 0    | 0    | 0    | 2 <sup>9</sup> /fx min.  | 51.2 μs min.           | 25.6 µs min. |
|                    | 1        | 1     | 1         | 0      | 0    | 0    | 0    | 0    | 2 <sup>10</sup> /fx min. | 102 µs min.            | 51.2 µs min. |
|                    | 1        | 1     | 1         | 1      | 0    | 0    | 0    | 0    | 2 <sup>11</sup> /fx min. | 204 µs min.            | 102 µs min.  |
|                    | 1        | 1     | 1         | 1      | 1    | 0    | 0    | 0    | 2 <sup>13</sup> /fx min. | 819 µs min.            | 409 µs min.  |
|                    | 1        | 1     | 1         | 1      | 1    | 1    | 0    | 0    | 2 <sup>15</sup> /fx min. | 3.27 ms min.           | 1.63 ms min. |
|                    | 1        | 1     | 1         | 1      | 1    | 1    | 1    | 0    | 2 <sup>17</sup> /fx min. | 13.1 ms min.           | 6.55 ms min. |
|                    | 1        | 1     | 1         | 1      | 1    | 1    | 1    | 1    | 2 <sup>18</sup> /fx min. | 26.2 ms min.           | 13.1 ms min. |

#### Figure 5 - 5 Format of Oscillation Stabilization Time Counter Status Register (OSTC)

Caution 1. After the above time has elapsed, the bits are set to 1 in order from the MOST8 bit and remain 1.

Caution 2. The oscillation stabilization time counter counts up to the oscillation stabilization time set by the oscillation stabilization time select register (OSTS).

In the following cases, set the oscillation stabilization time of the OSTS register to the value greater than the count value which is to be checked by the OSTC register.

- If the X1 clock starts oscillation while the high-speed on-chip oscillator clock is being used as the CPU clock.
- If the STOP mode is entered and then released while the high-speed on-chip oscillator clock is being used as the CPU clock with the X1 clock oscillating.

(Note, therefore, that only the status up to the oscillation stabilization time set by the OSTS register is set to the OSTC register after the STOP mode is released.)

Caution 3. The X1 clock oscillation stabilization wait time does not include the time until clock oscillation starts ("a" below).







## 5.3.5 Oscillation stabilization time select register (OSTS)

This register is used to select the X1 clock oscillation stabilization wait time.

When the X1 clock is made to oscillate by clearing the MSTOP bit to start the X1 oscillation circuit operating, actual operation is automatically delayed for the time set in the OSTS register.

When switching the CPU clock from the high-speed on-chip oscillator clock to the X1 clock, and when using the high-speed on-chip oscillator clock for switching the X1 clock from the oscillating state to STOP mode, use the oscillation stabilization time counter status register (OSTC) to confirm that the desired oscillation stabilization time has elapsed after release from the STOP mode. That is, use the OSTC register to check that the oscillation stabilization time corresponding to its setting has been reached.

The OSTS register can be set by an 8-bit memory manipulation instruction.

Reset signal generation sets the OSTS register to 07H.



| Address | FFFA3H | After reset: 07 | H R/W |                     |         |       |                                 |        |         |        |
|---------|--------|-----------------|-------|---------------------|---------|-------|---------------------------------|--------|---------|--------|
| Symbol  | 7      | 6               | 5     | 4                   | 3       |       | 2                               |        | 1       | 0      |
| OSTS    | 0      | 0               | 0     | 0                   | 0       |       | OSTS2                           | C      | OSTS1   | OSTS0  |
|         | OSTS2  | OSTS1           | OSTS0 |                     | Oscilla |       | tabilization tim<br>fx = 10 MHz | ie sel | i       | 20 MHz |
|         | 0      | 0               | 0     | 2 <sup>8</sup> /fx  |         | 25.6  | μs                              |        | 12.8 µs |        |
|         | 0      | 0               | 1     | 2 <sup>9</sup> /fx  |         | 51.2  | µs                              |        | 25.6 µs |        |
|         | 0      | 1               | 0     | 2 <sup>10</sup> /fx |         | 102 µ | IS                              |        | 51.2 µs |        |
|         | 0      | 1               | 1     | 2 <sup>11</sup> /fx |         | 204 µ | IS                              |        | 102 µs  |        |
|         | 1      | 0               | 0     | 2 <sup>13</sup> /fx |         | 819 µ | IS                              |        | 409 µs  |        |
|         | 1      | 0               | 1     | 2 <sup>15</sup> /fx |         | 3.27  | ms                              |        | 1.63 ms |        |
|         | 1      | 1               | 0     | 2 <sup>17</sup> /fx |         | 13.6  | ms                              |        | 6.55 ms |        |
|         | 1      | 1               | 1     | 2 <sup>18</sup> /fx |         | 26.2  | ms                              |        | 13.1 ms |        |

#### Figure 5 - 6 Format of Oscillation Stabilization Time Select Register (OSTS)

- Caution 1. Change the setting of the OSTS register before setting the MSTOP bit of the clock operation status control register (CSC) to 0.
- Caution 2. The oscillation stabilization time counter counts up to the oscillation stabilization time set by the OSTS register.

In the following cases, set the oscillation stabilization time of the OSTS register to the value greater than the count value which is to be checked by the OSTC register after the oscillation starts.

- If the X1 clock starts oscillation while the high-speed on-chip oscillator clock is being used as the CPU clock.
- If the STOP mode is entered and then released while the high-speed on-chip oscillator clock is being used as the CPU clock with the X1 clock oscillating. (Note, therefore, that only the status up to the oscillation stabilization time set by the OSTS register is set to the OSTC register after the STOP mode is released.)
- Caution 3. The X1 clock oscillation stabilization wait time does not include the time until clock oscillation starts ("a" below).







## 5.3.6 Peripheral enable registers 0, 2 (PER0, PER2)

This register is used to enable or disable supplying the clock to the peripheral hardware. Clock supply to the hardware that is not used is also stopped so as to decrease the power consumption and noise. To use the peripheral functions below, which are controlled by this register, set (1) the bit corresponding to each function before specifying the initial settings of the peripheral functions.

- 12-bit interval timer
- A/D converter
- Serial Interface IICA0
- Serial interface IICA1
- Serial interface IICA2 Note
- Serial array unit 0
- Timer array unit 0

The PER0 and PER2 registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.



| uress | : F00F0H     | After reset: 00                                                                                                                                                      | H R/W                                                                                                                                               |                                     |                  |                    |            |        |  |  |  |  |  |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------------------|--------------------|------------|--------|--|--|--|--|--|
| mbol  | <7>          | 6                                                                                                                                                                    | <5>                                                                                                                                                 | <4>                                 | 3                | <2>                | 1          | <0>    |  |  |  |  |  |
| PER0  | IICA2EN Note | IICA1EN                                                                                                                                                              | ADCEN                                                                                                                                               | IICA0EN                             | 0                | SAU0EN             | 0          | TAU0EN |  |  |  |  |  |
|       | IICA2EN Note |                                                                                                                                                                      | Сс                                                                                                                                                  | ontrol of serial i                  | nterface IICA2   | 2 input clock supp | ly         |        |  |  |  |  |  |
|       | 0            | Stops input clock supply.  • SFR used by the serial interface IICA2 cannot be written.  • The serial interface IICA2 is in the reset status.                         |                                                                                                                                                     |                                     |                  |                    |            |        |  |  |  |  |  |
|       | 1            |                                                                                                                                                                      | Enables input clock supply.<br>SFR used by the serial interface IICA2 can be read and written.                                                      |                                     |                  |                    |            |        |  |  |  |  |  |
|       | IICA1EN      |                                                                                                                                                                      | Control of serial interface IICA1 input clock supply                                                                                                |                                     |                  |                    |            |        |  |  |  |  |  |
|       | 0            | SFR used by                                                                                                                                                          | Stops input clock supply.<br>SFR used by the serial interface IICA1 cannot be written.<br>The serial interface IICA1 is in the reset status.        |                                     |                  |                    |            |        |  |  |  |  |  |
|       | 1            |                                                                                                                                                                      | The serial interface IICA1 is in the reset status.<br>nables input clock supply.<br>SFR used by the serial interface IICA1 can be read and written. |                                     |                  |                    |            |        |  |  |  |  |  |
|       | ADCEN        |                                                                                                                                                                      |                                                                                                                                                     | Control of A/D                      | converter inp    | out clock supply   |            |        |  |  |  |  |  |
|       | 0            | <ul> <li>SFR used by</li> </ul>                                                                                                                                      | Control of A/D converter input clock supply<br>Stops input clock supply.<br>• SFR used by the A/D converter cannot be written.                      |                                     |                  |                    |            |        |  |  |  |  |  |
|       | 1            | <ul> <li>The A/D converter is in the reset status.</li> <li>Enables input clock supply.</li> <li>SFR used by the A/D converter can be read and written.</li> </ul>   |                                                                                                                                                     |                                     |                  |                    |            |        |  |  |  |  |  |
|       | IICA0EN      |                                                                                                                                                                      | Control of serial interface IICA0 input clock supply                                                                                                |                                     |                  |                    |            |        |  |  |  |  |  |
|       | 0            |                                                                                                                                                                      | ock supply.<br>y the serial inte                                                                                                                    | rface IICA0 can<br>in the reset sta | not be written   |                    | · <b>j</b> |        |  |  |  |  |  |
|       | 1            | Enables input<br>• SFR used by                                                                                                                                       |                                                                                                                                                     | rface IICA0 can                     | be read and      | written.           |            |        |  |  |  |  |  |
|       | SAU0EN       |                                                                                                                                                                      | (                                                                                                                                                   | Control of seria                    | l array unit 0 i | nput clock supply  |            |        |  |  |  |  |  |
|       | 0            | -                                                                                                                                                                    | y the serial arra                                                                                                                                   | y unit 0 cannot<br>the reset status |                  |                    |            |        |  |  |  |  |  |
|       | 1            | Enables input <ul> <li>SFR used by</li> </ul>                                                                                                                        |                                                                                                                                                     | y unit 0 can be                     | read and writ    | ten.               |            |        |  |  |  |  |  |
|       | TAU0EN       |                                                                                                                                                                      |                                                                                                                                                     | Control of timer                    | array unit 0 i   | nput clock supply  |            |        |  |  |  |  |  |
|       | 0            | <ul> <li>SFR used by</li> </ul>                                                                                                                                      | Stops input clock supply.<br>• SFR used by timer array unit 0 cannot be written.                                                                    |                                     |                  |                    |            |        |  |  |  |  |  |
|       | 1            | <ul> <li>Timer array unit 0 is in the reset status.</li> <li>Enables input clock supply.</li> <li>SFR used by timer array unit 0 can be read and written.</li> </ul> |                                                                                                                                                     |                                     |                  |                    |            |        |  |  |  |  |  |

## Figure 5 - 7 Format of Peripheral Enable Register 0 (PER0)

Caution Be sure to clear bit 1, 3 to 0.



| Address: | F00FCH | After reset: 00H                                                                                                | H R/W                                                                                                                                                                   |   |   |   |   |   |  |  |  |
|----------|--------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|--|--|
| Symbol   | 7      | 6                                                                                                               | 5                                                                                                                                                                       | 4 | 3 | 2 | 1 | 0 |  |  |  |
| PER2     | TMKAEN | 0                                                                                                               | 0                                                                                                                                                                       | 0 | 0 | 0 | 0 | 0 |  |  |  |
|          |        |                                                                                                                 |                                                                                                                                                                         |   |   |   |   |   |  |  |  |
|          | TMKAEN |                                                                                                                 | Control of 12-bit interval timer input clock supply                                                                                                                     |   |   |   |   |   |  |  |  |
|          | 0      | SFRs used b                                                                                                     | <ul><li>Stops input clock supply.</li><li>SFRs used by the 12-bit interval timer cannot be written.</li><li>The 12-bit interval timer is in the reset status.</li></ul> |   |   |   |   |   |  |  |  |
|          | 1      | Enables input clock supply. <ul> <li>SFRs used by the 12-bit interval timer can be read and written.</li> </ul> |                                                                                                                                                                         |   |   |   |   |   |  |  |  |

## Figure 5 - 8 Format of Peripheral Enable Register 2 (PER2)

Caution Be Sure to clear bits 6 to 0 to 0.

## 5.3.7 Subsystem clock supply mode control register (OSMC)

The OSMC register can be used to select the count clock of the 12-bit interval timer. The OSMC register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 5 - 9 Format of Subsystem Clock Supply Mode Control Register (OSMC)

| Address | : F00F3H | After reset: 00H  | R/W                                                 |          |   |   |   |   |  |  |  |  |
|---------|----------|-------------------|-----------------------------------------------------|----------|---|---|---|---|--|--|--|--|
| Symbol  | 7        | 6                 | 5                                                   | 4        | 3 | 2 | 1 | 0 |  |  |  |  |
| OSMC    | 0        | 0                 | 0                                                   | WUTMMCK0 | 0 | 0 | 0 | 0 |  |  |  |  |
|         | WUTMMCK0 |                   | Selection of count clock for 12-bit interval timer. |          |   |   |   |   |  |  |  |  |
|         | 0        | No clock supplied | No clock supplied                                   |          |   |   |   |   |  |  |  |  |
|         | 1        | Low-speed on-ch   | ow-speed on-chip oscillator clock (fi∟)             |          |   |   |   |   |  |  |  |  |



## 5.3.8 High-speed on-chip oscillator frequency select register (HOCODIV)

The frequency of the high-speed on-chip oscillator which is set by an option byte (000C2H) can be changed by using high-speed on-chip oscillator frequency select register (HOCODIV). However, the selectable frequency depends on the FRQSEL4 and FRQSEL3 bits of the option byte (000C2H).

The HOCODIV register can be set by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to the value set by FRQSEL2 to FRQSEL0 of the option byte (000C2H).

#### Figure 5 - 10 Format of High-speed on-chip oscillator frequency select register (HOCODIV)

Address: F00A8H After reset: The value set by FRQSEL2 to FRQSEL0 of the option byte (000C2H) R/W

Symbol 7 6 5 4 3 2 1 0 HOCODIV 0 0 0 0 0 HOCODIV2 HOCODIV1 HOCODIV0

|          |                  |          | Selection of high-speed on-chip oscillator clock frequency |                    |                                                   |  |  |  |
|----------|------------------|----------|------------------------------------------------------------|--------------------|---------------------------------------------------|--|--|--|
| HOCODIV2 | HOCODIV1         | HOCODIV0 | FRQS                                                       | EL4 = 0            | FRQSEL4 = 1                                       |  |  |  |
|          |                  |          | FRQSEL3 = 0                                                | FRQSEL3 = 1        | FRQSEL3 = 0                                       |  |  |  |
| 0        | 0                | 0        | fін = 24 MHz                                               | Setting prohibited | fiH = 24/12/6 MHz Note 1<br>fHOCO = 48 MHz Note 2 |  |  |  |
| 0        | 0                | 1        | fiн = 12 MHz                                               | fін = 16 MHz       | fін = 12/6/3 MHz <b>Note 1</b><br>fносо = 24 MHz  |  |  |  |
| 0        | 1                | 0        | fiн = 6 MHz                                                | fiн = 8 MHz        | fін = 6/3 MHz <b>Note 1</b><br>fносо = 12 MHz     |  |  |  |
| 0        | 1                | 1        | fiн = 3 MHz                                                | fiн = 4 MHz        | fiн = 3 MHz<br>fносо = 6 MHz                      |  |  |  |
| 1        | 0                | 0        | Setting prohibited                                         | fiн = 2 MHz        | Setting prohibited                                |  |  |  |
| 1        | 0                | 1        | Setting prohibited                                         | fiн = 1 MHz        | Setting prohibited                                |  |  |  |
|          | Other than above |          | Setting prohibited                                         |                    |                                                   |  |  |  |

**Note 1.** See the MCKC register for division ratio settings.

**Note 2.** When using the high-speed on-chip oscillator clock to operate the USB/function controller, be sure to set fHOCO = 48 MHz.

| Option Byte (0 | 00C2H) Value | Flash Operation Mode      | Operating Frequency | Operating Voltage |  |
|----------------|--------------|---------------------------|---------------------|-------------------|--|
| CMODE1         | CMODE0       | Thash Operation Mode      | Range               | Range             |  |
| 1              | 1            | HS (high-speed main) mode | 1 to 24 MHz         | 2.7 to 3.6 V      |  |

- Caution 1. Set the HOCODIV register with the high-speed on-chip oscillator clock (fiH) selected as the CPU/peripheral hardware clock (fcLK).
- Caution 2. After the frequency is changed with the HOCODIV register, the frequency is switched after the following transition time has elapsed.
  - Operation for up to three clocks at the pre-change frequency
  - CPU/peripheral hardware clock wait at the post-change frequency for up to three clocks
- Caution 3. To change the frequency of the high-speed on-chip oscillator when X1 oscillation or external oscillation input is set for the system clock, stop the high-speed on-chip oscillator by setting bit 0 (HIOSTOP) of the CSC register to 1 and then change the frequency.



## 5.3.9 High-speed on-chip oscillator trimming register (HIOTRM)

This register is used to adjust the accuracy of the high-speed on-chip oscillator. With self-measurement of the high-speed on-chip oscillator frequency via a timer using high-accuracy external clock input (timer array unit), and so on, the accuracy can be adjusted.

The HIOTRM register can be set by an 8-bit memory manipulation instruction.

Caution The frequency will vary if the temperature and VDD pin voltage change after accuracy adjustment. When the temperature and VDD voltage change, accuracy adjustment must be executed regularly or before the frequency accuracy is required.

#### Figure 5 - 11 Format of High-Speed On-Chip Oscillator Trimming Register (HIOTRM)

| Address | : F00A0H | After reset: No | te R/W  |         |         |         |               |                      |
|---------|----------|-----------------|---------|---------|---------|---------|---------------|----------------------|
| Symbol  | 7        | 6               | 5       | 4       | 3       | 2       | 1             | 0                    |
| HIOTRM  | 0        | 0               | HIOTRM5 | HIOTRM4 | HIOTRM3 | HIOTRM2 | HIOTRM1       | HIOTRM0              |
|         | HIOTRM5  | HIOTRM4         | HIOTRM3 | HIOTRM2 | HIOTRM1 | HIOTRM0 |               | ed on-chip<br>llator |
|         | 0        | 0               | 0       | 0       | 0       | 0       | Minimum speed |                      |
|         | 0        | 0               | 0       | 0       | 0       | 1       |               |                      |
|         | 0        | 0               | 0       | 0       | 1       | 0       |               |                      |
|         | 0        | 0               | 0       | 0       | 1       | 1       |               |                      |
|         | 0        | 0               | 0       | 1       | 0       | 0       |               |                      |
|         |          |                 |         | •       |         |         |               |                      |
|         | 1        | 1               | 1       | 1       | 1       | 0       |               | 7                    |
|         | 1        | 1               | 1       | 1       | 1       | 1       | Maximu        | m speed              |

**Note** The value after a reset is adjusted at the time of shipment.

Caution 1. The HIOTRM register holds a six-bit value used to adjust the high-speed on-chip oscillator with an increment of 1 corresponding to an increase of frequency by about 0.05%.

Caution 2. For the usage example of the HIOTRM register, see the application note for RL78 MCU series Highspeed On-chip Oscillator (HOCO) Clock Frequency Correction (R01AN0464).



## 5.3.10 PLL control register (DSCCTL)

This register is used to control the operations of the PLL oscillator. The DSCCTL register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 5 - 12 Format of PLL Control Register (DSCCTL)

| Address: | F02E5H  | After reset: 00 | H R/W                               |   |   |         |      |       |  |  |
|----------|---------|-----------------|-------------------------------------|---|---|---------|------|-------|--|--|
| Symbol   | 7       | 6               | 5                                   | 4 | 3 | 2       | 1    | 0     |  |  |
| DSCCTL   | 0       | 0               | 0                                   | 0 | 0 | DSFRDIV | DSCM | DSCON |  |  |
| ĺ        | DSFRDIV |                 | PLL reference clock divider control |   |   |         |      |       |  |  |

 O
 No division

 1
 Divided by 2

**Remark** PLL reference clock is the high-speed system clock (fMX).

| DSCM | PLL multiplication selection |
|------|------------------------------|
| 0    | 12 times (6 times)           |
| 1    | 16 times (8 times)           |

**Remark** The frequency is devided by 2 in the last stage of the PLL oscillator, therefore the multiplication ratio becomes the value in parentheses.

| DSCON | PLL oscillation and output control |
|-------|------------------------------------|
| 0     | Stop                               |
| 1     | Ocsillation, output                |

Caution 1. Be sure to clear bits 3 to 7 to 0.

Caution 2. Be sure to set the DSCON bit to 0 before changing DSFRDIV and DSCM.

Caution 3. Do not set the DSCON bit to 0 while the PLL clock is selected as the system clock.



The combination which user can select as the USB clock when the PLL is used is shown below.

## Figure 5 - 13 Relationship between the PLL and the USB Clock



#### Table 5 - 3 USB Clock Frequency Setting Example

| High-speed system | Divided by k |      | n times  | Frequency after n | USB clock |  |
|-------------------|--------------|------|----------|-------------------|-----------|--|
| clock (fMX)       | DSFRDIV      | DSCM |          | times (fvco)      | (fusb)    |  |
| 16 MHz            | Divided by 2 | 0    | 12 times | 96 MHz            | 48 MHz    |  |
| 12 MHz            | Divided by 2 | 1    | 16 times | 96 MHz            | 48 MHz    |  |
| 8 MHz             | No division  | 0    | 12 times | 96 MHz            | 48 MHz    |  |
| 6 MHz             | No division  | 1    | 16 times | 96 MHz            | 48 MHz    |  |



## 5.3.11 Main clock control register (MCKC)

This register is used to control the operations of the main clock. The MCKC register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 5 - 14 Format of Main Clock Control Register (MCKC)

| Address: F | 02E6H | After reset: 00ł | H R/W |   |   |       |       |        |
|------------|-------|------------------|-------|---|---|-------|-------|--------|
| Symbol     | 7     | 6                | 5     | 4 | 3 | 2     | 1     | 0      |
| МСКС       | 0     | 0                | 0     | 0 | 0 | RDIV1 | RDIV0 | CKSELR |

| RDIV1 | RDIV0 | High-speed on-chip oscillator clock/PLL clock division ratio (divided by 2/4/8) selection |
|-------|-------|-------------------------------------------------------------------------------------------|
| 0     | 0     | Divided by 2                                                                              |
| 0     | 1     | Divided by 4                                                                              |
| 1     | 0     | Divided by 8                                                                              |
| 1     | 1     | Setting prohibited                                                                        |

| CKSELR | High-speed on-chip oscillator clock/PLL clock selection |  |  |  |  |  |
|--------|---------------------------------------------------------|--|--|--|--|--|
| 0      | h-speed on-chip oscillator clock (fHOCO)                |  |  |  |  |  |
| 1      | PLL clock (fPLL)                                        |  |  |  |  |  |

Caution 1. When selecting the high-speed on-chip oscillator clock as the USB clock (fusb), set the UCKSELC bit in the USB clock select register (UCKSEL) to 1.

Caution 2. When the clock is switched between the PLL clock (fPLL) and the high-speed on-chip oscillator clock (fHOCO), both clocks must be oscillating.

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



## 5.3.12 USB clock selection register (UCKSEL)

The UCKSEL register can be set by a 16-bit memory manipulation instruction. Reset signal generation clears this register to 0000H.

#### Figure 5 - 15 Format of USB clock selection register (UCKSEL)

| Address: | F04C4 | H, F040 | C5H | After i | reset: 00 | 000H | R/W |   |   |   |   |   |   |   |   |             |
|----------|-------|---------|-----|---------|-----------|------|-----|---|---|---|---|---|---|---|---|-------------|
| Symbol   | 15    | 14      | 13  | 12      | 11        | 10   | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
| UCKSEL   | 0     | 0       | 0   | 0       | 0         | 0    | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | UCKS<br>ELC |

| UCKSELC | USB clock selection                                                      |
|---------|--------------------------------------------------------------------------|
| 0       | High-speed on-chip oscillator clock (fHOCO) is not selected as USB clock |
| 1       | High-speed on-chip oscillator clock (fHOCO) is selected as USB clock     |

Caution 1. When selecting the high-speed on-chip oscillator clock (fHOCO) as the USB clock, set UCKSELC = 1 and the CKSELR bit in the MCKC register to 0 at the same time.

Caution 2. The USB clock select register can be rewritten only when the USB is disconnected.

Caution 3. The high-speed on-chip oscillator clock can be selected only when  $T_A = -20$  to  $+85^{\circ}C$ .

Caution 4. If the high-speed on-chip oscillator clock is selected as the USB clock, when the USB is suspended, perform USB suspended processing while the high-speed on-chip oscillator clock is selected (UCKSELC = 1).

Caution 5. If the high-speed on-chip oscillator clock is selected as the USB clock, when the USB is disconnected, perform USB stopped processing (including setting DPRPU = 0) before setting UCKSELC = 0.



## 5.4 System Clock Oscillator

## 5.4.1 X1 oscillator

The X1 oscillator oscillates with a crystal resonator or ceramic resonator (1 to 20 MHz) connected to the X1 and X2 pins.

An external clock can also be input. In this case, input the clock signal to the EXCLK pin.

To use the X1 oscillator, set bits 7 and 6 (EXCLK, OSCSEL) of the clock operation mode control register (CMC) as follows.

- Crystal or ceramic oscillation: EXCLK, OSCSEL = 0, 1
- External clock input: EXCLK, OSCSEL = 1, 1

When the X1 oscillator is not used, set the input port mode (EXCLK, OSCSEL = 0, 0).

When the pins are not used as input port pins, either, see Table 2 - 3 Connection of Unused Pins.

Figure 5 - 16 shows an example of the external circuit of the X1 oscillator.

#### Figure 5 - 16 Example of External Circuit of X1 Oscillator





ceramic resonator

10

(b) External clock



Caution When using the X1 oscillator, wire as follows in the area enclosed by the broken lines in the Figure 5 - 16 to avoid an adverse effect from wiring capacitance.

- Keep the wiring length as short as possible.
- Do not cross the wiring with the other signal lines. Do not route the wiring near a signal line through which a high fluctuating current flows.
- Always make the ground point of the oscillator capacitor the same potential as Vss. Do not ground the capacitor to a ground pattern through which a high current flows.
- Do not fetch signals from the oscillator.









NoteDo not place a power supply/GND pattern under the wiring section (section indicated by a broken line in the figure) of the<br/>X1 and X2 pins and the resonators in a multi-layer board or double-sided board.<br/>Do not configure a layout that will cause capacitance elements and affect the oscillation characteristics.





(f) Current flowing through ground line of oscillator (potential at points A, B, and C fluctuates)

(e) Wiring near high alternating current





(g) Signals are fetched





## 5.4.2 High-speed on-chip oscillator

The high-speed on-chip oscillator is incorporated in the R9A02G015. Oscillation can be controlled by bit 0 (HIOSTOP) of the clock operation status control register (CSC). The high-speed on-chip oscillator automatically starts oscillating after reset release.

## 5.4.3 Low-speed on-chip oscillator

The low-speed on-chip oscillator is incorporated in the R9A02G015.

The low-speed on-chip oscillator clock is used only as the watchdog timer, and 12-bit interval timer clock. The low-speed on-chip oscillator clock cannot be used as the CPU clock.

This clock operates when bit 4 (WDTON) of the option byte (000C0H), bit 4 (WUTMMCK0) of the subsystem clock supply mode control register (OSMC), or both are set to 1.

Unless the watchdog timer is stopped and WUTMMCK0 is a value other than zero, oscillation of the low-speed on-chip oscillator continues. Note that only when the watchdog timer is operating and the WUTMMCK0 bit is 0, oscillation of the low-speed on-chip oscillator will stop while the WDSTBYON bit is 0 and operation is in the HALT, STOP, or SNOOZE mode. While the watchdog timer operates, the low-speed on-chip oscillator clock does not stop even if the program freezes.

## 5.4.4 PLL (Phase Locked Loop)

The PLL circuit is incorporated in the R9A02G015. The PLL can be used to multiply the high-speed system clock. Operation of the PLL circuit can be controlled by using bit 0 (DSCON) of the PLL control register (DSCCTL).

Caution When switching from PLL mode to the internal high-speed oscillation clock and the highspeed system clock, stop the function (USB function controller) that provides the PLL output clock (fPLL).



## 5.5 Clock Generator Operation

The clock generator generates the following clocks and controls the operation modes of the CPU, such as standby mode (see **Figure 5 - 1**).

- Main system clock fMAIN
  - High-speed system clock fMX
  - X1 clock fx
  - External main system clock fEX
  - High-speed on-chip oscillator clock fHOCO
  - PLL clock fPLL
- Low-speed on-chip oscillator clock fiL
- CPU/peripheral hardware clock fclk

The CPU starts operation when the high-speed on-chip oscillator starts outputting after a reset release in the R9A02G015.

When the power supply voltage is turned on, the clock generator operation is shown in Figure 5 - 18.





Figure 5 - 18 Clock Generator Operation When Power Supply Voltage Is Turned On

- <1> When the power is turned on, an internal reset signal is generated by the power-on-reset (POR) circuit. Note that the reset state is maintained after a reset by the voltage detector or an external reset until the voltage reaches the range of operating voltage described in **2.4 AC Characteristics** of the R9A02G015 Data Sheet (R19DS0101E) (the above figure is an example when the external reset is in use).
- <2> When the reset is released, the high-speed on-chip oscillator automatically starts oscillation.
- <3> The CPU starts operation on the high-speed on-chip oscillator clock after waiting for the voltage to stabilize and a reset processing have been performed after reset release.
- <4> Set the start of oscillation of the X1 clock via software (see 5.6.2 Example of setting X1 oscillation clock).
- <5> When switching the CPU clock to the X1 clock, wait for the clock oscillation to stabilize, and then set switching via software (see 5.6.2 Example of setting X1 oscillation clock).
- Note 1. The reset processing time includes the oscillation accuracy stabilization time of the high-speed on-chip oscillator clock.
- **Note 2.** When releasing a reset, confirm the oscillation stabilization time for the X1 clock using the oscillation stabilization time counter status register (OSTC).
- Note 3. For the reset processing time, see CHAPTER 17 POWER-ON-RESET CIRCUIT.
- Caution It is not necessary to wait for the oscillation stabilization time when an external clock input from the EXCLK pin is used.



## 5.6 Controlling Clock

## 5.6.1 Example of setting high-speed on-chip oscillator

After a reset release, the CPU/peripheral hardware clock (fCLK) always starts operating with the high-speed onchip oscillator clock. The frequency of the high-speed on-chip oscillator can be selected from 48, 24, 16, 12, 8, 6, 4, 3, 2, and 1 MHz by using FRQSEL0 to FRQSEL4 of the option byte (000C2H). In addition, oscillation can be changed by the high-speed on-chip oscillator frequency select register (HOCODIV).

[Option byte setting]

Address: 000C2H

| Option           | 7      | 6      | 5 | 4       | 3       | 2       | 1       | 0       |
|------------------|--------|--------|---|---------|---------|---------|---------|---------|
| byte<br>(000C2H) | CMODE1 | CMODE0 |   | FRQSEL4 | FRQSEL3 | FRQSEL2 | FRQSEL1 | FRQSEL0 |
| (0000211)        | 1      | 1      | 1 | 1       | 0       | 0       | 0       | 0/1     |

| CMODE1           | CMODE0 | Setting of flash operation mode |                                                                  |  |  |  |  |  |
|------------------|--------|---------------------------------|------------------------------------------------------------------|--|--|--|--|--|
| 1                | 1      | HS (high speed main) mode       | HS (high speed main) mode VDD = 2.7 V to 5.5 V @ 1 MHz to 24 MHz |  |  |  |  |  |
| Other than above |        | Setting prohibited              |                                                                  |  |  |  |  |  |

| FRQSEL4 | FRQSEL3 | FRQSEL2         | FRQSEL1   | FRQSEL0    | Frequency of the high-speed on-chip<br>oscillator |                    |  |
|---------|---------|-----------------|-----------|------------|---------------------------------------------------|--------------------|--|
|         |         |                 |           |            | fносо                                             | fін                |  |
| 1       | 0       | 0               | 0         | 0          | 48 MHz Note 1                                     | 24/12/6 MHz Note 2 |  |
| 0       | 0       | 0               | 0         | 0          | 24 MHz                                            | 24 MHz             |  |
| 0       | 1       | 0               | 0         | 1          | 16 MHz                                            | 16 MHz             |  |
| 0       | 0       | 0               | 0         | 1          | 12 MHz                                            | 12 MHz             |  |
| 0       | 1       | 0               | 1         | 0          | 8 MHz                                             | 8 MHz              |  |
| 0       | 0       | 0               | 1         | 0          | 6 MHz                                             | 6 MHz              |  |
| 0       | 1       | 0               | 1         | 1          | 4 MHz                                             | 4 MHz              |  |
| 0       | 0       | 0               | 1         | 1          | 3 MHz                                             | 3 MHz              |  |
| 0       | 1       | 1               | 0         | 0          | 2 MHz                                             | 2 MHz              |  |
| 0       | 1       | 1               | 0         | 1          | 1 MHz                                             | 1 MHz              |  |
|         | C       | Other than abov | Setting p | prohibited |                                                   |                    |  |

**Note 1.** When you use PLL, set it in FRQSEL4 = 0, and, please do not choose 48 MHz.

**Note 2.** See the MCKC register for division ratio settings.



fносо = 12 MHz fiн = 3 MHz

fносо = 6 MHz

Setting prohibited

Setting prohibited

[High-speed on-chip oscillator frequency select register (HOCODIV) setting]

| Address | : F00A8H |          |          |                                                            |       |                    |          |                                                 |  |  |
|---------|----------|----------|----------|------------------------------------------------------------|-------|--------------------|----------|-------------------------------------------------|--|--|
| Symbol  | 7        | 6        | 5        | 4                                                          | 3     | 2                  | 1        | 0                                               |  |  |
| HOCODIV | 0        | 0        | 0        | 0                                                          | 0     | HOCODIV2           | HOCODIV1 | HOCODIV0                                        |  |  |
|         |          |          |          | Selection of high-speed on-chip oscillator clock frequency |       |                    |          |                                                 |  |  |
|         | HOCODIV2 | HOCODIV1 | HOCODIV0 |                                                            | FRQSE | EL4 = 0            | FR       | QSEL4 = 1                                       |  |  |
|         |          |          |          | FRQSEL                                                     | 3 = 0 | FRQSEL3 = 1        | FR       | QSEL3 = 0                                       |  |  |
|         | 0        | 0        | 0        | fін = 24 I                                                 | MHz   | Setting prohibited |          | fін = 24/12/6 MHz <b>Note</b><br>fносо = 48 MHz |  |  |
|         | 0        | 0        | 1        | fін = 12 I                                                 | MHz   | fін = 16 MHz       |          | fiн = 12/6/3 MHz <b>Note</b><br>fносо = 24 MHz  |  |  |
|         | 0        | 1        | 0        | fін = 6 N                                                  | 1Hz   | fін = 8 MHz        |          | 6/3 MHz Note                                    |  |  |

fih = 3 MHz

Setting prohibited

Setting prohibited

fiн = 4 MHz

fін = 2 MHz

fін = 1 MHz

Setting prohibited

| 1 |
|---|
|   |

Note

0

1

1

0

0

Other than above

See the MCKC register for division ratio settings.

1

0

1



## 5.6.2 Example of setting X1 oscillation clock

After a reset release, the CPU/peripheral hardware clock (fCLK) always starts operating with the high-speed onchip oscillator clock. To subsequently change the clock to the X1 oscillation clock, set the oscillator and start oscillation by using the oscillation stabilization time select register (OSTS) and clock operation mode control register (CMC) and clock operation status control register (CSC) and wait for oscillation to stabilize by using the oscillation stabilization time counter status register (OSTC). After the oscillation stabilizes, set the X1 oscillation clock to fCLK by using the system clock control register (CKC).

[Register settings] Set the register in the order of <1> to <5> below.

<1> Set (1) the OSCSEL bit of the CMC register, except for the cases where fx > 10 MHz, in such cases set (1) the AMPH bit, to operate the X1 oscillator.

|       | 7     | 6      | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|-------|--------|---|---|---|---|---|------|
| СМС   | EXCLK | OSCSEL |   |   |   |   |   | AMPH |
| CIVIC | 0     | 1      | 0 | 0 | 0 | 0 | 0 | 0/1  |

AMPH bit: Set this bit to 0 if the X1 oscillation clock is 10 MHz or less.

<2> Using the OSTS register, select the oscillation stabilization time of the X1 oscillator at releasing of the STOP mode.

Example: Setting values when a wait of at least 102  $\mu$ s is set based on a 10 MHz resonator.

|      | 7 | 6 | 5 | 4 | 3 | 2          | 1          | 0          |
|------|---|---|---|---|---|------------|------------|------------|
| OSTS | 0 | 0 | 0 | 0 | 0 | OSTS2<br>0 | OSTS1<br>1 | OSTS0<br>0 |

<3> Clear (0) the MSTOP bit of the CSC register to start oscillating the X1 oscillator.

|     | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|-----|-------|---|---|---|---|---|---|---------|
| 000 | MSTOP |   |   |   |   |   |   | HIOSTOP |
| CSC | 0     | 1 | 0 | 0 | 0 | 0 | 0 | 0       |

<4> Use the OSTC register to wait for oscillation of the X1 oscillator to stabilize. Example: Wait until the bits reach the following values when a wait of at least 102.4 µs is set based on a 10 MHz resonator.

|      | 7     | 6     | 5      | 4      | 3      | 2      | 1      | 0      |
|------|-------|-------|--------|--------|--------|--------|--------|--------|
| OSTC | MOST8 | MOST9 | MOST10 | MOST11 | MOST13 | MOST15 | MOST17 | MOST18 |
|      | I     | I     | 1      | 0      | 0      | 0      | 0      | 0      |

<5> Use the MCM0 bit of the CKC register to specify the X1 oscillation clock as the CPU/peripheral hardware clock.

|     | 7 | 6 | 5        | 4         | 3 | 2 | 1 | 0 |  |
|-----|---|---|----------|-----------|---|---|---|---|--|
| СКС | 0 | 0 | MCS<br>0 | MCM0<br>1 | 0 | 0 | 0 | 0 |  |



## Caution Set the HOCODIV register within the operable voltage range of the flash operation mode set in the option byte (000C2H) before and after the frequency change.

| Option Byte (000C2H) Value |        | Flash Operation Mode      | Operating Frequency | Operating Voltage Range |
|----------------------------|--------|---------------------------|---------------------|-------------------------|
| CMODE1                     | CMODE0 |                           | Range               | Operating voltage Nange |
| 1                          | 1      | HS (high-speed main) mode | 1 MHz to 24 MHz     | 2.7 V to 5.5 V          |

## 5.6.3 Example of setting PLL circuit

After setting the high-speed system clock (see **5.6.2 Example of setting X1 oscillation clock**), use the PLL control register (DSCCTL) to control the PLL circuit.

[Register settings] Set the register in the order of <1> to <5> below.

<1> Set the HIOSTOP bit in the CSC register to make the high-speed on-chip oscillator run.





#### R9A02G015

|      | 7 | 6                           | 5 | 4                   | 3                   | 2                                | 1            | 0           |
|------|---|-----------------------------|---|---------------------|---------------------|----------------------------------|--------------|-------------|
| мскс | 0 | 0                           | 0 | 0                   | 0                   | RDIV1<br>0/1                     | RDIV0<br>0/1 | CKSELR<br>1 |
|      |   |                             |   |                     |                     |                                  |              |             |
|      |   | t up a wait of <sup>·</sup> |   |                     |                     |                                  |              |             |
|      |   |                             |   | op the high-sp      | beed on-chip        | oscillator. <sup>Note</sup>      | 2            |             |
|      |   |                             |   | op the high-sp<br>4 | beed on-chip (<br>3 | oscillator. <sup>Note</sup><br>2 | 2            | 0           |

<8> When the PLL clock frequency divided by 2, 4, or 8 is selected as the main system clock (fMAIN), set the MCM0 bit in the CKC register to select the source for deriving the main system clock as a signal with a frequency (fiH) of up to 24 MHz.

|     | 7   | 6   | 5        | 4         | 3 | 2 | 1 | 0 |
|-----|-----|-----|----------|-----------|---|---|---|---|
| СКС | 0/1 | 0/1 | MCS<br>0 | MCM0<br>0 | 0 | 0 | 0 | 0 |

Note 1. No setting is required to change to the PLL while the CKSELR bit is 1.

When setting the CKSELR bit to 1, ensure that the high-speed on-chip oscillator is running.

**Note 2.** After oscillation by the X1 oscillator clock has become stable, allow at least 1 µs to elapse before starting the PLL. When restarting the PLL after it has been stopped, wait for at least 4 µs before using it in operations.

Note 3. Wait for 40 µs for oscillation by the oscillator clock to become stabled if the HIOSTOP bit is not set to 0.



## 5.6.4 CPU clock status transition diagram

Figure 5 - 19 shows the CPU clock status transition diagram of this product.



#### Figure 5 - 19 CPU Clock Status Transition Diagram



Table 5 - 4 shows transition of the CPU clock and examples of setting the SFR registers.

### Table 5 - 4 CPU Clock Transition and SFR Register Setting Examples (1/4)

#### (1) CPU operating with high-speed on-chip oscillator clock (B) after reset release (A)

| Status Transition     | SFR Register Setting                                                      |
|-----------------------|---------------------------------------------------------------------------|
| $(A) \rightarrow (B)$ | SFR registers do not have to be set (default status after reset release). |

#### (2) CPU operating with high-speed system clock (C) after reset release (A)

(The CPU operates with the high-speed on-chip oscillator clock immediately after a reset release (B).)

| (Setting sequence of SFR registers)                                                                                         |       |        |      |                  |                 |                        |                 |
|-----------------------------------------------------------------------------------------------------------------------------|-------|--------|------|------------------|-----------------|------------------------|-----------------|
| Setting Flag of SFR Register                                                                                                | СМ    | 6      |      | OSTS<br>Register | CSC<br>Register | OSTC<br>Register       | CKC<br>Register |
| Status Transition                                                                                                           | EXCLK | OSCSEL | AMPH | rtegistei        | MSTOP           | Register               | MCM0            |
| $\begin{array}{l} (A) \rightarrow (B) \rightarrow (C) \\ (X1 \mbox{ clock: 1 MHz} \leq fx \leq 10 \mbox{ MHz}) \end{array}$ | 0     | 1      | 0    | Note 2           | 0               | Must be<br>checked     | 1               |
|                                                                                                                             | 0     | 1      | 1    | Note 2           | 0               | Must be<br>checked     | 1               |
| $(A) \rightarrow (B) \rightarrow (C)$<br>(external main clock)                                                              | 1     | 1      | ×    | Note 2           | 0               | Must not be<br>checked | 1               |

**Note 1.** The clock operation mode control register (CMC) can be written only once by an 8-bit memory manipulation instruction after reset release.

Note 2. Set the oscillation stabilization time as follows.

• Desired the oscillation stabilization time counter status register (OSTC) oscillation stabilization time ≤ Oscillation stabilization time set by the oscillation stabilization time select register (OSTS)

Caution Set the clock after the supply voltage has reached the operable voltage of the clock to be set (see ELECTRICAL SPECIFICATIONS in the R9A02G015 Data Sheet (R19DS0101E)).



## Table 5 - 4 CPU Clock Transition and SFR Register Setting Examples (2/4)

### (3) CPU clock changing from high-speed on-chip oscillator clock (B) to high-speed system clock (C)

| CMC Register Note 1 |            | OSTS<br>Register | CSC<br>Register                                                   | OSTC<br>Register                                                                        | CKC<br>Register                                                  |                                                                                                                                     |
|---------------------|------------|------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| EXCLK               | OSCSEL     | AMPH             |                                                                   | MSTOP                                                                                   |                                                                  | MCM0                                                                                                                                |
| 0                   | 1          | 0                | Note 2                                                            | 0                                                                                       | Must be<br>checked                                               | 1                                                                                                                                   |
| 0                   | 1          | 1                | Note 2                                                            | 0                                                                                       | Must be<br>checked                                               | 1                                                                                                                                   |
| 1                   | 1          | ×                | Note 2                                                            | 0                                                                                       | Need not<br>be checked                                           | 1                                                                                                                                   |
|                     | EXCLK<br>0 | EXCLK OSCSEL     | EXCLK     OSCSEL     AMPH       0     1     0       0     1     1 | EXCLK     OSCSEL     AMPH       0     1     0     Note 2       0     1     1     Note 2 | RegisterRegisterRegisterEXCLKOSCSELAMPHMSTOP010Note 20011Note 20 | RegisterRegisterRegisterRegisterEXCLKOSCSELAMPHMSTOPMSTOP010Note 20Must be<br>checked011Note 20Must be<br>checked11×Note 20Need not |

Unnecessary if these registers are already set

Unnecessary if the CPU is operating with the high-speed system clock

**Note 1.** The clock operation mode control register (CMC) can be written only once by an 8-bit memory manipulation instruction after reset release. This setting is not necessary if it has already been set.

**Note 2.** Set the oscillation stabilization time as follows.

• Desired the oscillation stabilization time counter status register (OSTC) oscillation stabilization time ≤ Oscillation stabilization time select register (OSTS)

Caution Set the clock after the supply voltage has reached the operable voltage of the clock to be set (see ELECTRICAL SPECIFICATIONS in the R9A02G015 Data Sheet (R19DS0101E)).



## Table 5 - 4 CPU Clock Transition and SFR Register Setting Examples (3/4)

## (4) CPU clock changing from high-speed system clock (C) to high-speed on-chip oscillator clock (B)

| (Setting sequence of SFR registers) |              |                      |              |
|-------------------------------------|--------------|----------------------|--------------|
| Setting Flag of SFR Register        | CSC Register | Oscillation accuracy | CKC Register |
| Status Transition                   | HIOSTOP      | stabilization time   | MCM0         |
| $(C) \rightarrow (B)$               | 0            | 18 µs to 135 µs      | 0            |
|                                     |              |                      |              |

Unnecessary if the CPU is operating with the high-

speed on-chip oscillator clock

**Remark** The oscillation accuracy stabilization time changes according to the temperature conditions and the period over which the HIOSTOP bit is 0.

# (5) CPU clock changing from high-speed on-chip oscillator clock (B) to high-speed system clock (PLL mode) (K)

| (Setting sequence of SFR registers)  |                     |        |                 |        |                 |                    |                 |     |
|--------------------------------------|---------------------|--------|-----------------|--------|-----------------|--------------------|-----------------|-----|
| Setting Flag of SFR<br>Register      | CMC Register Note 1 |        |                 | OSTS   | CSC<br>Register | OSTC               | DSCCTL Register |     |
| Status<br>Transition                 | EXCLK               | OSCSEL | AMPH Register M | MSTOP  | Register        | DSFRDIV            | DSCM            |     |
| $(B) \rightarrow (K)$ (divided by 2) | 0/1                 | 1      | 0/1             | Note 2 | 0               | Must be<br>checked | 0/1             | 0/1 |
| $(B) \rightarrow (K)$ (divided by 4) | 0/1                 | 1      | 0/1             | Note 2 | 0               | Must be<br>checked | 0/1             | 0/1 |
| $(B) \rightarrow (K)$ (divided by 8) | 0/1                 | 1      | 0/1             | Note 2 | 0               | Must be<br>checked | 0/1             | 0/1 |

| MCKC I | CKC Register Waiting for Osci |               | DSCCTL<br>Register | Waiting for Oscillation<br>Stabilization | MCKC<br>Register |
|--------|-------------------------------|---------------|--------------------|------------------------------------------|------------------|
| RDIV1  | RDIV0                         | Stabilization | DSCON              | Stabilization                            | CKSELR           |
| 0      | 0                             | 1 µs          | 1                  | 40 µs                                    | 1                |
| 0      | 1                             |               | 1                  |                                          | 1                |
| 1      | 0                             |               | 1                  |                                          | 1                |

**Note 1.** Writing to the clock operating mode control register (CMC) can only proceed once and must be by an 8-bit memory manipulation instruction after release from the reset state.

Note 2. Set the oscillation stabilization time in the oscillation stabilization time select register (OSTS) as follows.

• Desired oscillation stabilization time setting of the oscillation stabilization time counter status register (OSTC) ≤ Oscillation stabilization time set in the OSTS register

Caution Completion of clock switching after the CKSELR bit has been set to 1 requires up to 2 clock cycles when the FRQSEL4 bit is 1, and up to 10 clock cycles when the FRQSEL4 bit is 0. Until the clock switching is completed, do not stop the high-speed on-chip oscillator.

Remark (A) to (L) in Table 5 - 4 correspond to (A) to (L) in Figure 5 - 19.



#### Table 5 - 4 CPU Clock Transition and SFR Register Setting Examples (4/4)

# (6) CPU clock changing from high-speed system clock (PLL mode) (K) to high-speed on-chip oscillator clock (B)

| (Setting sequence of SET registers) |          |               |          |               |          |
|-------------------------------------|----------|---------------|----------|---------------|----------|
| Setting Flag of SFR Register        | CSC      | Waiting for   | MCKC     | Waiting for   | DSCCTL   |
|                                     | Register | Oscillation   | Register | Oscillation   | Register |
| Status Transition                   | HIOSTOP  | Stabilization | CKSELR   | Stabilization | DSCON    |
| $(K) \rightarrow (B) FRQSEL4 = 0$   | 0        | 18 to 65 µs   | 0        | 256 clocks    | 0        |
| $(K) \rightarrow (B) FRQSEL4 = 1$   |          | 18 ro 135 µs  |          | 16 clocks     |          |

#### (Setting sequence of SFR registers)

#### (7) • HALT mode (E) set while CPU is operating with high-speed on-chip oscillator clock (B)

• HALT mode (F) set while CPU is operating with high-speed system clock (C)

## • HALT mode (L) set while CPU is operating with high-speed system clock (PLL mode) (K)

| Status Transition     | Setting                    |
|-----------------------|----------------------------|
| $(B) \to (E)$         | Executing HALT instruction |
| $(C) \rightarrow (F)$ |                            |
| $(K) \to (L)$         |                            |

#### (8) STOP mode (I) set while CPU is operating with high-speed system clock (C)

| Stat                  | tus Transition             | Setting                                       |                        |                |  |  |
|-----------------------|----------------------------|-----------------------------------------------|------------------------|----------------|--|--|
| $(B) \rightarrow (H)$ |                            | Stopping peripheral                           | —                      | Executing STOP |  |  |
| $(C) \to (I)$         | In X1 oscillation          | functions that cannot<br>operate in STOP mode | Sets the OSTS register | instruction    |  |  |
|                       | External main system clock |                                               | _                      |                |  |  |

**Remark** (A) to (L) in Table 5 - 4 correspond to (A) to (L) in Figure 5 - 19.

#### (9) CPU changing from STOP mode (H) to SNOOZE mode (J)

For details about the setting for switching from the STOP mode to the SNOOZE mode, see **10.8 SNOOZE Mode Function**, and **11.5.7 SNOOZE mode function**.

#### (10) STOP mode (I) set while CPU is operating with high-speed system clock (PLL mode) (K)

Switch to high-speed on-chip oscillator clock operation from PLL mode, stop the PLL (DSCON = 0), and then execute the STOP instruction.

**Remark** (A) to (L) in Table 5 - 4 correspond to (A) to (L) in Figure 5 - 19.



# 5.6.5 Condition before changing CPU clock and processing after changing CPU clock

Condition before changing the CPU clock and processing after changing the CPU clock are shown below.

| CPU                                    | J Clock                                | Condition Defers Change                                                                                                                                                                                                                                           | Dressesing After Change                                                                                                      |  |  |  |
|----------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Before Change                          | After Change                           | - Condition Before Change                                                                                                                                                                                                                                         | Processing After Change                                                                                                      |  |  |  |
| High-speed on-chip<br>oscillator clock | X1 clock                               | Stabilization of X1 oscillation<br>• OSCSEL = 1, EXCLK = 0, MSTOP = 0<br>• After elapse of oscillation stabilization time                                                                                                                                         | After checking that the CPU clock is<br>switched to the clock after change,<br>operating current can be reduced by           |  |  |  |
|                                        | External main system<br>clock          | Enabling input of external clock from the<br>EXCLK pin<br>• OSCSEL = 1, EXCLK = 1, MSTOP = 0                                                                                                                                                                      | stopping high-speed on-chip<br>oscillator (HIOSTOP = 1).                                                                     |  |  |  |
|                                        | PLL clock                              | Stabilization of X1 oscillation<br>• OSCSEL = 1, EXCLK = 0, MSTOP = 0<br>• After elapse of oscillation stabilization time<br>Or enabling input of external clock from the<br>EXCLK pin<br>• OSCSEL = 1, EXCLK = 1, MSTOP = 0<br>Oscillation of PLL<br>• DSCON = 1 |                                                                                                                              |  |  |  |
| X1 clock                               | High-speed on-chip<br>oscillator clock | Enabling oscillation of high-speed on-chip<br>oscillator<br>• HIOSTOP = 0<br>• After elapse of oscillation accuracy<br>stabilization time                                                                                                                         | After checking that the CPU clock is<br>switched to the clock after change,<br>X1 oscillation can be stopped<br>(MSTOP = 1). |  |  |  |
|                                        | External main system<br>clock          | Transition not possible<br>(To change the clock, set it again after<br>executing reset once.)                                                                                                                                                                     | _                                                                                                                            |  |  |  |
|                                        | PLL clock                              | Oscillation of PLL<br>• DSCON = 1<br>Enabling oscillation of high-speed on-chip<br>oscillator<br>• HIOSTOP = 0<br>• The oscillation accuracy stabilization time<br>has elapsed                                                                                    | _                                                                                                                            |  |  |  |

| Table 5 - 5 Changing | g CPU Clock (1/2) |
|----------------------|-------------------|
|----------------------|-------------------|



| CPU                           | Clock                                  | Condition Before Change                                                                                                                                                        | Processing After Change                                          |
|-------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| Before Change                 | After Change                           | Condition Belore Change                                                                                                                                                        | Processing Aller Change                                          |
| External main system<br>clock | High-speed on-chip<br>oscillator clock | Enabling oscillation of high-speed on-chip<br>oscillator<br>• HIOSTOP = 0<br>• After elapse of oscillation accuracy<br>stabilization time                                      | External main system clock input<br>can be disabled (MSTOP = 1). |
|                               | X1 clock                               | Transition not possible                                                                                                                                                        | —                                                                |
|                               | PLL clock                              | Oscillation of PLL<br>• DSCON = 1<br>Enabling oscillation of high-speed on-chip<br>oscillator<br>• HIOSTOP = 0<br>• The oscillation accuracy stabilization time<br>has elapsed | _                                                                |
| PLL clock                     | High-speed on-chip<br>oscillator clock | Oscillation of high-speed on-chip oscillator<br>• HIOSTOP = 0                                                                                                                  | Operating current can be reduced by stopping PLL (DSCON = 0).    |
|                               | X1 clock                               | Stabilization of X1 oscillation<br>• OSCSEL = 1, EXCLK = 0, MSTOP = 0<br>• After elapse of oscillation stabilization time                                                      |                                                                  |
|                               | External main system<br>clock          | Enabling input of external clock from the<br>EXCLK pin<br>• OSCSEL = 1, EXCLK = 1, MSTOP = 0                                                                                   |                                                                  |

Table 5 - 5 Changing CPU Clock (2/2)



## 5.6.6 Time required for switchover of CPU clock and system clock

By setting bit 4 (MCM0) of the system clock control register (CKC), the CPU clock can be switched, and main system clock can be switched (between the high-speed on-chip oscillator clock and the high-speed system clock).

The actual switchover operation is not performed immediately after rewriting to the CKC register; operation continues on the pre-switchover clock for several clocks (see Table 5 - 6 and Table 5 - 7).

Whether the main system clock is operating on the high-speed system clock or high-speed on-chip oscillator clock can be ascertained using bit 5 (MCS) of the CKC register.

When the CPU clock is switched, the peripheral hardware clock is also switched.

| Clock A | Switching directions | Clock B | Remark          |  |  |  |  |  |  |  |
|---------|----------------------|---------|-----------------|--|--|--|--|--|--|--|
| fін     | ←→                   | fмх     | See Table 5 - 7 |  |  |  |  |  |  |  |

Table 5 - 6 Maximum Time Required for System Clock Switchover

|                                                        | Table 5 - 7 Maximu | m Number of Clocks Required fo | r tih ↔ tmx     |  |  |
|--------------------------------------------------------|--------------------|--------------------------------|-----------------|--|--|
| Set Value Before Switchover Set Value After Switchover |                    |                                |                 |  |  |
|                                                        |                    | МСМО                           |                 |  |  |
| MCI                                                    | M0                 | 0                              | 1               |  |  |
|                                                        |                    | (fmain = fih)                  | (fmain = fmx)   |  |  |
| 0                                                      | fмx ≥ fiн          |                                | 2 clock         |  |  |
| (fmain = fih)                                          | fMX < fiH          |                                | 2 fiн/fмx clock |  |  |
| 1                                                      | fMX ≥ fiH          | 2 fмx/fiн clock                |                 |  |  |
| (fmain = fmx)                                          | fMX < fIH          | 2 clock                        |                 |  |  |

## Table 5 - 7 Maximum Number of Clocks Required for fin $\leftrightarrow$ fmx

**Remark 1.** The number of clocks listed in Table 5 - 7 is the number of CPU clocks before switchover. **Remark 2.** Calculate the number of clocks in Table 5 - 7 by removing the decimal portion.

ExampleWhen switching the main system clock from the high-speed on-chip oscillator clock (when 12 MHz selected)<br/>to the high-speed system clock (@ oscillation with fiH = 12 MHz, fMx = 10 MHz)

1 + fih/fmx = 1 + 12/10 = 1 + 1.2 = 2.2  $\rightarrow$  2 clocks



## 5.6.7 Conditions before clock oscillation is stopped

The following lists the register flag settings for stopping the clock oscillation (disabling external clock input) and conditions before the clock oscillation is stopped.

Before stopping the clock oscillation, check the conditions before the clock oscillation is stopped.

## Table 5 - 8 Conditions Before the Clock Oscillation Is Stopped and Flag Settings

| Clock                                  | Conditions Before Clock Oscillation Is Stopped<br>(External Clock Input Disabled)                    | Flag Settings of SFR Register |
|----------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------|
| High-speed on-chip oscillator<br>clock | MCS = 1<br>(The CPU is operating on a clock other than the high-<br>speed on-chip oscillator clock.) | HIOSTOP = 1                   |
| X1 clock<br>External main system clock | MCS = 0<br>(The CPU is operating on a clock other than the high-<br>speed system clock.)             | MSTOP = 1                     |



## 5.7 Resonator and Oscillator Constants

For the resonators for which operation has been verified and their oscillator constants, see the target product page on the Renesas Web site.

- Caution 1. The constants for these oscillator circuits are reference values based on specific environments set up for evaluation by the manufacturers. For actual applications, request evaluation by the manufacturer of the oscillator circuit mounted on a board. Furthermore, if you are switching from a different product to this microcontroller, and whenever you change the board, again request evaluation by the manufacturer of the oscillator circuit mounted on the new board.
- Caution 2. The oscillation voltage and oscillation frequency only indicate the oscillator characteristic. Use the R9A02G015 so that the internal operation conditions are within the specifications of the DC and AC characteristics.

Figure 5 - 20 External Oscillation Circuit Example





## X1 oscillation:

As of March, 2013 (1/2)

| Manufacturer                   | Resonator                                                                                                                         | Part Number<br>Note 3 | SMD/<br>Lead           | Frequency<br>(MHz) | Flash<br>operation<br>mode | Rec<br>Consta | Recommended Circuit<br>Constants Note 2 (reference) |         | Oscillatio<br>Ranç | on Voltage<br>ge (V) |  |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------|--------------------|----------------------------|---------------|-----------------------------------------------------|---------|--------------------|----------------------|--|
|                                |                                                                                                                                   |                       | Leau                   | (101112)           | Note 1                     | C1 (pF)       | C2 (pF)                                             | Rd (kΩ) | MIN.               | MAX.                 |  |
| Murata                         | Ceramic                                                                                                                           | CSTCC2M00G56-R0       | SMD                    | 2                  | LV                         | (47)          | (47)                                                | 0       | 1.6                | 5.5                  |  |
| Manufacturing res<br>Co., Ltd. | resonator                                                                                                                         | CSTCR4M00G55-R0       | SMD                    | 4                  |                            | (39)          | (39)                                                | 0       |                    |                      |  |
| CO., LIU.                      |                                                                                                                                   | CSTLS4M00G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCC2M00G56-R0       | SMD                    | 2                  | LS                         | (47)          | (47)                                                | 0       | 1.8                | 5.5                  |  |
|                                |                                                                                                                                   | CSTCR4M00G55-R0       | SMD                    | 4                  |                            | (39)          | (39)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTLS4M00G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCR4M19G55-R0       | SMD                    | 4.194              |                            | (39)          | (39)                                                | 0       | 1                  |                      |  |
|                                |                                                                                                                                   | CSTLS4M19G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCR4M91G53-R0       | SMD                    | 4.915              |                            | (15)          | (15)                                                | 0       | -                  |                      |  |
|                                |                                                                                                                                   | CSTLS4M91G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCR5M00G53-R0       | SMD                    | 5                  |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTLS5M00G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCR6M00G53-R0       | SMD                    | 6                  |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTLS6M00G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCE8M00G52-R0       | SMD                    | 8                  |                            | (10)          | (10)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTLS8M00G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCE8M38G52-R0       | SMD                    | 8.388              | HS                         | (10)          | (10)                                                | 0       | 2.4                | 5.5                  |  |
|                                |                                                                                                                                   | CSTLS8M38G53-B0       | Lead                   |                    |                            | (15)          | (15)                                                | 0       | -                  |                      |  |
|                                |                                                                                                                                   | CSTCE10M0G52-R0       | SMD                    | 10                 |                            | (10)          | (10)                                                | 0       |                    |                      |  |
|                                | CSTLS10M0G53-B0         Lead         (15)         (15)           CSTCE12M0G52-R0         SMD         12         (10)         (10) | (15)                  | (15)                   | 0                  | 1                          |               |                                                     |         |                    |                      |  |
|                                |                                                                                                                                   | 0                     |                        |                    |                            |               |                                                     |         |                    |                      |  |
|                                |                                                                                                                                   | CSTCE16M0V53-R0       | -R0 SMD 16 (15) (15) 0 |                    |                            |               |                                                     |         |                    |                      |  |
|                                |                                                                                                                                   | CSTLS16M0X51-B0       | Lead                   | 1                  |                            | (5)           | (5)                                                 | 0       |                    |                      |  |
|                                |                                                                                                                                   | CSTCE20M0V51-R0       | SMD                    | 20                 | 1                          | (5)           | (5)                                                 | 0       | 2.7                | 5.5                  |  |
|                                |                                                                                                                                   | CSTLS20M0X51-B0       | Lead                   | 1                  |                            | (5)           | (5)                                                 | 0       |                    |                      |  |

**Note 1.** Set the flash operation mode by using CMODE1 and CMODE0 bits of the option byte (000C2H).

Note 2. Values in parentheses in the C1 and C2 columns indicate an internal capacitance.

Note 3. Products supporting 105°C operation have different part numbers. For details, contact Murata Co., Ltd (http://www.murata.co.jp).

**Remark** Relationship between operation voltage width, operation frequency of CPU and operation mode is as below. HS (high-speed main) mode: 2.7 V ≤ VDD ≤ 5.5 V@1 MHz to 24 MHz



As of March, 2013 (2/2)

| Manufacturer           | Resonator             | Part Number                         | SMD/<br>Lead | Frequency<br>(MHz) | Flash<br>operation<br>mode | Reco<br>Constan | mmended Ci<br>ts <b>Note 2</b> (ref | rcuit<br>erence) | Oscillation Voltage<br>Range (V) |      |
|------------------------|-----------------------|-------------------------------------|--------------|--------------------|----------------------------|-----------------|-------------------------------------|------------------|----------------------------------|------|
|                        |                       |                                     | Loud         | (                  | Note 1                     | C1 (pF)         | C2 (pF)                             | Rd (kΩ)          | MIN.                             | MAX. |
| Nihon                  | Crystal               | NX8045GB Note 3                     | SMD          | 8                  |                            |                 | Note                                | 3                |                                  |      |
| Dempa<br>Kogyo         | resonator             | NX5032GA Note 3                     | SMD          | 16                 |                            |                 |                                     |                  |                                  |      |
| Co., Ltd.              |                       | NX3225HA Note 3                     | SMD          | 20                 |                            |                 |                                     |                  |                                  |      |
| Kyocera                | Crystal               | CX8045GB04000D0P                    | SMD          | 4                  | LV                         | 12              | 12                                  | 0                | 1.6                              | 5.5  |
| Crystal<br>Device Co., | resonator PTZ1 Note 4 |                                     |              | LS                 |                            |                 |                                     | 1.6              | 5.5                              |      |
| Ltd.                   |                       | CX8045GB04915D0P<br>PTZ1 Note 4     | SMD          | 4.915              | LS                         | 12              | 12                                  | 0                | 1.8                              | 5.5  |
|                        |                       | CX8045GB08000D0P<br>PTZ1 Note 4     | SMD          | 8                  | LS                         | 12              | 12                                  | 0                | 1.8                              | 5.5  |
|                        |                       | CX8045GB10000D0P<br>PTZ1 Note 4     | SMD          | 10                 | HS                         | 12              | 12                                  | 0                | 2.4                              | 5.5  |
|                        |                       | CX3225GB12000B0P<br>PTZ1 Note 4     | SMD          | 12                 | HS                         | 5               | 5                                   | 0                | 2.4                              | 5.5  |
|                        |                       | CX3225GB16000B0P<br>PTZ1 Note 4     | SMD          | 16                 | HS                         | 5               | 5                                   | 0                | 2.4                              | 5.5  |
|                        |                       | CX3225SB20000B0PP<br>TZ1 Note 4     | SMD          | 20                 | HS                         | 5               | 5                                   | 0                | 2.7                              | 5.5  |
| RIVER<br>ELETEC        | Crystal<br>resonator  | FCX-03-8.000MHZ-<br>J21140 Note 5   | SMD          | 8                  | HS                         | 3               | 3                                   | 0                | 2.4                              | 5.5  |
| CORPORATI<br>ON        |                       | FCX-04C-10.000MHZ-<br>J21139 Note 5 | SMD          | 10                 | HS                         | 4               | 4                                   | 0                | 2.4                              | 5.5  |
|                        |                       | FCX-05-12.000MHZ-<br>J21138 Note 5  | SMD          | 12                 | HS                         | 6               | 6                                   | 0                | 2.4                              | 5.5  |
|                        |                       | FCX-06-16.000MHZ-<br>J21137 Note 5  | SMD          | 16                 | HS                         | 4               | 4                                   | 0                | 2.4                              | 5.5  |

Note 1. Set the flash operation mode by using CMODE1 and CMODE0 bits of the option byte (000C2H).

**Note 2.** This resonator supports operation at up to 85°C. Contact crystal oscillator manufacturers with regard to products supporting operation at up to 105°C.

Note 3. When using this resonator, for details about the matching, contact Nihon Dempa Kogyo Co., Ltd (http://www.ndk.com/en).

**Note 4.** When using this resonator, for details about the matching, contact Kyocera Crystal Device Co., Ltd. (http://www.kyocera-crystal.jp, http://www.kyocera.co.jp).

**Note 5.** When using this resonator, for details about the matching, contact RIVER ELETEC CORPORATION (http://www.riverele.co.jp).

**Remark** Relationship between operation voltage width, operation frequency of CPU and operation mode is as below. HS (high-speed main) mode: 2.7 V ≤ V<sub>DD</sub> ≤ 5.5 V@1 MHz to 24 MHz



# **CHAPTER 6 TIMER ARRAY UNIT**

The timer array unit has eight 16-bit timers.

Each 16-bit timer is called a channel and can be used as an independent timer. In addition, two or more "channels" can be used to create a high-accuracy timer.





For details about each function, see the table below.

| Independent channel operation function                                  | Simultaneous channel operation function                      |
|-------------------------------------------------------------------------|--------------------------------------------------------------|
| <ul> <li>Interval timer (→ refer to 6.8.1)</li> </ul>                   | <ul> <li>One-shot pulse output (→ refer to 6.9.1)</li> </ul> |
| <ul> <li>Square wave output (→ refer to 6.8.1)</li> </ul>               | <ul> <li>PWM output (→ refer to 6.9.2)</li> </ul>            |
| <ul> <li>External event counter (→ refer to 6.8.2)</li> </ul>           | <ul> <li>Multiple PWM output (→ refer to 6.9.3)</li> </ul>   |
| <ul> <li>Input pulse interval measurement (→ refer to 6.8.3)</li> </ul> |                                                              |
| Measurement of high-/low-level width of input signal                    |                                                              |
| $(\rightarrow$ refer to <b>6.8.4</b> )                                  |                                                              |
| • Delay counter ( $\rightarrow$ refer to <b>6.8.5</b> )                 |                                                              |

It is possible to use the 16-bit timer of channels 1 and 3 as two 8-bit timers (higher and lower). The functions that can use channels 1 and 3 as 8-bit timers are as follows:

- Interval timer (upper or lower 8-bit timer)/square wave output (lower 8-bit timer only)
- External event counter (lower 8-bit timer only)
- Delay counter (lower 8-bit timer only)



## 6.1 Functions of Timer Array Unit

Timer array unit has the following functions.

## 6.1.1 Independent channel operation function

By operating a channel independently, it can be used for the following purposes without being affected by the operation mode of other channels.

(1) Interval timer

Each timer of a unit can be used as a reference timer that generates an interrupt (INTTMmn) at fixed intervals.



(2) Square wave output

A toggle operation is performed each time INTTMmn interrupt is generated and a square wave with a duty factor of 50% is output from a timer output pin (TOmn).



(3) External event counter

Each timer of a unit can be used as an event counter that generates an interrupt when the number of the valid edges of a signal input to the timer input pin (TImn) has reached a specific value.



(4) Input pulse interval measurement

Counting is started by the valid edge of a pulse signal input to a timer input pin (TImn). The count value of the timer is captured at the valid edge of the next pulse. In this way, the interval of the input pulse can be measured.



(Remark is listed on the next page.)



(5) Measurement of high-/low-level width of input signal

Counting is started by a single edge of the signal input to the timer input pin (TImn), and the count value is captured at the other edge. In this way, the high-level or low-level width of the input signal can be measured.



(6) Delay counter

Counting is started at the valid edge of the signal input to the timer input pin (TImn), and an interrupt is generated after any delay period.



**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)

# 6.1.2 Simultaneous channel operation function

By using the combination of a master channel (a reference timer mainly controlling the cycle) and slave channels (timers operating according to the master channel), channels can be used for the following purposes.

(1) One-shot pulse output

Two channels are used as a set to generate a one-shot pulse with a specified output timing and a specified pulse width.





#### (2) PWM (Pulse Width Modulation) output

Two channels are used as a set to generate a pulse with a specified period and a specified duty factor.



#### (3) Multiple PWM (Pulse Width Modulation) output

By extending the PWM function and using one master channel and two or more slave channels, up to seven types of PWM signals that have a specific period and a specified duty factor can be generated.



- Caution For details about the rules of simultaneous channel operation function, see 6.4.1 Basic rules of simultaneous channel operation function.
- Remarkm: Unit number (m = 0), n: Channel number (n = 0 to 7),<br/>p, q: Slave channel number (n \leq 7)

# 6.1.3 8-bit timer operation function (channels 1 and 3 only)

The 8-bit timer operation function makes it possible to use a 16-bit timer channel in a configuration consisting of two 8-bit timer channels. This function can only be used for channels 1 and 3.

```
Caution There are several rules for using 8-bit timer operation function.
For details, see 6.4.2 Basic rules of 8-bit timer operation function (channels 1 and 3 only).
```



# 6.2 Configuration of Timer Array Unit

Timer array unit includes the following hardware.

| Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer count register mn (TCRmn)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Timer data register mn (TDRmn)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| TI00 to TI07 Note 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TO00 to TO07 Note 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <registers block="" of="" setting="" unit=""> <ul> <li>Peripheral enable register 0 (PER0)</li> <li>Timer clock select register m (TPSm)</li> <li>Timer channel enable status register m (TEm)</li> <li>Timer channel start register m (TSm)</li> <li>Timer channel stop register m (TTm)</li> <li>Timer channel stop register m (TTm)</li> <li>Timer output select register 0 (TIS0)</li> <li>Timer output enable register m (TOEm)</li> <li>Timer output register m (TOM)</li> <li>Timer output register m (TOLm)</li> <li>Timer output level register m (TOLm)</li> <li>Timer output mode register m (TOMm)</li> </ul> <registers channel="" each="" of=""> <ul> <li>Timer status register mn (TSRmn)</li> <li>Noise filter enable register 1 (NFEN1)</li> <li>Port mode control register (PMCxx) Note 3</li> <li>Port mode register (PMxx) Note 3</li> <li>Port register (PXx) Note 3</li> </ul></registers></registers> |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Note 1. TI07 is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.

Note 2. TO07 is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.

 Note 3.
 The Port mode registers (PMxx) and port registers (Pxx) to be set differ depending on the product. For details, see 4.5.3

 Register setting examples for used port and alternate functions.



The port pins alternatively used as timer I/O pins in each timer array unit channel depend on the product.

| Timer array unit channels | with USB | without USB |
|---------------------------|----------|-------------|
| Channel 0                 | T100/    | TO00        |
| Channel 1                 | TI01/    | TO01        |
| Channel 2                 | TI02/    | TO02        |
| Channel 3                 | TI03/    | TO03        |
| Channel 4                 | TI04/    | TO04        |
| Channel 5                 | T105/    | TO05        |
| Channel 6                 | TI06/    | TO06        |
| Channel 7                 |          | TI07/TO07   |

#### Table 6 - 2 Timer I/O Pins provided in Each Product

Figure 6 - 1 shows the block diagram of the timer array unit.





#### Figure 6 - 1 Entire Configuration of Timer Array Unit 0

Remark fil: Low-speed on-chip oscillator clock frequency



Figure 6 - 2 Internal Block Diagram of Channel 0 of Timer Array Unit

Interrupt signal to slave channel

















Figure 6 - 6 Internal Block Diagram of Channel 5 of Timer Array Unit







## 6.2.1 Timer count register mn (TCRmn)

The TCRmn register is a 16-bit read-only register and is used to count clocks.

The value of this counter is incremented or decremented in synchronization with the rising edge of a count clock. Whether the counter is incremented or decremented depends on the operation mode that is selected by the MDmn3 to MDmn0 bits of timer mode register mn (TMRmn) (refer to **6.3.3 Timer mode register mn (TMRmn)**).

#### Figure 6 - 8 Format of Timer count register mn (TCRmn)

Address: F0180H, F0181H (TCR00) to F018EH, F018FH (TCR07) After reset: FFFFH R

|       |    |    | F  | 0181H | (TCR00 | )) |   |   |   |   | F | 0180H | (TCR00 | )) |   |   |
|-------|----|----|----|-------|--------|----|---|---|---|---|---|-------|--------|----|---|---|
| ,     | 15 | 14 | 13 | 12    | 11     | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3      | 2  | 1 | 0 |
| TCRmn |    |    |    |       |        |    |   |   |   |   |   |       |        |    |   |   |

**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)

The count value can be read by reading timer count register mn (TCRmn).

The count value is set to FFFFH in the following cases.

- When the reset signal is generated
- When the TAUmEN bit of peripheral enable register 0 (PER0) is cleared
- When counting of the slave channel has been completed in the PWM output mode
- When counting of the slave channel has been completed in the delay count mode
- When counting of the master/slave channel has been completed in the one-shot pulse output mode
- When counting of the slave channel has been completed in the multiple PWM output mode
- The count value is cleared to 0000H in the following cases.
- · When the start trigger is input in the capture mode
- · When capturing has been completed in the capture mode

# Caution The count value is not captured to timer data register mn (TDRmn) even when the TCRmn register is read.



The TCRmn register read value differs as follows according to operation mode changes and the operating status.

|                                    |                                | Timer count register mn (TCRmn) Read Value Note                        |                                                                                          |                                                                                             |                                                              |  |  |  |  |  |  |
|------------------------------------|--------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|--|--|--|--|
| Operation Mode                     | Count Mode                     | Value if the<br>operation mode was<br>changed after<br>releasing reset | Value if the<br>operation was<br>restarted after count<br>operation paused<br>(TTmn = 1) | Value if the<br>operation mode was<br>changed after count<br>operation paused<br>(TTmn = 1) | Value when waiting<br>for a start trigger<br>after one count |  |  |  |  |  |  |
| Interval timer mode                | Interval timer mode Count down |                                                                        | Value if stop                                                                            | Undefined                                                                                   | —                                                            |  |  |  |  |  |  |
| Capture mode                       | Count up                       | 0000H                                                                  | Value if stop                                                                            | Undefined                                                                                   | —                                                            |  |  |  |  |  |  |
| Event counter mode                 |                                |                                                                        | Value if stop                                                                            | Undefined                                                                                   | _                                                            |  |  |  |  |  |  |
| One-count mode                     | Count down                     | FFFFH                                                                  | Value if stop                                                                            | Undefined                                                                                   | FFFFH                                                        |  |  |  |  |  |  |
| Capture & one- Count up count mode |                                | 0000H                                                                  | Value if stop                                                                            | Undefined                                                                                   | Capture value of<br>TDRmn register + 1                       |  |  |  |  |  |  |

**Note** This indicates the value read from the TCRmn register when channel n has stopped operating as a timer (TEmn = 0) and has been enabled to operate as a counter (TSmn = 1). The read value is held in the TCRmn register until the count operation starts.



## 6.2.2 Timer data register mn (TDRmn)

This is a 16-bit register from which a capture function and a compare function can be selected.

The capture or compare function can be switched by selecting an operation mode by using the MDmn3 to MDmn0 bits of timer mode register mn (TMRmn).

The value of the TDRmn register can be changed at any time.

This register can be read or written in 16-bit units.

In addition, for the TDRm1 and TDRm3 registers, while in the 8-bit timer mode (when the SPLIT bits of timer mode registers 01 and 03 (TMRm1, TMRm3) are 1), it is possible to rewrite the data in 8-bit units, with TDRm1H and TDRm3H used as the higher 8 bits, and TDRm1L and TDRm3L used as the lower 8 bits. However, reading is only possible in 16-bit units.

Reset signal generation clears this register to 0000H.

#### Figure 6 - 9 Format of Timer data register mn (TDRmn) (n = 0, 2, 4 to 7)

Address: FFF18H, FFF19H (TDR00), FFF64H, FFF65H (TDR02) After reset: 0000H R/W FFF68H, FFF69H (TDR04) to FFF6EH, FFF6FH (TDR07)

|       |    |    | F  | FF19H | (TDR00 | )) |   |   |   |   | F | FF18H | (TDR00 | )) |   |   |
|-------|----|----|----|-------|--------|----|---|---|---|---|---|-------|--------|----|---|---|
| ,     | 15 | 14 | 13 | 12    | 11     | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3      | 2  | 1 | 0 |
| TDRmn |    |    |    |       |        |    |   |   |   |   |   |       |        |    |   |   |



| Address: | FFF1A | λH, FFF | 1BH (T | DR01), | FFF66H | H, FFF6 | 7H (TD | R03) | Afte | r reset: | 00H | F    | R/W    |    |   |   |
|----------|-------|---------|--------|--------|--------|---------|--------|------|------|----------|-----|------|--------|----|---|---|
|          |       |         | FF     | F1BH ( | TDR01  | H)      |        |      |      |          | FF  | F1AH | (TDR01 | L) |   |   |
| (        | 15    | 14      | 13     | 12     | 11     | 10      | 9      | 8    | 7    | 6        | 5   | 4    | 3      | 2  | 1 | 0 |
| TDRmn    |       |         |        |        |        |         |        |      |      |          |     |      |        |    |   |   |

(i) When timer data register mn (TDRmn) is used as compare register

Counting down is started from the value set to the TDRmn register. When the count value reaches 0000H, an interrupt signal (INTTMmn) is generated. The TDRmn register holds its value until it is rewritten.

# Caution The TDRmn register does not perform a capture operation even if a capture trigger is input, when it is set to the compare function.

(ii) When timer data register mn (TDRmn) is used as capture register

The count value of timer count register mn (TCRmn) is captured to the TDRmn register when the capture trigger is input.

A valid edge of the TImn pin can be selected as the capture trigger. This selection is made by timer mode register mn (TMRmn).



# 6.3 Registers Controlling Timer Array Unit

Timer array unit is controlled by the following registers.

- Peripheral enable register 0 (PER0)
- Timer clock select register m (TPSm)
- Timer mode register mn (TMRmn)
- Timer status register mn (TSRmn)
- Timer channel enable status register m (TEm)
- Timer channel start register m (TSm)
- Timer channel stop register m (TTm)
- Timer input select register 0 (TIS0)
- Timer output enable register m (TOEm)
- Timer output register m (TOm)
- Timer output level register m (TOLm)
- Timer output mode register m (TOMm)
- Noise filter enable register 1 (NFEN1)
- Port mode control register (PMCxx)
- Port mode register (PMxx)
- Port register (Pxx)

# Caution Which registers and bits are included depends on the product. Be sure to set bits that are not mounted to their initial values.



## 6.3.1 Peripheral enable register 0 (PER0)

This registers is used to enable or disable supplying the clock to the peripheral hardware. Clock supply to a hardware macro that is not used is stopped in order to reduce the power consumption and noise. When the timer array unit 0 is used, be sure to set bit 0 (TAU0EN) of this register to 1.

The PER0 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 6 - 11 Format of Peripheral enable register 0 (PER0)

| Symbol     <7>     <6>     <5>     <4>     3     <2>     1     <0>       PER0     IICA2EN<br>Note     IICA1EN     ADCEN     IICA0EN     0     SAU0EN     0     TAU0EN | Address: | F00F0H          | After reset: 00H | H R/W |         |   |        |   |        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------|------------------|-------|---------|---|--------|---|--------|
| I IICA1EN ADCEN I IICA0EN 0 SAU0EN 0 TAU0EN                                                                                                                           | Symbol   | <7>             | <6>              | <5>   | <4>     | 3 | <2>    | 1 | <0>    |
|                                                                                                                                                                       | PER0     | IICA2EN<br>Note | IICA1EN          | ADCEN | IICA0EN | 0 | SAU0EN | 0 | TAU0EN |

| TAU0EN | Control of timer array unit input clock                                                                                                                         |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | <ul><li>Stops supply of input clock.</li><li>SFR used by the timer array unit cannot be written.</li><li>The timer array unit is in the reset status.</li></ul> |
| 1      | Supplies input clock.<br>• SFR used by the timer array unit can be read/written.                                                                                |

Note This bit is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.

- Caution 1. When setting the timer array unit, be sure to set the following registers first while the TAUmEN bit is set to 1. If TAUmEN = 0, the values of the registers which control the timer array unit are cleared to their initial values and writing to them is ignored (except for the timer input select register (TIS0), noise filter enable register 1 (NFEN1), port mode control register 0 (PMC0), port mode registers 0, 5, 7 (PM0, PM5, PM7), and port registers 0, 5, 7 (P0, P5, P7)).
  - Timer clock select register m (TPSm)
  - Timer mode register mn (TMRmn)
  - Timer status register mn (TSRmn)
  - Timer channel enable status register m (TEm)
  - Timer channel start register m (TSm)
  - Timer channel stop register m (TTm)
  - Timer output enable register m (TOEm)
  - Timer output register m (TOm)
  - Timer output level register m (TOLm)
  - Timer output mode register m (TOMm)

Caution 2. Be sure to clear bits 1 and 6 to 0.



# 6.3.2 Timer clock select register m (TPSm)

The TPSm register is a 16-bit register that is used to select two types or four types of operation clocks (CKm0, CKm1, CKm2, CKm3) that are commonly supplied to each channel. CKm0 is selected by using bits 3 to 0 of the TPSm register, and CKm1 is selected by using bits 7 to 4 of the TPSm register. In addition, only for channels 1 and 3, CKm2 and CKm3 can be also selected. CKm2 is selected by using bits 9 and 8 of the TPSm register, and CKm3 is selected by using bits 13 and 12 of the TPSm register.

Rewriting of the TPSm register during timer operation is possible only in the following cases.

If the PRSm00 to PRSm03 bits can be rewritten (n = 0 to 7):

All channels for which CKm0 is selected as the operation clock (CKSmn1, CKSmn0 = 0, 0) are stopped (TEmn = 0).

If the PRSm10 to PRSm13 bits can be rewritten (n = 0 to 7):

All channels for which CKm2 is selected as the operation clock (CKSmn1, CKSmn0 = 0, 1) are stopped (TEmn = 0).

If the PRSm20 and PRSm21 bits can be rewritten (n = 1, 3):

All channels for which CKm1 is selected as the operation clock (CKSmn1, CKSmn0 = 1, 0) are stopped (TEmn = 0).

If the PRSm30 and PRSm31 bits can be rewritten (n = 1, 3):

All channels for which CKm3 is selected as the operation clock (CKSmn1, CKSmn0 = 1, 1) are stopped (TEmn = 0).

The TPSm register can be set by a 16-bit memory manipulation instruction. Reset signal generation clears this register to 0000H.



| Address: | F01B6      | H, F01     | B7H        | А          | fter res | et: 000                                                                                                                                         | 0H         | R/W        |            |            |            |                     |                      |            |            |            |
|----------|------------|------------|------------|------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|------------|------------|------------|---------------------|----------------------|------------|------------|------------|
| Symbol   | 15         | 14         | 13         | 12         | 11       | 10                                                                                                                                              | 9          | 8          | 7          | 6          | 5          | 4                   | 3                    | 2          | 1          | 0          |
| TPSm     | 0          | 0          | PRSm<br>31 | PRSm<br>30 | 0        | 0                                                                                                                                               | PRSm<br>21 | PRSm<br>20 | PRSm<br>13 | PRSm<br>12 | PRSm<br>11 | PRSm<br>10          | PRSm<br>03           | PRSm<br>02 | PRSm<br>01 | PRSm<br>00 |
| [        |            |            |            |            |          |                                                                                                                                                 | Se         | election   | of opera   | ation clo  | ock (CK    | mk) <sup>Note</sup> | <sup>e</sup> (k = 0, | 1)         |            |            |
|          | PRS<br>mk3 | PRS<br>mk2 | PRS<br>mk1 | PRS<br>mk0 |          |                                                                                                                                                 |            | к=<br>/Hz  | fCL        | к =<br>1Hz | fCL        |                     | fCL                  | ,          | -          | κ =<br>MHz |
|          | 0          | 0          | 0          | 0          | fC       | LK                                                                                                                                              |            | ЛНZ        | _          | 1Hz        | -          | ИНz                 |                      | ИНz        |            | MHz        |
|          | 0          | 0          | 0          | 1          | fCL      | к/2                                                                                                                                             | 1 MHz      |            | 2.5 MHz    |            | 5 N        | 1Hz                 | 10 N                 | ИНz        | 12 MHz     |            |
|          | 0          | 0          | 1          | 0          | fCLł     | 2<sup 2                                                                                                                                         | 500 kHz    |            | 1.25 MHz   |            | 2.5 MHz    |                     | 5 MHz                |            | 6 N        | 1Hz        |
|          | 0          | 0          | 1          | 1          | fCLF     | 2<sup 3                                                                                                                                         | 250 kHz    |            | 625        | kHz        | 1.25 MHz   |                     | 2.5 MHz              |            | 3 N        | 1Hz        |
|          | 0          | 1          | 0          | 0          | fclł     | 24</td <td>125</td> <td>kHz</td> <td>313</td> <td>kHz</td> <td>625</td> <td>kHz</td> <td colspan="2">1.25 MHz</td> <td colspan="2">1.5 MHz</td> | 125        | kHz        | 313        | kHz        | 625        | kHz                 | 1.25 MHz             |            | 1.5 MHz    |            |
|          | 0          | 1          | 0          | 1          | fCLł     | 2<sup 5                                                                                                                                         | 62.5       | i kHz      | 156        | kHz        | 313        | kHz                 | 625 kHz              |            | 750 kHz    |            |
|          | 0          | 1          | 1          | 0          | fCLł     | fCLK/2 <sup>6</sup>                                                                                                                             |            | 31.3 kHz   |            | kHz        | 156 kHz    |                     | 313 kHz              |            | 375 kHz    |            |
|          | 0          | 1          | 1          | 1          | fCLł     | fclк/2 <sup>7</sup>                                                                                                                             |            | 15.6 kHz   |            | 39.1 kHz   |            | 78.1 kHz            |                      | 156 kHz    |            | 5 kHz      |
|          | 1          | 0          | 0          | 0          | fCLł     | 2<sup 8                                                                                                                                         | 7.81 kHz   |            | 19.5 kHz   |            | 39.1 kHz   |                     | 78.1 kHz             |            | 93.8       | kHz        |
|          | 1          | 0          | 0          | 1          | fCLł     | 2<sup 9                                                                                                                                         | 3.91       | 3.91 kHz   |            | 9.77 kHz   |            | 19.5 kHz            |                      | 39.1 kHz   |            | kHz        |
|          | 1          | 0          | 1          | 0          | fCLK     | fcLK/2 <sup>10</sup>                                                                                                                            |            | 1.95 kHz   |            | 4.88 kHz   |            | 9.77 kHz            |                      | 19.5 kHz   |            | kHz        |
|          | 1          | 0          | 1          | 1          | fCLK     | fclк/2 <sup>11</sup>                                                                                                                            |            | 977 Hz     |            | 2.44 kHz   |            | 4.88 kHz            |                      | 9.77 kHz   |            | kHz        |
|          | 1          | 1          | 0          | 0          | fCLK     | /2 <sup>12</sup>                                                                                                                                | 488        | 488 Hz     |            | 1.22 kHz   |            | 2.44 kHz            |                      | 4.88 kHz   |            | kHz        |
|          | 1          | 1          | 0          | 1          | fCLK     | fclk/2 <sup>13</sup>                                                                                                                            |            | 244 Hz     |            | 610 Hz     |            | 1.22 kHz            |                      | 2.44 kHz   |            | kHz        |
|          | 1          | 1          | 1          | 0          | fclk     | /2 <sup>14</sup>                                                                                                                                | 122        | 122 Hz     |            | 305 Hz     |            | 610 Hz              |                      | 1.22 kHz   |            | kHz        |
|          | 1          | 1          | 1          | 1          | fCLK     | /2 <sup>15</sup>                                                                                                                                | 61.0       | ) Hz       | 153        | Hz         | 305        | Hz                  | 610                  | 610 Hz     |            | l Hz       |

#### Figure 6 - 12 Format of Timer clock select register m (TPSm) (1/2)

**Note** When changing the clock selected for fCLK (by changing the system clock control register (CKC) value), stop timer array unit (TTm = 00FFH).

Caution 1. Be sure to clear bits 15, 14, 11, and 10 to "0".

Caution 2. If fcLK (undivided) is selected as the operation clock (CKmk) and TDRnm is set to 0000H (n = 0, m = 0 to 7), interrupt requests output from timer array units cannot be used.

- Remark 1. fCLK: CPU/peripheral hardware clock frequency
- **Remark 2.** The above fCLK/2<sup>r</sup> is not a signal which is simply divided fCLK by 2r, but a signal which becomes high level for one period of fCLK from its rising edge (r = 1 to 15). For details, see **6.5.1 Count clock (fTCLK)**.



| Address | : F01B6 | 6H, F01 | B7H        | A          | After res        | set: 000 | 00H        | R/W         |                                          |                 |                  |                   |                  |            |             |            |
|---------|---------|---------|------------|------------|------------------|----------|------------|-------------|------------------------------------------|-----------------|------------------|-------------------|------------------|------------|-------------|------------|
| Symbol  | 15      | 14      | 13         | 12         | 11               | 10       | 9          | 8           | 7                                        | 6               | 5                | 4                 | 3                | 2          | 1           | 0          |
| TPSm    | 0       | 0       | PRSm<br>31 | PRSm<br>30 | 0                | 0        | PRSm<br>21 | PRSm<br>20  | PRSm<br>13                               | PRSm<br>12      | PRSm<br>11       | PRSm<br>10        | PRSm<br>03       | PRSm<br>02 | PRSm<br>01  | PRSm<br>00 |
|         | PRS     | PRS     |            |            |                  |          | Seleo      | ction of    | f operation clock (CKm2) <sup>Note</sup> |                 |                  |                   |                  |            |             |            |
|         | m21     | m20     |            |            |                  |          | -          | к=<br>/Hz   | fc∟<br>5 N                               | к =<br>1Hz      | fclk =<br>10 MHz |                   | fclk =<br>20 MHz |            | fcL<br>24 M |            |
|         | 0       | 0       |            | fc∟        | к/2              |          | 1 N        | /Hz         | 2.5                                      | MHz             | 5 MHz            |                   | 10 N             | MHz        | 12 1        | ИНz        |
|         | 0       | 1       |            | fCLł       | 2<sup 2          |          | 500        | kHz         | 1.25                                     | MHz             | 2.5              | MHz               | 5 N              | 1Hz        | 6 N         | 1Hz        |
|         | 1       | 0       |            | fCLł       | 2<sup 4          |          | 125        | kHz         | 313                                      | kHz             | 625              | kHz               | 1.25             | MHz        | 1.5         | MHz        |
|         | 1       | 1       |            | fCL        | 2<sup 6          |          | 31.3       | kHz         | 78.1                                     | kHz             | 156.2            | 2 kHz             | 313              | kHz        | 375         | kHz        |
|         | PRS     | PRS     |            |            |                  |          | Seleo      | ction of    | operatic                                 | on clock        | (CKm3            | ) <sup>Note</sup> |                  |            |             |            |
|         | m31     | m30     |            |            |                  |          |            | к =<br>/IHz |                                          | fclk =<br>5 MHz |                  | к =<br>ИНz        |                  |            | fc∟<br>24 № |            |
|         | 0       | 0       |            | fclł       | 2<sup 8          |          | 7.81       | kHz         | 19.5 kHz                                 |                 | 39.1 kHz         |                   | 78.1             | kHz        | 93.8        | kHz        |
|         | 0       | 1       |            | fclk       | /2 <sup>10</sup> |          | 1.95       | kHz         | 4.88                                     | kHz             | 9.77             | kHz               | 19.5             | kHz        | 23.4        | kHz        |
|         | 1       | 0       |            | fclk       | /212             |          | 488        | 3 Hz        | 1.22                                     | kHz             | 2.44 kHz         |                   | 4.88 kHz         |            | 5.86        | kHz        |
|         | 1       | 1       |            | fclk       | /2 <sup>14</sup> |          | 122        | 2 Hz        | 305                                      | i Hz            | 610              | Hz                | 1.22             | kHz        | 1.46        | kHz        |
|         |         |         |            |            |                  |          | •          |             |                                          |                 |                  |                   |                  |            |             |            |

#### Figure 6 - 13 Format of Timer clock select register m (TPSm) (2/2)

**Note** When changing the clock selected for fCLK (by changing the system clock control register (CKC) value), stop the timer array unit (TTm = 00FFH).

The timer array unit must also be stopped if the operating clock (fMCK) or the valid edge of the signal input from the TImn pin is selected.

Caution Be sure to clear bits 15, 14, 11, and 10 to "0".

By using channels 1 and 3 in the 8-bit timer mode and specifying CKm2 or CKm3 as the operation clock, the interval times shown in Table 6 - 4 can be achieved by using the interval timer function.

| C                 | Clock                | Interval time <sup>Note</sup> (fCLK = 20 MHz) |              |              |              |  |  |  |  |  |  |  |
|-------------------|----------------------|-----------------------------------------------|--------------|--------------|--------------|--|--|--|--|--|--|--|
| C                 | JUCK                 | 16 µs                                         | 160 µs       | 1.6 ms       | 16 ms        |  |  |  |  |  |  |  |
|                   | fclk/2               | $\checkmark$                                  | —            | —            | _            |  |  |  |  |  |  |  |
| C<br>CKm2<br>CKm3 | fclk/2 <sup>2</sup>  | $\checkmark$                                  | —            | —            | _            |  |  |  |  |  |  |  |
|                   | fclk/2 <sup>4</sup>  | $\checkmark$                                  | $\checkmark$ | —            | _            |  |  |  |  |  |  |  |
|                   | fclk/2 <sup>6</sup>  | $\checkmark$                                  | $\checkmark$ | —            | _            |  |  |  |  |  |  |  |
|                   | fclk/2 <sup>8</sup>  | _                                             | $\checkmark$ | $\checkmark$ | _            |  |  |  |  |  |  |  |
| Cl/m2             | fcLк/2 <sup>10</sup> |                                               | $\checkmark$ | $\checkmark$ |              |  |  |  |  |  |  |  |
| CKm3              | fclk/2 <sup>12</sup> | _                                             | —            | $\checkmark$ | $\checkmark$ |  |  |  |  |  |  |  |
|                   | fcLK/2 <sup>14</sup> | _                                             | _            | $\checkmark$ | $\checkmark$ |  |  |  |  |  |  |  |

Table 6 - 4 Interval Times Available for Operation Clock CKSm2 or CKSm3

**Note** The margin is within 5%.

Remark 1. fclk: CPU/peripheral hardware clock frequency

Remark 2. For details of a signal of fCLK/2<sup>j</sup> selected with the TPSm register, see 6.5.1 Count clock (fTCLK).

RENESAS

# 6.3.3 Timer mode register mn (TMRmn)

The TMRmn register sets an operation mode of channel n. This register is used to select the operation clock (fMCK), select the count clock, select the master/slave, select the 16 or 8-bit timer (only for channels 1 and 3), specify the start trigger and capture trigger, select the valid edge of the timer input, and specify the operation mode (interval, capture, event counter, one-count, or capture and one-count).

Rewriting the TMRmn register is prohibited when the register is in operation (when TEmn = 1). However, bits 7 and 6 (CISmn1, CISmn0) can be rewritten even while the register is operating with some functions (when TEmn = 1) (for details, see **6.7 Timer Input (TImn) Control** and **6.9 Simultaneous Channel Operation Function of Timer Array Unit**).

The TMRmn register can be set by a 16-bit memory manipulation instruction. Reset signal generation clears this register to 0000H.

Caution The bits mounted depend on the channels in bit 11 of TMRmn register. TMRm2, TMRm4, TMRm6: MASTERmn bit (n = 2, 4, 6) TMRm1, TMRm3: SPLITmn bit (n = 1, 3) TMRm0, TMRm5, TMRm7: Fixed to 0



| Address                | : F0190 | H, F019 <sup>-</sup> | 1H (TN | /IR00) to | F019E        | H, F019    | /IR07)     | Afte       | r reset:   | 0000H      | R/W |   |           |           |           |           |
|------------------------|---------|----------------------|--------|-----------|--------------|------------|------------|------------|------------|------------|-----|---|-----------|-----------|-----------|-----------|
| Symbol                 | 15      | 14                   | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5   | 4 | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 2, 4, 6) |         | CKSm<br>n0           | 0      | CCSm<br>n | MAST<br>ERmn | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0   | 0 | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                 | 15      | 14                   | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5   | 4 | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 1, 3)    | -       | CKSm<br>n0           | 0      | CCSm<br>n | SPLIT<br>mn  | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0   | 0 | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                 | 15      | 14                   | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5   | 4 | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 0, 5, 7) | -       | CKSm<br>n0           | 0      | CCSm<br>n | 0<br>Note    | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0   | 0 | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |

#### Figure 6 - 14 Format of Timer mode register mn (TMRmn) (1/4)

| CKS<br>mn1 | CKS<br>mn0                                         | Selection of operation clock (fMCK) of channel n                                                                                    |  |  |  |  |  |  |  |  |  |  |  |
|------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| 0          | 0                                                  | Operation clock CKm0 set by timer clock select register m (TPSm)                                                                    |  |  |  |  |  |  |  |  |  |  |  |
| 0          | 1                                                  | Operation clock CKm2 set by timer clock select register m (TPSm)                                                                    |  |  |  |  |  |  |  |  |  |  |  |
| 1          | 0                                                  | Operation clock CKm1 set by timer clock select register m (TPSm)                                                                    |  |  |  |  |  |  |  |  |  |  |  |
| 1          | 1                                                  | Operation clock CKm3 set by timer clock select register m (TPSm)                                                                    |  |  |  |  |  |  |  |  |  |  |  |
| depen      | iding or                                           | ick (fMCK ) is used by the edge detector. A count clock (fTCLK) and a sampling clock are generated in the setting of the CCSmn bit. |  |  |  |  |  |  |  |  |  |  |  |
| The o      | peration                                           | n clocks CKm2 and CKm3 can only be selected for channels 1 and 3.                                                                   |  |  |  |  |  |  |  |  |  |  |  |
| CC         | Smn                                                | Selection of count clock (fTCLK) of channel n                                                                                       |  |  |  |  |  |  |  |  |  |  |  |
| (          | 0                                                  | Operation clock (fмск) specified by the CKSmn0 and CKSmn1 bits                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            | Valid edge of input signal input from the TImn pin |                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |

 In channel 1, Valid edge of input signal selected by TIS0

 Count clock (fTCLK) is used for the counter, output controller, and interrupt controller.

**Note** Bit 11 is fixed at 0 of read only, write is ignored.

Caution 1. Be sure to clear bits 13, 5, and 4 to "0".

Caution 2. The timer array unit must be stopped (TTm = 00FFH) if the clock selected for fCLK is changed (by changing the value of the system clock control register (CKC)), even if the operating clock specified by using the CKSmn0 and CKSmn1 bits (fMCK) or the valid edge of the signal input from the TImn pin is selected as the count clock (fTCLK).

**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)

1



| Address                | : F0190    | H, F019    | 1H (TN | /IR00) to | F019E        | /IR07)     | Afte       | r reset:   | 0000H      | R/W        |   |   |           |           |           |           |
|------------------------|------------|------------|--------|-----------|--------------|------------|------------|------------|------------|------------|---|---|-----------|-----------|-----------|-----------|
| Symbol                 | 15         | 14         | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5 | 4 | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 2, 4, 6) |            | CKSm<br>n0 | 0      | CCSm<br>n | MAST<br>ERmn | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0 | 0 | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                 | 15         | 14         | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5 | 4 | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 1, 3)    |            | CKSm<br>n0 | 0      | CCSm<br>n | SPLIT<br>mn  | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0 | 0 | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                 | 15         | 14         | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5 | 4 | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 0, 5, 7) | CKSm<br>n1 | CKSm<br>n0 | 0      | CCSm<br>n | 0<br>Note    | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0 | 0 | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |

#### Figure 6 - 15 Format of Timer mode register mn (TMRmn) (2/4)

(Bit 11 of TMRmn (n = 2, 4, 6))

| MASTERmn                         | Selection between using channel n independently or simultaneously with another channel (as a slave or master)                                                                                                                                                                     |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                | Operates in independent channel operation function or as slave channel in simultaneous channel operation function.                                                                                                                                                                |
| 1                                | Operates as master channel in simultaneous channel operation function.                                                                                                                                                                                                            |
| Be sure to use<br>the highest ch | 2, 4, 6 can be set as a master channel (MASTERmn = 1).<br>e channel 0, 5, 7 are fixed to 0 (Regardless of the bit setting, channel 0 operates as master, because it is<br>nannel).<br>STERmn bit to 0 for a channel that is used with the independent channel operation function. |

#### (Bit 11 of TMRmn (n = 1, 3))

| SPLITmn | Selection of 8 or 16-bit timer operation for channels 1 and 3                                                                                        |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Operates as 16-bit timer.<br>(Operates in independent channel operation function or as slave channel in simultaneous channel<br>operation function.) |
| 1       | Operates as 8-bit timer.                                                                                                                             |

| STS<br>mn2 | STS<br>mn1 | STS<br>mn0 | Setting of start trigger or capture trigger of channel n                                                                                       |
|------------|------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | 0          | 0          | Only software trigger start is valid (other trigger sources are unselected).                                                                   |
| 0          | 0          | 1          | Valid edge of the TImn pin input is used as both the start trigger and capture trigger.                                                        |
| 0          | 1          | 0          | Both the edges of the TImn pin input are used as a start trigger and a capture trigger.                                                        |
| 1          | 0          | 0          | Interrupt signal of the master channel is used (when the channel is used as a slave channel with the simultaneous channel operation function). |
| Othe       | r than a   | bove       | Setting prohibited                                                                                                                             |

Note Bit 11 is fixed at 0 of read only, write is ignored.



| Address                | F0190      | H, F019    | 1H (TN | /IR00) to | F019E        | H, F019    | /R07)      | Afte       | r reset:   | 0000H      | F | R/W |           |           |           |           |
|------------------------|------------|------------|--------|-----------|--------------|------------|------------|------------|------------|------------|---|-----|-----------|-----------|-----------|-----------|
| Symbol                 | 15         | 14         | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5 | 4   | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 2, 4, 6) | CKSm<br>n1 | CKSm<br>n0 | 0      | CCSm<br>n | MAST<br>ERmn | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0 | 0   | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                 | 15         | 14         | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5 | 4   | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 1, 3)    | CKSm<br>n1 | CKSm<br>n0 | 0      | CCSm<br>n | SPLIT<br>mn  | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0 | 0   | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                 | 15         | 14         | 13     | 12        | 11           | 10         | 9          | 8          | 7          | 6          | 5 | 4   | 3         | 2         | 1         | 0         |
| TMRmn<br>(n = 0, 5, 7) | CKSm<br>n1 | CKSm<br>n0 | 0      | CCSm<br>n | 0<br>Note    | STSm<br>n2 | STSm<br>n1 | STSm<br>n0 | CISmn<br>1 | CISmn<br>0 | 0 | 0   | MDmn<br>3 | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |

### Figure 6 - 16 Format of Timer mode register mn (TMRmn) (3/4)

| CIS     | CIS                 | Selection of TImn pin input valid edge (n = 0, 1)                                                   |  |  |  |  |  |  |  |  |  |  |
|---------|---------------------|-----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| mn1     | mn0                 |                                                                                                     |  |  |  |  |  |  |  |  |  |  |
| 0       | 0                   | Falling edge                                                                                        |  |  |  |  |  |  |  |  |  |  |
| 0       | 1                   | Rising edge                                                                                         |  |  |  |  |  |  |  |  |  |  |
| 1       | 0                   | Both edges (when low-level width is measured)                                                       |  |  |  |  |  |  |  |  |  |  |
|         |                     | Start trigger: Falling edge, Capture trigger: Rising edge                                           |  |  |  |  |  |  |  |  |  |  |
| 1       | 1                   | Both edges (when high-level width is measured)                                                      |  |  |  |  |  |  |  |  |  |  |
|         |                     | Start trigger: Rising edge, Capture trigger: Falling edge                                           |  |  |  |  |  |  |  |  |  |  |
| If both | the edg             | ges are specified when the value of the STSmn2 to STSmn0 bits is other than 010B, set the CISmn1 to |  |  |  |  |  |  |  |  |  |  |
| CISmr   | CISmn0 bits to 10B. |                                                                                                     |  |  |  |  |  |  |  |  |  |  |

Note Bit 11 is fixed at 0 of read only, write is ignored.



| Address               | ldress: F0190H, F0191H (TMR00) to F019EH, F019FH (TMR07) After reset: 0000H R/W |                   |                 |                  |                             |              |             |                                                                                                                                                               |            |                     |                        |           |               |                       |           |           |           |
|-----------------------|---------------------------------------------------------------------------------|-------------------|-----------------|------------------|-----------------------------|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------|------------------------|-----------|---------------|-----------------------|-----------|-----------|-----------|
| Symbol                | 15                                                                              | 1                 | 14              | 13               | 12                          | 11           | 10          | 9                                                                                                                                                             | 8          | 7                   | 6                      | 5         | 4             | 3                     | 2         | 1         | 0         |
| TMRmn<br>n = 2, 4, 6) | CKSı<br>n1                                                                      |                   | (Sm<br>n0       | 0                | CCSm<br>n                   | MAST<br>ERmn | STSm<br>n2  | STSm<br>n1                                                                                                                                                    | STSm<br>n0 | CISmn<br>1          | CISmn<br>0             | 0         | 0             | MDmn<br>3             | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                | 15                                                                              | 1                 | 14              | 13               | 12                          | 11           | 10          | 9                                                                                                                                                             | 8          | 7                   | 6                      | 5         | 4             | 3                     | 2         | 1         | 0         |
| TMRmn<br>(n = 1, 3)   | CKSı<br>n1                                                                      |                   | (Sm<br>n0       | 0                | CCSm<br>n                   | SPLIT<br>mn  | STSm<br>n2  | STSm<br>n1                                                                                                                                                    | STSm<br>n0 | CISmn<br>1          | CISmn<br>0             | 0         | 0             | MDmn<br>3             | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
| Symbol                | 15                                                                              | 1                 | 14              | 13               | 12                          | 11           | 10          | 9                                                                                                                                                             | 8          | 7                   | 6                      | 5         | 4             | 3                     | 2         | 1         | 0         |
| TMRmn<br>n = 0, 5, 7) | CKSı<br>n1                                                                      |                   | (Sm<br>n0       | 0                | CCSm<br>n                   | 0<br>Note 1  | STSm<br>n2  | STSm<br>n1                                                                                                                                                    | STSm<br>n0 | CISmn<br>1          | CISmn<br>0             | 0         | 0             | MDmn<br>3             | MDmn<br>2 | MDmn<br>1 | MDmn<br>0 |
|                       | MD<br>mn3                                                                       | MD<br>mn2         | MD<br>mn1       | 0                | peration                    | mode         | of chan     | nel n                                                                                                                                                         | (          | Corresp             | onding f               | unction   |               | Cour                  | nt opera  | tion of 1 | FCR       |
|                       | 0                                                                               | 0                 | 0               | Inter            | val time                    | r mode       |             |                                                                                                                                                               |            |                     | / Square<br>output (   |           | )             | Countin               | g down    |           |           |
|                       | 0<br>0                                                                          | 1<br>1            | 0               | · ·              | ure moo<br>nt counte        |              | •           |                                                                                                                                                               |            |                     | terval m<br>t counte   |           | nent          | Countin<br>Countin    |           |           |           |
|                       | 1 0 0 One-count mode                                                            |                   |                 |                  |                             |              |             |                                                                                                                                                               | -          |                     | / One-s<br>output (    |           | Counting down |                       |           |           |           |
|                       | 1                                                                               | 1                 | 0               | Capt             | ure & oi                    | ne-cour      | it mode     |                                                                                                                                                               |            | irement<br>of input | ∶of high-<br>signal    | /low-le   | /el           | Countin               | g up      |           |           |
|                       |                                                                                 | r than a<br>opera |                 |                  | ng prohi<br>n mode v        |              | ependir     | ng on M                                                                                                                                                       | Dmn0 t     | oit (see            | the table              | e below)  | ).            |                       |           |           |           |
|                       | (Val                                                                            |                   | t by the        |                  | mode<br>n3 to MD<br>above)) | mn1 bits     | , MDi<br>n0 |                                                                                                                                                               |            | Set                 | ting of s              | tarting c | ountir        | ng and in             | terrupt   |           |           |
|                       |                                                                                 |                   | timer ı<br>mode |                  | (0, 0, 0)<br>0)             |              | 0           |                                                                                                                                                               |            |                     | ot gener<br>not char   |           |               | unting is             | started   |           |           |
|                       |                                                                                 |                   |                 |                  |                             |              | 1           |                                                                                                                                                               |            |                     | enerateo<br>hanges)    |           | countii       | ng is star            | ted       |           |           |
|                       |                                                                                 |                   |                 |                  | e (0, 1, 1                  | -            | 0           | (time                                                                                                                                                         | er outpu   | t does r            | not chan               | ge, eith  | er).          | unting is             | started   |           |           |
|                       | • On                                                                            | e-cou             | int mo          | de <sup>No</sup> | <sup>te 2</sup> (1, C       | , 0)         | 0           | At th                                                                                                                                                         | at time    | interru             | id durino<br>pt is not | genera    | ted, ei       | ther.                 |           |           |           |
|                       |                                                                                 |                   |                 |                  |                             | · · · ·      | 1           | At th                                                                                                                                                         | at time    | interru             | pt is not              | genera    | ted.          | ation <sup>Note</sup> |           |           |           |
|                       | • Ca                                                                            | pture             | & one           | -cour            | it mode                     | (1, 1, 0)    | ) 0         | 0 Timer interrupt is not generated when counting is started<br>(timer output does not change, either).<br>Start trigger is invalid during counting operation. |            |                     |                        |           |               |                       |           |           |           |
|                       |                                                                                 |                   |                 |                  |                             |              |             | At th                                                                                                                                                         | at time    | interrup            | ot is not              | generat   | ed, eit       | her.                  |           |           |           |

#### Figure 6 - 17 Format of Timer mode register mn (TMRmn) (4/4)

Note 1. Bit 11 is fixed at 0 of read only, write is ignored.

**Note 2.** In one-count mode, interrupt output (INTTMmn) when starting a count operation and TOmn output are not controlled.

**Note 3.** If the start trigger (TSmn = 1) is issued during operation, the counter is initialized, an interrupt is generated, and recounting is started (does not occur the interrupt request).

## 6.3.4 Timer status register mn (TSRmn)

The TSRmn register indicates the overflow status of the counter of channel n.

The TSRmn register is valid only in the capture mode (MDmn3 to MDmn1 = 010B) and capture & one-count mode (MDmn3 to MDmn1 = 110B). See **Table 6 - 5** for the operation of the OVF bit in each operation mode and set/clear conditions.

The TSRmn register can be read by a 16-bit memory manipulation instruction.

The lower 8 bits of the TSRmn register can be set with an 8-bit memory manipulation instruction with TSRmnL. Reset signal generation clears this register to 0000H.

#### Figure 6 - 18 Format of Timer status register mn (TSRmn)

| Address: | : F01A(                                  | )H, F01, | A1H (ፐና    | 3R00) to  | ა F01AE  | EH, F01 | AFH (T | SR07)   | Afte    | r reset: | 0000H     | R       |         |   |   |     |
|----------|------------------------------------------|----------|------------|-----------|----------|---------|--------|---------|---------|----------|-----------|---------|---------|---|---|-----|
| Symbol   | 15                                       | 14       | 13         | 12        | 11       | 10      | 9      | 8       | 7       | 6        | 5         | 4       | 3       | 2 | 1 | 0   |
| TSRmn    | 0                                        | 0        | 0          | 0         | 0        | 0       | 0      | 0       | 0       | 0        | 0         | 0       | 0       | 0 | 0 | OVF |
| ļ        | OVF Counter overflow status of channel n |          |            |           |          |         |        |         |         |          |           |         |         |   |   | ]   |
| ļ        | 0                                        | Overflc  | w does     | s not occ | our.     |         |        |         |         |          |           |         |         |   |   |     |
| Ī        | 1 Overflow occurs.                       |          |            |           |          |         |        |         |         |          |           |         |         |   |   |     |
| ļ        | When                                     | OVF =    | 1, this fl | ag is cle | eared (C | OVF = 0 | ) when | the nex | t value | is captu | ired with | out ove | erflow. |   |   |     |

**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)

#### Table 6 - 5 OVF Bit Operation and Set/Clear Conditions in Each Operation Mode

| Timer operation mode                  | OVF bit | Set/clear conditions                         |
|---------------------------------------|---------|----------------------------------------------|
| Capture mode                          | clear   | When no overflow has occurred upon capturing |
| Capture & one-count mode              | set     | When an overflow has occurred upon capturing |
| Interval timer mode                   | clear   | _                                            |
| Event counter mode     One-count mode | set     | (Use prohibited)                             |

Remark The OVF bit does not change immediately after the counter has overflowed, but changes upon the subsequent capture.



### 6.3.5 Timer channel enable status register m (TEm)

The TEm register is used to enable or stop the timer operation of each channel.

Each bit of the TEm register corresponds to each bit of the timer channel start register m (TSm) and the timer channel stop register m (TTm). When a bit of the TSm register is set to 1, the corresponding bit of this register is set to 1. When a bit of the TTm register is set to 1, the corresponding bit of this register is cleared to 0.

The TEm register can be read by a 16-bit memory manipulation instruction.

The lower 8 bits of the TEm register can be set with a 1-bit or 8-bit memory manipulation instruction with TEmL. Reset signal generation clears this register to 0000H.

Figure 6 - 19 Format of Timer channel enable status register m (TEm)

| Address: | : F01B(   | )H, F01 | B1H               | 1       | After res | et: 000  | )0H       | R       |                     |          |           |          |         |          |          |       |
|----------|-----------|---------|-------------------|---------|-----------|----------|-----------|---------|---------------------|----------|-----------|----------|---------|----------|----------|-------|
| Symbol   | 15        | 14      | 13                | 12      | 11        | 10       | 9         | 8       | 7                   | 6        | 5         | 4        | 3       | 2        | 1        | 0     |
| TEm      | 0         | 0       | 0                 | 0       | TEHm<br>3 | 0        | TEHm<br>1 | 0       | TEm7                | TEm6     | TEm5      | TEm4     | TEm3    | TEm2     | TEm1     | TEm0  |
| -        | TEH<br>m3 | Indic   | ation of          | whethe  | er opera  | tion of  | the highe |         | timer is<br>mer moo |          | d or sto  | pped wł  | hen cha | nnel 3 i | s in the | 8-bit |
|          | 0         | Operat  | tion is st        | topped. |           |          |           |         |                     |          |           |          |         |          |          |       |
|          | 1         | Operat  | ation is enabled. |         |           |          |           |         |                     |          |           |          |         |          |          |       |
| -<br>1   |           |         | ation is enabled. |         |           |          |           |         |                     |          |           |          |         |          |          |       |
|          | TEH<br>m1 | Indic   | ation of          | whethe  | r operat  | lion of  | the highe |         | timer is<br>mer moo |          | d or sto  | pped wh  | nen cha | nnel 1 i | s in the | 8-bit |
|          | 0         | Operat  | tion is st        | topped. |           |          |           |         |                     |          |           |          |         |          |          |       |
|          | 1         | Operat  | tion is er        | nabled. |           |          |           |         |                     |          |           |          |         |          |          |       |
|          |           |         |                   |         |           |          |           |         |                     |          |           |          |         |          |          |       |
|          | TEm<br>n  |         |                   |         | h         | ndicatio | on of ope | eration | enable/s            | stop sta | tus of cl | hannel r | ก       |          |          |       |
|          | 0         | Operat  | tion is st        | topped. |           |          |           |         |                     |          |           |          |         |          |          |       |
|          | 1         | Operat  | tion is er        | nabled. |           |          |           |         |                     | -        | -         | -        | -       | -        | -        | -     |

This bit displays whether operation of the lower 8-bit timer for TEm1 and TEm3 is enabled or stopped when channel 1 or 3 is in the 8-bit timer mode.



# 6.3.6 Timer channel start register m (TSm)

The TSm register is a trigger register that is used to initialize timer count register mn (TCRmn) and start the counting operation of each channel.

When a bit of this register is set to 1, the corresponding bit of timer channel enable status register m (TEm) is set to 1. The TSmn, TSHm1, TSHm3 bits are immediately cleared when operation is enabled (TEmn, TEHm1, TEHm3 = 1), because they are trigger bits.

The TSm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the TSm register can be set with a 1-bit or 8-bit memory manipulation instruction with TSmL. Reset signal generation clears this register to 0000H.

Figure 6 - 20 Format of Timer channel start register m (TSm)

| Address: | F01B2     | 2H, F01E                                                                                                                                                                                                                                                                                                                                                                                                                        | 33H                                                                                                                                                                                                                                                                                   | /        | After rese | et: 000 | D0H                                    | R/W     |            |           |         |         |            |           |          |      |
|----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|---------|----------------------------------------|---------|------------|-----------|---------|---------|------------|-----------|----------|------|
| Symbol   | 15        | 14                                                                                                                                                                                                                                                                                                                                                                                                                              | 13                                                                                                                                                                                                                                                                                    | 12       | 11         | 10      | 9                                      | 8       | 7          | 6         | 5       | 4       | 3          | 2         | 1        | 0    |
| TSm      | 0         | 0                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                     | 0        | TSHm<br>3  | 0       | TSHm<br>1                              | 0       | TSm7       | TSm6      | TSm5    | TSm4    | TSm3       | TSm2      | TSm1     | TSm0 |
|          | TSH<br>m3 | Trigge                                                                                                                                                                                                                                                                                                                                                                                                                          | r to ena                                                                                                                                                                                                                                                                              | ble ope  | eration (s | tart o  | peration)                              | of the  | higher 8   | -bit time | er when | channe  | el 3 is in | 1 the 8-b | it timer | mode |
|          | 0         | No trigg                                                                                                                                                                                                                                                                                                                                                                                                                        | ger oper                                                                                                                                                                                                                                                                              | ation    |            |         |                                        |         |            |           |         |         |            |           |          |      |
|          | 1         | The TC                                                                                                                                                                                                                                                                                                                                                                                                                          | Rm3 re                                                                                                                                                                                                                                                                                | gister o | count ope  | eratio  | ount oper<br>n start in t<br>counter). | the int |            |           |         | count o | peratior   | n enable  | ed state | (see |
|          | TSH<br>m1 |                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                       |          |            |         |                                        |         |            |           |         |         |            |           |          |      |
|          | 0         | No trigg                                                                                                                                                                                                                                                                                                                                                                                                                        | trigger operation                                                                                                                                                                                                                                                                     |          |            |         |                                        |         |            |           |         |         |            |           |          |      |
|          | 1         | The TC                                                                                                                                                                                                                                                                                                                                                                                                                          | <ul> <li>b trigger operation</li> <li>be TEHm1 bit is set to 1 and the count operation becomes enabled.</li> <li>be TCRm1 register count operation start in the interval timer mode in the count operation enabled state (see ble 6 - 6 in 6.5.2 Start timing of counter).</li> </ul> |          |            |         |                                        |         |            |           |         |         |            |           |          |      |
|          | TSm<br>n  |                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                       |          |            | O       | peration e                             | enable  | (start) tr | igger of  | fchanne | el n    |            |           |          |      |
|          | 0         | No trigg                                                                                                                                                                                                                                                                                                                                                                                                                        | ger oper                                                                                                                                                                                                                                                                              | ation    |            |         |                                        |         |            |           |         |         |            |           |          |      |
|          | 1         | The TEmn bit is set to 1 and the count operation becomes enabled.<br>The TCRmn register count operation start in the count operation enabled state varies depending on each<br>operation mode (see <b>Table 6 - 6</b> in <b>6.5.2 Start timing of counter</b> ).<br>This bit is the trigger to enable operation (start operation) of the lower 8-bit timer for TSm1 and TSm3 when<br>channel 1 or 3 is in the 8-bit timer mode. |                                                                                                                                                                                                                                                                                       |          |            |         |                                        |         |            |           |         |         |            |           |          |      |

Caution 1. Be sure to clear bits 15 to 12, 10, and 8 to "0".

Caution 2. When switching from a function that does not use TImn pin input to one that does, the following wait period is required from when timer mode register mn (TMRmn) is set until the TSmn (TSHm1, TSHm3) bit is set to 1.

When the TImn pin noise filter is enabled (TNFENmn = 1): Four cycles of the operation clock (fMCK) When the TImn pin noise filter is disabled (TNFENmn = 0): Two cycles of the operation clock (fMCK)

Remark 1. When the TSm register is read, 0 is always read.



TTm7 TTm6 TTm5 TTm4 TTm3 TTm2 TTm1 TTm0

0

TTm

0

# 6.3.7 Timer channel stop register m (TTm)

0

0

0

3

The TTm register is a trigger register that is used to stop the counting operation of each channel.

When a bit of this register is set to 1, the corresponding bit of timer channel enable status register m (TEm) is cleared to 0. The TTmn, TTHm1, TTHm3 bits are immediately cleared when operation is stopped (TEmn, TEHm1, TEHm3 = 0), because they are trigger bits.

The TTm register can be set by a 16-bit memory manipulation instruction.

0

The lower 8 bits of the TTm register can be set with a 1-bit or 8-bit memory manipulation instruction with TTmL. Reset signal generation clears this register to 0000H.

|          |       |         | 9   |    |            |         |      |     |       |      | ••••• | ,    |      |      |           |
|----------|-------|---------|-----|----|------------|---------|------|-----|-------|------|-------|------|------|------|-----------|
| Address: | F01B4 | 4H, F01 | B5H |    | After rese | et: 000 | ЮH   | R/W |       |      |       |      |      |      |           |
| Symbol   | 15    | 14      | 13  | 12 | 11         | 10      | 9    | 8   | 7     | 6    | 5     | 4    | 3    | 2    | 1         |
|          | 0     | 0       | 0   | 0  | TTHm       | 0       | TTHm | 0   | TT: 7 | TTmC | TTmr  | TTmA | TT 0 | TT:0 | <b>TT</b> |

1

0

#### Figure 6 - 21 Format of Timer channel stop register m (TTm)

| TTH<br>m3 | Trigger to stop operation of the higher 8-bit timer when channel 3 is in the 8-bit timer mode |
|-----------|-----------------------------------------------------------------------------------------------|
| 0         | No trigger operation                                                                          |
| 1         | TEHm3 bit is cleared to 0 and the count operation is stopped.                                 |
|           |                                                                                               |
| TTH       |                                                                                               |

| TTH<br>m1 | Trigger to stop operation of the higher 8-bit timer when channel 1 is in the 8-bit timer mode |
|-----------|-----------------------------------------------------------------------------------------------|
| 0         | No trigger operation                                                                          |
| 1         | TEHm1 bit is cleared to 0 and the count operation is stopped.                                 |

| TTm<br>n | Operation stop trigger of channel n                                                                                                                                                                     |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | No trigger operation                                                                                                                                                                                    |
| 1        | TEmn bit is cleared to 0 and the count operation is stopped.<br>This bit is the trigger to stop operation of the lower 8-bit timer for TTm1 and TTm3 when channel 1 or 3 is in the<br>8-bit timer mode. |

Caution Be sure to clear bits 15 to 12, 10, and 8 of the TTm register to "0".

**Remark 1.** When the TTm register is read, 0 is always read.



# 6.3.8 Timer input select register 0 (TIS0)

The TIS0 register is used to select the channel 0 and 1 timer input. The TIS0 register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 6 - 22 Format of Timer input select register 0 (TIS0)

| Address: | F0074H | After reset: 00H | l R/W |                 |                  |                          |                |       |
|----------|--------|------------------|-------|-----------------|------------------|--------------------------|----------------|-------|
| Symbol   | 7      | 6                | 5     | 4               | 3                | 2                        | 1              | 0     |
| TIS0     | 0      | 0                | 0     | 0               | 0                | TIS02                    | TIS01          | TIS00 |
| r        |        | · · · · ·        |       |                 |                  |                          |                |       |
|          | TIS02  | TIS01            | TIS00 |                 | Selection of ti  | mer input used           | with channel 1 |       |
|          | 0      | 0                | 0     | Input signal of | timer input pir  | n (TI01)                 |                |       |
|          | 0      | 0                | 1     |                 |                  |                          |                |       |
|          | 0      | 1                | 0     |                 |                  |                          |                |       |
|          | 0      | 1                | 1     |                 |                  |                          |                |       |
|          | 1      | 0                | 0     | Low-speed on    | -chip oscillator | <sup>-</sup> clock (fi∟) |                |       |
|          | (      | Other than above | 9     | Setting prohib  | ited             |                          |                |       |

Caution At least 1/fMCK + 10 ns is necessary as the high-level and low-level widths of the timer input to be selected.



# 6.3.9 Timer output enable register m (TOEm)

The TOEm register is used to enable or disable timer output of each channel.

Channel n for which timer output has been enabled becomes unable to rewrite the value of the TOmn bit of timer output register m (TOm) described later by software, and the value reflecting the setting of the timer output function through the count operation is output from the timer output pin (TOmn).

The TOEm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the TOEm register can be set with a 1-bit or 8-bit memory manipulation instruction with TOEmL.

Reset signal generation clears this register to 0000H.

| Address | : F01BA | AH, F011 | BBH                                      | A        | After res  | et: 000 | 0H        | R/W      |           |            |           |           |           |           |           |           |
|---------|---------|----------|------------------------------------------|----------|------------|---------|-----------|----------|-----------|------------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol  | 15      | 14       | 13                                       | 12       | 11         | 10      | 9         | 8        | 7         | 6          | 5         | 4         | 3         | 2         | 1         | 0         |
| TOEm    | 0       | 0        | 0                                        | 0        | 0          | 0       | 0         | 0        | TOEm<br>7 | TOEm<br>6  | TOEm<br>5 | TOEm<br>4 | TOEm<br>3 | TOEm<br>2 | TOEm<br>1 | TOEm<br>0 |
| -       |         |          |                                          |          |            |         |           |          |           |            |           |           |           |           |           |           |
|         | TOE     |          | Timer output enable/disable of channel n |          |            |         |           |          |           |            |           |           |           |           |           |           |
|         | mn      |          |                                          |          |            |         |           |          |           |            |           |           |           |           |           |           |
|         | 0       | Timer o  | mer output is disabled.                  |          |            |         |           |          |           |            |           |           |           |           |           |           |
|         |         | Timer o  | peratio                                  | n is not | applied    | to the  | TOmn b    | it and t | he outpu  | ıt is fixe | ed.       |           |           |           |           |           |
|         |         | Writing  | to the 1                                 | ГOmn b   | it is ena  | bled ar | nd the le | evel set | in the T  | Omn bi     | t is outp | ut from   | the TO    | mn pin.   |           |           |
|         | 1       | Timer o  | output is                                | s enable | d.         |         |           |          |           |            |           |           |           |           |           |           |
|         |         | Timer c  | peratio                                  | n is app | lied to t  | he TOr  | nn bit ai | nd an o  | utput wa  | veform     | is gene   | erated.   |           |           |           |           |
|         |         | Writing  | to the T                                 | TOmn b   | it is igno | ored.   |           |          |           |            |           |           |           |           |           |           |

#### Figure 6 - 23 Format of Timer output enable register m (TOEm)

Caution Be sure to clear bits 15 to 8 to "0".



# 6.3.10 Timer output register m (TOm)

The TOm register is a buffer register of timer output of each channel.

The value of each bit in this register is output from the timer output pin (TOmn) of each channel.

The TOmn bit of this register can be rewritten by software only when timer output is disabled (TOEmn = 0). When timer output is enabled (TOEmn = 1), rewriting this register by software is ignored, and the value is changed only by the timer operation.

To use the P51/TI00/TO00, P52/TI01/TO01, P53/TI02/TO02, P54/TI03/TO03, P55/TI04/TO04, P00/TI05/TO05, P01/TI06/TO06, P74/TI07/TO07 pin as a port function pin, set the corresponding TOmn bit to "0".

The TOm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the TOm register can be set with an 8-bit memory manipulation instruction with TOmL. Reset signal generation clears this register to 0000H.

Figure 6 - 24 Format of Timer output register m (TOm)

| Address | : F01B8 | 3H, F01E                   | 39H      | A         | After res | ress: F01B8H, F01B9H After reset: 0000H<br>nbol 15 14 13 12 11 10 9 |    |         |           |        |      |      |      |      |      |      |
|---------|---------|----------------------------|----------|-----------|-----------|---------------------------------------------------------------------|----|---------|-----------|--------|------|------|------|------|------|------|
| Symbol  | 15      | 14                         | 13       | 12        | 11        | 10                                                                  | 9  | 8       | 7         | 6      | 5    | 4    | 3    | 2    | 1    | 0    |
| TOm     | 0       | 0                          | 0        | 0         | 0         | 0                                                                   | 0  | 0       | TOm7      | TOm6   | TOm5 | TOm4 | TOm3 | TOm2 | TOm1 | TOm0 |
|         | TOm     |                            |          |           |           |                                                                     |    |         |           |        |      |      |      |      |      |      |
|         | n       |                            |          |           |           |                                                                     | Ti | imer ou | tput of c | hannel | n    |      |      |      |      |      |
|         | 0       | Timer o                    | output v | alue is ' | '0".      |                                                                     |    |         |           |        |      |      |      |      |      |      |
|         | 1       | Timer output value is "1". |          |           |           |                                                                     |    |         |           |        |      |      |      |      |      |      |

Caution Be sure to clear bits 15 to 8 to "0".



# 6.3.11 Timer output level register m (TOLm)

The TOLm register is a register that controls the timer output level of each channel.

The setting of the inverted output of channel n by this register is reflected at the timing of set or reset of the timer output signal while the timer output is enabled (TOEmn = 1) in the Slave channel output mode (TOMmn = 1). In the master channel output mode (TOMmn = 0), this register setting is invalid.

The TOLm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the TOLm register can be set with an 8-bit memory manipulation instruction with TOLmL. Reset signal generation clears this register to 0000H.

| Address: | F01B0     | CH, F01  | BDH                                | A      | After res | et: 0000 | ЭН       | R/W     |           |           |           |           |           |           |           |   |
|----------|-----------|----------|------------------------------------|--------|-----------|----------|----------|---------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---|
| Symbol   | 15        | 14       | 13                                 | 12     | 11        | 10       | 9        | 8       | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0 |
| TOLm     | 0         | 0        | 0                                  | 0      | 0         | 0        | 0        | 0       | TOLm<br>7 | TOLm<br>6 | TOLm<br>5 | TOLm<br>4 | TOLm<br>3 | TOLm<br>2 | TOLm<br>1 | 0 |
|          | TOL<br>mn |          |                                    |        |           | С        | ontrol o | f timer | output le | evel of c | hannel    | n         |           |           |           |   |
|          | 0         | Positive | psitive logic output (active-high) |        |           |          |          |         |           |           |           |           |           |           |           |   |
|          | 1         | Negativ  | /e logic                           | output | (active-  | ow)      |          |         |           |           |           |           |           |           |           |   |

#### Figure 6 - 25 Format of Timer output level register m (TOLm)

Caution Be sure to clear bits 15 to 8, and 0 to "0".

**Remark 1.** If the value of this register is rewritten during timer operation, the timer output logic is inverted when the timer output signal changes next, instead of immediately after the register value is rewritten.



# 6.3.12 Timer output mode register m (TOMm)

The TOMm register is used to control the timer output mode of each channel.

When a channel is used for the independent channel operation function, set the corresponding bit of the channel to be used to 0.

When a channel is used for the simultaneous channel operation function (PWM output, one-shot pulse output, or multiple PWM output), set the corresponding bit of the master channel to 0 and the corresponding bit of the slave channel to 1.

The setting of each channel n by this register is reflected at the timing when the timer output signal is set or reset while the timer output is enabled (TOEmn = 1).

The TOMm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the TOMm register can be set with an 8-bit memory manipulation instruction with TOMmL. Reset signal generation clears this register to 0000H.

#### Figure 6 - 26 Format of Timer output mode register m (TOMm)

| Address: | F01BE | H, F01I | BFH | A  | After res | et: 0000 | ЭH | R/W |           |           |           |           |           |           |           |   |
|----------|-------|---------|-----|----|-----------|----------|----|-----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---|
| Symbol   | 15    | 14      | 13  | 12 | 11        | 10       | 9  | 8   | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0 |
| TOMm     | 0     | 0       | 0   | 0  | 0         | 0        | 0  | 0   | TOMm<br>7 | TOMm<br>6 | TOMm<br>5 | TOMm<br>4 | TOMm<br>3 | TOMm<br>2 | TOMm<br>1 | 0 |

| TOM<br>mn | Control of timer output mode of channel n                                                                                                                                                       |  |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|           |                                                                                                                                                                                                 |  |  |  |  |  |  |
| 0         | Master channel output mode (to produce toggle output by timer interrupt request signal (INTTMmn)                                                                                                |  |  |  |  |  |  |
| 1         | Slave channel output mode (output is set by the timer interrupt request signal (INTTMmn) of the master channel, and reset by the timer interrupt request signal (INTTM0p) of the slave channel) |  |  |  |  |  |  |

Caution Be sure to clear bits 15 to 8, and 0 to "0".

Remark m: Unit number (m = 0) n: Channel number

n = 0 to 7 (n = 0, 2, 4, 6 for master channel)

p: Slave channel number

n < p ≤ 7

(For details of the relation between the master channel and slave channel, refer to **6.4.1 Basic rules of simultaneous channel operation function**.)



# 6.3.13 Noise filter enable register 1 (NFEN1)

The NFEN1 register is used to set whether the noise filter can be used for the timer input signal to each channel. Enable the noise filter by setting the corresponding bits to 1 on the pins in need of noise removal. When the noise filter is enabled, after synchronization with the operating clock (fMCK) for the target channel, whether the signal keeps the same value for two clock cycles is detected. When the noise filter is disabled, the input signal is only synchronized with the operating clock (fMCK) for the target channel <sup>Note</sup>. The NFEN1 register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

# Note For details, see 6.5.1 (2) When valid edge of input signal via the Timn pin is selected (CCSmn = 1), 6.5.2 Start timing of counter, and 6.7 Timer Input (Timn) Control.



| Address: F0071H    |                    | After reset: 00I | H R/W   |                   |                   |                  |         |         |
|--------------------|--------------------|------------------|---------|-------------------|-------------------|------------------|---------|---------|
| Symbol             | 7                  | 6                | 5       | 4                 | 3                 | 2                | 1       | 0       |
| NFEN1              | TNFEN07            | TNFEN06          | TNFEN05 | TNFEN04           | TNFEN03           | TNFEN02          | TNFEN01 | TNFEN00 |
| Γ                  | TNFEN07            |                  |         | Enable/disable    | e using noise fil | ter of TI07 pin  |         |         |
| Ē                  | 0 Noise filter OFF |                  |         |                   |                   |                  |         |         |
| Ē                  | 1                  | Noise filter ON  |         |                   |                   |                  |         |         |
| Г                  | TNFEN06            |                  | Enal    | ole/disable using | g noise filter of | TI06 pin input s | signal  |         |
| ŀ                  | 0 Noise filter OFF |                  |         |                   |                   |                  |         |         |
|                    | 1                  | Noise filter ON  |         |                   |                   |                  |         |         |
| Г                  | TNFEN05            |                  | Enal    | ble/disable using | g noise filter of | TI05 pin input s | signal  |         |
| F                  | 0 Noise filter OFF |                  |         |                   |                   |                  |         |         |
| -                  | 1                  | Noise filter ON  |         |                   |                   |                  |         |         |
| -<br>r             | TNFEN04            |                  | Enal    | ble/disable using | g noise filter of | TI04 pin input s | signal  |         |
| F                  | 0                  | Noise filter OF  |         |                   | <u> </u>          |                  | 0       |         |
| -                  | 1                  | Noise filter ON  |         |                   |                   |                  |         |         |
| Г                  | TNFEN03            |                  | Enal    | ble/disable using | g noise filter of | TI03 pin input s | signal  |         |
| F                  | 0                  | Noise filter OF  | F       |                   |                   |                  |         |         |
| Ē                  | 1                  | Noise filter ON  |         |                   |                   |                  |         |         |
| Γ                  | TNFEN02            |                  | Enal    | ble/disable using | g noise filter of | TI02 pin input s | signal  |         |
| F                  | 0                  | Noise filter OF  |         |                   | -                 |                  | -       |         |
| -                  | 1                  | Noise filter ON  | l       |                   |                   |                  |         |         |
| -<br>Г             | TNFEN01            |                  | Enal    | ble/disable using | q noise filter of | TI01 pin input s | signal  |         |
| 0 Noise filter OFF |                    |                  |         |                   | -                 |                  | -       |         |
| F                  | 1                  | Noise filter ON  |         |                   |                   |                  |         |         |
| -<br>F             | TNFEN00            |                  | Enal    | ble/disable using | q noise filter of | TI00 pin input s | signal  |         |
| ŀ                  | 0                  | Noise filter OF  |         |                   |                   |                  | ~       |         |
| F                  | 1                  | Noise filter ON  |         |                   |                   |                  |         |         |

### Figure 6 - 27 Format of Noise filter enable register 1 (NFEN1)



# 6.3.14 Registers that control port functions of timer input/output pins

Using the timer array unit requires setting of the registers that control the port functions for the port pins with which the timer array unit pin functions for the target channel are multiplexed (port mode register (PMxx), port register (Pxx), and port mode control register (PMCxx)). For details, see **4.3.1 Port mode registers (PMxx)**, **4.3.2 Port registers (Pxx)**, and **4.3.6 Port mode control registers (PMCxx)**.

The port mode register (PMxx), port register (Pxx), and port mode control register (PMCxx) to be set depend on the product. For details, see **4.5.3 Register setting examples for used port and alternate functions**.

Using a port pin which is multiplexed with a timer output pin function (e.g. P51/TI00/TO00, P53/TI02/TO02) for timer output requires setting the corresponding bits in the port mode register (PMxx) and port register (Pxx) to 0.

Example When P53/T002/TI02 is to be used for timer output Set the PM53 bit of port mode register 0 to 0. Set the P53 bit of port register 0 to 0.

Using a port pin which is multiplexed with a timer input pin function (e.g. P51/TI00/TO00, P53/TI02/TO02) for timer input requires setting the corresponding bit in the port mode register (PMxx) to 1. At this time, the value of the corresponding bit in the port register (Pxx) may be 0 or 1.

- Example When P53/TO02/TI02 is to be used for timer input Set the PM53 bit of port mode register 0 to 1. Set the P53 bit of port register 0 to 0 or 1.
- **Remark** The P00/TI05/TO05/ANI16 and P01/TI06/TO06 pins are multiplexed with an analog input pin function. When using the timer I/O function, be sure to set the corresponding bit of the PMC0 register which switches between digital I/O and analog input to "0".



# 6.4 Basic Rules of Timer Array Unit

## 6.4.1 Basic rules of simultaneous channel operation function

When simultaneously using multiple channels, namely, a combination of a master channel (a reference timer mainly counting the cycle) and slave channels (timers operating according to the master channel), the following rules apply.

- (1) Only an even channel (channel 0, 2, 4, etc.) can be set as a master channel.
- (2) Any channel, except channel 0, can be set as a slave channel.
- (3) The slave channel must be lower than the master channel.

Example If channel 2 is set as a master channel, channel 3 or those that follow (channels 3, 4, 5, etc.) can be set as a slave channel.

- (4) Two or more slave channels can be set for one master channel.
- (5) When two or more master channels are to be used, slave channels with a master channel between them may not be set.

Example If channels 0 and 4 are set as master channels, channels 1 to 3 can be set as the slave channels of master channel 0. Channels 5 to 7 cannot be set as the slave channels of master channel 0.

- (6) The operating clock for a slave channel in combination with a master channel must be the same as that of the master channel. The CKSmn0, CKSmn1 bits (bit 15, 14 of timer mode register mn (TMRmn)) of the slave channel that operates in combination with the master channel must be the same value as that of the master channel.
- (7) A master channel can transmit INTTMmn (interrupt), start software trigger, and count clock to the lower channels.
- (8) A slave channel can use INTTMmn (interrupt), a start software trigger, or the count clock of the master channel as a source clock, but cannot transmit its own INTTMmn (interrupt), start software trigger, or count clock to channels with lower channel numbers.
- (9) A master channel cannot use INTTMmn (interrupt), a start software trigger, or the count clock from the other higher master channel as a source clock.
- (10) To simultaneously start channels that operate in combination, the channel start trigger bit (TSmn) of the channels in combination must be set at the same time.
- (11) During the counting operation, a TSmn bit of a master channel or TSmn bits of all channels which are operating simultaneously can be set. It cannot be applied to TSmn bits of slave channels alone.
- (12) To stop the channels in combination simultaneously, the channel stop trigger bit (TTmn) of the channels in combination must be set at the same time.
- (13) CKm2/CKm3 cannot be selected while channels are operating simultaneously, because the operating clocks of master channels and slave channels have to be synchronized.
- (14) Timer mode register m0 (TMRm0) has no master bit (it is fixed as "0"). However, as channel 0 is the highest channel, it can be used as a master channel during simultaneous operation.



The rules of the simultaneous channel operation function are applied in a channel group (a master channel and slave channels forming one simultaneous channel operation function).

If two or more channel groups that do not operate in combination are specified, the basic rules of the simultaneous channel operation function in **6.4.1 Basic rules of simultaneous channel operation function** do not apply to the channel groups.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)

Example





### 6.4.2 Basic rules of 8-bit timer operation function (channels 1 and 3 only)

The 8-bit timer operation function makes it possible to use a 16-bit timer channel in a configuration consisting of two 8-bit timer channels.

This function can only be used for channels 1 and 3, and there are several rules for using it. The basic rules for this function are as follows:

- (1) The 8-bit timer operation function applies only to channels 1 and 3.
- (2) When using 8-bit timers, set the SPLIT bit of timer mode register mn (TMRmn) to 1.
- (3) The higher 8 bits can be operated as the interval timer function.
- (4) At the start of operation, the higher 8 bits output INTTMm1H/INTTMm3H (an interrupt) (which is the same operation performed when MDmn0 is set to 1).
- (5) The operation clock of the higher 8 bits is selected according to the CKSmn1 and CKSmn0 bits of the lowerbit TMRmn register.
- (6) For the higher 8 bits, the TSHm1/TSHm3 bit is manipulated to start channel operation and the TTHm1/TTHm3 bit is manipulated to stop channel operation. The channel status can be checked using the TEHm1/TEHm3 bit.
- (7) The lower 8 bits operate according to the TMRmn register settings. The following three functions support operation of the lower 8 bits:
  - Interval timer function
  - External event counter function
  - Delay count function
- (8) For the lower 8 bits, the TSm1/TSm3 bit is manipulated to start channel operation and the TTm1/TTm3 bit is manipulated to stop channel operation. The channel status can be checked using the TEm1/TEm3 bit.
- (9) During 16-bit operation, manipulating the TSHm1, TSHm3, TTHm1, and TTHm3 bits is invalid. The TSm1, TSm3, TTm1, and TTm3 bits are manipulated to operate channels 1 and 3. The TEHm3 and TEHm1 bits are not changed.
- (10) For the 8-bit timer function, the simultaneous operation functions (one-shot pulse, PWM, and multiple PWM) cannot be used.



## 6.5 Operation of Counter

## 6.5.1 Count clock (fTCLK)

The count clock (fTCLK) of the timer array unit can be selected between following by CCSmn bit of timer mode register mn (TMRmn).

- Operation clock (fMCK) specified by the CKSmn0 and CKSmn1 bits
- Valid edge of input signal input from the TImn pin

Because the timer array unit is designed to operate in synchronization with fCLK, the timings of the count clock (fTCLK) are shown below.

(1) When operation clock (fMCK) specified by the CKSmn0 and CKSmn1 bits is selected (CCSmn = 0) The count clock (fTCLK) is between fCLK to fCLK /2<sup>15</sup> by setting of timer clock select register m (TPSm). When a divided fCLK is selected, however, the clock selected in TPSmn register, but a signal which becomes high level for one period of fCLK from its rising edge. When a fCLK is selected, fixed to high level. Counting of timer count register mn (TCRmn) delayed by one period of fCLK from rising edge of the count clock, because of synchronization with fCLK. But, this is described as "counting at rising edge of the count clock", as a matter of convenience.





Remark 1. △ : Rising edge of the count clock
 ▲ : Synchronization, increment/decrement of counter
 Remark 2. fCLK: CPU/peripheral hardware clock



(2) When valid edge of input signal via the TImn pin is selected (CCSmn = 1)

The count clock (fTCLK) becomes the signal that detects valid edge of input signal via the TImn pin and synchronizes next rising fMCK. The count clock (fTCLK) is delayed for 1 to 2 periods of fMCK from the input signal via the TImn pin (when a noise filter is used, the delay becomes 3 to 4 clocks).

Counting of timer count register mn (TCRmn) delayed by one period of fCLK from rising edge of the count clock, because of synchronization with fCLK. But, this is described as "counting at valid edge of input signal via the TImn pin", as a matter of convenience.





<1> Setting TSmn bit to 1 enables the timer to be started and to become wait state for valid edge of input signal via the TImn pin.

<3> The edge is detected by the rising of the sampled signal and the detection signal (count clock) is output.

- **Remark 1.**  $\triangle$  : Rising edge of the count clock
  - Synchronization, increment/decrement of counter
- Remark 2. fcLK: CPU/peripheral hardware clock
  - fмск: Operation clock of channel n
- **Remark 3.** The waveform of the input signal via TImn pin of the input pulse interval measurement, the measurement of high/low width of input signal, and the delay counter, and the one-shot pulse output are the same as that shown in Figure 6 29.



## 6.5.2 Start timing of counter

Timer count register mn (TCRmn) becomes enabled to operation by setting of TSmn bit of timer channel start register m (TSm).

Operations from count operation enabled state to timer count Register mn (TCRmn) count start is shown in Table 6 - 6.

| Timer operation mode     | Operation when TSmn = 1 is set                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interval timer mode      | No operation is carried out from start trigger detection (TSmn = 1) until count clock generation.<br>The first count clock loads the value of the TDRmn register to the TCRmn register and the subsequent count clock performs count down operation (see <b>6.5.3 (1) Operation of interval timer mode</b> ).                                                                                                                    |
| Event counter mode       | Writing 1 to the TSmn bit loads the value of the TDRmn register to the TCRmn register.<br>If detect edge of TImn input. The subsequent count clock performs count down operation.<br>(see <b>6.5.3 (2) Operation of event counter mode</b> ).                                                                                                                                                                                    |
| Capture mode             | No operation is carried out from start trigger detection (TSmn = 1) until count clock generation.<br>The first count clock loads 0000H to the TCRmn register and the subsequent count clock performs count up operation (see <b>6.5.3 (3) Operation of capture mode (input pulse interval measurement)</b> ).                                                                                                                    |
| One-count mode           | The waiting-for-start-trigger state is entered by writing 1 to the TSmn bit while the timer is stopped (TEmn = 0).<br>No operation is carried out from start trigger detection until count clock generation.<br>The first count clock loads the value of the TDRmn register to the TCRmn register and the subsequent count clock performs count down operation (see <b>6.5.3 (4) Operation of one-count mode</b> ).              |
| Capture & one-count mode | The waiting-for-start-trigger state is entered by writing 1 to the TSmn bit while the timer is stopped (TEmn = 0).<br>No operation is carried out from start trigger detection until count clock generation.<br>The first count clock loads 0000H to the TCRmn register and the subsequent count clock performs count up operation (see 6.5.3 (5) Start timing in capture & one-count mode (when high-level width is measured)). |



## 6.5.3 Operation of counter

Here, the counter operation in each mode is explained.

- (1) Operation of interval timer mode
  - <1> Operation is enabled (TEmn = 1) by writing 1 to the TSmn bit. Timer count register mn (TCRmn) holds the initial value until count clock generation.
  - <2> A start trigger is generated at the first count clock after operation is enabled.
  - <3> When the MDmn0 bit is set to 1, INTTMmn is generated by the start trigger.
  - <4> By the first count clock after the operation enable, the value of timer data register mn (TDRmn) is loaded to the TCRmn register and counting starts in the interval timer mode.
  - <5> When the TCRmn register counts down and its count value is 0000H, INTTMmn is generated and the value of timer data register mn (TDRmn) is loaded to the TCRmn register and counting keeps on.



#### Figure 6 - 30 Operation Timing (In Interval Timer Mode)

Caution In the first cycle operation of count clock after writing the TSmn bit, an error at a maximum of one clock is generated since count start delays until count clock has been generated. When the information on count start timing is necessary, an interrupt can be generated at count start by setting MDmn0 = 1.

Remark fMCK, the start trigger detection signal, and INTTMmn become active between one clock in synchronization with fCLK.



- (2) Operation of event counter mode
  - <1> Timer count register mn (TCRmn) holds its initial value while operation is stopped (TEmn = 0).
  - <2> Operation is enabled (TEmn = 1) by writing 1 to the TSmn bit.
  - <3> As soon as 1 has been written to the TSmn bit and 1 has been set to the TEmn bit, the value of timer data register mn (TDRmn) is loaded to the TCRmn register to start counting.
  - <4> After that, the TCRmn register value is counted down according to the count clock of the valid edge of the TImn input.



Figure 6 - 31 Operation Timing (In Event Counter Mode)

**Remark** The above figure shows the timing when the noise filter is not used. By making the noise filter on-state, the edge detection becomes 2 fMCK cycles (it sums up to 3 to 4 cycles) later than the normal cycle of TImn input. The error per one period occurs be the asynchronous between the period of the TImn input and that of the count clock (fMCK).



- (3) Operation of capture mode (input pulse interval measurement)
  - <1> Operation is enabled (TEmn = 1) by writing 1 to the TSmn bit.
  - <2> Timer count register mn (TCRmn) holds the initial value until count clock generation.
  - <3> A start trigger is generated at the first count clock after operation is enabled. And the value of 0000H is loaded to the TCRmn register and counting starts in the capture mode. (When the MDmn0 bit is set to 1, INTTMmn is generated by the start trigger.)
  - <4> On detection of the valid edge of the TImn input, the value of the TCRmn register is captured to timer data register mn (TDRmn) and INTTMmn is generated. However, this capture value is no meaning. The TCRmn register keeps on counting from 0000H.
  - <5> On next detection of the valid edge of the TImn input, the value of the TCRmn register is captured to timer data register mn (TDRmn) and INTTMmn is generated.

#### Figure 6 - 32 Operation Timing (In Capture Mode: Input Pulse Interval Measurement)



- **Note** If a clock has been input to TImn (the trigger exists) when capturing starts, counting starts when a trigger is detected, even if no edge is detected. Therefore, the first captured value (<4>) does not determine a pulse interval (in the above figure, 0001 just indicates two clock cycles but does not determine the pulse interval) and so the user can ignore it.
- Caution In the first cycle operation of count clock after writing the TSmn bit, an error at a maximum of one clock is generated since count start delays until count clock has been generated. When the information on count start timing is necessary, an interrupt can be generated at count start by setting MDmn0 = 1.
- **Remark** The above figure shows the timing when the noise filter is not used. By making the noise filter on-state, the edge detection becomes 2 fMCK cycles (it sums up to 3 to 4 cycles) later than the normal cycle of TImn input. The error per one period occurs be the asynchronous between the period of the TImn input and that of the count clock (fMCK).



- (4) Operation of one-count mode
  - <1> Operation is enabled (TEmn = 1) by writing 1 to the TSmn bit.
  - <2> Timer count register mn (TCRmn) holds the initial value until start trigger generation.
  - <3> Rising edge of the TImn input is detected.
  - <4> On start trigger detection, the value of timer data register mn (TDRmn) is loaded to the TCRmn register and count starts.
  - <5> When the TCRmn register counts down and its count value is 0000H, INTTMmn is generated and the value of the TCRmn register becomes FFFFH and counting stops.



Figure 6 - 33 Operation Timing (In One-count Mode)

**Remark** The above figure shows the timing when the noise filter is not used. By making the noise filter on-state, the edge detection becomes 2 fMCK cycles (it sums up to 3 to 4 cycles) later than the normal cycle of TImn input. The error per one period occurs be the asynchronous between the period of the TImn input and that of the count clock (fMCK).



- (5) Start timing in capture & one-count mode (when high-level width is measured)
  - <1> Operation is enabled (TEmn = 1) by writing 1 to the TSmn bit of timer channel start register m (TSm).
  - <2> Timer count register mn (TCRmn) holds the initial value until start trigger generation.
  - <3> Rising edge of the TImn input is detected.
  - <4> On start trigger detection, the value of 0000H is loaded to the TCRmn register and count starts.
  - <5> On detection of the falling edge of the TImn input, the value of the TCRmn register is captured to timer data register mn (TDRmn) and INTTMmn is generated.

Figure 6 - 34 Operation Timing (In Capture & One-count Mode: High-level Width Measurement)



**Remark** The above figure shows the timing when the noise filter is not used. By making the noise filter on-state, the edge detection becomes 2 fMCK cycles (it sums up to 3 to 4 cycles) later than the normal cycle of TImn input. The error per one period occurs be the asynchronous between the period of the TImn input and that of the count clock (fMCK).



## 6.6 Channel Output (TOmn pin) Control

## 6.6.1 TOmn pin output circuit configuration





The following describes the TOmn pin output circuit.

- <1> When TOMmn = 0 (master channel output mode), the set value of timer output level register m (TOLm) is ignored and only INTTM0p (slave channel timer interrupt) is transmitted to timer output register m (TOm).
- <2> When TOMmn = 1 (slave channel output mode), both INTTMmn (master channel timer interrupt) and INTTM0p (slave channel timer interrupt) are transmitted to the TOm register.

At this time, the TOLm register becomes valid and the signals are controlled as follows:

When TOLmn = 0: Positive logic output (INTTMmn  $\rightarrow$  set, INTTM0p  $\rightarrow$  reset) When TOLmn = 1: Negative logic output (INTTMmn  $\rightarrow$  reset, INTTM0p  $\rightarrow$  set)

When INTTMmn and INTTM0p are simultaneously generated, (0% output of PWM), INTTM0p (reset signal) takes priority, and INTTMmn (set signal) is masked.

<3> While timer output is enabled (TOEmn = 1), INTTMmn (master channel timer interrupt) and INTTM0p (slave channel timer interrupt) are transmitted to the TOm register. Writing to the TOm register (TOmn write signal) becomes invalid.

When TOEmn = 1, the TOmn pin output never changes with signals other than interrupt signals.

To initialize the TOmn pin output level, it is necessary to set timer operation is stopped (TOEmn = 0) and to write a value to the TOm register.

- <4> While timer output is disabled (TOEmn = 0), writing to the TOmn bit to the target channel (TOmn write signal) becomes valid. When timer output is disabled (TOEmn = 0), neither INTTMmn (master channel timer interrupt) nor INTTM0p (slave channel timer interrupt) is transmitted to the TOm register.
- <5> The TOm register can always be read, and the TOmn pin output level can be checked.

```
Remarkm: Unit number (m = 0)<br/>n: Channel number<br/>n = 0 to 7 (n = 0, 2, 4, 6 for master channel)<br/>p: Slave channel number<br/>n
```



## 6.6.2 TOmn Pin Output Setting

The following figure shows the procedure and status transition of the TOmn output pin from initial setting to timer operation start.





<1> The operation mode of timer output is set.

- TOMmn bit (0: Master channel output mode, 1: Slave channel output mode)
- TOLmn bit (0: Positive logic output, 1: Negative logic output)
- <2> The timer output signal is set to the initial status by setting timer output register m (TOm).
- <3> The timer output operation is enabled by writing 1 to the TOEmn bit (writing to the TOm register is disabled).
- <4> The port is set to digital I/O by port mode control register (PMCxx).
- <5> The port I/O setting is set to output (see 6.3.14 Registers that control port functions of timer input/output pins).
- <6> The timer operation is enabled (TSmn = 1).



## 6.6.3 Cautions on Channel Output Operation

(1) Changing values set in the registers TOm, TOEm, and TOLm during timer operation Since the timer operations (operations of timer count register mn (TCRmn) and timer data register mn (TDRmn)) are independent of the TOmn output circuit and changing the values set in timer output register m (TOm), timer output enable register m (TOEm), and timer output level register m (TOLm) does not affect the timer operation, the values can be changed during timer operation. To output an expected waveform from the TOmn pin by timer operation, however, set the TOm, TOEm, TOLm, and TOMm registers to the values stated in the register setting example of each operation shown by 6.7 and 6.8.

When the values set to the TOEm, and TOMm registers (but not the TOm register) are changed close to the occurrence of the timer interrupt (INTTMmn) of each channel, the waveform output to the TOmn pin might differ, depending on whether the values are changed immediately before or immediately after the timer interrupt (INTTMmn) occurs.



(2) Default level of TOmn pin and output level after timer operation start

The change in the output level of the TOmn pin when timer output register m (TOm) is written while timer output is disabled (TOEmn = 0), the initial level is changed, and then timer output is enabled (TOEmn = 1) before port output is enabled, is shown below.

(a) When operation starts with master channel output mode (TOMmn = 0) setting

The setting of timer output level register m (TOLm) is invalid when master channel output mode (TOMmn = 0). When the timer operation starts after setting the default level, the toggle signal is generated and the output level of the TOmn pin is reversed.





**Remark 1.** Toggle: Reverse TOmn pin output status **Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0 to 7)



(b) When operation starts with slave channel output mode (TOMmp = 1) setting (PWM output))
 When slave channel output mode (TOMmp = 1), the active level is determined by timer output level register m (TOLm) setting.





 Remark 1. Set:
 The output signal of the TOmp pin changes from inactive level to active level.

 Reset:
 The output signal of the TOmp pin changes from active level to inactive level.

 Remark 2.
 m: Unit number (m = 0), p: Channel number (p = 1 to 7)



- (3) Operation of TOmn pin in slave channel output mode (TOMmn = 1)
  - (a) When timer output level register m (TOLm) setting has been changed during timer operation When the TOLm register setting has been changed during timer operation, the setting becomes valid at the generation timing of the TOmn pin change condition. Rewriting the TOLm register does not change the output level of the TOmn pin.

The operation when TOMmn is set to 1 and the value of the TOLm register is changed while the timer is operating (TEmn = 1) is shown below.

#### Figure 6 - 39 Operation when TOLm Register Has Been Changed Contents during Timer Operation



Remark 1. Set:The output signal of the TOmn pin changes from inactive level to active level.Reset:The output signal of the TOmn pin changes from active level to inactive level.

**Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0 to 7)

(b) Set/reset timing

To realize 0%/100% output at PWM output, the TOmn pin/TOmn bit set timing at master channel timer interrupt (INTTMmn) generation is delayed by 1 count clock by the slave channel.

If the set condition and reset condition are generated at the same time, a higher priority is given to the latter.

Figure 6 - 40 shows the set/reset operating statuses where the master/slave channels are set as follows.

Master channel: TOEmn = 1, TOMmn = 0, TOLmn = 0 Slave channel: TOEmp = 1, TOMmp = 1, TOLmp = 0







#### (1) Basic operation timing

#### (2) Operation timing when 0% duty



Remark 1.Internal reset signal:TOmn pin reset/toggle signalInternal set signal:TOmn pin set signalRemark 2.m: Unit number (m = 0)n: Channel numbern = 0 to 7 (n = 0, 2, 4, 6 for master channel)p: Slave channel numbern \leq 7



## 6.6.4 Collective manipulation of TOmn bit

In timer output register m (TOm), the setting bits for all the channels are located in one register in the same way as timer channel start register m (TSm). Therefore, the TOmn bit of all the channels can be manipulated collectively.

Only the desired bits can also be manipulated by enabling writing only to the TOmn bits (TOEmn = 0) that correspond to the relevant bits of the channel used to perform output (TOmn).

| Before writir | ng       |         |          |       |         |         |       |        |           |           |           |           |           |           |           |           |
|---------------|----------|---------|----------|-------|---------|---------|-------|--------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| тоо           | 0        | 0       | 0        | 0     | 0       | 0       | 0     | 0      | TO07      | TO06      | TO05      | TO04      | TO03      | TO02      | TO01      | TO00      |
| 100           | 0        | 0       | 0        | 0     | 0       | 0       | 0     | 0      | 0         | 0         | 1         | 0         | 0         | 0         | 1         | 0         |
|               |          |         |          |       |         |         |       | _      | TOE07     | TOE06     | TOE05     | TOE04     | TOE03     | TOE02     | TOE01     | TOE00     |
| TOE0          | 0        | 0       | 0        | 0     | 0       | 0       | 0     | 0      | 0         | 0         | 1         | 0         | 1         | 1         | 1         | 1         |
|               |          |         |          |       |         |         |       |        |           |           |           |           |           |           |           |           |
| Data to be v  | vritten  |         |          |       |         |         |       |        |           |           |           |           |           |           |           |           |
|               | 0        | 0       | 0        | 0     | 0       | 0       | 0     | 0      | 0         | 0         | 0         | 0         | 0         | 1         | 1         | 1         |
|               |          |         |          |       |         |         |       |        | $\phi$    | $\phi$    | $\star$   | $\phi$    | $\star$   | $\star$   | $\star$   | $\star$   |
| After writing |          |         |          |       |         |         |       |        | V         | ▼         | ▼         |           |           |           | V         | •         |
| тоо           | 0        | 0       | 0        | 0     | 0       | 0       | 0     | 0      | TO07<br>1 | TO06<br>1 | TO05<br>1 | TO04<br>0 | TO03<br>0 | TO02<br>0 | TO01<br>1 | TO00<br>0 |
| Writir        | ng is de | one onl | y to the | e TOm | n bit w | ith TOE | Emn = | 0, and | writing   | to the    | TOmn      | bit with  | n TOEr    | nn = 1    | is igno   | red.      |

| Figure 6 - 41 | Example of TO0n | Bit Collective | Manipulation |
|---------------|-----------------|----------------|--------------|
| inguio o fi   |                 |                | manipalation |

Writing is done only to the TOmn bit with TOEmn = 0, and writing to the TOmn bit with TOEmn = 1 is ignored. TOmn (channel output) to which TOEmn = 1 is set is not affected by the write operation. Even if the write operation is done to the TOmn bit, it is ignored and the output change by timer operation is normally done.







## 6.6.5 Timer Interrupt and TOmn Pin Output at Operation Start

In the interval timer mode or capture mode, the MDmn0 bit in timer mode register mn (TMRmn) sets whether or not to generate a timer interrupt at count start.

When MDmn0 is set to 1, the count operation start timing can be known by the timer interrupt (INTTMmn) generation.

In the other modes, neither timer interrupt at count operation start nor TOmn output is controlled.

Figure 6 - 43 shows operation examples when the interval timer mode (TOEmn = 1, TOMmn = 0) is set.

#### Figure 6 - 43 Operation examples of timer interrupt at count operation start and TOmn output



(b) When MDmn0 is set to 0

When MDmn0 is set to 1, a timer interrupt (INTTMmn) is output at count operation start, and TOmn performs a toggle operation.

When MDmn0 is set to 0, a timer interrupt (INTTMmn) is not output at count operation start, and TOmn does not change either. After counting one cycle, INTTMmn is output and TOmn performs a toggle operation.



## 6.7 Timer Input (TImn) Control

## 6.7.1 TImn input circuit configuration

A signal is input from a timer input pin, goes through a noise filter and an edge detector, and is sent to a timer controller. Enable the noise filter for the pin in need of noise removal. The following shows the configuration of the input circuit.

Figure 6 - 44 Input Circuit Configuration



## 6.7.2 Noise filter

When the noise filter is disabled, the input signal is only synchronized with the operating clock (fMCK) for channel n. When the noise filter is enabled, after synchronization with the operating clock (fMCK) for channel n, whether the signal keeps the same value for two clock cycles is detected. The following shows differences in waveforms output from the noise filter between when the noise filter is enabled and disabled.

Figure 6 - 45 Sampling Waveforms through Tlmn Input Pin with Noise Filter Enabled and Disabled



Caution The input waveforms to the Tlmn pin are shown to explain the operation when the noise filter is enabled or disabled.



## 6.7.3 Cautions on channel input operation

When a timer input pin is set as unused, the operating clock is not supplied to the noise filter. Therefore, after settings are made to use the timer input pin, the following wait time is necessary before a trigger is specified to enable operation of the channel corresponding to the timer input pin.

(1) Noise filter is disabled

When bits 12 (CCSmn), 9 (STSmn1), and 8 (STSmn0) in the timer mode register mn (TMRmn) are 0 and then one of them is set to 1, wait for at least two cycles of the operating clock (fMCK), and then set the operation enable trigger bit in the timer channel start register (TSm).

(2) Noise filter is enabled

When bits 12 (CCSmn), 9 (STSmn1), and 8 (STSmn0) in the timer mode register mn (TMRmn) are all 0 and then one of them is set to 1, wait for at least four cycles of the operating clock (fMCK), and then set the operation enable trigger bit in the timer channel start register (TSm).



## 6.8 Independent Channel Operation Function of Timer Array Unit

### 6.8.1 Operation as interval timer/square wave output

#### (1) Interval timer

The timer array unit can be used as a reference timer that generates INTTMmn (timer interrupt) at fixed intervals.

The interrupt generation period can be calculated by the following expression.

Generation period of INTTMmn (timer interrupt) = Period of count clock × (Set value of TDRmn + 1)

(2) Operation as square wave output

TOmn performs a toggle operation as soon as INTTMmn has been generated, and outputs a square wave with a duty factor of 50%.

The period and frequency for outputting a square wave from TOmn can be calculated by the following expressions.

Period of square wave output from TOmn = Period of count clock × (Set value of TDRmn + 1) × 2
Frequency of square wave output from TOmn = Frequency of count clock/{(Set value of TDRmn + 1) × 2}

Timer count register mn (TCRmn) operates as a down counter in the interval timer mode.

The TCRmn register loads the value of timer data register mn (TDRmn) at the first count clock after the channel start trigger bit (TSmn, TSHm1, TSHm3) of timer channel start register m (TSm) is set to 1. If the MDmn0 bit of timer mode register mn (TMRmn) is 0 at this time, INTTMmn is not output and TOmn is not toggled. If the MDmn0 bit of the TMRmn register is 1, INTTMmn is output and TOmn is toggled.

After that, the TCRmn register count down in synchronization with the count clock.

When TCRmn = 0000H, INTTMmn is output and TOmn is toggled at the next count clock. At the same time, the TCRmn register loads the value of the TDRmn register again. After that, the same operation is repeated.

The TDRmn register can be rewritten at any time. The new value of the TDRmn register becomes valid from the next period.







Note When channels 1 and 3, the clock can be selected from CKm0, CKm1, CKm2 and CKm3.

#### Figure 6 - 47 Example of Basic Timing of Operation as Interval Timer/Square Wave Output (MDmn0 = 1)



**Remark 1.** m: Unit number (m = 0), n: Channel number (n = 0 to 7)

 Remark 2.
 TSmn:
 Bit n of timer channel start register m (TSm)

 TEmn:
 Bit n of timer channel enable status register m (TEm)

 TCRmn:
 Timer count register mn (TCRmn)

 TDRmn:
 Timer data register mn (TDRmn)

 TOmn:
 TOmn pin output signal





#### Figure 6 - 48 Example of Set Contents of Registers During Operation as Interval Timer/Square Wave Output



|                               | Software Operation                                                                                                                                                                                                                                                           | Hardware Status                                                                                                                                                                                                                                                                                                              |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TAU<br>default<br>setting     |                                                                                                                                                                                                                                                                              | Power-off status<br>(Clock supply is stopped and writing to each register<br>is disabled.)                                                                                                                                                                                                                                   |
|                               | Sets the TAUmEN bit of peripheral enable register 0 (PER0) to 1.                                                                                                                                                                                                             | Power-on status. Each channel stops operating.<br>(Clock supply is started and writing to each register i<br>enabled.)                                                                                                                                                                                                       |
|                               | Sets timer clock select register m (TPSm).<br>Determines clock frequencies of CKm0 to CKm3.                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                              |
| Channel<br>default<br>setting | Sets timer mode register mn (TMRmn) (determines<br>operation mode of channel).<br>Sets interval (period) value to timer data register mn<br>(TDRmn).                                                                                                                         | Channel stops operating.<br>(Clock is supplied and some power is consumed.)                                                                                                                                                                                                                                                  |
|                               | To use the TOmn output<br>Clears the TOMmn bit of timer output mode register m<br>(TOMm) to 0 (master channel output mode).<br>Clears the TOLmn bit to 0.<br>Sets the TOmn bit and determines default level of the<br>TOmn output.                                           | The TOmn pin goes into Hi-Z output state.<br>The TOmn default setting level is output when the port<br>mode register is in the output mode and the port registe                                                                                                                                                              |
|                               | Sets the TOEmn bit to 1 and enables operation of TOmn. →<br>Clears the port register and port mode register to 0. →                                                                                                                                                          | is 0.<br>TOmn does not change because channel stops<br>operating.<br>The TOmn pin outputs the TOmn set level.                                                                                                                                                                                                                |
| Operation     start           | (Sets the TOEmn bit to 1 only if using TOmn output and<br>resuming operation.).<br>Sets the TSmn (TSHm1, TSHm3) bit to 1.<br>The TSmn (TSHm1, TSHm3) bit automatically returns<br>to 0 because it is a trigger bit.                                                          | TEmn (TEHm1, TEHm3) = 1, and count operation<br>starts.<br>Value of the TDRmn register is loaded to timer cour<br>register mn (TCRmn). INTTMmn is generated and<br>TOmn performs toggle operation if the MDmn0 bit o<br>the TMRmn register is 1.                                                                             |
| During<br>operation           | Set value of the TDRmn register can be changed.<br>The TCRmn register can always be read.<br>The TSRmn register is not used.<br>Set values of the TOm and TOEm registers can be<br>changed.<br>Set values of the TMRmn register, TOMmn, and TOLmn<br>bits cannot be changed. | Counter (TCRmn) counts down. When count value<br>reaches 0000H, the value of the TDRmn register is<br>loaded to the TCRmn register again and the count<br>operation is continued. By detecting TCRmn = 0000H,<br>INTTMmn is generated and TOmn performs toggle<br>operation.<br>After that, the above operation is repeated. |
| Operation<br>stop             | The TTmn (TTHm1, TTHm3) bit is set to 1<br>The TTmn (TTHm1, TTHm3) bit automatically returns<br>to 0 because it is a trigger bit.                                                                                                                                            | TEmn (TEHm1, TEHm3), and count operation stops.<br>The TCRmn register holds count value and stops.<br>The TOmn output is not initialized but holds current<br>status.                                                                                                                                                        |
|                               | The TOEmn bit is cleared to 0 and value is set to the  TOmn bit.                                                                                                                                                                                                             | The TOmn pin outputs the TOmn bit set level.                                                                                                                                                                                                                                                                                 |

Figure 6 - 49 Operation Procedure of Interval Timer/Square Wave Output Function (1/2)

(Remark is listed on the next page.)



|             | Software Operation                                                                                                                                                                     | Hardware Status                                                                                                                                                             |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TAU<br>stop | To hold the TOmn pin output level<br>Clears the TOmn bit to 0 after the value to<br>be held is set to the port register.<br>When holding the TOmn pin output level is not<br>necessary | The TOmn pin output level is held by port function.                                                                                                                         |
|             | Setting not required.<br>The TAUmEN bit of the PER0 register is cleared to 0. –                                                                                                        | Power-off status<br>All circuits are initialized and SFR of each channel is<br>also initialized.<br>(The TOmn bit is cleared to 0 and the TOmn pin is set<br>to port mode.) |

#### Figure 6 - 50 Operation Procedure of Interval Timer/Square Wave Output Function (2/2)



#### 6.8.2 Operation as external event counter

The timer array unit can be used as an external event counter that counts the number of times the valid input edge (external event) is detected in the TImn pin. When a specified count value is reached, the event counter generates an interrupt. The specified number of counts can be calculated by the following expression.

Specified number of counts = Set value of TDRmn + 1

Timer count register mn (TCRmn) operates as a down counter in the event counter mode.

The TCRmn register loads the value of timer data register mn (TDRmn) by setting any channel start trigger bit (TSmn, TSHm1, TSHm3) of timer channel start register m (TSm) to 1.

The TCRmn register counts down each time the valid input edge of the TImn pin has been detected. When TCRmn = 0000H, the TCRmn register loads the value of the TDRmn register again, and outputs INTTMmn.

After that, the above operation is repeated.

An irregular waveform that depends on external events is output from the TOmn pin. Stop the output by setting the TOEmn bit of timer output enable register m (TOEm) to 0.

The TDRmn register can be rewritten at any time. The new value of the TDRmn register becomes valid during the next count period.

Figure 6 - 51 Block Diagram of Operation as External Event Counter







#### Figure 6 - 52 Example of Basic Timing of Operation as External Event Counter

- **Remark 2.** TSmn: Bit n of timer channel start register m (TSm)
  - TEmn: Bit n of timer channel enable status register m (TEm)
  - TImn: TImn pin input signal
  - TCRmn: Timer count register mn (TCRmn)
  - TDRmn: Timer data register mn (TDRmn)







#### Figure 6 - 53 Example of Set Contents of Registers in External Event Counter Mode



|                               | Software Operation                                                                                                                                                                                                                                                                                                           | Hardware Status                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TAU<br>default<br>setting     |                                                                                                                                                                                                                                                                                                                              | Power-off status<br>(Clock supply is stopped and writing to each register<br>is disabled.)                                                                                                                                                                                                                                                                   |
|                               | Sets the TAUmEN bit of peripheral enable register 0 (PER0) to 1.                                                                                                                                                                                                                                                             | Power-on status. Each channel stops operating.<br>(Clock supply is started and writing to each register i<br>enabled.)                                                                                                                                                                                                                                       |
|                               | Sets timer clock select register m (TPSm).<br>Determines clock frequencies of CKm0 to CKm3.                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                              |
| Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable<br>register 1 (NFEN1) to 0 (off) or 1 (on).<br>Sets timer mode register mn (TMRmn) (determines<br>operation mode of channel).<br>Sets number of counts to timer data register mn<br>(TDRmn).<br>Clears the TOEmn bit of timer output enable register m<br>(TOEm) to 0. | Channel stops operating.<br>(Clock is supplied and some power is consumed.)                                                                                                                                                                                                                                                                                  |
| Operation<br>start            | Sets the TSmn bit to 1<br>The TSmn bit automatically returns to 0 because it is<br>a trigger bit.                                                                                                                                                                                                                            | TEmn = 1, and count operation starts.<br>Value of the TDRmn register is loaded to timer cour<br>register mn (TCRmn) and detection of the TImn pin<br>input edge is awaited.                                                                                                                                                                                  |
| During<br>operation           | Set value of the TDRmn register can be changed.<br>The TCRmn register can always be read.<br>The TSRmn register is not used.<br>Set values of the TMRmn register, TOMmn, TOLmn,<br>TOmn, and TOEmn bits cannot be changed.                                                                                                   | Counter (TCRmn) counts down each time input edge of<br>the TImn pin has been detected. When count value<br>reaches 0000H, the value of the TDRmn register is<br>loaded to the TCRmn register again, and the count<br>operation is continued. By detecting TCRmn = 0000H,<br>the INTTMmn output is generated.<br>After that, the above operation is repeated. |
| Operation<br>stop             | The TTmn bit is set to 1.<br>The TTmn bit automatically returns to 0 because it is<br>a trigger bit.                                                                                                                                                                                                                         | TEmn = 0, and count operation stops.<br>The TCRmn register holds count value and stops.                                                                                                                                                                                                                                                                      |
| TAU<br>stop                   | The TAUmEN bit of the PER0 register is cleared to 0. →                                                                                                                                                                                                                                                                       | Power-off status<br>All circuits are initialized and SFR of each channel is<br>also initialized.                                                                                                                                                                                                                                                             |



#### 6.8.3 Operation as input pulse interval measurement

The count value can be captured at the TImn valid edge and the interval of the pulse input to TImn can be measured. In addition, the count value can be captured by using software operation (TSmn = 1) as a capture trigger while the TEmn bit is set to 1.

The pulse interval can be calculated by the following expression.

TImn input pulse interval =

Period of count clock × ((10000H × TSRmn: OVF) + (Capture value of TDRmn + 1))

# Caution The TImn pin input is sampled using the operating clock selected with the CKSmn bit of timer mode register mn (TMRmn), so an error of up to one operating clock cycle occurs.

Timer count register mn (TCRmn) operates as an up counter in the capture mode.

When the channel start trigger bit (TSmn) of timer channel start register m (TSm) is set to 1, the TCRmn register counts up from 0000H in synchronization with the count clock.

When the TImn pin input valid edge is detected, the count value of the TCRmn register is transferred (captured) to timer data register mn (TDRmn) and, at the same time, the TCRmn register is cleared to 0000H, and the INTTMmn is output. If the counter overflows at this time, the OVF bit of timer status register mn (TSRmn) is set to 1. If the counter does not overflow, the OVF bit is cleared. After that, the above operation is repeated.

As soon as the count value has been captured to the TDRmn register, the OVF bit of the TSRmn register is updated depending on whether the counter overflows during the measurement period. Therefore, the overflow status of the captured value can be checked.

If the counter reaches a full count for two or more periods, it is judged to be an overflow occurrence, and the OVF bit of the TSRmn register is set to 1. However, a normal interval value cannot be measured for the OVF bit, if two or more overflows occur.

Set the STSmn2 to STSmn0 bits of the TMRmn register to 001B to use the valid edges of TImn as a start trigger and a capture trigger.

#### Figure 6 - 55 Block Diagram of Operation as Input Pulse Interval Measurement



Note When channels 1 and 3, the clock can be selected from CKm0, CKm1, CKm2 and CKm3.





#### Figure 6 - 56 Example of Basic Timing of Operation as Input Pulse Interval Measurement (MDmn0 = 0)

- Remark 2. TSmn: Bit n of timer channel start register m (TSm)
  - TEmn: Bit n of timer channel enable status register m (TEm)
    - TImn: TImn pin input signal
    - TCRmn: Timer count register mn (TCRmn)
    - TDRmn: Timer data register mn (TDRmn)
    - OVF: Bit 0 of timer status register mn (TSRmn)









RENESAS

|                               | Software Operation                                                                                                                                                                                                                                                                                 | Hardware Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TAU<br>default<br>setting     |                                                                                                                                                                                                                                                                                                    | Power-off status<br>(Clock supply is stopped and writing to each register<br>is disabled.)                                                                                                                                                                                                                                                                                                                                                                                                              |
|                               | Sets the TAUmEN bit of peripheral enable register 0 (PER0) to 1.                                                                                                                                                                                                                                   | Power-on status. Each channel stops operating.<br>(Clock supply is started and writing to each register i<br>enabled.)                                                                                                                                                                                                                                                                                                                                                                                  |
|                               | Sets timer clock select register m (TPSm).<br>Determines clock frequencies of CKm0 to CKm3.                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable<br>register 1 (NFEN1) to 0 (off) or 1 (on).<br>Sets timer mode register mn (TMRmn) (determines<br>operation mode of channel).                                                                                                                | Channel stops operating.<br>(Clock is supplied and some power is consumed.)                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Operation<br>start            | Sets TSmn bit to 1<br>The TSmn bit automatically returns to 0 because it is a<br>trigger bit.                                                                                                                                                                                                      | TEmn = 1, and count operation starts.<br>Timer count register mn (TCRmn) is cleared to 0000<br>at the count clock input.<br>When the MDmn0 bit of the TMRmn register is 1,<br>INTTMmn is generated.                                                                                                                                                                                                                                                                                                     |
| During<br>operation           | Set values of only the CISmn1 and CISmn0 bits of the<br>TMRmn register can be changed.<br>The TDRmn register can always be read.<br>The TCRmn register can always be read.<br>The TSRmn register can always be read.<br>Set values of the TOMmn, TOLmn, TOmn, and TOEmn<br>bits cannot be changed. | Counter (TCRmn) counts up from 0000H. When the valid edge of the TImn pin input is detected or the TSm bit is set to 1, the count value is transferred (captured) t timer data register mn (TDRmn). At the same time, the TCRmn register is cleared to 0000H, and the INTTMm signal is generated.<br>If an overflow occurs at this time, the OVF bit of timer status register mn (TSRmn) is set; if an overflow does not occur, the OVF bit is cleared.<br>After that, the above operation is repeated. |
| Operation<br>stop             | The TTmn bit is set to 1.<br>The TTmn bit automatically returns to 0 because it is<br>a trigger bit.                                                                                                                                                                                               | TEmn = 0, and count operation stops.<br>The TCRmn register holds count value and stops.<br>The OVF bit of the TSRmn register is also held.                                                                                                                                                                                                                                                                                                                                                              |
| TAU<br>stop                   | The TAUmEN bit of the PER0 register is cleared to 0. →                                                                                                                                                                                                                                             | Power-off status<br>All circuits are initialized and SFR of each channel is<br>also initialized.                                                                                                                                                                                                                                                                                                                                                                                                        |

| Figure 6 - 58 Operation Procedure When Input Pulse Interval Measurement Function Is Used |
|------------------------------------------------------------------------------------------|
|------------------------------------------------------------------------------------------|



### 6.8.4 Operation as input signal high-/low-level width measurement

By starting counting at one edge of the TImn pin input and capturing the number of counts at another edge, the signal width (high-level width/low-level width) of TImn can be measured. The signal width of TImn can be calculated by the following expression.

Signal width of TImn input = Period of count clock × ((10000H × TSRmn: OVF) + (Capture value of TDRmn + 1))

# Caution The TImn pin input is sampled using the operating clock selected with the CKSmn bit of timer mode register mn (TMRmn), so an error equivalent to one operation clock occurs.

Timer count register mn (TCRmn) operates as an up counter in the capture & one-count mode.

When the channel start trigger bit (TSmn) of timer channel start register m (TSm) is set to 1, the TEmn bit is set to 1 and the TImn pin start edge detection wait status is set.

When the TImn pin input start edge (rising edge of the TImn pin input when the high-level width is to be measured) is detected, the counter counts up from 0000H in synchronization with the count clock. When the valid capture edge (falling edge of the TImn pin input when the high-level width is to be measured) is detected later, the count value is transferred to timer data register mn (TDRmn) and, at the same time, INTTMmn is output. If the counter overflows at this time, the OVF bit of timer status register mn (TSRmn) is set to 1. If the counter does not overflow, the OVF bit is cleared. The TCRmn register stops at the value "value transferred to the TDRmn register + 1", and the TImn pin start edge detection wait status is set. After that, the above operation is repeated.

As soon as the count value has been captured to the TDRmn register, the OVF bit of the TSRmn register is updated depending on whether the counter overflows during the measurement period. Therefore, the overflow status of the captured value can be checked.

If the counter reaches a full count for two or more periods, it is judged to be an overflow occurrence, and the OVF bit of the TSRmn register is set to 1. However, a normal interval value cannot be measured for the OVF bit, if two or more overflows occur.

Whether the high-level width or low-level width of the TImn pin is to be measured can be selected by using the CISmn1 and CISmn0 bits of the TMRmn register.

Because this function is used to measure the signal width of the TImn pin input, the TSmn bit cannot be set to 1 while the TEmn bit is 1.

CISmn1, CISmn0 of TMRmn register = 10B: Low-level width is measured. CISmn1, CISmn0 of TMRmn register = 11B: High-level width is measured.





Note For channels 1 and 3, the clock can be selected from CKm0, CKm1, CKm2 and CKm3.







- **Remark 2.** TSmn: Bit n of timer channel start register m (TSm)
  - TEmn: Bit n of timer channel enable status register m (TEm)
  - TImn: TImn pin input signal
  - TCRmn: Timer count register mn (TCRmn)
  - TDRmn: Timer data register mn (TDRmn)
  - OVF: Bit 0 of timer status register mn (TSRmn)







#### Figure 6 - 62 Operation Procedure When Input Signal High-/Low-Level Width Measurement Function Is Used

|                               | Software Operation                                                                                                                                                                                                                            | Hardware Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| TAU<br>default<br>setting     |                                                                                                                                                                                                                                               | Power-off status<br>(Clock supply is stopped and writing to each register<br>is disabled.)                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|                               | Sets the TAUmEN bit of peripheral enable register 0<br>(PER0) to 1. ———————————————————————————————————                                                                                                                                       | Power-on status. Each channel stops operating.<br>(Clock supply is started and writing to each register i<br>enabled.)                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                               | Sets timer clock select register m (TPSm).<br>Determines clock frequencies of CKm0 to CKm3.                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable<br>register 1 (NFEN1) to 0 (off) or 1 (on).<br>Sets timer mode register mn (TMRmn) (determines<br>operation mode of channel).<br>Clears the TOEmn bit to 0 and stops operation of TOmn. | Channel stops operating.<br>(Clock is supplied and some power is consumed.)                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Operation<br>start            | Sets the TSmn bit to 1<br>The TSmn bit automatically returns to 0 because it is<br>a trigger bit.                                                                                                                                             | TEmn = 1, and the TImn pin start edge detection wait status is set.                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                               | Detects the TImn pin input count start valid edge.                                                                                                                                                                                            | Clears timer count register mn (TCRmn) to 0000H and starts counting up.                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| During<br>operation           | Set value of the TDRmn register can always be read.<br>The TCRmn register can always be read.<br>The TSRmn register can always be read.<br>Set values of the TMRmn register, TOMmn, TOLmn,<br>TOmn, and TOEmn bits cannot be changed.         | When the TImn pin start edge is detected, the counter<br>(TCRmn) counts up from 0000H. If a capture edge of the<br>TImn pin is detected, the count value is transferred to<br>timer data register mn (TDRmn) and INTTMmn is<br>generated.<br>If an overflow occurs at this time, the OVF bit of timer<br>status register mn (TSRmn) is set; if an overflow does<br>not occur, the OVF bit is cleared. The TCRmn register<br>stops the count operation until the next TImn pin start<br>edge is detected. |  |  |  |
| Operation<br>stop             | The TTmn bit is set to 1.<br>The TTmn bit automatically returns to 0 because it is<br>a trigger bit.                                                                                                                                          | TEmn = 0, and count operation stops.<br>The TCRmn register holds count value and stops.<br>The OVF bit of the TSRmn register is also held.                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| TAU<br>stop                   | The TAUmEN bit of the PER0 register is cleared to 0. →                                                                                                                                                                                        | Power-off status<br>All circuits are initialized and SFR of each channel is<br>also initialized.                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |

**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)



#### 6.8.5 Operation as delay counter

It is possible to start counting down when the valid edge of the TImn pin input is detected (an external event), and then generate INTTMmn (a timer interrupt) after any specified interval.

It is also possible to start counting down and generate INTTMmn (timer interrupt) at any interval by setting TSmn to 1 by software while TEmn = 1.

The interrupt generation period can be calculated by the following expression.

#### Generation period of INTTMmn (timer interrupt) = Period of count clock × (Set value of TDRmn + 1)

Timer count register mn (TCRmn) operates as a down counter in the one-count mode.

When the channel start trigger bit (TSmn, TSHm1, TSHm3) of timer channel start register m (TSm) is set to 1, the TEmn, TEHm1, TEHm3 bits are set to 1 and the TImn pin input valid edge detection wait status is set.

Timer count register mn (TCRmn) starts operating upon TImn pin input valid edge detection and loads the value of timer data register mn (TDRmn). The TCRmn register counts down from the value of the TDRmn register it has loaded, in synchronization with the count clock. When TCRmn = 0000H, it outputs INTTMmn and stops counting until the next TImn pin input valid edge is detected.

The TDRmn register can be rewritten at any time. The new value of the TDRmn register becomes valid from the next period.





Note For using channels 1 and 3, the clock can be selected from CKm0, CKm1, CKm2 and CKm3.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)





#### Figure 6 - 64 Example of Basic Timing of Operation as Delay Counter

- **Remark 1.** m: Unit number (m = 0), n: Channel number (n = 0 to 7)
- Remark 2. TSmn: Bit n of timer channel start register m (TSm)
  - TEmn: Bit n of timer channel enable status register m (TEm)
  - TImn: TImn pin input signal
  - TCRmn: Timer count register mn (TCRmn)
  - TDRmn: Timer data register mn (TDRmn)









R19UH0112EJ0100 Rev.1.00 Mar 29, 2019



|                               | Software Operation                                                                                                                                                                                                                                                                                                 | Hardware Status                                                                                                                                                                                                                                                     |  |  |  |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| TAU<br>default<br>setting     |                                                                                                                                                                                                                                                                                                                    | Power-off status<br>(Clock supply is stopped and writing to each register<br>is disabled.)                                                                                                                                                                          |  |  |  |
|                               | Sets the TAUmEN bit of peripheral enable register 0<br>(PER0) to 1.                                                                                                                                                                                                                                                | Power-on status. Each channel stops operating.<br>(Clock supply is started and writing to each register is<br>enabled.)                                                                                                                                             |  |  |  |
|                               | Sets timer clock select register m (TPSm).<br>Determines clock frequencies of CKm0 to CKm3.                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                     |  |  |  |
| Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable<br>register 1 (NFEN1) to 0 (off) or 1 (on).<br>Sets timer mode register mn (TMRmn) (determines<br>operation mode of channel).<br>INTTMmn output delay is set to timer data register mn<br>(TDRmn).<br>Clears the TOEmn bit to 0 and stops operation of TOmn. | Channel stops operating.<br>(Clock is supplied and some power is consumed.)                                                                                                                                                                                         |  |  |  |
| Operation<br>start            | Sets the TSmn bit to 1<br>The TSmn bit automatically returns to 0 because it is<br>a trigger bit.                                                                                                                                                                                                                  | TEmn = 1, and the start trigger detection (the valid edge<br>of the TImn pin input is detected or the TSmn bit is set to<br>1) wait status is set.                                                                                                                  |  |  |  |
|                               | Detects the TImn pin input valid edge.                                                                                                                                                                                                                                                                             | Value of the TDRmn register is loaded to the timer count register mn (TCRmn).                                                                                                                                                                                       |  |  |  |
| During<br>operation           | Set value of the TDRmn register can be changed.<br>The TCRmn register can always be read.<br>The TSRmn register is not used.                                                                                                                                                                                       | The counter (TCRmn) counts down. When the count value of TCRmn reaches 0000H, the INTTMmn output is generated, and the count operation stops until the next start trigger detection (the valid edge of the TImn pin input is detected or the TSmn bit is set to 1). |  |  |  |
| Operation<br>stop             | The TTmn bit is set to 1<br>The TTmn bit automatically returns to 0 because it is<br>a trigger bit.                                                                                                                                                                                                                | TEmn = 0, and count operation stops.<br>The TCRmn register holds count value and stops.                                                                                                                                                                             |  |  |  |
| TAU<br>stop                   | The TAUmEN bit of the PER0 register is cleared to 0. →                                                                                                                                                                                                                                                             | Power-off status<br>All circuits are initialized and SFR of each channel is<br>also initialized.                                                                                                                                                                    |  |  |  |

Figure 6 - 66 Operation Procedure When Delay Counter Function Is Used

**Remark** m: Unit number (m = 0), n: Channel number (n = 0 to 7)



# 6.9 Simultaneous Channel Operation Function of Timer Array Unit

# 6.9.1 Operation as one-shot pulse output function

By using two channels as a set, a one-shot pulse having any delay pulse width can be generated from the signal input to the TImn pin.

The delay time and pulse width can be calculated by the following expressions.

Delay time = {Set value of TDRmn (master) + 2} × Count clock period Pulse width = {Set value of TDRmp (slave)} × Count clock period

The master channel operates in the one-count mode and counts the delays. Timer count register mn (TCRmn) of the master channel starts operating upon start trigger detection and loads the value of timer data register mn (TDRmn).

The TCRmn register counts down from the value of the TDRmn register it has loaded, in synchronization with the count clock. When TCRmn = 0000H, it outputs INTTMmn and stops counting until the next start trigger is detected.

The slave channel operates in the one-count mode and counts the pulse width. The TCRmp register of the slave channel starts operation using INTTMmn of the master channel as a start trigger, and loads the value of the TDRmp register. The TCRmp register counts down from the value of The TDRmp register it has loaded, in synchronization with the count value. When count value = 0000H, it outputs INTTMmp and stops counting until the next start trigger (INTTMmn of the master channel) is detected. The output level of TOmp becomes active one count clock after generation of INTTMmn from the master channel, and inactive when TCRmp = 0000H.

Instead of using the TImn pin input, a one-shot pulse can also be output using the software operation (TSmn = 1) as a start trigger.

- Caution The timing of loading of timer data register mn (TDRmn) of the master channel is different from that of the TDRmp register of the slave channel. If the TDRmn and TDRmp registers are rewritten during counting, therefore, an illegal waveform may be output in conflict with the timing of loading. Rewrite the TDRmn register after INTTMmn is generated and the TDRmp register after INTTMmp is generated.
- Remarkm: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6)p: Slave channel number (n \leq 7)





Figure 6 - 67 Block Diagram of Operation as One-Shot Pulse Output Function

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6)) p: Slave channel number (n \leq 7)





Figure 6 - 68 Example of Basic Timing of Operation as One-Shot Pulse Output Function

Remark 1. m: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6) p: Slave channel number (n 
Remark 2. TSmn, TSmp: Bit n, p of timer channel start register m (TSm) TEmn, TEmp: Bit n, p of timer channel enable status register m (TEm) TImn, TImp: TImn and TImp pins input signal TCRmn, TCRmp: Timer count registers mn, mp (TCRmn, TCRmp) TDRmn, TDRmp: Timer data registers mn, mp (TDRmn, TDRmp)

TOmn, TOmp: TOmn and TOmp pins output signal





Figure 6 - 69 Example of Set Contents of Registers When One-Shot Pulse Output Function Is Used (Master Channel)









|                               | Software Operation                                                                                                                                                                                                                                                                                                                                                           | Hardware Status                                                                                                                                                       |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TAU<br>default<br>setting     |                                                                                                                                                                                                                                                                                                                                                                              | Power-off status<br>(Clock supply is stopped and writing to each register<br>is disabled.)                                                                            |
|                               | Sets the TAUmEN bit of peripheral enable registers 0<br>(PER0) to 1.                                                                                                                                                                                                                                                                                                         | Power-on status. Each channel stops operating.<br>(Clock supply is started and writing to each register is<br>enabled.)                                               |
|                               | Sets timer clock select register m (TPSm).<br>Determines clock frequencies of CKm0 and CKm1.                                                                                                                                                                                                                                                                                 |                                                                                                                                                                       |
| Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable<br>registers 1 (NFEN1) to 1.<br>Sets timer mode register mn, mp (TMRmn, TMRmp) of<br>two channels to be used (determines operation mode of<br>channels).<br>An output delay is set to timer data register mn (TDRmn)<br>of the master channel, and a pulse width is set to the<br>TDRmp register of the slave channel. | Channel stops operating.<br>(Clock is supplied and some power is consumed.)                                                                                           |
|                               | Sets slave channel.<br>The TOMmp bit of timer output mode register m<br>(TOMm) is set to 1 (slave channel output mode).<br>Sets the TOLmp bit.<br>Sets the TOmp bit and determines default level of the<br>TOmp output.<br>Sets the TOEmp bit to 1 and enables operation of                                                                                                  | The TOmp pin goes into Hi-Z output state.<br>The TOmp default setting level is output when the port<br>mode register is in output mode and the port register is<br>0. |
|                               |                                                                                                                                                                                                                                                                                                                                                                              | TOmp does not change because channel stops operating.                                                                                                                 |

Figure 6 - 71 Operation Procedure of One-Shot Pulse Output Function (1/2)

(Remark is listed on the next page.)



|                     | Software Operation                                                                                                                                                                                                                                                                                                                                                                          | Hardware Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation<br>start  | Sets the TOEmp bit (slave) to 1 (only when operation is<br>resumed).<br>The TSmn (master) and TSmp (slave) bits of timer<br>channel start register m (TSm) are set to 1 at the same<br>time.<br>The TSmn and TSmp bits automatically return to 0<br>because they are trigger bits.                                                                                                          | The TEmn and TEmp bits are set to 1 and the master<br>channel enters the start trigger detection (the valid edg<br>of the TImn pin input is detected or the TSmn bit of the<br>master channel is set to 1) wait status.<br>Counter stops operating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                     | <ul> <li>Count operation of the master channel is started by start trigger detection of the master channel.</li> <li>Detects the TImn pin input valid edge.</li> <li>Sets the TSmn bit of the master channel to 1 by software Note.</li> <li>Note Do not set the TSmn bit of the slave channel to 1.</li> </ul>                                                                             | Master channel starts counting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| During<br>operation | Set values of only the CISmn1 and CISmn0 bits of the<br>TMRmn register can be changed.<br>Set values of the TMRmp, TDRmn, TDRmp registers,<br>TOMmn, TOMmp, TOLmn, and TOLmp bits cannot be<br>changed.<br>The TCRmn and TCRmp registers can always be read.<br>The TSRmn and TSRmp registers are not used.<br>Set values of the TOm and TOEm registers by slave<br>channel can be changed. | Master channel loads the value of the TDRmn register<br>to timer count register mn (TCRmn) by the start trigger<br>detection (the valid edge of the TImn pin input is<br>detected or the TSmn bit of the master channel is set to<br>1), and the counter starts counting down. When the<br>count value reaches TCRmn = 0000H, the INTTMmn<br>output is generated, and the counter stops until the nex<br>start trigger detection.<br>The slave channel, triggered by INTTMmn of the master<br>channel, loads the value of the TDRmp register to the<br>TCRmp register, and the counter starts counting down.<br>The output level of TOmp becomes active one count<br>clock after generation of INTTMmn from the master<br>channel. It becomes inactive when TCRmp = 0000H,<br>and the counting operation is stopped.<br>After that, the above operation is repeated. |  |  |
| Operation           | The TTmn (master) and TTmp (slave) bits are set to 1 at                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| stop                | the same time<br>The TTmn (master) and TTmp (slave) bits are set to 1<br>at the same time.                                                                                                                                                                                                                                                                                                  | <ul> <li>TEmn, TEmp = 0, and count operation stops.</li> <li>The TCRmn and TCRmp registers hold count value and stop.</li> <li>The TOmp output is not initialized but holds current status.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                     | The TOEmp bit of slave channel is cleared to 0 and value is set to the TOmp bit.                                                                                                                                                                                                                                                                                                            | The TOmp pin outputs the TOmp set level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| TAU<br>stop         | To hold the TOmp pin output level<br>Clears the TOmp bit to 0 after the value to be held is                                                                                                                                                                                                                                                                                                 | The TOmp pin output level is held by port function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                     | The TAUmEN bit of the PER0 register is cleared to 0. →                                                                                                                                                                                                                                                                                                                                      | Power-off status<br>All circuits are initialized and SFR of each channel is<br>also initialized.<br>(The TOmp bit is cleared to 0 and the TOmp pin is se<br>to port mode.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |

Figure 6 - 72 Operation Procedure of One-Shot Pulse Output Function (2/2)

Remarkm: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6)p: Slave channel number (n

# 6.9.2 Operation as PWM function

Two channels can be used as a set to generate a pulse of any period and duty factor. The period and duty factor of the output pulse can be calculated by the following expressions.

```
Pulse period = {Set value of TDRmn (master) + 1} × Count clock period
Duty factor [%] = {Set value of TDRmp (slave)}/{Set value of TDRmn (master) + 1} × 100
0% output: Set value of TDRmp (slave) = 0000H
100% output: Set value of TDRmp (slave) ≥ {Set value of TDRmn (master) + 1}
```

**Remark** The duty factor exceeds 100% if the set value of TDRmp (slave) > (set value of TDRmn (master) + 1), it summarizes to 100% output.

The master channel operates in the interval timer mode. If the channel start trigger bit (TSmn) of timer channel start register m (TSm) is set to 1, an interrupt (INTTMmn) is output, the value set to timer data register mn (TDRmn) is loaded to timer count register mn (TCRmn), and the counter counts down in synchronization with the count clock. When the counter reaches 0000H, INTTMmn is output, the value of the TDRmn register is loaded again to the TCRmn register, and the counter counts down. This operation is repeated until the channel stop trigger bit (TTmn) of timer channel stop register m (TTm) is set to 1.

If two channels are used to output a PWM waveform, the period until the master channel counts down to 0000H is the PWM output (TOmp) cycle.

The slave channel operates in one-count mode. By using INTTMmn from the master channel as a start trigger, the TCRmp register loads the value of the TDRmp register and the counter counts down to 0000H. When the counter reaches 0000H, it outputs INTTMmp and waits until the next start trigger (INTTMmn from the master channel) is generated.

If two channels are used to output a PWM waveform, the period until the slave channel counts down to 0000H is the PWM output (TOmp) duty.

PWM output (TOmp) goes to the active level one clock after the master channel generates INTTMmn and goes to the inactive level when the TCRmp register of the slave channel becomes 0000H.

- Caution To rewrite both timer data register mn (TDRmn) of the master channel and the TDRmp register of the slave channel, a write access is necessary two times. The timing at which the values of the TDRmn and TDRmp registers are loaded to the TCRmn and TCRmp registers is upon occurrence of INTTMmn of the master channel. Thus, when rewriting is performed split before and after occurrence of INTTMmn of the master channel, the TOmp pin cannot output the expected waveform. To rewrite both the TDRmn register of the master and the TDRmp register of the slave, therefore, be sure to rewrite both the registers immediately after INTTMmn is generated from the master channel.
- **Remark**m: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6)p: Slave channel number (n \leq 7)





Figure 6 - 73 Block Diagram of Operation as PWM Function

Remarkm: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6)p: Slave channel number (n \leq 7)





Figure 6 - 74 Example of Basic Timing of Operation as PWM Function

**Remark 1.** m: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6)

p: Slave channel number (n < p ≤ 7)

 Remark 2.
 TSmn, TSmp:
 Bit n, p of timer channel start register m (TSm)

 TEmn, TEmp:
 Bit n, p of timer channel enable status register m (TEm)

 TCRmn, TCRmp:
 Timer count registers mn, mp (TCRmn, TCRmp)

 TDRmn, TDRmp:
 Timer data registers mn, mp (TDRmn, TDRmp)

 TOmn, TOmp:
 TOmn and TOmp pins output signal



#### Figure 6 - 75 Example of Set Contents of Registers When PWM Function (Master Channel) Is Used





#### Figure 6 - 76 Example of Set Contents of Registers When PWM Function (Slave Channel) Is Used



|         | Software Operation                                          | Hardware Status                                                    |
|---------|-------------------------------------------------------------|--------------------------------------------------------------------|
| TAU     |                                                             | Power-off status                                                   |
| default |                                                             | (Clock supply is stopped and writing to each register              |
| setting |                                                             | is disabled.)                                                      |
|         | Sets the TAUmEN bit of peripheral enable register 0         |                                                                    |
|         | (PER0) to 1.                                                | Power-on status. Each channel stops operating.                     |
|         |                                                             | (Clock supply is started and writing to each register is enabled.) |
|         | Sets timer clock select register m (TPSm).                  |                                                                    |
|         | Determines clock frequencies of CKm0 and CKm1.              |                                                                    |
| Channel | Sets timer mode registers mn, mp (TMRmn, TMRmp) of          | Channel stops operating.                                           |
| default | two channels to be used (determines operation mode of       | (Clock is supplied and some power is consumed.)                    |
| setting | channels).                                                  |                                                                    |
|         | An interval (period) value is set to timer data register mn |                                                                    |
|         | (TDRmn) of the master channel, and a duty factor is set     |                                                                    |
|         | to the TDRmp register of the slave channel.                 |                                                                    |
|         | Sets slave channel.                                         | The TOmp pin goes into Hi-Z output state.                          |
|         | The TOMmp bit of timer output mode register m               |                                                                    |
|         | (TOMm) is set to 1 (slave channel output mode).             |                                                                    |
|         | Sets the TOLmp bit.                                         |                                                                    |
|         | Sets the TOmp bit and determines default level of the       |                                                                    |
|         | TOmp output.                                                | The TOmp default setting level is output when the port             |
|         |                                                             | mode register is in output mode and the port register is           |
|         | Sets the TOEmp bit to 1 and enables operation of            | 0.                                                                 |
|         | TOmp. —                                                     | TOmp does not change because channel stops<br>operating.           |
|         | Clears the port register and port mode register to 0. →     | The TOmp pin outputs the TOmp set level.                           |

Figure 6 - 77 Operation Procedure When PWM Function Is Used (1/2)

(Remark is listed on the next page.)



|                       |                     | Software Operation                                                                                                                                                                                                                                                                                                                  | Hardware Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|-----------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                       | Operation     start | Sets the TOEmp bit (slave) to 1 (only when operation is<br>resumed).<br>The TSmn (master) and TSmp (slave) bits of timer<br>channel start register m (TSm) are set to 1 at the same<br>time.<br>The TSmn and TSmp bits automatically return to 0<br>because they are trigger bits.                                                  | <ul> <li>TEmn = 1, TEmp = 1</li> <li>When the master channel starts counting, INTTMmn is generated. Triggered by this interrupt, the slave channel also starts counting.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| Operation is resumed. | During<br>operation | Set values of the TMRmn and TMRmp registers,<br>TOMmn, TOMmp, TOLmn, and TOLmp bits cannot be<br>changed.<br>Set values of the TDRmn and TDRmp registers can be<br>changed after INTTMmn of the master channel is<br>generated.<br>The TCRmn and TCRmp registers can always be read.<br>The TSRmn and TSRmp registers are not used. | The counter of the master channel loads the TDRmn<br>register value to timer count register mn (TCRmn), and<br>counts down. When the count value reaches TCRmn =<br>0000H, INTTMmn output is generated. At the same<br>time, the value of the TDRmn register is loaded to the<br>TCRmn register, and the counter starts counting down<br>again.<br>At the slave channel, the value of the TDRmp register is<br>loaded to the TCRmp register, triggered by INTTMmn of<br>the master channel, and the counter starts counting<br>down. The output level of TOmp becomes active one<br>count clock after generation of the INTTMmn output<br>from the master channel. It becomes inactive when<br>TCRmp = 0000H, and the counting operation is<br>stopped.<br>After that, the above operation is repeated. |  |  |  |
|                       | Operation<br>stop   | The TTmn (master) and TTmp (slave) bits are set to 1 at the same time.<br>The TTmn and TTmp bits automatically return to 0 because they are trigger bits.                                                                                                                                                                           | TEmn, TEmp = 0, and count operation stops.<br>The TCRmn and TCRmp registers hold count value<br>and stop.<br>The TOmp output is not initialized but holds current<br>status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                       |                     | The TOEmp bit of slave channel is cleared to 0 and value is set to the TOmp bit.                                                                                                                                                                                                                                                    | The TOmp pin outputs the TOmp set level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                       | TAU<br>stop         | To hold the TOmp pin output level<br>Clears the TOmp bit to 0 after the value to be held →<br>is set to the port register.<br>When holding the TOmp pin output level is not<br>necessary<br>Setting not required.                                                                                                                   | The TOmp pin output level is held by port function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                       |                     | The TAUmEN bit of the PER0 register is cleared to 0. →                                                                                                                                                                                                                                                                              | Power-off status<br>All circuits are initialized and SFR of each channel is<br>also initialized.<br>(The TOmp bit is cleared to 0 and the TOmp pin is set<br>to port mode.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |

| Figure 6 - 78 Operation Procedur | e When PWM Function Is Used (2/2) |
|----------------------------------|-----------------------------------|
|----------------------------------|-----------------------------------|

Remarkm: Unit number (m = 0), n: Channel number (n = 0, 2, 4, 6)p: Slave channel number (n

#### 6.9.3 Operation as multiple PWM output function

By extending the PWM function and using multiple slave channels, many PWM waveforms with different duty values can be output.

For example, when using two slave channels, the period and duty factor of an output pulse can be calculated by the following expressions.

Pulse period = {Set value of TDRmn (master) + 1} × Count clock period Duty factor 1 [%] = {Set value of TDRmp (slave 1)}/{Set value of TDRmn (master) + 1} × 100 Duty factor 2 [%] = {Set value of TDRmq (slave 2)}/{Set value of TDRmn (master) + 1} × 100

Remark Although the duty factor exceeds 100% if the set value of TDRmp (slave 1) > {set value of TDRmn (master) + 1} or if the {set value of TDRmq (slave 2)} > {set value of TDRmn (master) + 1}, it is summarized into 100% output.

Timer count register mn (TCRmn) of the master channel operates in the interval timer mode and counts the periods.

The TCRmp register of the slave channel 1 operates in one-count mode, counts the duty factor, and outputs a PWM waveform from the TOmp pin. The TCRmp register loads the value of timer data register mp (TDRmp), using INTTMmn of the master channel as a start trigger, and starts counting down. When TCRmp = 0000H, TCRmp outputs INTTMmp and stops counting until the next start trigger (INTTMmn of the master channel) has been input. The output level of TOmp becomes active one count clock after generation of INTTMmn from the master channel, and inactive when TCRmp = 0000H.

In the same way as the TCRmp register of the slave channel 1, the TCRmq register of the slave channel 2 operates in one-count mode, counts the duty factor, and outputs a PWM waveform from the TOmq pin. The TCRmq register loads the value of the TDRmq register, using INTTMmn of the master channel as a start trigger, and starts counting down. When TCRmq = 0000H, the TCRmq register outputs INTTMmq and stops counting until the next start trigger (INTTMmn of the master channel) has been input. The output level of TOmq becomes active one count clock after generation of INTTMmn from the master channel, and inactive when TCRmq = 0000H.

When channel 0 is used as the master channel as above, up to three types of PWM signals can be output at the same time.

- Caution To rewrite both timer data register mn (TDRmn) of the master channel and the TDRmp register of the slave channel 1, write access is necessary at least twice. Since the values of the TDRmn and TDRmp registers are loaded to the TCRmn and TCRmp registers after INTTMmn is generated from the master channel, if rewriting is performed separately before and after generation of INTTMmn from the master channel, the TOmp pin cannot output the expected waveform. To rewrite both the TDRmn register of the master and the TDRmp register of the slave, be sure to rewrite both the registers immediately after INTTMmn is generated from the master channel (This applies also to the TDRmq register of the slave channel 2).
- Remarkm: Unit number (m = 0), n: Channel number (n = 0, 2, 4)p: Slave channel number 1, q: Slave channel number 2n (Where p and q are integers greater than n)





Figure 6 - 79 Block Diagram of Operation as Multiple PWM Output Function (output two types of PWMs)

Remarkm: Unit number (m = 0), n: Channel number (n = 0, 2, 4)p: Slave channel number 1, q: Slave channel number 2n (Where p and q are integers greater than n)





Figure 6 - 80 Example of Basic Timing of Operation as Multiple PWM Output Function (Output two types of PWMs) (1/2)

(Remark is listed on the next page.)

TOmn, TOmp, TOmq:

 Remark 1. m: Unit number (m = 0), n: Channel number (n = 0, 2, 4)

 p: Slave channel number 1, q: Slave channel number 2

 n 

 Remark 2. TSmn, TSmp, TSmq:
 Bit n, p, q of timer channel start register m (TSm)

 TEmn, TEmp, TEmq:
 Bit n, p, q of timer channel enable status register m (TEm)

 TCRmn, TCRmp, TCRmq:
 Timer count registers mn, mp, mq (TCRmn, TCRmp, TCRmq)

 TDRmn, TDRmp, TDRmq:
 Timer data registers mn, mp, mq (TDRmn, TDRmp, TDRmq)

TOmn, TOmp, and TOmq pins output signal

R19UH0112EJ0100 Rev.1.00 Mar 29, 2019







0

MDmp0

1

0

MDmq0

1

#### Figure 6 - 82 Example of Set Contents of Registers When Multiple PWM Output Function (Slave Channel) Is Used (output two types of PWMs) Timer mode register mp, mg (TMRmp, TMRmg) (a) 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 CCSmp M/S Note STSmp2 CKSmp1 CKSmp0 STSmp1 STSmp0 CISmp1 CISmp0 MDmp3 MDmp2 MDmp1 TMRmp 1/0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 CKSmg1 CKSmq0 CCSmg M/S Note STSmg2 STSmg1 STSmq0 CISmq1 CISmq0 MDmq3 MDmg2 MDmg1 TMRmg 1/0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 Operation mode of channel p, q 100B: One-count mode Start trigger during operation 1: Trigger input is valid. Selection of TImp and TImp pins input edge 00B: Sets 00B because these are not used. Start trigger selection 100B: Selects INTTMmn of master channel. Setting of MASTERmp, MASTERmq bits (channels 2, 4, 6) 0: Independent channel operation function. Setting of SPLITmp, SPLITmq bits (channels 1, 3) 1: 16-bit timer mode. Count clock selection 0: Selects operation clock (fMCK). Operation clock (fMCK) selection 00B: Selects CKm0 as operation clock of channel p, q. 10B: Selects CKm1 as operation clock of channel p, q. \* Make the same setting as master channel. (b) Timer output register m (TOm) Bit q Bit p 0: Outputs 0 from TOmp or TOmq. TOmq TOmp TOm 1: Outputs 1 from TOmp or TOmq. 1/0 1/0 (c) Timer output enable register m (TOEm) Bit q Bit p TOEmq TOEmp 0: Stops the TOmp or TOmg output operation by counting operation. TOEm 1: Enables the TOmp or TOmq output operation by counting operation. 1/0 1/0 Timer output level register m (TOLm) (d) Bit q Bit p 0: Positive logic output (active-high) TOLmq TOLmp TOLm 1: Negative logic output (active-low) 1/0 1/0 Timer output mode register m (TOMm) (e) Bit q Bit p

Remark

TOMmp

1

1: Sets the slave channel output mode.

m: Unit number (m = 0), n: Channel number (n = 0, 2, 4)

p: Slave channel number 1, q: Slave channel number 2 n (Where p and q are integers greater than n)

TMRm2, TMRm4, TMRm6:

TMRm1, TMRm3:

TMRm5, TMRm7:

TOMmq

1 Note

TOMm



MASTERmp, MASTERmq bit

SPLITmp, SPLIT0q bit

Fixed to 0

#### Figure 6 - 83 Operation Procedure When Multiple PWM Output Function Is Used (output two types of PWMs) (1/2)

|                               | Software Operation                                                                                                                                                                                                                                                                                                           | Hardware Status                                                                                                                                                                                                       |  |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| TAU<br>default<br>setting     | Sets the TAUmEN bit of peripheral enable register 0<br>(PER0) to 1. ———————————————————————————————————                                                                                                                                                                                                                      | Power-off status<br>(Clock supply is stopped and writing to each register<br>is disabled.)<br>Power-on status. Each channel stops operating.<br>(Clock supply is started and writing to each register is<br>enabled.) |  |
|                               | Sets timer clock select register m (TPSm).<br>Determines clock frequencies of CKm0 and CKm1.                                                                                                                                                                                                                                 |                                                                                                                                                                                                                       |  |
| Channel<br>default<br>setting | Sets timer mode registers mn, mp, mq (TMRmn,<br>TMRmp, TMRmq) of each channel to be used<br>(determines operation mode of channels).<br>An interval (period) value is set to timer data register mn<br>(TDRmn) of the master channel, and a duty factor is set<br>to the TDRmp and TDRmq registers of the slave<br>channels. | Channel stops operating.<br>(Clock is supplied and some power is consumed.)                                                                                                                                           |  |
|                               | Sets slave channels.<br>The TOMmp and TOMmq bits of timer output mode<br>register m (TOMm) are set to 1 (slave channel output<br>mode).<br>Clears the TOLmp and TOLmq bits to 0.<br>Sets the TOmp and TOmq bits and determines<br>default level of the TOmp and TOmq outputs.                                                | The TOmp and TOmq pins go into Hi-Z output state.<br>The TOmp and TOmq default setting levels are output<br>when the port mode register is in output mode and the                                                     |  |
|                               |                                                                                                                                                                                                                                                                                                                              | port register is 0.<br>TOmp and TOmq do not change because channels stop<br>operating.<br>The TOmp and TOmq pins output the TOmp and TOmq                                                                             |  |
|                               |                                                                                                                                                                                                                                                                                                                              | set levels.                                                                                                                                                                                                           |  |

(Remark is listed on the next page.)



Operation is resumed.

|                                         | Software Operation                                                                                                                                                                                                                                                                                                                                                                  | Hardware Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Operation<br/>start</li> </ul> | (Sets the TOEmp and TOEmq (slave) bits to 1 only<br>when resuming operation.)<br>The TSmn bit (master), and TSmp and TSmq (slave)<br>bits of timer channel start register m (TSm) are set to 1<br>at the same time.<br>The TSmn, TSmp, and TSmq bits automatically return to<br>0 because they are trigger bits.                                                                    | TEmn = 1, TEmp, TEmq = 1<br>When the master channel starts counting, INTTMmn<br>is generated. Triggered by this interrupt, the slave<br>channel also starts counting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| During<br>operation                     | Set values of the TMRmn, TMRmp, TMRmq registers,<br>TOMmn, TOMmp, TOMmq, TOLmn, TOLmp, and<br>TOLmq bits cannot be changed.<br>Set values of the TDRmn, TDRmp, and TDRmq<br>registers can be changed after INTTMmn of the master<br>channel is generated.<br>The TCRmn, TCRmp, and TCRmq registers can always<br>be read.<br>The TSRmn, TSRmp, and TSRmq registers are not<br>used. | The counter of the master channel loads the TDRmn register<br>value to timer count register mn (TCRmn) and counts down.<br>When the count value reaches TCRmn = 0000H, INTTMmn<br>output is generated. At the same time, the value of the TDRmn<br>register is loaded to the TCRmn register, and the counter<br>starts counting down again.<br>At the slave channel 1, the values of the TDRmp register are<br>transferred to the TCRmp register, triggered by INTTMmn of<br>the master channel, and the counter starts counting down. The<br>output levels of TOmp become active one count clock after<br>generation of the INTTMmn output from the master channel. It<br>becomes inactive when TCRmp = 0000H, and the counting<br>operation is stopped.<br>At the slave channel 2, the values of the TDRmq register are<br>transferred to TCRmq register, triggered by INTTMmn of the<br>master channel, and the counter starts counting down. The<br>output levels of TOmp become active one count clock after<br>generation of the INTTMmn output from the master channel. It<br>becomes inactive when TCRmp = 0000H, and the counting<br>operation is stopped.<br>At the slave channel 2, the values of the TDRmq register are<br>transferred to TCRmq register, triggered by INTTMmn of the<br>master channel, and the counter starts counting down. The<br>output levels of TOmq become active one count clock after<br>generation of the INTTMmn output from the master channel. It<br>becomes inactive when TCRmq = 0000H, and the counting<br>operation is stopped.<br>After that, the above operation is repeated. |
| Operation<br>stop                       | The TTmn, TTmp, and TTmq bits automatically return<br>to 0 because they are trigger bits.<br>The TOEmp and TOEmq bits of slave channels are cleared to                                                                                                                                                                                                                              | TEmn, TEmp, TEmq = 0, and count operation stops.<br>The TCRmn, TCRmp, and TCRmq registers hold<br>count value and stop.<br>The TOmp and TOmq output are not initialized but<br>hold current status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TAU<br>stop                             | To hold the TOmp and TOmq pin output levels<br>Clears the TOmp and TOmq bits to 0 after<br>the value to be held is set to the port register. →<br>When holding the TOmp and TOmq pin output levels<br>are not necessary<br>Setting not required<br>The TAUMEN bit of the PER0 register is cleared to 0. →                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                         |                                                                                                                                                                                                                                                                                                                                                                                     | All circuits are initialized and SFR of each channel is<br>also initialized.<br>(The TOmp and TOmq bits are cleared to 0 and the<br>TOmp and TOmq pins are set to port mode.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Remarkm: Unit number (m = 0), n: Channel number (n = 0, 2, 4)p: Slave channel number, q: Slave channel numbern (Where p and q are integer greater than n)



# 6.10 Cautions When Using Timer Array Unit

# 6.10.1 Cautions When Using Timer output

Depends on products, a pin is assigned a timer output and other alternate functions. In this case, outputs of the other alternate functions must be set in initial status.

For details, see 4.5 Register Settings When Using Alternate Function.



# **CHAPTER 7 12-BIT INTERVAL TIMER**

# 7.1 Functions of 12-bit Interval Timer

An interrupt (INTIT) is generated at any previously specified time interval. It can be utilized for wakeup from STOP mode and triggering an A/D converter's SNOOZE mode.

# 7.2 Configuration of 12-bit Interval Timer

The 12-bit interval timer includes the following hardware.

| ltem                   | Configuration                                       |  |  |  |
|------------------------|-----------------------------------------------------|--|--|--|
| Counter 12-bit counter |                                                     |  |  |  |
| Control registers      | Peripheral enable register 2 (PER2)                 |  |  |  |
|                        | Peripheral reset control register 2 (PRR2)          |  |  |  |
|                        | Subsystem clock supply mode control register (OSMC) |  |  |  |
|                        | 12-bit interval timer control register (ITMC)       |  |  |  |

#### Table 7 - 1 Configuration of 12-bit Interval Timer







# 7.3 Registers Controlling 12-bit Interval Timer

The 12-bit interval timer is controlled by the following registers.

- Peripheral enable register 2 (PER2)
- Peripheral reset control register 2 (PRR2)
- Subsystem clock supply mode control register (OSMC)
- 12-bit interval timer control register (ITMC)

# 7.3.1 Peripheral enable register 2 (PER2)

This register is used to enable or disable supplying the clock to the peripheral hardware. Clock supply to a hardware macro that is not used is stopped in order to reduce the power consumption and noise. When the 12-bit interval timer is used, be sure to set bit 7 (TMKAEN) of this register to 1. The PER2 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 7 - 2 Format of Peripheral enable register 2 (PER2)

| Address: F00FCH |        | After reset: 00 | H R/W |   |   |   |   |   |
|-----------------|--------|-----------------|-------|---|---|---|---|---|
| Symbol          | <7>    | 6               | 5     | 4 | 3 | 2 | 1 | 0 |
| PER2            | TMKAEN | 0               | 0     | 0 | 0 | 0 | 0 | 0 |
|                 |        |                 |       |   |   |   |   |   |

| TMKAEN | Control of 12-bit interval timer input clock supply                                                                                                                             |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | <ul> <li>Stops input clock supply.</li> <li>SFR used by the 12-bit interval timer cannot be written. The read value is 0H. However, the SFR is not initialized. Note</li> </ul> |
| 1      | Enables input clock supply.<br>• SFR used by the 12-bit interval timer can be read and written.                                                                                 |

Note To initialize the 12-bit interval timer and the SFR used by the 12-bit interval timer, use bit 7 (TMKARES) of PRR2.

Caution 1. Be sure to clear the following bits to 0.

Bits 0 to 6

Caution 2. Do not change the target bit in the PER2 register while operation of each peripheral function is enabled. Change the setting specified by PER2 while operation of each peripheral function assigned to PER2 is stopped.



#### 7.3.2 Peripheral reset control register 2 (PRR2)

This register is used for individual reset control of each peripheral hardware.

This MCU controls reset and reset release of each peripheral hardware supported by the PRR2 register.

To reset the 12-bit interval timer, be sure to set bit 7 (TMKARES) to 1.

The PRR2 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 7 - 3 Format of Peripheral reset control register 2 (PRR2)

| Address: F00FDH |                                     | After reset: 00 | H R/W            |           |                     |             |   |   |
|-----------------|-------------------------------------|-----------------|------------------|-----------|---------------------|-------------|---|---|
| Symbol          | <7>                                 | 6               | 5                | 4         | 3                   | 2           | 1 | 0 |
| PRR2            | TMKARES                             | 0               | 0                | 0         | 0                   | 0           | 0 | 0 |
| [               | TMKARES                             |                 |                  | Reset con | trol of 12-bit inte | erval timer |   | ] |
|                 | 0                                   | 12-bit interval | timer reset rele | ase       |                     |             |   |   |
|                 | 1 12-bit interval timer reset state |                 |                  |           |                     |             |   |   |

### 7.3.3 Subsystem clock supply mode control register (OSMC)

Be sure to set the WUTMMCK0 bit to 1 while using 12-bit interval timer. The OSMC register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 7 - 4 Format of Subsystem clock supply mode control register (OSMC)

| Address: F00F3H |          | After reset: 00H R/W |                 | Note                |                 |           |   |   |
|-----------------|----------|----------------------|-----------------|---------------------|-----------------|-----------|---|---|
| Symbol          | 7        | 6                    | 5               | <4>                 | 3               | 2         | 1 | 0 |
| OSMC            | 0        | 0                    | 0               | WUTMMCK0            | 0               | 0         | 0 | 0 |
|                 | WUTMMCK0 |                      |                 |                     | _               |           |   |   |
|                 | 0        | Do not set the       | WUTMMCK         | ) bit to 0 while us | ng 12-bit inter | val timer |   |   |
|                 | 1        | Low-speed on         | -chip oscillato | or clock            |                 |           |   |   |

Note Be sure to set bits 0, 1, 5, 6 and 7 to 0. Bits 2 and 3 are read-only, write is ignored.



## 7.3.4 12-bit interval timer control register (ITMC)

This register is used to set up the starting and stopping of the 12-bit interval timer operation and to specify the timer compare value.

The ITMC register can be set by a 16-bit memory manipulation instruction. Reset signal generation clears this register to 0FFFH.

#### Figure 7 - 5 Format of 12-bit interval timer control register (ITMC)

| Address: | FFF90H | After reset: 0F | FFH R/W |    |                   |
|----------|--------|-----------------|---------|----|-------------------|
| Symbol   | 15     | 14              | 13      | 12 | 11 to 0           |
| ITMC     | RINTE  | 0               | 0       | 0  | ITCMP11 to ITCMP0 |

| ſ | RINTE | 12-bit interval timer operation control |
|---|-------|-----------------------------------------|
| ľ | 0     | Count operation stopped (count clear)   |
| I | 1     | Count operation started                 |

| ITCMP11 to ITCMP0                                                             | Specification of the 12-bit interval timer compare value                                |  |  |  |  |
|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--|--|--|--|
| 001H                                                                          | These bits generate a fixed-cycle interrupt (count clock cycles x (ITCMP setting + 1)). |  |  |  |  |
| •                                                                             |                                                                                         |  |  |  |  |
| •                                                                             |                                                                                         |  |  |  |  |
| •                                                                             |                                                                                         |  |  |  |  |
| FFFH                                                                          |                                                                                         |  |  |  |  |
| 000H Setting prohibit                                                         |                                                                                         |  |  |  |  |
| Example interrupt cycles when 001H or FFFH is specified for ITCMP11 to ITCMP0 |                                                                                         |  |  |  |  |
| <ul> <li>ITCMP11 to ITCMP0 = 001H, count clock: when fiL = 15 kHz</li> </ul>  |                                                                                         |  |  |  |  |
| 1/15 [kHz] × (1 + 1) = 0.133333 [ms] ≅ 133.33 [μs]                            |                                                                                         |  |  |  |  |
| <ul> <li>ITCMP11 to ITCMP0 = FFFH, count clock: when fiL = 15 kHz</li> </ul>  |                                                                                         |  |  |  |  |
| 1/15 [kHz] × (4095 + 1) ≅ 273.07 [ms]                                         |                                                                                         |  |  |  |  |

Caution 1. Before changing the RINTE bit from 1 to 0, use the interrupt mask flag register to disable the INTIT interrupt servicing. When the operation starts (from 0 to 1) again, clear the ITIF flag, and then enable the interrupt servicing.

Caution 2. The value read from the RINTE bit is applied one count clock cycle after setting the RINTE bit.

Caution 3. When setting the RINTE bit after returned from standby mode and entering standby mode again, confirm that the written value of the RINTE bit is reflected, or wait that more than one clock of the count clock has elapsed after returned from standby mode. Then enter standby mode.

Caution 4. Only change the setting of the ITCMP11 to ITCMP0 bits when RINTE = 0. However, it is possible to change the settings of the ITCMP11 to ITCMP0 bits at the same time as when changing RINTE from 0 to 1 or 1 to 0.



# 7.4 12-bit Interval Timer Operation

# 7.4.1 12-bit interval timer operation timing

The count value specified for the ITCMP11 to ITCMP0 bits is used as an interval to operate an 12-bit interval timer that repeatedly generates interrupt requests (INTIT).

When the RINTE bit is set to 1, the 12-bit counter starts counting.

When the 12-bit counter value matches the value specified for the ITCMP11 to ITCMP0 bits, the 12-bit counter value is cleared to 0, counting continues, and an interrupt request signal (INTIT) is generated at the same time.

The basic operation of the 12-bit interval timer is as follows.

#### Figure 7 - 6 12-bit Interval Timer Operation Timing (ITCMP11 to ITCMP0 = 0FFH, count clock: fi∟ = 15 kHz)





# 7.4.2 Start of count operation and re-enter to HALT/STOP mode after returned from HALT/STOP mode

When setting the RINTE bit after returned from HALT or STOP mode and entering HALT or STOP mode again, write 1 to the RINTE bit, and confirm the written value of the RINTE bit is reflected or wait for at least one cycle of the count clock.

Then, enter HALT or STOP mode.

- After setting RINTE to 1, confirm by polling that the RINTE bit has become 1, and then enter HALT or STOP mode (see **Example 1** in **Figure 7 7**).
- After setting RINTE to 1, wait for at least one cycle of the count clock and then enter HALT or STOP mode (see **Example 2** in **Figure 7 7**).

#### Figure 7 - 7 Procedure of entering to HALT or STOP mode after setting RINTE to 1





# CHAPTER 8 CLOCK OUTPUT/BUZZER OUTPUT CONTROLLER

# 8.1 Functions of Clock Output/Buzzer Output Controller

The clock output controller is intended for clock output for supply to peripheral ICs. Buzzer output is a function to output a square wave of buzzer frequency.

The PCLBUZ0 pin outputs a clock selected by clock output select register n (CKSn).

Figure 8 - 1 shows the Block Diagram of Clock Output/Buzzer Output Controller.

Remark n = 0





Figure 8 - 1 Block Diagram of Clock Output/Buzzer Output Controller



# 8.2 Configuration of Clock Output/Buzzer Output Controller

The clock output/buzzer output controller includes the following hardware.

| Item              | Configuration                          |  |
|-------------------|----------------------------------------|--|
| Control registers | Clock output select registers n (CKSn) |  |
|                   | Port mode register 0 (PM0)             |  |
|                   | Port register 0 (P0)                   |  |

#### Table 8 - 1 Configuration of Clock Output/Buzzer Output Controller

# 8.3 Registers Controlling Clock Output/Buzzer Output Controller

# 8.3.1 Clock output select registers n (CKSn)

These registers set output enable/disable for clock output or for the buzzer frequency output pin (PCLBUZ0), and set the output clock.

Select the clock to be output from the PCLBUZ0 pin by using the CKSn register.

The CKSn register are set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears these registers to 00H.



| Address: FFFA5H (CKS0) |                                                      | After reset: 00 | θH          | R/W                   |                  |                    |                    |                    |
|------------------------|------------------------------------------------------|-----------------|-------------|-----------------------|------------------|--------------------|--------------------|--------------------|
| Symbol                 | <7>                                                  | 6               | 5           | 4                     | 3                | 2                  | 1                  | 0                  |
| CKSn                   | PCLOEn                                               | 0               | 0           | 0                     | 0                | CCSn2              | CCSn1              | CCSn0              |
| Γ                      | PCLOEn                                               |                 | P           | CLBUZ0 pin ou         | itput enable/dis | able specification | on                 |                    |
| ľ                      | 0                                                    | Output disable  | e (default) |                       |                  |                    |                    |                    |
|                        | 1                                                    | Output enable   | 1           |                       |                  |                    |                    |                    |
| [                      | CCSn2 CCSn1 CCSn0 PCLBUZn pin output clock selection |                 |             |                       |                  |                    |                    |                    |
|                        |                                                      |                 |             |                       | fmain =<br>5 MHz | fmain =<br>10 MHz  | fmain =<br>20 MHz  | fmain =<br>24 MHz  |
| Ī                      | 0                                                    | 0               | 0           | fmain                 | 5 MHz            | 10 MHz             | Setting prohibited | Setting prohibited |
|                        | 0                                                    | 0               | 1           | fmain/2               | 2.5 MHz          | 5 MHz              | 10 MHz             | Setting prohibited |
|                        | 0                                                    | 1               | 0           | fmain/2 <sup>2</sup>  | 1.25 MHz         | 2.5 MHz            | 5 MHz              | 6 MHz              |
| ľ                      | 0                                                    | 1               | 1           | fmain/2 <sup>3</sup>  | 625 kHz          | 1.25 MHz           | 2.5 MHz            | 3 MHz              |
|                        | 1                                                    | 0               | 0           | fmain/2 <sup>4</sup>  | 312.5 kHz        | 625 kHz            | 1.25 MHz           | 1.5 MHz            |
| ſ                      | 1                                                    | 0               | 1           | fmain/2 <sup>11</sup> | 2.44 kHz         | 4.88 kHz           | 9.77 kHz           | 11.7 kHz           |
|                        | 1                                                    | 1               | 0           | fmain/2 <sup>12</sup> | 1.22 kHz         | 2.44 kHz           | 4.88 kHz           | 5.86 kHz           |
|                        | 1                                                    | 1               | 1           | fmain/2 <sup>13</sup> | 610 Hz           | 1.22 kHz           | 2.44 kHz           | 2.93 kHz           |

#### Figure 8 - 2 Format of Clock output select registers n (CKSn)

Caution 1. Change the output clock after disabling clock output (PCLOEn = 0).

Caution 2. To shift to STOP mode, set PCLOEn = 0 before executing the STOP instruction.

Remark 1. n = 0 Remark 2. fmain: Main system clock frequency



# 8.3.2 Registers controlling port functions of pins to be used for clock or buzzer output

Using a port pin for clock or buzzer output requires setting of the registers that control the port functions multiplexed on the target pin (port mode register (PMxx), port register (Pxx)). For details, see **4.3.1 Port mode registers (PMxx)** and **4.3.2 Port registers (Pxx)**.

Specifically, using a port pin with a multiplexed clock or buzzer output function (e.g. P00/INTP12/TI05/TO05/ ANI16/PCLBUZ0) for clock or buzzer output, requires setting the corresponding bits in the port mode register (PMxx) and port register (Pxx) to 0.



# 8.4 Operations of Clock Output/Buzzer Output Controller

One pin can be used to output a clock or buzzer sound.

The PCLBUZ0 pin outputs a clock/buzzer selected by the clock output select register 0 (CKS0).

## 8.4.1 Operation as output pin

The PCLBUZ0 pin is output as the following procedures.

- <1> Set 0 in the bit of the port mode register (PMxx) and port register (Pxx) which correspond to the port which has a pin used as the PCLBUZ0 pin.
- <2> Select the output frequency with bits 0 to 3 (CCSn0 to CCSn2) of the clock output select register (CKSn) of the PCLBUZ0 pin (output in disabled status).
- <3> Set bit 7 (PCLOEn) of the CKSn register to 1 to enable clock/buzzer output.
- Remark 1. The controller used for outputting the clock starts or stops outputting the clock one clock after enabling or disabling clock output (PCLOEn bit) is switched. At this time, pulses with a narrow width are not output. Figure 8 - 3 shows enabling or stopping output using the PCLOEn bit and the timing of outputting the clock.

Remark 2. n = 0





## 8.5 Cautions of clock output/buzzer output controller

If STOP mode is entered within 1.5 clock cycles output from the PCLBUZ0 pin after the output is disabled (PCLOEn = 0), the PCLBUZ0 output width becomes shorter.



# **CHAPTER 9 WATCHDOG TIMER**

# 9.1 Functions of Watchdog Timer

The counting operation of the watchdog timer is set by the option byte (000C0H).

The watchdog timer operates on the low-speed on-chip oscillator clock (fiL).

The watchdog timer is used to detect an inadvertent program loop. If a program loop is detected, an internal reset signal is generated.

Program loop is detected in the following cases.

- If the watchdog timer counter overflows
- If a 1-bit manipulation instruction is executed on the watchdog timer enable register (WDTE)
- If data other than "ACH" is written to the WDTE register
- If data is written to the WDTE register during a window close period

When a reset occurs due to the watchdog timer, bit 4 (WDTRF) of the reset control flag register (RESF) is set to 1. For details of the RESF register, see **CHAPTER 16 RESET FUNCTION**.

When 75% + 1/2 fiL of the overflow time is reached, an interval interrupt can be generated.



# 9.2 Configuration of Watchdog Timer

The watchdog timer includes the following hardware.

| Table 9 - 1 Configuration | of Watchdog Timer |
|---------------------------|-------------------|
|---------------------------|-------------------|

| Item             | Configuration                         |  |
|------------------|---------------------------------------|--|
| Counter          | Internal counter (17 bits)            |  |
| Control register | Watchdog timer enable register (WDTE) |  |

How the counter operation is controlled, overflow time, window open period, and interval interrupt are set by the option byte.

| Setting of Watchdog Timer                                           | Option Byte (000C0H)            |
|---------------------------------------------------------------------|---------------------------------|
| Watchdog timer interval interrupt                                   | Bit 7 (WDTINT)                  |
| Window open period                                                  | Bits 6 and 5 (WINDOW1, WINDOW0) |
| Controlling counter operation of watchdog timer                     | Bit 4 (WDTON)                   |
| Overflow time of watchdog timer                                     | Bits 3 to 1 (WDCS2 to WDCS0)    |
| Controlling counter operation of watchdog timer (in HALT/STOP mode) | Bit 0 (WDSTBYON)                |

Remark For the option byte, see CHAPTER 21 OPTION BYTE.





Remark fiL: Low-speed on-chip oscillator clock



#### 9.3 Register Controlling Watchdog Timer

The watchdog timer is controlled by the watchdog timer enable register (WDTE).

# 9.3.1 Watchdog timer enable register (WDTE)

Writing "ACH" to the WDTE register clears the watchdog timer counter and starts counting again. This register can be set by an 8-bit memory manipulation instruction. Reset signal generation sets this register to 9AH or 1AH <sup>Note</sup>.

#### Figure 9 - 2 Format of Watchdog timer enable register (WDTE)

| Address: | FFFABH | BH After reset: 1AH/9AH Note |   | R/W |   |   |   |   |
|----------|--------|------------------------------|---|-----|---|---|---|---|
| Symbol   | 7      | 6                            | 5 | 4   | 3 | 2 | 1 | 0 |
| WDTE     |        |                              |   |     |   |   |   |   |

Note

The WDTE register reset value differs depending on the WDTON bit setting value of the option byte (000C0H). To operate watchdog timer, set the WDTON bit to 1.

| WDTON Bit Setting Value                     | WDTE Register Reset Value |
|---------------------------------------------|---------------------------|
| 0 (watchdog timer count operation disabled) | 1AH                       |
| 1 (watchdog timer count operation enabled)  | 9AH                       |

Caution 1. If a value other than "ACH" is written to the WDTE register, an internal reset signal is generated.

Caution 2. If a 1-bit memory manipulation instruction is executed for the WDTE register, an internal reset signal is generated.

Caution 3. The value read from the WDTE register is 9AH/1AH (this differs from the written value (ACH)).



# 9.4 Operation of Watchdog Timer

# 9.4.1 Controlling operation of watchdog timer

- 1. When the watchdog timer is used, its operation is specified by the option byte (000C0H).
- Enable counting operation of the watchdog timer by setting bit 4 (WDTON) of the option byte (000C0H) to 1 (the counter starts operating after a reset release) (for details, see **CHAPTER 21**).

| WDTON | Watchdog Timer Counter                                    |  |
|-------|-----------------------------------------------------------|--|
| 0     | Counter operation disabled (counting stopped after reset) |  |
| 1     | Counter operation enabled (counting started after reset)  |  |

- Set an overflow time by using bits 3 to 1 (WDCS2 to WDCS0) of the option byte (000C0H) (for details, see 9.4.2 and CHAPTER 21).
- Set a window open period by using bits 6 and 5 (WINDOW1 and WINDOW0) of the option byte (000C0H) (for details, see **9.4.3** and **CHAPTER 21**).
- 2. After a reset release, the watchdog timer starts counting.
- 3. By writing "ACH" to the watchdog timer enable register (WDTE) after the watchdog timer starts counting and before the overflow time set by the option byte, the watchdog timer is cleared and starts counting again.
- 4. After that, write the WDTE register the second time or later after a reset release during the window open period. If the WDTE register is written during a window close period, an internal reset signal is generated.
- 5. If the overflow time expires without "ACH" written to the WDTE register, an internal reset signal is generated.

An internal reset signal is generated in the following cases.

- If a 1-bit manipulation instruction is executed on the WDTE register
- If data other than "ACH" is written to the WDTE register
- Caution 1.When data is written to the watchdog timer enable register (WDTE) for the first time after reset release, the watchdog timer is cleared in any timing regardless of the window open time, as long as the register is written before the overflow time, and the watchdog timer starts counting again.
- Caution 2. After "ACH" is written to the WDTE register, an error of up to 2 clocks (fIL) may occur before the watchdog timer is cleared.
- Caution 3. The watchdog timer can be cleared immediately before the count value overflows.



# Caution 4. The operation of the watchdog timer in the HALT and STOP modes differs as follows depending on the set value of bit 0 (WDSTBYON) of the option byte (000C0H).

|                | WDSTBYON = 0                    | WDSTBYON = 1                        |
|----------------|---------------------------------|-------------------------------------|
| In HALT mode   | Watchdog timer operation stops. | Watchdog timer operation continues. |
| In STOP mode   |                                 |                                     |
| In SNOOZE mode |                                 |                                     |

If WDSTBYON = 0, the watchdog timer resumes counting after the HALT or STOP mode is released. At this time, the counter is cleared to 0 and counting starts.

When operating with the X1 oscillation clock after releasing the STOP mode, the CPU starts operating after the oscillation stabilization time has elapsed.

Therefore, if the period between the STOP mode release and the watchdog timer overflow is short, an overflow occurs during the oscillation stabilization time, causing a reset.

Consequently, set the overflow time in consideration of the oscillation stabilization time when operating with the X1 oscillation clock and when the watchdog timer is to be cleared after the STOP mode release by an interval interrupt.

# 9.4.2 Setting overflow time of watchdog timer

Set the overflow time of the watchdog timer by using bits 3 to 1 (WDCS2 to WDCS0) of the option byte (000C0H).

If an overflow occurs, an internal reset signal is generated. The present count is cleared and the watchdog timer starts counting again by writing "ACH" to the watchdog timer enable register (WDTE) during the window open period before the overflow time.

The following overflow times can be set.

| WDCS2 | WDCS1 | WDCS0 | Overflow Time of Watchdog Timer<br>(fiL = 17.25 kHz (MAX.)) |  |
|-------|-------|-------|-------------------------------------------------------------|--|
| 0     | 0     | 0     | 2 <sup>6</sup> /fiL (3.71 ms)                               |  |
| 0     | 0     | 1     | 2 <sup>7</sup> /fi∟ (7.42 ms)                               |  |
| 0     | 1     | 0     | 2 <sup>8</sup> /fiL (14.84 ms)                              |  |
| 0     | 1     | 1     | 2 <sup>9</sup> /fiL (29.68 ms)                              |  |
| 1     | 0     | 0     | 2 <sup>11</sup> /fi∟ (118.72 ms)                            |  |
| 1     | 0     | 1     | 2 <sup>13</sup> /fi∟ (474.89 ms)                            |  |
| 1     | 1     | 0     | 2 <sup>14</sup> /fi∟ (949.79 ms)                            |  |
| 1     | 1     | 1     | 2 <sup>16</sup> /fi∟ (3799.18 ms)                           |  |

**Remark** fil: Low-speed on-chip oscillator clock frequency



#### 9.4.3 Setting window open period of watchdog timer

Set the window open period of the watchdog timer by using bits 6 and 5 (WINDOW1, WINDOW0) of the option byte (000C0H). The outline of the window is as follows.

- If "ACH" is written to the watchdog timer enable register (WDTE) during the window open period, the watchdog timer is cleared and starts counting again.
- Even if "ACH" is written to the WDTE register during the window close period, an abnormality is detected and an internal reset signal is generated.

Example: If the window open period is 50%



Caution When data is written to the WDTE register for the first time after reset release, the watchdog timer is cleared in any timing regardless of the window open time, as long as the register is written before the overflow time, and the watchdog timer starts counting again.

The window open period can be set is as follows.

| WINDOW1 | WINDOW0 | Window Open Period of Watchdog Timer |
|---------|---------|--------------------------------------|
| 0       | 0       | Setting prohibited                   |
| 0       | 1       | 50%                                  |
| 1       | 0       | 75% Note                             |
| 1       | 1       | 100%                                 |

#### Table 9 - 4 Setting Window Open Period of Watchdog Timer

**Note** When the window open period is set to 75%, clearing the counter of the watchdog timer (writing ACH to WDTE) must proceed outside the corresponding period from among those listed below, over which clearing of the counter is prohibited

(for example, confirming that the interval timer interrupt request flag (WDTIIF) of the watchdog timer is set).

| WDCS2 | WDCS1 | WDCS0 | Watchdog timer overflow time<br>(fi∟ = 17.25 kHz (MAX.)) | Period over which clearing the counter is prohibited when the window open period is set to 75% |
|-------|-------|-------|----------------------------------------------------------|------------------------------------------------------------------------------------------------|
| 0     | 0     | 0     | 2 <sup>6</sup> /fi∟ (3.71 ms)                            | 1.85 ms to 2.51 ms                                                                             |
| 0     | 0     | 1     | 2 <sup>7</sup> /fi∟ (7.42 ms)                            | 3.71 ms to 5.02 ms                                                                             |
| 0     | 1     | 0     | 2 <sup>8</sup> /fi∟ (14.84 ms)                           | 7.42 ms to 10.04 ms                                                                            |
| 0     | 1     | 1     | 2 <sup>9</sup> /fi∟ (29.68 ms)                           | 14.84 ms to 20.08 ms                                                                           |
| 1     | 0     | 0     | 2 <sup>11</sup> /fi∟ (118.72 ms)                         | 56.36 ms to 80.32 ms                                                                           |
| 1     | 0     | 1     | 2 <sup>13</sup> /fi∟ (474.90 ms)                         | 237.44 ms to 321.26 ms                                                                         |
| 1     | 1     | 0     | 2 <sup>14</sup> /fi∟ (949.80 ms)                         | 474.89 ms to 642.51 ms                                                                         |
| 1     | 1     | 1     | 2 <sup>16</sup> /fi∟ (3799.19 ms)                        | 1899.59 ms to 2570.04 ms                                                                       |

Caution

on When bit 0 (WDSTBYON) of the option byte (000C0H) = 0, the window open period is 100% regardless of the values of the WINDOW1 and WINDOW0 bits.

**Remark** If the overflow time is set to 2<sup>9</sup>/fiL, the window close time and open time are as follows.

|                   | Setting of Window Open Period |                   |               |  |  |
|-------------------|-------------------------------|-------------------|---------------|--|--|
|                   | 50%                           | 75%               | 100%          |  |  |
| Window close time | 0 to 20.08 ms                 | 0 to 10.04 ms     | None          |  |  |
| Window open time  | 20.08 to 29.68 ms             | 10.04 to 29.68 ms | 0 to 29.68 ms |  |  |

<When window open period is 50%>

Overflow time:

2<sup>9</sup>/fiL (MAX.) = 2<sup>9</sup>/17.25 kHz (MAX.) = 29.68 ms

Window close time:

0 to 2<sup>9</sup>/fiL (MIN.) × (1 - 0.5) = 0 to 2<sup>9</sup>/12.75 kHz × 0.5 = 0 to 20.08 ms

• Window open time:

29/fiL (MIN.) × (1 - 0.5) to 29/fiL (MAX.) = 29/12.75 kHz × 0.5 to 29/17.25 kHz = 20.08 to 29.68 ms

# 9.4.4 Setting watchdog timer interval interrupt

Setting bit 7 (WDTINT) of an option byte (000C0H) can generate an interval interrupt (INTWDTI) when 75% + 1/2 fiL of the overflow time is reached.

| WDTINT | Use of Watchdog Timer Interval Interrupt                                       |  |
|--------|--------------------------------------------------------------------------------|--|
| 0      | nterval interrupt is not used.                                                 |  |
| 1      | nterval interrupt is generated when 75% + 1/2 fi∟ of overflow time is reached. |  |

Caution When operating with the X1 oscillation clock after releasing the STOP mode, the CPU starts operating after the oscillation stabilization time has elapsed.

Therefore, if the period between the STOP mode release and the watchdog timer overflow is short, an overflow occurs during the oscillation stabilization time, causing a reset.

Consequently, set the overflow time in consideration of the oscillation stabilization time when operating with the X1 oscillation clock and when the watchdog timer is to be cleared after the STOP mode release by an interval interrupt.

**Remark** The watchdog timer continues counting even after INTWDTI is generated (until ACH is written to the watchdog timer enable register (WDTE)). If ACH is not written to the WDTE register before the overflow time, an internal reset signal is generated.



# CHAPTER 10 A/D CONVERTER

The number of analog input channels of the A/D converter is shown below.

|                                        | with USB                        | without USB                     |  |
|----------------------------------------|---------------------------------|---------------------------------|--|
|                                        | 32-pin                          | 32-pin                          |  |
| Analog input channels                  | 8 ch                            | 8 ch                            |  |
| · ···································· | (ANI0 to ANI5, ANI16 and ANI17) | (ANI0 to ANI5, ANI16 and ANI17) |  |

# 10.1 Function of A/D Converter

The A/D converter is used to convert analog input signals into digital values, and is configured to control analog inputs, including up to 8 channels of A/D converter analog inputs (ANI0 to ANI5, ANI16 and ANI17). 10-bit or 8-bit resolution can be selected by the ADTYP bit of the A/D converter mode register 2 (ADM2). The A/D converter has the following function.

#### • 10-bit/8-bit resolution A/D conversion

10-bit or 8-bit resolution A/D conversion is carried out repeatedly for one analog input channel selected from ANI0 to ANI5, ANI16 and ANI17. Each time an A/D conversion operation ends, an interrupt request (INTAD) is generated (when in the select mode).



#### Various A/D conversion modes can be specified by using the mode combinations below.

| Trigger mode              | Software trigger                | Conversion is started by software.                                                                                                                                                                                                                                                                     |
|---------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | Hardware trigger no-wait mode   | Conversion is started by detecting a hardware trigger.                                                                                                                                                                                                                                                 |
|                           | Hardware trigger wait mode      | The power is turned on by detecting a hardware trigger while the<br>system is off and in the conversion standby state, and conversion<br>is then started automatically after the stabilization wait time<br>passes.<br>When using the SNOOZE mode function, specify the hardware<br>trigger wait mode. |
| Channel selection mode    | Select mode                     | A/D conversion is performed on the analog input of one selected channel.                                                                                                                                                                                                                               |
|                           | Scan mode                       | A/D conversion is performed on the analog input of four channels<br>in order. Four consecutive channels can be selected from ANI0 to<br>ANI5, ANI16 and ANI17 as analog input channels.                                                                                                                |
| Conversion operation mode | One-shot conversion mode        | A/D conversion is performed on the selected channel once.                                                                                                                                                                                                                                              |
|                           | Sequential conversion mode      | A/D conversion is sequentially performed on the selected channels until it is stopped by software.                                                                                                                                                                                                     |
| Operation voltage mode    | Standard 1 or standard 2 mode   | Conversion is done in the operation voltage range of 2.7 V $\leq$ VDD $\leq$ 5.5 V.                                                                                                                                                                                                                    |
| Sampling time selection   | Sampling clock cycles:<br>7 faD | The sampling time in standard 1 mode is seven cycles of the conversion clock (fAD). Select this mode when the output impedance of the analog input source is high and the sampling time should be long.                                                                                                |
|                           | Sampling clock cycles:<br>5 fAD | The sampling time in standard 2 mode is five cycles of the conversion clock (fAD). Select this mode when enough sampling time is ensured (for example, when the output impedance of the analog input source is low).                                                                                   |





Figure 10 - 1 Block Diagram of A/D Converter



# 10.2 Configuration of A/D Converter

The A/D converter includes the following hardware.

(1) ANI0 to ANI5, ANI16 and ANI17

These are the analog input pins of the 8 channels of the A/D converter. They input analog signals to be converted into digital signals. Pins other than the one selected as the analog input pin can be used as I/O port pins.

(2) Sample & hold circuit

The sample & hold circuit samples each of the analog input voltages sequentially sent from the input circuit, and sends them to the A/D voltage comparator. This circuit also holds the sampled analog input voltage during A/D conversion.

(3) A/D voltage comparator

This A/D voltage comparator compares the voltage generated from the voltage tap of the comparison voltage generator with the analog input voltage. If the analog input voltage is found to be greater than the reference voltage (1/2 AVREF) as a result of the comparison, the most significant bit (MSB) of the successive approximation register (SAR) is set. If the analog input voltage is less than the reference voltage (1/2 AVREF), the MSB bit of the SAR is reset.

After that, bit 8 of the SAR register is automatically set, and the next comparison is made. The voltage tap of the comparison voltage generator is selected by the value of bit 9, to which the result has been already set.

Bit 9 = 0: (1/4 AVREF) Bit 9 = 1: (3/4 AVREF)

The voltage tap of the comparison voltage generator and the analog input voltage are compared and bit 8 of the SAR register is manipulated according to the result of the comparison.

Analog input voltage  $\geq$  Voltage tap of comparison voltage generator: Bit 8 = 1 Analog input voltage  $\leq$  Voltage tap of comparison voltage generator: Bit 8 = 0

Comparison is continued like this to bit 0 of the SAR register. When performing A/D conversion at a resolution of 8 bits, the comparison continues until bit 2 of the SAR register.

- (4) Comparison voltage generator
   The comparison voltage generator generates the comparison voltage input from an analog input pin.
- (5) Successive approximation register (SAR)

The SAR register is a register that sets voltage tap data whose values from the comparison voltage generator match the voltage values of the analog input pins, 1 bit at a time starting from the most significant bit (MSB). If data is set in the SAR register all the way to the least significant bit (LSB) (end of A/D conversion), the contents of the SAR register (conversion results) are held in the A/D conversion result register (ADCR). When all the specified A/D conversion operations have ended, an A/D conversion end interrupt request signal (INTAD) is generated.



**Remark** AVREF: The + side reference voltage of the A/D converter. This can be selected from AVREFP, the internal reference voltage (1.45 V), and VDD.

#### (6) 10-bit A/D conversion result register (ADCR)

The A/D conversion result is loaded from the successive approximation register to this register each time A/D conversion is completed, and the ADCR register holds the A/D conversion result in its higher 10 bits (the lower 6 bits are fixed to 0).

#### (7) 8-bit A/D conversion result register (ADCRH)

The A/D conversion result is loaded from the successive approximation register to this register each time A/D conversion is completed, and the ADCRH register stores the higher 8 bits of the A/D conversion result.

(8) Controller

This circuit controls the conversion time of an input analog signal that is to be converted into a digital signal, as well as starting and stopping of the conversion operation. When A/D conversion has been completed, this controller generates INTAD through the A/D conversion result upper limit/lower limit comparator.

(9) AVREFP pin

This pin inputs an external reference voltage (AVREFP).

If using AVREFP as the + side reference voltage of the A/D converter, set the ADREFP1 and ADREFP0 bits of A/D converter mode register 2 (ADM2) to 0 and 1, respectively.

The analog signals input to ANI0 to ANI5, ANI16 and ANI17 are converted to digital signals based on the voltage applied between AVREFP and the - side reference voltage (AVREFM/VSS).

In addition to AVREFP, it is possible to select VDD or the internal reference voltage (1.45 V) as the + side reference voltage of the A/D converter.

(10) AVREFM pin

This pin inputs an external reference voltage (AVREFM). If using AVREFM as the – side reference voltage of the A/D converter, set the ADREFM bit of the ADM2 register to 1.

In addition to AVREFM, it is possible to select VSS as the - side reference voltage of the A/D converter.



# 10.3 Registers Controlling A/D Converter

The A/D converter is controlled by the following registers.

- Peripheral enable register 0 (PER0)
- A/D converter mode register 0 (ADM0)
- A/D converter mode register 1 (ADM1)
- A/D converter mode register 2 (ADM2)
- 10-bit A/D conversion result register (ADCR)
- 8-bit A/D conversion result register (ADCRH)
- Analog input channel specification register (ADS)
- Conversion result comparison upper limit setting register (ADUL)
- Conversion result comparison lower limit setting register (ADLL)
- A/D test register (ADTES)
- Port mode control registers 0, 2 (PMC0, PMC2)
- Port mode registers 0, 2 (PM0, PM2)



## 10.3.1 Peripheral enable register 0 (PER0)

This register is used to enable or disable supplying the clock to the peripheral hardware. Clock supply to a hardware macro that is not used is stopped in order to reduce the power consumption and noise. When the A/D converter is used, be sure to set bit 5 (ADCEN) of this register to 1. The PER0 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 10 - 2 Format of Peripheral Enable Register 0 (PER0)

| Address: | F00F0H       | After reset: 00 | H R/W |         |   |        |   |        |
|----------|--------------|-----------------|-------|---------|---|--------|---|--------|
| Symbol   | <7>          | <6>             | <5>   | <4>     | 3 | <2>    | 1 | <0>    |
| PER0     | IICA2EN Note | IICA1EN         | ADCEN | IICA0EN | 0 | SAU0EN | 0 | TAU0EN |

| ADCEN | Control of A/D converter input clock supply                                                                                                            |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0     | <ul><li>Stops input clock supply.</li><li>SFR used by the A/D converter cannot be written.</li><li>The A/D converter is in the reset status.</li></ul> |  |
| 1     | <ul><li>Enables input clock supply.</li><li>SFR used by the A/D converter can be read/written.</li></ul>                                               |  |

Note This bit is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.

- Caution 1. When setting the A/D converter, be sure to set the following registers first while the ADCEN bit is set to 1. If ADCEN = 0, the values of the A/D converter control registers are cleared to their initial values and writing to them is ignored (except for port mode registers 0 and 2 (PM0, PM2), port mode control registers 0, and 2 (PMC0, PMC2)).
  - A/D converter mode register 0 (ADM0)
  - A/D converter mode register 1 (ADM1)
  - A/D converter mode register 2 (ADM2)
  - 10-bit A/D conversion result register (ADCR)
  - 8-bit A/D conversion result register (ADCRH)
  - Analog input channel specification register (ADS)
  - · Conversion result comparison upper limit setting register (ADUL)
  - Conversion result comparison lower limit setting register (ADLL)
  - A/D test register (ADTES).

Caution 2. Be sure to clear the bits 1, 3 to 0.



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

This register sets the conversion time for analog input to be A/D converted, and starts/stops conversion. The ADM0 register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 10 - 3 Format of A/D Converter Mode Register 0 (ADM0)

| Address:                                                        | FFF30H                                                                                                                                                                                                                                                            | After reset: 00 | H R/W      |            |                  |            |            |      |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|------------|------------------|------------|------------|------|
| Symbol                                                          | <7>                                                                                                                                                                                                                                                               | 6               | 5          | 4          | 3                | 2          | 1          | <0>  |
| ADM0                                                            | ADCS                                                                                                                                                                                                                                                              | ADMD            | FR2 Note 1 | FR1 Note 1 | FR0 Note 1       | LV1 Note 1 | LV0 Note 1 | ADCE |
| Г                                                               | ADCS                                                                                                                                                                                                                                                              |                 |            | A/D conv   | version operatio | on control |            |      |
|                                                                 | Stops conversion operation<br>0 [When read]<br>Conversion stopped/standby status                                                                                                                                                                                  |                 |            |            |                  |            |            |      |
| -                                                               | Enables conversion operation<br>[When readNote 2 <sup>Note 2</sup> ]<br>1 While in the software trigger mode: Conversion operation status<br>While in the hardware trigger wait mode: A/D power supply stabilization wait status +<br>conversion operation status |                 |            |            |                  |            |            |      |
| ADMD Specification of the A/D conversion channel selection mode |                                                                                                                                                                                                                                                                   |                 |            |            |                  |            |            |      |

| ADMD | Specification of the A/D conversion channel selection mode |
|------|------------------------------------------------------------|
| 0    | Select mode                                                |
| 1    | Scan mode                                                  |

| ADCE | A/D voltage comparator operation control Note 2 |
|------|-------------------------------------------------|
| 0    | Stops A/D voltage comparator operation          |
| 1    | Enables A/D voltage comparator operation        |

- Note 1. For details of the FR2 to FR0, LV1, LV0 bits, and A/D conversion, see Table 10 3 A/D Conversion Time Selection.
- **Note 2.** While in the software trigger mode or hardware trigger no-wait mode, the operation of the A/D voltage comparator is controlled by the ADCS and ADCE bits, and it takes 1 μs from the start of operation for the operation to stabilize. Therefore, when the ADCS bit is set to 1 after 1 μs or more has elapsed from the time ADCE bit is set to 1, the conversion result at that time has priority over the first conversion result. Otherwise, ignore data of the first conversion.
- Caution 1. Change the ADMD, FR2 to FR0, LV1, and LV0 bits while conversion is stopped (ADCS = 0, ADCE = 0).
- Caution 2. Do not set the ADCS bit to 1 and the ADCE bit to 0 at the same time.
- Caution 3. Do not change the ADCS and ADCE bits from 0 to 1 at the same time by using an 8-bit manipulation instruction. Be sure to set these bits in the order described in 11.7 A/D Converter Setup Flowchart.



| ADCS | ADCE | A/D Conversion Operation     |  |  |  |  |
|------|------|------------------------------|--|--|--|--|
| 0    | 0    | Conversion stopped state     |  |  |  |  |
| 0    | 1    | Conversion standby state     |  |  |  |  |
| 1    | 0    | Setting prohibited           |  |  |  |  |
| 1    | 1    | Conversion-in-progress state |  |  |  |  |

#### Table 10 - 1 Settings of ADCS and ADCE Bits

# Table 10 - 2 Setting and Clearing Conditions for ADCS Bit

|                  | A/D Convers | sion Mode                  | Set Conditions       | Clear Conditions                                                                                                                                      |  |
|------------------|-------------|----------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Software trigger | Select mode | Sequential conversion mode | When 1 is written to | When 0 is written to ADCS                                                                                                                             |  |
|                  |             | One-shot conversion mode   | ADCS                 | <ul> <li>When 0 is written to ADCS</li> <li>The bit is automatically cleared to 0 when A/D conversion ends.</li> </ul>                                |  |
|                  | Scan mode   | Sequential conversion mode |                      | When 0 is written to ADCS                                                                                                                             |  |
|                  |             | One-shot conversion mode   |                      | <ul> <li>When 0 is written to ADCS</li> <li>The bit is automatically cleared to 0 when conversion ends on the specified four channels.</li> </ul>     |  |
| Hardware trigger | Select mode | Sequential conversion mode | _                    | When 0 is written to ADCS                                                                                                                             |  |
| no-wait mode     |             | One-shot conversion mode   |                      | When 0 is written to ADCS                                                                                                                             |  |
|                  | Scan mode   | Sequential conversion mode |                      | When 0 is written to ADCS                                                                                                                             |  |
|                  |             | One-shot conversion mode   |                      | When 0 is written to ADCS                                                                                                                             |  |
| Hardware trigger | Select mode | Sequential conversion mode | When a hardware      | When 0 is written to ADCS                                                                                                                             |  |
| wait mode        |             | One-shot conversion mode   | trigger is input     | <ul> <li>When 0 is written to ADCS</li> <li>The bit is automatically cleared to 0 when A/D conversion ends.</li> </ul>                                |  |
|                  | Scan mode   | Sequential conversion mode | _                    | When 0 is written to ADCS                                                                                                                             |  |
|                  |             | One-shot conversion mode   |                      | <ul> <li>When 0 is written to ADCS</li> <li>The bit is automatically cleared to 0 when<br/>conversion ends on the specified four channels.</li> </ul> |  |





Figure 10 - 4 Timing Chart When A/D Voltage Comparator Is Used

**Note 1.** While in the software trigger mode or hardware trigger no-wait mode, the time from the rising of the ADCE bit to the falling of the ADCS bit must be 1 µs or longer to stabilize the internal circuit.

|     | ADM0 |     | Conversion Clock | Conversion Start Time (Number of fCLK Clocks)           |                            |  |  |  |
|-----|------|-----|------------------|---------------------------------------------------------|----------------------------|--|--|--|
| FR2 | FR1  | FR0 | (fAD)            | Software trigger mode/<br>Hardware trigger no wait mode | Hardware trigger wait mode |  |  |  |
| 0   | 0    | 0   | fclk/64          | 63                                                      | 1                          |  |  |  |
| 0   | 0    | 1   | fclk/32          | 31                                                      |                            |  |  |  |
| 0   | 1    | 0   | fclk/16          | 15                                                      |                            |  |  |  |
| 0   | 1    | 1   | fclk/8           | 7                                                       |                            |  |  |  |
| 1   | 0    | 0   | fclk/6           | 5                                                       |                            |  |  |  |
| 1   | 0    | 1   | fclk/5           | 4                                                       |                            |  |  |  |
| 1   | 1    | 0   | fclk/4           | 3                                                       |                            |  |  |  |
| 1   | 1    | 1   | fclk/2           | 1                                                       |                            |  |  |  |

Note 2. The following time is the maximum amount of time necessary to start conversion.

However, for the second and subsequent conversion in sequential conversion mode and for conversion of the channel specified by scan 1, 2, and 3 in scan mode, the conversion start time and stabilization wait time for A/D power supply do not occur after a hardware trigger is detected.

- Caution 1. If using the hardware trigger wait mode, setting the ADCS bit to 1 is prohibited (but the bit is automatically switched to 1 when the hardware trigger signal is detected). However, it is possible to clear the ADCS bit to 0 to specify the A/D conversion standby status.
- Caution 2. While in the one-shot conversion mode of the hardware trigger no-wait mode, the ADCS flag is not automatically cleared to 0 when A/D conversion ends. Instead, 1 is retained.
- Caution 3. Only rewrite the value of the ADCE bit when ADCS = 0 (while in the conversion stopped/conversion standby status).
- Caution 4. To complete A/D conversion, specify at least the following time as the hardware trigger interval:

 Hardware trigger no wait mode:
 2 fcLK clock + A/D conversion time

 Hardware trigger wait mode:
 2 fcLK clock + stabilization wait time + A/D conversion time

**Remark** fCLK: CPU/peripheral hardware clock frequency

#### Table 10 - 3 A/D Conversion Time Selection (1/2)

| A/D Converter Mode Register 0 |     |        |     | ster 0 | Mode     | Conversion  | Number of                  | Conversion |                                                            | Conversion         | n Time at 10-      | Bit Resolutio                    | n                                 |        |           |
|-------------------------------|-----|--------|-----|--------|----------|-------------|----------------------------|------------|------------------------------------------------------------|--------------------|--------------------|----------------------------------|-----------------------------------|--------|-----------|
|                               | (   | (ADM0) | )   |        |          | Clock (fAD) | Conversion<br>Clock Note 1 | Time       | $2.7 \text{ V} \le \text{V}_{\text{DD}} \le 5.5 \text{ V}$ |                    |                    |                                  |                                   |        |           |
| FR2                           | FR1 | FR0    | LV1 | LV0    |          |             |                            |            | fclk =<br>1 MHz                                            | fclk =<br>4 MHz    | fclk =<br>8 MHz    | fclk =<br>16 MHz                 | fclk =<br>24 MHz                  |        |           |
| 0                             | 0   | 0      | 1   | 0      | Normal 1 | fclk/64     | 19 fAD<br>(number of       | 1216/fclk  | Setting prohibited                                         | Setting prohibited | Setting prohibited | Setting prohibited               | Setting prohibited                |        |           |
| 0                             | 0   | 1      |     |        |          | fclk/32     | sampling<br>clock:         | 608/fclk   |                                                            |                    |                    | 38 µs                            | 25.3333 µs                        |        |           |
| 0                             | 1   | 0      |     |        |          | fclk/16     | 7 fad)                     | 304/fclk   |                                                            |                    | 38 µs              | 19 µs                            | 12.6667 µs                        |        |           |
| 0                             | 1   | 1      |     |        |          | fclk/8      |                            | 152/fclk   |                                                            | 38 µs              | 19 µs              | 9.5 µs                           | 6.3333 µs                         |        |           |
| 1                             | 0   | 0      |     |        |          | fclk/6      |                            | 114/fclk   |                                                            | 28.5 µs            | 14.25 µs           | 7.125 µs                         | 4.7500 µs                         |        |           |
| 1                             | 0   | 1      |     |        |          | fclk/5      |                            | 95/fclk    |                                                            | 23.75 µs           | 11.875 µs          | 5.9375 µs                        | 3.9583 µs                         |        |           |
| 1                             | 1   | 0      |     |        |          | fclk/4      |                            | 76/fclk    |                                                            | 19 µs              | 9.5 µs             | 4.75 µs                          | 3.1667 µs<br><sub>Note 2, 3</sub> |        |           |
| 1                             | 1   | 1      |     |        |          | fclk/2      |                            | 38/fclk    | 38 µs                                                      | 9.5 µs             | 4.75 µs            | 2.375 µs<br><sub>Note 2,</sub> 3 | Setting prohibited                |        |           |
| 0                             | 0   | 0      | 1   | 1      | Normal 2 | fclk/64     | 17 fAD<br>(number of       | 1088/fclk  | Setting prohibited                                         | Setting prohibited | Setting prohibited | Setting prohibited               | Setting prohibited                |        |           |
| 0                             | 0   | 1      |     |        |          | fclk/32     | sampling<br>clock:         | 544/fclk   |                                                            |                    |                    | 34 µs                            | 22.6667 µs                        |        |           |
| 0                             | 1   | 0      |     |        |          | fclk/16     | 5 fad)                     | 272/fclk   |                                                            |                    | 34 µs              | 17 µs                            | 11.3333 µs                        |        |           |
| 0                             | 1   | 1      |     |        |          | fclk/8      |                            |            |                                                            | 136/fclk           |                    | 34 µs                            | 17 µs                             | 8.5 µs | 5.6667 µs |
| 1                             | 0   | 0      |     |        |          | fclk/6      |                            | 102/fclk   |                                                            | 25.5 µs            | 12.75 µs           | 6.375 µs                         | 4.2500 µs                         |        |           |
| 1                             | 0   | 1      |     |        |          | fclk/5      |                            | 85/fclk    |                                                            | 21.25 µs           | 10.625 µs          | 5.3125 µs                        | 3.5417 μs<br>Note 2               |        |           |
| 1                             | 1   | 0      |     |        |          | fclk/4      |                            | 68/fclk    |                                                            | 17 µs              | 8.5 µs             | 4.25 µs                          | 2.8333 µs<br><sub>Note 2, 3</sub> |        |           |
| 1                             | 1   | 1      |     |        |          | fCLK/2      |                            | 34/fclk    | 34 µs                                                      | 8.5 µs             | 4.25 µs            | 2.125 µs<br><sub>Note 2,</sub> 3 | Setting<br>prohibited             |        |           |

| (1) When there is no A/D power supply stabilization wait time          |
|------------------------------------------------------------------------|
| Normal mode 1, 2 (software trigger mode/hardware trigger no-wait mode) |

**Note 1.** These are the numbers of clock cycles when conversion is with 10-bit resolution. When eight-bit resolution is selected, the values are shorter by two cycles of the conversion clock (fAD).

Note 2. This value is prohibited when using the temperature sensor

Note 3. Setting prohibited in the 3.6 V

Caution 1. The A/D conversion time must also be within the relevant range of conversion times (tconv) described in 2.6.1 A/D converter characteristics of the R9A02G015 Data Sheet (R19DS0101E).

Caution 2. Rewrite the FR2 to FR0, LV1 and LV0 bits to other than the same data while conversion is stopped (ADCS = 0, ADCE = 0).

Caution 3. The above conversion time does not include conversion state time. Conversion state time add in the first conversion. Select conversion time, taking clock frequency errors into consideration.

Remark fclk: CPU/peripheral hardware clock frequency

#### Table 10 - 4 A/D Conversion Time Selection (2/2)

| _       |         |         |         |         |             |             |                             |                            |                          |                                                            |                                      |                    |                                  |                                   |  |          |    |       |         |         |                                |
|---------|---------|---------|---------|---------|-------------|-------------|-----------------------------|----------------------------|--------------------------|------------------------------------------------------------|--------------------------------------|--------------------|----------------------------------|-----------------------------------|--|----------|----|-------|---------|---------|--------------------------------|
|         | D Cor   |         |         |         | Mode        | -           |                             |                            |                          |                                                            | Conversion Time at 10-Bit Resolution |                    |                                  |                                   |  |          |    |       |         |         |                                |
| R       | egiste  | er 0 (  | ADM     | 0)      |             | Clock (fAD) | Stabilization<br>Wait Clock | Conversion<br>Clock Note 2 | Wait Time+<br>Conversion | $2.7 \text{ V} \le \text{V}_{\text{DD}} \le 5.5 \text{ V}$ |                                      |                    |                                  |                                   |  |          |    |       |         |         |                                |
| FR<br>2 | FR<br>1 | FR<br>0 | LV<br>1 | LV<br>0 |             |             |                             |                            | Time                     | fclk =<br>1 MHz                                            | fclk =<br>4 MHz                      | fclk =<br>8 MHz    | fclk =<br>16 MHz                 | fclk =<br>24 MHz                  |  |          |    |       |         |         |                                |
| 0       | 0       | 0       | 0       | 0       | Normal<br>1 | fclk/64     | 8 fad                       | 19 fAD<br>(number of       | 1728/fclk                | Setting prohibited                                         | Setting prohibited                   | Setting prohibited | Setting prohibited               | Setting prohibited                |  |          |    |       |         |         |                                |
| 0       | 0       | 1       | Ì       |         |             | fclk/32     |                             | sampling<br>clock:         | 864/fclk                 |                                                            |                                      |                    | 54 µs                            | 36.0 µs                           |  |          |    |       |         |         |                                |
| 0       | 1       | 0       |         |         |             | fclk/16     |                             | 7 fad)                     | 432/fclk                 |                                                            |                                      | 54 µs              | 27 µs                            | 18.0 µs                           |  |          |    |       |         |         |                                |
| 0       | 1       | 1       |         |         |             | fclk/8      |                             |                            | 216/fclk                 |                                                            | 54 µs                                | 27 µs              | 13.5 µs                          | 9.0 µs                            |  |          |    |       |         |         |                                |
| 1       | 0       | 0       |         |         |             | fclk/6      |                             |                            | 162/fclk                 |                                                            | 40.5 µs                              | 20.25 µs           | 10.125 µs                        | 6.8 µs                            |  |          |    |       |         |         |                                |
| 1       | 0       | 1       |         |         |             | fclk/5      |                             |                            | 135/fclk                 |                                                            | 33.75 µs                             | 16.875 µs          | 8.4375 µs                        | 5.6 µs                            |  |          |    |       |         |         |                                |
| 1       | 1       | 0       |         |         |             | fclk/4      |                             |                            |                          |                                                            |                                      |                    |                                  |                                   |  | 108/fclk | 27 | 27 µs | 13.5 µs | 6.75 µs | 4.5 μs<br><sub>Note 3,</sub> 4 |
| 1       | 1       | 1       |         |         |             | fclk/2      |                             |                            | 54/fclk                  | 54 µs                                                      | 13.5 µs                              | 6.75 µs            | 3.375 µs<br><sub>Note 3,</sub> 4 | Setting prohibited                |  |          |    |       |         |         |                                |
| 0       | 0       | 0       | 0       | 1       | Normal<br>2 | fclk/64     | 8 fad                       | 17 fAD<br>(number of       | 1600/fclk                | Setting prohibited                                         | Setting prohibited                   | Setting prohibited | Setting prohibited               | Setting prohibited                |  |          |    |       |         |         |                                |
| 0       | 0       | 1       | Ì       |         |             | fclk/32     |                             | sampling<br>clock:         | 800/fclk                 |                                                            |                                      |                    | 50 µs                            | 33.3333 µs                        |  |          |    |       |         |         |                                |
| 0       | 1       | 0       |         |         |             | fclk/16     |                             | 5 fad)                     | 400/fclk                 |                                                            |                                      | 50 µs              | 25 µs                            | 16.6667 µs                        |  |          |    |       |         |         |                                |
| 0       | 1       | 1       |         |         |             | fclk/8      |                             |                            | 200/fclk                 |                                                            | 50 µs                                | 25 µs              | 12.5 µs                          | 8.3333 µs                         |  |          |    |       |         |         |                                |
| 1       | 0       | 0       |         |         |             | fclk/6      |                             |                            | 150/fclk                 |                                                            | 37.5 µs                              | 18.75 µs           | 9.375 µs                         | 6.2500 µs                         |  |          |    |       |         |         |                                |
| 1       | 0       | 1       |         |         |             | fclk/5      |                             |                            | 125/fclk                 | 50 µs                                                      | 31.25 µs                             | 15.625 µs          | 7.8125 µs                        | 5.2083 µs<br>Note 3               |  |          |    |       |         |         |                                |
| 1       | 1       | 0       |         |         |             | fclk/4      |                             |                            | 100/fclk                 |                                                            | 25 µs                                | 12.5 µs            | 6.25 µs                          | 4.1667 µs<br><sub>Note 3,</sub> 4 |  |          |    |       |         |         |                                |
| 1       | 1       | 1       |         |         |             | fclk/2      |                             |                            | 50/fclk                  |                                                            | 12.5 µs                              | 6.25 µs            | 3.125 µs<br><sub>Note 3,</sub> 4 | Setting prohibited                |  |          |    |       |         |         |                                |

(2) When there is A/D power supply stabilization wait time

| Normal mode 1, 2 (hardware trigger wait mode No | ote 1) |
|-------------------------------------------------|--------|
|-------------------------------------------------|--------|

**Note 1.** For the second and subsequent conversion in sequential conversion mode and for conversion of the channel specified by scan 1, 2, and 3 in scan mode, the conversion start time and stabilization wait time for A/D power supply do not occur after a hardware trigger is detected (see table 11-3 (1/4)).

**Note 2.** These are the numbers of clock cycles when conversion is with 10-bit resolution. When eight-bit resolution is selected, the values are shorter by two cycles of the conversion clock (fAD).

**Note 3.** This value is prohibited when using the temperature sensor

**Note 4.** Setting prohibited in the 3.6 V

Caution 1. The A/D conversion time must also be within the relevant range of conversion times (tCONV) described in 2.6.1 A/D converter characteristics of the R9A02G015 Data Sheet (R19DS0101E). Note that the conversion time (tCONV) does not include the A/D power supply stabilization wait time.

Caution 2. Rewrite the FR2 to FR0, LV1 and LV0 bits to other than the same data while conversion is stopped (ADCS = 0, ADCE = 0).

Caution 3. The above conversion time does not include conversion state time. Conversion state time add in the first conversion. Select conversion time, taking clock frequency errors into consideration.

Caution 4. When hardware trigger wait mode, specify the conversion time, including the A/D power supply stabilization wait time from the hardware trigger detection.

Remark fclk: CPU/peripheral hardware clock frequency





#### Figure 10 - 5 A/D Converter Sampling and A/D Conversion Timing (Example for Software Trigger Mode)



# 10.3.3 A/D converter mode register 1 (ADM1)

This register is used to specify the A/D conversion trigger, conversion mode, and hardware trigger signal. The ADM1 register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 10 - 6 Format of A/D Converter Mode Register 1 (ADM1)

| Address: FFF32H |        | After reset: 00 | H R/W |   |   |   |        |        |
|-----------------|--------|-----------------|-------|---|---|---|--------|--------|
| Symbol          | <7>    | 6               | 5     | 4 | 3 | 2 | 1      | 0      |
| ADM1            | ADTMD1 | ADTMD0          | ADSCM | 0 | 0 | 0 | ADTRS1 | ADTRS0 |

| ADTMD1 | ADTMD0 | Selection of the A/D conversion trigger mode |
|--------|--------|----------------------------------------------|
| 0      | —      | Software trigger mode                        |
| 1      | 0      | Hardware trigger no-wait mode                |
| 1      | 1      | Hardware trigger wait mode                   |

| ADSCM | Specification of the A/D conversion mode |
|-------|------------------------------------------|
| 0     | Sequential conversion mode               |
| 1     | One-shot conversion mode                 |

| ADTRS1 | ADTRS0 | Selection of the hardware trigger signal                           |
|--------|--------|--------------------------------------------------------------------|
| 0      | 0      | End of timer channel 1 count or capture interrupt signal (INTTM01) |
| 0      | 1      | Setting prohibited                                                 |
| 1      | 0      | Setting prohibited                                                 |
| 1      | 1      | 12-bit interval timer interrupt signal (INTIT)                     |

Caution 1. Rewrite the value of the ADM1 register while conversion is stopped (ADCS = 0, ADCE = 0).

Caution 2. To complete A/D conversion, specify at least the following time as the hardware trigger interval: Hardware trigger no wait mode: 2 fcLK clock + conversion start time + A/D conversion time Hardware trigger wait mode: 2 fcLK clock + conversion start time + A/D power supply stabilization wait time + A/D conversion time

Caution 3. In modes other than SNOOZE mode, input of the next INTIT will not be recognized as a valid hardware trigger for up to four fcLK cycles after the first INTIT is input.



## 10.3.4 A/D converter mode register 2 (ADM2)

This register is used to select the + side or - side reference voltage of the A/D converter, check the upper limit and lower limit A/D conversion result values, select the resolution, and specify whether to use the SNOOZE mode.

The ADM2 register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 10 - 7 Format of A/D Converter Mode Register 2 (ADM2) (1/2)

| Address: F0010H |         | After reset: 00ł | H R/W  |   |       |     |   |       |
|-----------------|---------|------------------|--------|---|-------|-----|---|-------|
| Symbol          | 7       | 6                | 5      | 4 | <3>   | <2> | 1 | <0>   |
| ADM2            | ADREFP1 | ADREFP0          | ADREFM | 0 | ADRCK | AWC | 0 | ADTYP |

| ADREFP1                                                                                                          | ADREFP0 | Selection of the + side reference voltage source of the A/D converter |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------|---------|-----------------------------------------------------------------------|--|--|--|--|--|--|
| 0                                                                                                                | 0       | Supplied from VDD                                                     |  |  |  |  |  |  |
| 0                                                                                                                | 1       | Supplied from P20/AVREFP/ANI0                                         |  |  |  |  |  |  |
| 1                                                                                                                | 0       | Supplied from the internal reference voltage (1.45 V) Note            |  |  |  |  |  |  |
| 1                                                                                                                | 1       | Setting prohibited                                                    |  |  |  |  |  |  |
| • When ADREFP1 or ADREFP0 bit is rewritten, this must be configured in accordance with the following procedures. |         |                                                                       |  |  |  |  |  |  |

(1) Set ADCE = 0

(2) Change the values of ADREFP1 and ADREFP0

(3) Reference voltage stabilization wait time (A)

(4) Set ADCE = 1

(5) Reference voltage stabilization wait time (B)

When ADREFP1 and ADREFP0 are set to 1 and 0, the setting is changed to A = 5  $\mu$ s, B = 1  $\mu$ s.

When ADREFP1 and ADREFP0 are set to 0 and 0 or 0 and 1, A needs no wait and B = 1  $\mu s.$ 

• When ADREFP1 and ADREFP0 are set to 1 and 0, respectively, A/D conversion cannot be performed on the temperature sensor output and internal reference voltage output.

Be sure to perform A/D conversion while ADISS = 0.

| ADREFM | Selection of the – side reference voltage source of the A/D converter |
|--------|-----------------------------------------------------------------------|
| 0      | Supplied from Vss                                                     |
| 1      | Supplied from P21/AVREFM/ANI1                                         |

| ADRCK          | Selection of the – side reference voltage source of the A/D converter                                                                   |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0              | The interrupt signal (INTAD) is output when the ADLL register $\leq$ the ADCR register $\leq$ the ADUL register (<1>).                  |
| 1              | The interrupt signal (INTAD) is output when the ADCR register < the ADLL register (<2>) or the ADUL register < the ADCR register (<3>). |
| Figures 10 - 8 | shows the generation range of the interrupt signal (INTAD) for <1> to <3>.                                                              |

**Note** This setting can be used only in HS (high-speed main) mode.

Caution 1. Rewrite the value of the ADM2 register while conversion is stopped (ADCS = 0, ADCE = 0).

- Caution 2. Do not set the ADREFP1 bit to 1 when shifting to STOP mode.
- Caution 3. When using AVREFP and AVREFM, specify ANI0 and ANI1 as the analog input channels and specify input mode by using the port mode register.



| dress: | F0010H                                                                                                                                        | After reset: 00H                                                                                                                                                       | H R/W                                                                                                                                                          |                                                                                                                          |                                                                                                                                                                                          |                                                                                                                                |                                                                                                          |                                                              |  |  |  |  |  |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|--|--|--|--|
| mbol   | 7                                                                                                                                             | 6                                                                                                                                                                      | 5                                                                                                                                                              | 4                                                                                                                        | <3>                                                                                                                                                                                      | <2>                                                                                                                            | 1                                                                                                        | <0>                                                          |  |  |  |  |  |  |
| DM2    | ADREFP1                                                                                                                                       | ADREFP0                                                                                                                                                                | ADREFM                                                                                                                                                         | 0                                                                                                                        | ADRCK                                                                                                                                                                                    | AWC                                                                                                                            | 0                                                                                                        | ADTYP                                                        |  |  |  |  |  |  |
|        | AWC                                                                                                                                           |                                                                                                                                                                        |                                                                                                                                                                |                                                                                                                          |                                                                                                                                                                                          |                                                                                                                                |                                                                                                          |                                                              |  |  |  |  |  |  |
|        | 0                                                                                                                                             | Do not use the SNOOZE mode function.                                                                                                                                   |                                                                                                                                                                |                                                                                                                          |                                                                                                                                                                                          |                                                                                                                                |                                                                                                          |                                                              |  |  |  |  |  |  |
|        | 1                                                                                                                                             | 1 Use the SNOOZE mode function.                                                                                                                                        |                                                                                                                                                                |                                                                                                                          |                                                                                                                                                                                          |                                                                                                                                |                                                                                                          |                                                              |  |  |  |  |  |  |
|        | The SNOOZ<br>CPU/periphe<br>Using the SN<br>Using the SN<br>When using<br>Note + conver<br>Even when used<br>before shifting<br>Also, be sure | eral hardware clo<br>NOOZE mode fu<br>NOOZE mode fu<br>the SNOOZE m<br>ersion start time<br>using SNOOZE<br>ing to STOP mode<br>to change the<br>bit is left set to 1, | n can only be s<br>ock (fCLK). If an<br>unction in the so<br>unction in the so<br>tode function, s<br>+ A/D power su<br>mode, be sure<br>le.<br>AWC bit to 0 a | pecified wher<br>by other clock<br>oftware trigge<br>equential com-<br>pecify a hard<br>upply stabiliza<br>to set the AW | the high-speed<br>is selected, spec<br>r mode or hardwa<br>version mode is p<br>ware trigger inter<br>tion wait time + A<br>'C bit to 0 in norm<br>from STOP mode<br>t normally in spite | ifying this mod<br>are trigger no-v<br>prohibited.<br>val of at least "<br>VD conversion<br>nal operation m<br>e to normal ope | e is prohibited<br>vait mode is p<br>shift time to S<br>time +2 fCLK o<br>node and char<br>eration mode. | l.<br>rohibited.<br>NOOZE mode<br>clock"<br>ige it to 1 just |  |  |  |  |  |  |

Figure 10 - 8 Format of A/D Converter Mode Register 2 (ADM2) (2/2)

# ADTYP Selection of the A/D conversion resolution 0 10-bit resolution 1 8-bit resolution

Note Refer to "From STOP to SNOOZE" in 19.3.3 SNOOZE mode.

Caution Only rewrite the value of the ADM2 register while conversion operation is stopped (which is indicated by the ADCS bit of A/D converter mode register 0 (ADM0) being 0).

#### Figure 10 - 9 ADRCK Bit Interrupt Signal Generation Range

# ADCR register value (A/D conversion result)



Remark If INTAD does not occur, the A/D conversion result is not stored in the ADCR or ADCRH register.



#### 10.3.5 10-bit A/D conversion result register (ADCR)

This register is a 16-bit register that stores the A/D conversion result. The lower 6 bits are fixed to 0. Each time A/D conversion ends, the conversion result is loaded from the successive approximation register (SAR). The higher 8 bits of the conversion result are stored in FFF1FH and the lower 2 bits are stored in the higher 2 bits of FFF1EH Note.

The ADCR register can be read by a 16-bit memory manipulation instruction. Reset signal generation clears this register to 0000H.

**Note** If the A/D conversion result is outside the range specified by using the A/D conversion comparison function (the value specified by the ADRCK bit of the ADM2 register and ADUL/ADLL registers; see Figure 11-8), the result is not stored.

#### Figure 10 - 10 Format of 10-bit A/D Conversion Result Register (ADCR)

| Address: FFF1FH, FFF1EH After reset: 0000H |  |  |  |     |     |  | H F | ٦ |  |   |     |     |   |   |   |
|--------------------------------------------|--|--|--|-----|-----|--|-----|---|--|---|-----|-----|---|---|---|
| Symbol                                     |  |  |  | FFF | 1FH |  |     |   |  |   | FFF | 1EH |   |   |   |
| ADCR                                       |  |  |  |     |     |  |     |   |  | 0 | 0   | 0   | 0 | 0 | 0 |

Caution 1. When 8-bit resolution A/D conversion is selected (when the ADTYP bit of A/D converter mode register 2 (ADM2) is 1) and the ADCR register is read, 0 is read from the lower two bits (ADCR1 and ADCR0).

Caution 2. When the ADCR register is accessed in 16-bit units, the higher 10 bits of the conversion result are read in order starting at bit 15.



## 10.3.6 8-bit A/D conversion result register (ADCRH)

This register is an 8-bit register that stores the A/D conversion result. The higher 8 bits of 10-bit resolution are stored <sup>Note</sup>.

The ADCRH register can be read by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

**Note** If the A/D conversion result is outside the range specified by using the A/D conversion comparison function (the value specified by the ADRCK bit of the ADM2 register and ADUL/ADLL registers; see Figure 10 - 8), the result is not stored.

#### Figure 10 - 11 Format of 8-bit A/D Conversion Result Register (ADCRH)

| Address: | FF1FH | After reset: 00H | H R |   |   |   |   |   |
|----------|-------|------------------|-----|---|---|---|---|---|
| Symbol   | 7     | 6                | 5   | 4 | 3 | 2 | 1 | 0 |
| ADCRH    |       |                  |     |   |   |   |   |   |

Caution 1. When writing to the A/D converter mode register 0 (ADM0) and analog input channel specification register (ADS), the contents of the ADCRH register may become undefined. Read the conversion result following conversion completion before writing to the ADM0 and ADS. Using timing other than the above may cause an incorrect conversion result to be read.



# **10.3.7** Analog input channel specification register (ADS)

This register specifies the input channel of the analog voltage to be A/D converted. The ADS register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 10 - 12 Format of Analog Input Channel Specification Register (ADS) (1/2)

| Address: | FFF31H | 1H After reset: 00H |   |      |      |      |      |      |
|----------|--------|---------------------|---|------|------|------|------|------|
| Symbol   | 7      | 6                   | 5 | 4    | 3    | 2    | 1    | 0    |
| ADS      | ADISS  | 0                   | 0 | ADS4 | ADS3 | ADS2 | ADS1 | ADS0 |

#### $\bigcirc$ Select mode (ADMD = 0)

|       |      | ,          |           | r    |      | i                       |                                                    |
|-------|------|------------|-----------|------|------|-------------------------|----------------------------------------------------|
| ADISS | ADS4 | ADS3       | ADS2      | ADS1 | ADS0 | Analog input<br>channel | Input source                                       |
| 0     | 0    | 0          | 0         | 0    | 0    | ANI0                    | P20/ANI0/AVREFP pin                                |
| 0     | 0    | 0          | 0         | 0    | 1    | ANI1                    | P21/ANI1/AVREFM pin                                |
| 0     | 0    | 0          | 0         | 1    | 0    | ANI2                    | P22/ANI2 pin                                       |
| 0     | 0    | 0          | 0         | 1    | 1    | ANI3                    | P23/ANI3 pin                                       |
| 0     | 0    | 0          | 1         | 0    | 0    | ANI4                    | P24/ANI4 pin                                       |
| 0     | 0    | 0          | 1         | 0    | 1    | ANI5                    | P25/ANI5 pin                                       |
| 0     | 1    | 0          | 0         | 0    | 0    | ANI16                   | P00/ANI16 pin                                      |
| 0     | 1    | 0          | 0         | 0    | 1    | ANI17                   | P01/ANI17 pin                                      |
| 1     | 0    | 0          | 0         | 0    | 0    | _                       | Temperature sensor output Note                     |
| 1     | 0    | 0          | 0         | 0    | 1    | -                       | Internal reference voltage output<br>(1.45 V) Note |
|       |      | Other than | the above |      |      | Setting prohibit        | ted                                                |

**Note** Operation is possible only in HS (high-speed main) mode.



#### Figure 10 - 13 Format of Analog Input Channel Specification Register (ADS) (2/2)

| Address: | FFF31H | After reset: 00 | H R/W |      |      |      |      |      |
|----------|--------|-----------------|-------|------|------|------|------|------|
| Symbol   | 7      | 6               | 5     | 4    | 3    | 2    | 1    | 0    |
| ADS      | ADISS  | 0               | 0     | ADS4 | ADS3 | ADS2 | ADS1 | ADS0 |

#### O Select mode (ADMD = 0)

| ADISS | ADS4 | ADS3       | ADS2      | ADS1 | ADS0        | Analog input channel |        |        |        |
|-------|------|------------|-----------|------|-------------|----------------------|--------|--------|--------|
|       |      |            |           |      |             | Scan 0               | Scan 1 | Scan 2 | Scan 3 |
| 0     | 0    | 0          | 0         | 0    | 0           | ANI0                 | ANI1   | ANI2   | ANI3   |
| 0     | 0    | 0          | 0         | 0    | 1           | ANI1                 | ANI2   | ANI3   | ANI4   |
| 0     | 0    | 0          | 0         | 1    | 0           | ANI2                 | ANI3   | ANI4   | ANI5   |
|       | •    | Other than | the above | •    | Setting pro | hibited              | •      | •      |        |

Caution 1. Be sure to clear bits 5 and 6 to 0.

- Caution 2. Set a channel to be used for A/D conversion in the input mode by using port mode registers 0, 2 (PM0, PM2).
- Caution 3. Do not set the pin that is set by port mode control registers 0, 2 (PMC0, PMC2) as digital I/O by the ADS register.
- Caution 4. Rewrite the value of the ADISS bit while conversion is stopped (ADCS = 0, ADCE = 0).
- Caution 5. If using AVREFP as the + side reference voltage of the A/D converter, do not select ANI0 as an A/D conversion channel.
- Caution 6. If using AVREFM as the side reference voltage of the A/D converter, do not select ANI1 as an A/D conversion channel.
- Caution 7. If the ADISS bit is set to 1, the internal reference voltage output (1.45 V) cannot be used for the + side reference voltage. After the ADISS bit is set to 1, the initial conversion result cannot be used. For the setting flow, see 10.7.4 Setup when using temperature sensor (example for software trigger mode and one-shot conversion mode).
- Caution 8. Do not set the ADISS bit to 1 when shifting to STOP mode.



#### 10.3.8 Conversion result comparison upper limit setting register (ADUL)

This register is used to specify the setting for checking the upper limit of the A/D conversion results. The A/D conversion results and ADUL register value are compared, and interrupt signal (INTAD) generation is controlled in the range specified for the ADRCK bit of A/D converter mode register 2 (ADM2) (shown in Figure 10 - 8).

The ADUL register can be set by an 8-bit memory manipulation instruction. Reset signal generation sets this register to FFH.

# Caution When 10-bit resolution A/D conversion is selected, the higher eight bits of the 10-bit A/D conversion result register (ADCR) are compared with the ADUL register.

#### Figure 10 - 14 Format of Conversion Result Comparison Upper Limit Setting Register (ADUL)

| Address: I | =0011H | After reset: FF | H R/W |       |       |       |       |       |
|------------|--------|-----------------|-------|-------|-------|-------|-------|-------|
| Symbol     | 7      | 6               | 5     | 4     | 3     | 2     | 1     | 0     |
| ADUL       | ADUL7  | ADUL6           | ADUL5 | ADUL4 | ADUL3 | ADUL2 | ADUL1 | ADUL0 |

#### 10.3.9 Conversion result comparison lower limit setting register (ADLL)

This register is used to specify the setting for checking the lower limit of the A/D conversion results. The A/D conversion results and ADLL register value are compared, and interrupt signal (INTAD) generation is controlled in the range specified for the ADRCK bit of A/D converter mode register 2 (ADM2) (shown in Figure 10 - 8).

The ADLL register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 10 - 15 Format of Conversion Result Comparison Lower Limit Setting Register (ADLL)

| Address: F | <sup>=</sup> 0012H | After reset: 00H | H R/W |       |       |       |       |       |
|------------|--------------------|------------------|-------|-------|-------|-------|-------|-------|
| Symbol     | 7                  | 6                | 5     | 4     | 3     | 2     | 1     | 0     |
| ADLL       | ADLL7              | ADLL6            | ADLL5 | ADLL4 | ADLL3 | ADLL2 | ADLL1 | ADLL0 |

Caution 1. When A/D conversion with 10-bit resolution is selected, the eight higher-order bits of the 10-bit A/D conversion result register (ADCR) are compared with the values in the ADUL and ADLL registers.

Caution 2. Only write new values to the ADUL and ADLL registers while conversion is stopped (ADCS = 0, ADCE = 0).

Caution 3. The setting of the ADUL registers must be greater than that of the ADLL register.



# 10.3.10 A/D test register (ADTES)

This register is used to select the + side reference voltage or - side reference voltage for the converter, an analog input

channel (ANIxx), the temperature sensor output, or the internal reference voltage output (1.45 V) as the target for A/D

conversion.

When using this register to test the converter, set as follows.

• For zero-scale measurement, select the - side reference voltage as the target for conversion.

• For full-scale measurement, select the + side reference voltage as the target for conversion.

The ADTES register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 10 - 16 Format of A/D Test Register (ADTES)

| Address: F0013H |   | After reset: 00 | H R/W |   |   |   |        |        |
|-----------------|---|-----------------|-------|---|---|---|--------|--------|
| Symbol          | 7 | 6               | 5     | 4 | 3 | 2 | 1      | 0      |
| ADTES           | 0 | 0               | 0     | 0 | 0 | 0 | ADTES1 | ADTES0 |
| _               |   | -i              | i     |   |   |   |        |        |

|  | ADTES1     | ADTES0    | A/D conversion target                                                                                                                                                                        |  |  |  |  |
|--|------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|  | 0 0<br>1 0 |           | ANIxx/temperature sensor output <sup>Note</sup> /internal reference voltage output (1.45 V) <sup>Note</sup> (This is specified using the analog input channel specification register (ADS).) |  |  |  |  |
|  |            |           | The - side reference voltage (selected by the ADREFM bit of the ADM2 register)                                                                                                               |  |  |  |  |
|  | 1          | 1         | The + side reference voltage (selected by the ADREFP1 or ADREFP0 bit of the ADM2 register)                                                                                                   |  |  |  |  |
|  | Other than | the above | Setting prohibited                                                                                                                                                                           |  |  |  |  |

Note

The temperature sensor output and internal reference voltage output (1.45 V) can be selected only in the HS (high-speed main) mode.

## 10.3.11 Registers controlling port function of analog input pins

Set up the registers for controlling the functions of the ports shared with the analog input pins of the A/D converter (port mode registers (PMxx), port mode control registers (PMCxx). For details, see **4.3.1 Port mode registers** (PMxx) and **4.3.6 Port mode control registers** (PMCxx).

When using the ANI0 to ANI5, ANI16 and ANI17 pins for analog input of the A/D converter, set the port mode register (PMxx) bit and port mode control register (PMCxx) bit corresponding to each port to 1.



# **10.4** A/D Converter Conversion Operations

The A/D converter conversion operations are described below.

- <1> The voltage input to the selected analog input channel is sampled by the sample & hold circuit.
- <2> When sampling has been done for a certain time, the sample & hold circuit is placed in the hold state and the sampled voltage is held until the A/D conversion operation has ended.
- <3> Bit 9 of the successive approximation register (SAR) is set. The series resistor string voltage tap is set to (1/2) AVREF by the tap selector.
- <4> The voltage difference between the series resistor string voltage tap and sampled voltage is compared by the voltage comparator. If the analog input is greater than (1/2) AVREF, the MSB bit of the SAR register remains set to 1. If the analog input is smaller than (1/2) AVREF, the MSB bit is reset to 0.
- <5> Next, bit 8 of the SAR register is automatically set to 1, and the operation proceeds to the next comparison. The series resistor string voltage tap is selected according to the preset value of bit 9, as described below.
  - Bit 9 = 1: (3/4) AVREF
  - Bit 9 = 0: (1/4) AVREF

The voltage tap and sampled voltage are compared and bit 8 of the SAR register is manipulated as follows.

- Sampled voltage ≤ Voltage tap: Bit 8 = 1
- Sampled voltage < Voltage tap: Bit 8 = 0
- <6> Comparison is continued in this way up to bit 0 of the SAR register.
- <7> Upon completion of the comparison of 10 bits, an effective digital result value remains in the SAR register, and the result value is transferred to the A/D conversion result register (ADCR, ADCRH) and then latched. At the same time, the A/D conversion end interrupt request (INTAD) can also be generated.
- <8> Repeat steps <1> to <7>, until the ADCS bit is cleared to 0 <sup>Note</sup>. To stop the A/D converter, clear the ADCS bit to 0.
- **Note** While in the sequential conversion mode, the ADCS flag is not automatically cleared to 0. This flag is not automatically cleared to 0 while in the one-shot conversion mode of the hardware trigger no-wait mode, either. Instead, 1 is retained.
- **Remark 1.** Two types of the A/D conversion result registers are available.
  - ADCR register (16 bits): Store 10-bit A/D conversion value
  - ADCRH register (8 bits): Store 8-bit A/D conversion value
- **Remark 2.** AVREF: The + side reference voltage of the A/D converter. This can be selected from AVREFP, the internal reference voltage (1.45 V), and V<sub>DD</sub>.





Figure 10 - 17 Conversion Operation of A/D Converter (Software Trigger Mode)

In one-shot conversion mode, the ADCS bit is automatically cleared to 0 after completion of A/D conversion. In sequential conversion mode, A/D conversion operations proceed continuously until the software clears bit 7 (ADCS) of the A/D converter mode register 0 (ADM0) to 0.

Writing to the analog input channel specification register (ADS) during A/D conversion interrupts the current conversion after which A/D conversion of the analog input specified by the ADS register proceeds. Data from the A/D conversion that was in progress are discarded.

Reset signal generation clears the A/D conversion result register (ADCR, ADCRH) to 0000H or 00H.



## 10.5 Input Voltage and Conversion Results

The relationship between the analog input voltage input to the analog input pins (ANI0 to ANI5, ANI16 and ANI17) and the theoretical A/D conversion result (stored in the 10-bit A/D conversion result register (ADCR)) is shown by the following expression.

SAR = INT (
$$\frac{V_{AIN}}{AV_{REF}} \times 1024 + 0.5$$
)  
ADCR = SAR × 64

or

$$(\frac{\text{ADCR}}{64} - 0.5) \times \frac{\text{AVREF}}{1024} \le \text{VAIN} < (\frac{\text{ADCR}}{64} + 0.5) \times \frac{\text{AVREF}}{1024}$$

where, INT(): Function which returns integer part of value in parentheses

- VAIN: Analog input voltage
- AVREF: AVREF pin voltage
- ADCR: A/D conversion result register (ADCR) value
- SAR: Successive approximation register

Figure 10 - 18 shows the Relationship Between Analog Input Voltage and A/D Conversion Result.





**Remark** AVREF: The + side reference voltage of the A/D converter. This can be selected from AVREFP, the internal reference voltage (1.45 V), and VDD.

## 10.6 A/D Converter Operation Modes

The operation of each A/D converter mode is described below. In addition, the procedure for specifying each mode is described in **10.7** A/D Converter Setup Flowchart.

## **10.6.1** Software trigger mode (select mode, sequential conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to perform the A/D conversion of the analog input specified by the analog input channel specification register (ADS).
- <3> When A/D conversion ends, the conversion result is stored in the A/D conversion result register (ADCR, ADCRH), and the A/D conversion end interrupt request signal (INTAD) is generated. After A/D conversion ends, the next A/D conversion immediately starts.
- <4> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <5> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the analog input respecified by the ADS register. The partially converted data is discarded.
- <6> Even if a hardware trigger is input during conversion operation, A/D conversion does not start.
- <7> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status.
- <8> When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCE = 0, specifying 1 for ADCS is ignored and A/D conversion does not start.

### Figure 10 - 19 Example of Software Trigger Mode (Select Mode, Sequential Conversion Mode) Operation Timing

|                      | <                                      | 1> AD(                | CE is set to 1   |                                                             |                                                                          |                                                 |                  |                                                                                                        |                  | ADCE is cl       | eared to 0. <8     | 3><br>L            |
|----------------------|----------------------------------------|-----------------------|------------------|-------------------------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------|------------------|------------------|--------------------|--------------------|
| ADCE                 | The trigger<br>is not<br>acknowledged. | 1,                    |                  | set to 1 while in the<br>n standby status.                  | <4> ADCS is overwritten <6<br>with 1 during A/D<br>conversion operation. |                                                 |                  | <6> A hardware trigger is generated 0 during A/D ✓ ↓ (and ignored). ADCS is cleared to  0 during A/D ✓ |                  |                  |                    | The trigger is not |
| ADCS                 |                                        |                       |                  |                                                             |                                                                          |                                                 | <:               | ADS is rewritte<br>5> A/D conversion<br>(from ANI0 to A                                                | operation        |                  |                    | acknowledged.      |
| ADS                  |                                        |                       |                  | Data 1<br>(ANI0)                                            |                                                                          |                                                 |                  | Data 2<br>(ANI1)                                                                                       |                  |                  |                    |                    |
| A/D                  |                                        |                       | <3               | A/D conversion <<br>ends and the next<br>conversion starts. | 3>                                                                       | Conversion is <<br>interrupted<br>and restarts. | 3><br>↓          | <                                                                                                      | 3> <             | 3><br>↓          | Conversion         | is                 |
| conversion<br>status | Stop<br>status                         | Conversion<br>standby | Data 1<br>(ANI0) | Data 1<br>(ANI0)                                            | Data 1<br>(ANI0)                                                         | Data 1<br>(ANI0)                                | Data 1<br>(ANI0) | Data 2<br>(ANI1)                                                                                       | Data 2<br>(ANI1) | Data 2<br>(ANI1) | Conversion standby | Stop<br>status     |
| ADCR,<br>ADCRH       |                                        |                       |                  | Data 1<br>(ANI0)                                            |                                                                          | Data 1<br>(ANI0)                                |                  | Data 1<br>(ANI0)                                                                                       | Data 2<br>(ANI1) |                  | Data 2<br>(ANI1)   |                    |
| INTAD                |                                        |                       |                  |                                                             |                                                                          |                                                 | h                |                                                                                                        | Π                | h                |                    |                    |



## **10.6.2** Software trigger mode (select mode, one-shot conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to perform the A/D conversion of the analog input specified by the analog input channel specification register (ADS).
- <3> When A/D conversion ends, the conversion result is stored in the A/D conversion result register (ADCR, ADCRH), and the A/D conversion end interrupt request signal (INTAD) is generated.
- <4> After A/D conversion ends, the ADCS bit is automatically cleared to 0, and the system enters the A/D conversion standby status.
- <5> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <6> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the analog input respecified by the ADS register. The partially converted data is discarded.
- <7> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status.
- <8> When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCE = 0, specifying 1 for ADCS is ignored and A/D conversion does not start. In addition, A/D conversion does not start even if a hardware trigger is input while in the A/D conversion standby status.

### Figure 10 - 20 Example of Software Trigger Mode (Select Mode, One-Shot Conversion Mode) Operation Timing

|                             | <                                     | 1> AD<br>↓            | CE is set to 1.                                                     |    |                                                                              |                  |                                                             |   |                       |                  |              |                                                         |     |                    | ADCE             | E is cleared to 0. <                                                 | 8>                                     |
|-----------------------------|---------------------------------------|-----------------------|---------------------------------------------------------------------|----|------------------------------------------------------------------------------|------------------|-------------------------------------------------------------|---|-----------------------|------------------|--------------|---------------------------------------------------------|-----|--------------------|------------------|----------------------------------------------------------------------|----------------------------------------|
| ADCE<br>ADCS                | The trigger<br>is not<br>cknowledged. |                       | ADCS is set to<br>2> 1 while in the<br>conversion<br>standby status | <4 | ADCS is<br>> automatically <<br>cleared to 0<br>after<br>conversion<br>ends. | 2> <5>           | ADCS is overwritt<br>with 1 during A/D<br>conversion operat | < |                       | <2>              | A/D cor      | rewritten during<br>iversion operation<br>NI0 to ANI1). | <4> | <2                 | > <              | ADCS is<br>7> cleared to 0<br>during A/D<br>conversion<br>operation. | The trigger<br>is not<br>acknowledged. |
| ADS                         |                                       |                       | Data 1<br>(ANI0)                                                    |    |                                                                              |                  |                                                             |   |                       |                  | X            | Data 2<br>(ANI1)                                        |     |                    |                  |                                                                      |                                        |
|                             |                                       |                       |                                                                     | <3 | A/D<br>conversion<br>ends.                                                   |                  | Conversion is interrupted and restarts.                     | < | ;3><br>₩              |                  |              | (                                                       | <3> |                    |                  | Conversion is                                                        |                                        |
| A/D<br>conversion<br>status | Stop<br>status                        | Conversion<br>standby |                                                                     |    | Conversion<br>standby                                                        | Data 1<br>(ANI0) | Data 1<br>(ANI0)                                            |   | Conversion<br>standby | Data 1<br>(ANI0) |              | Data 2<br>(ANI1)                                        |     | nversion<br>tandby | Data 2<br>(ANI1) | Conversion<br>standby                                                | Stop<br>status                         |
| ADCR,<br>ADCRH              |                                       |                       |                                                                     |    |                                                                              | Dat<br>(AN       |                                                             |   |                       |                  | ta 1<br>NIO) |                                                         |     |                    |                  | oata 2<br>ANI1)                                                      |                                        |
| INTAD                       |                                       |                       |                                                                     |    |                                                                              |                  |                                                             |   |                       |                  |              |                                                         |     |                    |                  |                                                                      |                                        |



## **10.6.3** Software trigger mode (scan mode, sequential conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to perform A/D conversion on the four analog input channels specified by scan 0 to scan 3, which are specified by the analog input channel specification register (ADS). A/D conversion is performed on the analog input channels in order, starting with that specified by scan 0.
- <3> A/D conversion is sequentially performed on the four analog input channels, the conversion results are stored in the A/D conversion result register (ADCR, ADCRH) each time conversion ends, and the A/D conversion end interrupt request signal (INTAD) is generated. After A/D conversion of the four channels ends, the A/D conversion of the channel following the specified channel automatically starts (until all four channels are finished).
- <4> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts at the first channel. The partially converted data is discarded.
- <5> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the first channel respecified by the ADS register. The partially converted data is discarded.
- <6> Even if a hardware trigger is input during conversion operation, A/D conversion does not start.
- <7> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status.
- <8> When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCE = 0, specifying 1 for ADCS is ignored and A/D conversion does not start.

### Figure 10 - 21 Example of Software Trigger Mode (Scan Mode, Sequential Conversion Mode) Operation Timing





## **10.6.4** Software trigger mode (scan mode, one-shot conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to perform A/D conversion on the four analog input channels specified by scan 0 to scan 3, which are specified by the analog input channel specification register (ADS). A/D conversion is performed on the analog input channels in order, starting with that specified by scan 0.
- <3> A/D conversion is sequentially performed on the four analog input channels, the conversion results are stored in the A/D conversion result register (ADCR, ADCRH) each time conversion ends, and the A/D conversion end interrupt request signal (INTAD) is generated.
- <4> After A/D conversion of the four channels ends, the ADCS bit is automatically cleared to 0, and the system enters the A/D conversion standby status.
- <5> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts at the first channel. The partially converted data is discarded.
- <6> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the first channel respecified by the ADS register. The partially converted data is discarded.
- <7> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status.
- <8> When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCE = 0, specifying 1 for ADCS is ignored and A/D conversion does not start. In addition, A/D conversion does not start even if a hardware trigger is input while in the A/D conversion standby status.

### Figure 10 - 22 Example of Software Trigger Mode (Scan Mode, One-Shot Conversion Mode) Operation Timing





# 10.6.5 Hardware trigger no-wait mode (select mode, sequential conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to place the system in the hardware trigger standby status (and conversion does not start at this stage). Note that, while in this status, A/D conversion does not start even if ADCS is set to 1.
- <3> If a hardware trigger is input while ADCS = 1, A/D conversion is performed on the analog input specified by the analog input channel specification register (ADS).
- <4> When A/D conversion ends, the conversion result is stored in the A/D conversion result register (ADCR, ADCRH), and the A/D conversion end interrupt request signal (INTAD) is generated. After A/D conversion ends, the next A/D conversion immediately starts.
- <5> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <6> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the analog input respecified by the ADS register. The partially converted data is discarded.
- <7> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <8> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status. However, the A/D converter does not stop in this status.
- <9> When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCS = 0, inputting a hardware trigger is ignored and A/D conversion does not start.

### Figure 10 - 23 Example of Hardware Trigger No-Wait Mode (Select Mode, Sequential Conversion Mode) Operation Timing



## 10.6.6 Hardware trigger no-wait mode (select mode, one-shot conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to place the system in the hardware trigger standby status (and conversion does not start at this stage). Note that, while in this status, A/D conversion does not start even if ADCS is set to 1.
- <3> If a hardware trigger is input while ADCS = 1, A/D conversion is performed on the analog input specified by the analog input channel specification register (ADS).
- <4> When A/D conversion ends, the conversion result is stored in the A/D conversion result register (ADCR, ADCRH), and the A/D conversion end interrupt request signal (INTAD) is generated.
- <5> After A/D conversion ends, the ADCS bit remains set to 1, and the system enters the A/D conversion standby status.
- <6> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <7> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the analog input respecified by the ADS register. The partially converted data is discarded.
- <8> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <9> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status. However, the A/D converter does not stop in this status.
- <10>When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCS = 0, inputting a hardware trigger is ignored and A/D conversion does not start.

### Figure 10 - 24 Example of Hardware Trigger No-Wait Mode (Select Mode, One-Shot Conversion Mode) Operation Timing



## 10.6.7 Hardware trigger no-wait mode (scan mode, sequential conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to place the system in the hardware trigger standby status (and conversion does not start at this stage). Note that, while in this status, A/D conversion does not start even if ADCS is set to 1.
- <3> If a hardware trigger is input while ADCS = 1, A/D conversion is performed on the four analog input channels specified by scan 0 to scan 3, which are specified by the analog input channel specification register (ADS). A/D conversion is performed on the analog input channels in order, starting with that specified by scan 0.
- <4> A/D conversion is sequentially performed on the four analog input channels, the conversion results are stored in the A/D conversion result register (ADCR, ADCRH) each time conversion ends, and the A/D conversion end interrupt request signal (INTAD) is generated. After A/D conversion of the four channels ends, the A/D conversion of the channel following the specified channel automatically starts.
- <5> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts at the first channel. The partially converted data is discarded.
- <6> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the first channel respecified by the ADS register. The partially converted data is discarded.
- <7> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <8> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status. However, the A/D converter does not stop in this status.
- <9> When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCE = 0, specifying 1 for ADCS is ignored and A/D conversion does not start.

## Figure 10 - 25 Example of Hardware Trigger No-Wait Mode (Scan Mode, Sequential Conversion Mode) Operation Timing





## 10.6.8 Hardware trigger no-wait mode (scan mode, one-shot conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> After the software counts up to the stabilization wait time (1 µs), the ADCS bit of the ADM0 register is set to 1 to place the system in the hardware trigger standby status (and conversion does not start at this stage). Note that, while in this status, A/D conversion does not start even if ADCS is set to 1.
- <3> If a hardware trigger is input while ADCS = 1, A/D conversion is performed on the four analog input channels specified by scan 0 to scan 3, which are specified by the analog input channel specification register (ADS). A/D conversion is performed on the analog input channels in order, starting with that specified by scan 0.
- <4> A/D conversion is sequentially performed on the four analog input channels, the conversion results are stored in the A/D conversion result register (ADCR, ADCRH) each time conversion ends, and the A/D conversion end interrupt request signal (INTAD) is generated.
- <5> After A/D conversion of the four channels ends, the ADCS bit remains set to 1, and the system enters the A/D conversion standby status.
- <6> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts at the first channel. The partially converted data is discarded.
- <7> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the first channel respecified by the ADS register. The partially converted data is discarded.
- <8> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts at the first channel. The partially converted data is discarded.
- <9> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, and the system enters the A/D conversion standby status. However, the A/D converter does not stop in this status.
- <10>When ADCE is cleared to 0 while in the A/D conversion standby status, the A/D converter enters the stop status. When ADCS = 0, inputting a hardware trigger is ignored and A/D conversion does not start.

### Figure 10 - 26 Example of Software Trigger Mode (Scan Mode, One-Shot Conversion Mode) Operation Timing





## 10.6.9 Hardware trigger wait mode (select mode, sequential conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the hardware trigger standby status.
- <2> If a hardware trigger is input while in the hardware trigger standby status, A/D conversion is performed on the analog input specified by the analog input channel specification register (ADS). The ADCS bit of the ADM0 register is automatically set to 1 according to the hardware trigger input.
- <3> When A/D conversion ends, the conversion result is stored in the A/D conversion result register (ADCR, ADCRH), and the A/D conversion end interrupt request signal (INTAD) is generated. After A/D conversion ends, the next A/D conversion immediately starts. (At this time, no hardware trigger is necessary.)
- <4> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <5> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the analog input respecified by the ADS register. The partially converted data is discarded.
- <6> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <7> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, the system enters the hardware trigger standby status, and the A/D converter enters the stop status. When ADCE = 0, inputting a hardware trigger is ignored and A/D conversion does not start.

### Figure 10 - 27 Example of Hardware Trigger Wait Mode (Select Mode, Sequential Conversion Mode) Operation Timing





## 10.6.10 Hardware trigger wait mode (select mode, one-shot conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the hardware trigger standby status.
- <2> If a hardware trigger is input while in the hardware trigger standby status, A/D conversion is performed on the analog input specified by the analog input channel specification register (ADS). The ADCS bit of the ADM0 register is automatically set to 1 according to the hardware trigger input.
- <3> When A/D conversion ends, the conversion result is stored in the A/D conversion result register (ADCR, ADCRH), and the A/D conversion end interrupt request signal (INTAD) is generated.
- <4> After A/D conversion ends, the ADCS bit is automatically cleared to 0, and the A/D converter enters the stop status.
- <5> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <6> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the analog input respecified by the ADS register. The partially converted data is discarded.
- <7> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is initialized.
- <8> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, the system enters the hardware trigger standby status, and the A/D converter enters the stop status. When ADCE = 0, inputting a hardware trigger is ignored and A/D conversion does not start.

## Figure 10 - 28 Example of Hardware Trigger Wait Mode (Select Mode, One-Shot Conversion Mode) Operation Timing





## 10.6.11 Hardware trigger wait mode (scan mode, sequential conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> If a hardware trigger is input while in the hardware trigger standby status, A/D conversion is performed on the four analog input channels specified by scan 0 to scan 3, which are specified by the analog input channel specification register (ADS). The ADCS bit of the ADM0 register is automatically set to 1 according to the hardware trigger input. A/D conversion is performed on the analog input channels in order, starting with that specified by scan 0.
- <3> A/D conversion is sequentially performed on the four analog input channels, the conversion results are stored in the A/D conversion result register (ADCR, ADCRH) each time conversion ends, and the A/D conversion end interrupt request signal (INTAD) is generated. After A/D conversion of the four channels ends, the A/D conversion of the channel following the specified channel automatically starts.
- <4> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts at the first channel. The partially converted data is discarded.
- <5> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the first channel respecified by the ADS register. The partially converted data is discarded.
- <6> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <7> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, the system enters the hardware trigger standby status, and the A/D converter enters the stop status. When ADCE = 0, inputting a hardware trigger is ignored and A/D conversion does not start.

### Figure 10 - 29 Example of Hardware Trigger Wait Mode (Scan Mode, Sequential Conversion Mode) Operation Timing





## **10.6.12** Hardware trigger wait mode (scan mode, one-shot conversion mode)

- <1> In the stop status, the ADCE bit of A/D converter mode register 0 (ADM0) is set to 1, and the system enters the A/D conversion standby status.
- <2> If a hardware trigger is input while in the hardware trigger standby status, A/D conversion is performed on the four analog input channels specified by scan 0 to scan 3, which are specified by the analog input channel specification register (ADS). The ADCS bit of the ADM0 register is automatically set to 1 according to the hardware trigger input. A/D conversion is performed on the analog input channels in order, starting with that specified by scan 0.
- <3> A/D conversion is sequentially performed on the four analog input channels, the conversion results are stored in the A/D conversion result register (ADCR, ADCRH) each time conversion ends, and the A/D conversion end interrupt request signal (INTAD) is generated.
- <4> After A/D conversion ends, the ADCS bit is automatically cleared to 0, and the A/D converter enters the stop status.
- <5> If a hardware trigger is input during conversion operation, the current A/D conversion is interrupted, and conversion restarts at the first channel. The partially converted data is discarded.
- <6> When the value of the ADS register is rewritten or overwritten during conversion operation, the current A/D conversion is interrupted, and A/D conversion is performed on the first channel respecified by the ADS register. The partially converted data is discarded.
- <7> When ADCS is overwritten with 1 during conversion operation, the current A/D conversion is interrupted, and conversion restarts. The partially converted data is discarded.
- <8> When ADCS is cleared to 0 during conversion operation, the current A/D conversion is interrupted, the system enters the hardware trigger standby status, and the A/D converter enters the stop status. When ADCE = 0, inputting a hardware trigger is ignored and A/D conversion does not start.

### Figure 10 - 30 Example of Hardware Trigger Wait Mode (Scan Mode, One-Shot Conversion Mode) Operation Timing





## 10.7 A/D Converter Setup Flowchart

The A/D converter setup flowchart in each operation mode is described below.

## 10.7.1 Setting up software trigger mode



Figure 10 - 31 Setting up Software Trigger Mode

**Note** Depending on the settings of the ADRCK bit and ADUL/ADLL register, there is a possibility of no interrupt signal being generated. In this case, the results are not stored in the ADCR, ADCRH registers.



## 10.7.2 Setting up hardware trigger no-wait mode



#### Figure 10 - 32 Setting up Hardware Trigger No-Wait Mode

**Note** Depending on the settings of the ADRCK bit and ADUL/ADLL register, there is a possibility of no interrupt signal being generated. In this case, the results are not stored in the ADCR, ADCRH registers.



## 10.7.3 Setting up hardware trigger wait mode



### Figure 10 - 33 Setting up Hardware Trigger Wait Mode

**Note** Depending on the settings of the ADRCK bit and ADUL/ADLL register, there is a possibility of no interrupt signal being generated. In this case, the results are not stored in the ADCR, ADCRH registers.



## 10.7.4 Setup when using temperature sensor (example for software trigger mode and one-shot conversion mode)

### Figure 10 - 34 Setup when temperature sensor output/internal reference voltage output is selected



**Note** Depending on the settings of the ADRCK bit and ADUL/ADLL register, there is a possibility of no interrupt signal being generated. In this case, the results are not stored in the ADCR, ADCRH registers.

Caution Operation is possible only in HS (high-speed main) mode.



## 10.7.5 Setting up test mode



### Figure 10 - 35 Setting up Test Trigger Mode

**Note** Depending on the settings of the ADRCK bit and ADUL/ADLL register, there is a possibility of no interrupt signal being generated. In this case, the results are not stored in the ADCR, ADCRH registers.

Caution For the procedure for testing the A/D converter, see 23.3.8 A/D test function.



## **10.8 SNOOZE Mode Function**

In the SNOOZE mode, A/D conversion is triggered by inputting a hardware trigger in the STOP mode. Normally, A/D conversion is stopped while in the STOP mode, but, by using the SNOOZE mode, A/D conversion can be performed without operating the CPU by inputting a hardware trigger. This is effective for reducing the operation current. If the A/D conversion result range is specified using the ADUL and ADLL registers, A/D conversion results can be judged at a certain interval of time in SNOOZE mode. Using this function enables power supply voltage monitoring and input key judgment based on A/D inputs.

In the SNOOZE mode, only the following two conversion modes can be used:

- Hardware trigger wait mode (select mode, one-shot conversion mode)
- · Hardware trigger wait mode (scan mode, one-shot conversion mode)

## Caution That the SNOOZE mode can only be specified when the high-speed on-chip oscillator clock is selected for fcLK.



### Figure 10 - 36 Block Diagram When Using SNOOZE Mode Function

When using the SNOOZE mode function, the initial setting of each register is specified before switching to the STOP mode (for details about these settings, see **10.7.3 Setting up hardware trigger wait mode** <sup>Note 2</sup>). Just before move to STOP mode, bit 2 (AWC) of A/D converter mode register 2 (ADM2) is set to 1. After the initial settings are specified, bit 0 (ADCE) of A/D converter mode register 0 (ADM0) is set to 1.

If a hardware trigger is input after switching to the STOP mode, the high-speed on-chip oscillator clock is supplied to the A/D converter. After supplying this clock, the system automatically counts up to the A/D power supply stabilization wait time, and then A/D conversion starts.

The SNOOZE mode operation after A/D conversion ends differs depending on whether an interrupt signal is generated <sup>Note 1</sup>.

- **Note 1.** Depending on the setting of the A/D conversion result comparison function (ADRCK bit, ADUL/ADLL register), there is a possibility of no interrupt signal being generated.
- Note 2. Be sure to set the ADM1 register to E2H or E3H.
- **Remark** The hardware trigger is INTIT. Specify the hardware trigger by using the A/D Converter Mode Register 1 (ADM1).



(1) If an interrupt is generated after A/D conversion ends

If the A/D conversion result value is inside the range of values specified by the A/D conversion result comparison function (which is set up by using the ADRCK bit and ADUL/ADLL register), the A/D conversion end interrupt request signal (INTAD) is generated.

• While in the select mode

When A/D conversion ends and an A/D conversion end interrupt request signal (INTAD) is generated, the A/D converter returns to normal operation mode from SNOOZE mode. At this time, be sure to clear bit 2 (AWC = 0: SNOOZE mode release) of the A/D converter mode register 2 (ADM2). If the AWC bit is left set to 1, A/D conversion will not start normally in the subsequent SNOOZE or normal operation mode.

• While in the scan mode

If even one A/D conversion end interrupt request signal (INTAD) is generated during A/D conversion of the four channels, the clock request signal remains at the high level, and the A/D converter switches from the SNOOZE mode to the normal operation mode. At this time, be sure to clear bit 2 (AWC = 0: SNOOZE mode release) of A/D converter mode register 2 (ADM2) to 0. If the AWC bit is left set to 1, A/D conversion will not start normally in the subsequent SNOOZE or normal operation mode.

Figure 10 - 37 Operation Example When Interrupt Is Generated After A/D Conversion Ends (While in Scan Mode)





(2) If no interrupt is generated after A/D conversion ends

If the A/D conversion result value is outside the range of values specified by the A/D conversion result comparison function (which is set up by using the ADRCK bit and ADUL/ADLL register), the A/D conversion end interrupt request signal (INTAD) is not generated.

• While in the select mode

If the A/D conversion end interrupt request signal (INTAD) is not generated after A/D conversion ends, the clock request signal (an internal signal) is automatically set to the low level, and supplying the high-speed onchip oscillator clock stops. If a hardware trigger is input later, A/D conversion work is again performed in the SNOOZE mode.

• While in the scan mode

If the A/D conversion end interrupt request signal (INTAD) is not generated even once during A/D conversion of the four channels, the clock request signal (an internal signal) is automatically set to the low level after A/D conversion of the four channels ends, and supplying the high-speed on-chip oscillator clock stops. If a hardware trigger is input later, A/D conversion work is again performed in the SNOOZE mode.

Figure 10 - 38 Operation Example When No Interrupt Is Generated After A/D Conversion Ends (While in Scan Mode)









- Note 1. If the A/D conversion end interrupt request signal (INTAD) is not generated by setting ADRCK bit and ADUL/ADLL register, the result is not stored in the ADCR and ADCRH registers. The system enters the STOP mode again. If a hardware trigger is input later, A/D conversion operation is again performed in the SNOOZE mode.
- **Note 2.** If the AWC bit is left set to 1, A/D conversion will not start normally in spite of the subsequent SNOOZE or normal operation mode. Be sure to clear the AWC bit to 0.



## 10.9 How to Read A/D Converter Characteristics Table

Here, special terms unique to the A/D converter are explained.

(1) Resolution

This is the minimum analog input voltage that can be identified. That is, the percentage of the analog input voltage per bit of digital output is called 1LSB (Least Significant Bit). The percentage of 1LSB with respect to the full scale is expressed by %FSR (Full Scale Range).

1LSB is as follows when the resolution is 10 bits.

1LSB = 1/2<sup>10</sup> = 1/1024 = 0.098%FSR

Accuracy has no relation to resolution, but is determined by overall error.

(2) Overall error

This shows the maximum error value between the actual measured value and the theoretical value. Zero-scale error, full-scale error, integral linearity error, and differential linearity errors that are combinations of these express the overall error.

Note that the quantization error is not included in the overall error in the characteristics table.

(3) Quantization error

When analog values are converted to digital values, a  $\pm 1/2$ LSB error naturally occurs. In an A/D converter, an analog input voltage in a range of  $\pm 1/2$ LSB is converted to the same digital code, so a quantization error cannot be avoided.

Note that the quantization error is not included in the overall error, zero-scale error, full-scale error, integral linearity error, and differential linearity error in the characteristics table.









### (4) Zero-scale error

This shows the difference between the actual measurement value of the analog input voltage and the theoretical value (1/2LSB) when the digital output changes from 0.....000 to 0.....001. If the actual measurement value is greater than the theoretical value, it shows the difference between the actual measurement value of the analog input voltage and the theoretical value (3/2LSB) when the digital output changes from 0.....01 to 0......010.

(5) Full-scale error

This shows the difference between the actual measurement value of the analog input voltage and the theoretical value (Full-scale -3/2LSB) when the digital output changes from 1.....110 to 1.....111.

(6) Integral linearity error

This shows the degree to which the conversion characteristics deviate from the ideal linear relationship. It expresses the maximum value of the difference between the actual measurement value and the ideal straight line when the zero-scale error and full-scale error are 0.

(7) Differential linearity error

While the ideal width of code output is 1LSB, this indicates the difference between the actual measurement value and the ideal value.







### Figure 10 - 43 Full-Scale Error





### (8) Conversion time

This expresses the time from the start of sampling to when the digital output is obtained. The sampling time is included in the conversion time in the characteristics table.

### (9) Sampling time

This is the time the analog switch is turned on for the analog voltage to be sampled by the sample & hold circuit.





## **10.10** Cautions for A/D Converter

(1) Operating current in STOP mode

Shift to STOP mode after stopping the A/D converter (by setting bit 7 (ADCS) of A/D converter mode register 0 (ADM0) to 0). The operating current can be reduced by setting bit 0 (ADCE) of the ADM0 register to 0 at the same time.

To restart from the standby status, clear bit 0 (ADIF) of interrupt request flag register 1H (IF1H) to 0 and start operation.

### (2) Input range of ANI0 to ANI5, ANI16 and ANI17 pins

Observe the rated range of the ANI0 to ANI5, ANI16 and ANI17 pins input voltage. If a voltage exceeding VDD and AVREFP or below VSs and AVREFM or lower (even in the range of absolute maximum ratings) is input to an analog input channel, the converted value of that channel becomes undefined. In addition, the converted values of the other channels may also be affected.

When internal reference voltage (1.45 V) is selected as the reference voltage for the + side of the A/D converter, do not input voltage exceeding internal reference voltage (1.45 V) to a pin selected by the ADS register. However, it is no problem that a pin not selected by the ADS register is input voltage exceeding the internal reference voltage (1.45 V).

### Caution The internal reference voltage (1.45 V) can be selected only in HS (high-speed main) mode.

- (3) Conflicting operations
  - <1> Conflict between the A/D conversion result register (ADCR, ADCRH) write and the ADCR or ADCRH register read by instruction upon the end of conversion The ADCR or ADCRH register read has priority. After the read operation, the new conversion result is

The ADCR or ADCRH register read has priority. After the read operation, the new conversion result is written to the ADCR or ADCRH registers.

- <2> Conflict between the ADCR or ADCRH register write and the A/D converter mode register 0 (ADM0) write, the analog input channel specification register (ADS) write upon the end of conversion The ADM0, ADS registers write has priority. The ADCR or ADCRH register write is not performed, nor is the conversion end interrupt signal (INTAD) generated.
- (4) Noise countermeasures

To maintain the 10-bit resolution, attention must be paid to noise input to the AVREFP, VDD, ANI0 to ANI5, ANI16 and ANI17.

- <1> Connect a capacitor with a low equivalent resistance and a good frequency response to the power supply.
- <2> The higher the output impedance of the analog input source, the greater the influence. To reduce the noise, connecting external capacitor as shown in Figure 10 44 is recommended.
- <3> Do not switch these pins with other pins during conversion.
- <4> The accuracy is improved if the HALT mode is set immediately after the start of conversion.



### Figure 10 - 46 Analog Input Pin Connection



- (5) Analog input (ANIn) pins
  - <1> The analog input pins (ANI0 to ANI5, ANI16 and ANI17) are also used as input port pins (P20 to P25, P00 and P01).

When A/D conversion is performed with any of the ANI0 to ANI5, ANI16 and ANI17 pins selected, do not access P20 to P25, P00 and P01 while conversion is in progress; otherwise the conversion resolution may be degraded.

- <2> If a digital pulse is applied to the pins adjacent to the pins currently used for A/D conversion, the expected value of the A/D conversion may not be obtained due to coupling noise. Therefore, do not apply a pulse to the pins adjacent to the pin undergoing A/D conversion.
- (6) Input impedance of analog input (ANIn) pins

This A/D converter charges a sampling capacitor for sampling during sampling time.

Therefore, only a leakage current flows when sampling is not in progress, and a current that charges the capacitor flows during sampling. Consequently, the input impedance fluctuates depending on whether sampling is in progress, and on the other states.

To make sure that sampling is effective, however, it is recommended to keep the output impedance of the analog input source to within 1 k $\Omega$ , and to connect a capacitor of about 100 pF to the ANI0 to ANI5, ANI16 and ANI17 pins (see Figure 10 - 45).

The sampling capacitor may be being charged while the setting of the ADCS bit is 0 and immediately after sampling is restarted and so is not defined at these times. Accordingly, the state of conversion is undefined after charging starts in the next round of conversion after the value of the ADCS bit has been 1 or when conversion is repeated. Thus, to secure full charging regardless of the size of fluctuations in the analog signal, ensure that the output impedances of the sources of analog inputs are low or secure sufficient time for the completion of conversion.

(7) Interrupt request flag (ADIF)

The interrupt request flag (ADIF) is not cleared even if the analog input channel specification register (ADS) is changed.

Therefore, if an analog input pin is changed during A/D conversion, the A/D conversion result and ADIF flag for the pre-change analog input may be set just before the ADS register rewrite. Caution is therefore required since, at this time, when ADIF flag is read immediately after the ADS register rewrite, ADIF flag is set despite the fact A/D conversion for the post-change analog input has not ended.

When A/D conversion is stopped and then resumed, clear ADIF flag before the A/D conversion operation is resumed.



Figure 10 - 47 Timing of A/D Conversion End Interrupt Request Generation

(8) Conversion results just after A/D conversion start

While in the software trigger mode or hardware trigger no-wait mode, the first A/D conversion value immediately after A/D conversion starts may not fall within the rating range if the ADCS bit is set to 1 within 1 µs after the ADCE bit was set to 1. Take measures such as polling the A/D conversion end interrupt request (INTAD) and removing the first conversion result.

(9) A/D conversion result register (ADCR, ADCRH) read operation

When a write operation is performed to A/D converter mode register 0 (ADM0), analog input channel specification register (ADS) and port mode control register (PMC), the contents of the ADCR and ADCRH registers may become undefined. Read the conversion result following conversion completion before writing to the ADM0, ADS, or PMC register. Using a timing other than the above may cause an incorrect conversion result to be read.



### (10) Internal equivalent circuit

The equivalent circuit of the analog input block is shown below.

### Figure 10 - 48 Internal Equivalent Circuit of ANIn Pin



### Table 10 - 5 Resistance and Capacitance Values of Equivalent Circuit (Reference Values)

| AVREFP, VDD         | ANIn Pins       | R1 [kΩ] | C1 [pF] | C2 [pF] |
|---------------------|-----------------|---------|---------|---------|
| 3.6 V ≤ VDD ≤ 5.5 V | ANI0 to ANI5    | 14      | 8       | 2.5     |
| 5.0 V = VDD = 5.5 V | ANI16 and ANI17 | 18      | 8       | 7.0     |
| 2.7 V ≤ Vpp < 3.6 V | ANI0 to ANI5    | 39      | 8       | 2.5     |
| 2.7 V = VDD < 3.0 V | ANI16 and ANI17 | 53      | 8       | 7.0     |

**Remark 1.** The resistance and capacitance values shown in Table 10 - 5 are not guaranteed values.

(11) Starting the A/D converter

Start the A/D converter after the AVREFP and VDD voltages stabilize.



## **CHAPTER 11 SERIAL ARRAY UNIT**

The serial array unit has two serial channels. All channels can achieve UART, 3-wire serial (CSI) and simplified I<sup>2</sup>C. Function assignment of each channel supported by the R9A02G015 is as shown below.

### 32-pin products

| ſ | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C |
|---|------|---------|-------------|--------------|-------------------------------------|
| ĺ | 0    | 0       | CSI00       | UART0        | IIC00                               |
|   |      | 1       | CSI01       |              | IIC01                               |



## 11.1 Functions of Serial Array Unit

Each serial interface supported by the R9A02G015 has the following features.

## 11.1.1 3-wire serial I/O (CSI00, CSI01)

Data is transmitted or received in synchronization with the serial clock (SCK) output from the master channel. 3-wire serial communication is clocked communication performed by using three communication lines: one for the serial clock (SCK), one for transmitting serial data (SO), one for receiving serial data (SI). For details about the settings, see **11.5 Operation of 3-Wire Serial I/O (CSI00, CSI01) Communication**.

[Data transmission/reception]

- Data length of 7 or 8 bits
- Phase control of transmit/receive data
- MSB/LSB first selectable

[Clock control]

- Master/slave selection
- Phase control of I/O clock
- Setting of transfer period by prescaler and internal counter of each channel
- Maximum transfer rate Note

During master communication:

Max. fcLk/2 (CSI00 only) Max. fcLk/4

During slave communication: Max. fMCK/6

[Interrupt function]

• Transfer end interrupt/buffer empty interrupt

[Error detection flag]

Overrun error

CSIs of the following channels supports the SNOOZE mode. When SCK input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. Only the following CSIs can be specified.

• CSI00

Note Use the clocks within a range satisfying the SCK cycle time (tkcr) characteristics. For details, see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E).



## 11.1.2 UART (UART0)

This is a start-stop synchronization function using two lines: serial data transmission (TxD) and serial data reception (RxD) lines. By using these two communication lines, each data frame, which consist of a start bit, data, parity bit, and stop bit, is transferred asynchronously (using the internal baud rate) between the microcontroller and the other communication party. Full-duplex UART communication can be performed by using a channel dedicated to transmission (even-numbered channel) and a channel dedicated to reception (odd-numbered channel).

For details about the settings, see 11.6 Operation of UART (UART0) Communication.

[Data transmission/reception]

- Data length of 7, 8, or 9 bits
- Select the MSB/LSB first
- · Level setting of transmit/receive data and select of reverse
- Parity bit appending and parity check functions
- Stop bit appending

[Interrupt function]

- Transfer end interrupt/buffer empty interrupt
- Error interrupt in case of framing error, parity error, or overrun error
- [Error detection flag]
- · Framing error, parity error, or overrun error

In addition, UART reception supports the SNOOZE mode. When RxD input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. UART can be specified when the high-speed on-chip oscillator clock (fIH) is selected for the CPU/peripheral hardware clock (fCLK) in the SNOOZE mode.



## 11.1.3 Simplified I<sup>2</sup>C (IIC00, IIC01)

This is a clocked communication function to communicate with two or more devices by using two lines: serial clock (SCL) and serial data (SDA). This simplified I<sup>2</sup>C is designed for single communication with a device such as EEPROM, flash memory, or A/D converter, and therefore, it functions only as a master.

Make sure by using software, as well as operating the control registers, that the AC specifications of the start and stop conditions are observed.

For details about the settings, see 11.7 Operation of Simplified I<sup>2</sup>C (IIC00, IIC01) Communication.

[Data transmission/reception]

- Master transmission, master reception (only master function with a single master)
- ACK output function Note and ACK detection function
- Data length of 8 bits (When an address is transmitted, the address is specified by the higher 7 bits, and the least significant bit is used for R/W control.)
- Manual generation of start condition and stop condition
- [Interrupt function]

Transfer end interrupt

[Error detection flag]

- ACK error or overrun error
- \* [Functions not supported by simplified I<sup>2</sup>C]
- Slave transmission, slave reception
- Arbitration loss detection function
- Wait detection functions
- **Note** When receiving the last data, ACK will not be output if 0 is written to the SOEmn bit (serial output enable register m (SOEm)) and serial communication data output is stopped. See the processing flow in **11.7.3 (2)** for details.



## 11.2 Configuration of Serial Array Unit

The serial array unit includes the following hardware.

| Table 11 - 1 Con | figuration of | Serial Array Unit |
|------------------|---------------|-------------------|
|------------------|---------------|-------------------|

| Item               | Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Shift register     | 8 bits or 9 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Buffer register    | Lower 8 bits or 9 bits of serial data register mn (SDRmn) Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Serial clock I/O   | SCK00, SCK01 pins (for 3-wire serial I/O) and SCL00, SCL01 pins (for simplified I <sup>2</sup> C)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Serial data input  | SI00, SI01 pins (for 3-wire serial I/O), RxD0 pin (for UART)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Serial data output | SO00, SO01 pins (for 3-wire serial I/O), TxD0 pin (for UART)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Serial data I/O    | SDA00, SDA01 pins (for simplified I <sup>2</sup> C)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Control registers  | <registers block="" of="" setting="" unit=""> <ul> <li>Peripheral enable register 0 (PER0)</li> <li>Peripheral reset control register 0 (PRR0)</li> <li>Serial clock select register m (SPSm)</li> <li>Serial channel enable status register m (SEm)</li> <li>Serial channel start register m (SSm)</li> <li>Serial channel stop register m (SOEm)</li> <li>Serial output enable register m (SOEm)</li> <li>Serial output register m (SOEm)</li> <li>Serial output register m (SOCm)</li> <li>Serial standby control register m (SCCm)</li> <li>Noise filter enable register 0 (NFEN0)</li> <li></li> <li></li> <li></li> <li></li> <li>Serial data register mn (SDRmn)</li> <li>Serial communication operation setting register mn (SCRmn)</li> <li></li> <li>Serial status register mn (SRmn)</li> <li></li> <li>Serial flag clear trigger register mn (SIRmn)</li> <li></li> <li></li> <li>Port input mode register 5 (PIM5)</li> <li>Port mode register 5 (PM5)</li> <li>Port register 5 (P5)</li> </ul></registers> |

(Note and Remark are listed on the next page.)



| Note | The lower 8 bits of serial data register mn (SDRmn) can be read or written as the following SFRs, depending on the |
|------|--------------------------------------------------------------------------------------------------------------------|
|      | communication mode.                                                                                                |
|      | CSIp communicationSIOp (CSIp data register)                                                                        |
|      | UARTq receptionRXDq (UARTq receive data register)                                                                  |
|      |                                                                                                                    |

- UARTq transmission .......TXDq (UARTq transmit data register)
- IICr communication ...... SIOr (IICr data register)

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), q: UART number (q = 0), r: IIC number (r = 00, 01)



Figure 11 - 1 shows the Block Diagram of Serial Array Unit 0.



### Figure 11 - 1 Block Diagram of Serial Array Unit 0



### 11.2.1 Shift register

This is a 9-bit register that converts parallel data into serial data or vice versa.

In case of the UART communication of nine bits of data, nine bits (bits 0 to 8) are used Note.

During reception, it converts data input to the serial pin into parallel data.

When data is transmitted, the value set to this register is output as serial data from the serial output pin.

The shift register cannot be directly manipulated by program.

To read or write the shift register, use the lower 8/9 bits of serial data register mn (SDRmn).

|                | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|---|---|---|---|---|---|---|---|
| Shift register |   |   |   |   |   |   |   |   |   |
| <br>           |   |   |   |   |   |   |   |   |   |

Note Only the following UARTs can be specified for the 9-bit data length. • UART0

### 11.2.2 Lower 8/9 bits of the serial data register mn (SDRmn)

The SDRmn register is the transmit/receive data register (16 bits) of channel n. Bits 8 to 0 (lower 9 bits) <sup>Note</sup> or bits 7 to 0 (lower 8 bits) function as a transmit/receive buffer register, and bits 15 to 9 are used as a register that sets the division ratio of the operation clock (fMCK).

When data is received, parallel data converted by the shift register is stored in the lower 8/9 bits. When data is to be transmitted, set transmit data to be transferred to the shift register to the lower 8/9 bits.

The data stored in the lower 8/9 bits of this register is as follows, depending on the setting of bits 0 and 1 (DLSmn0, DLSmn1) of serial communication operation setting register mn (SCRmn), regardless of the output sequence of the data.

- 7-bit data length (stored in bits 0 to 6 of SDRmn register)
- 8-bit data length (stored in bits 0 to 7 of SDRmn register)
- 9-bit data length (stored in bits 0 to 8 of SDRmn register)

The SDRmn register can be read or written in 16-bit units.

The lower 8/9 bits of the SDRmn register can be read or written <sup>Note</sup> as the following SFRs, depending on the communication mode.

- · CSIp communication...... SIOp (CSIp data register)
- UARTq reception ..... RXDq (UARTq receive data register)
- UARTq transmission ...... TXDq (UARTq transmit data register)
- IICr communication ...... SIOr (IICr data register)

Reset signal generation clears the SDRmn register to 0000H.

**Note** Using an 8-bit memory manipulation instruction to write to the SDRmn[7:0] bits while operation is stopped (SEmn = 0) is prohibited (doing so clears the SDRmn[15:9] bits to 0).

Remark 1. After data is received, 0 is stored in bits 0 to 8 in bit portions that exceed the data length.

Remark 2. m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01),

q: UART number (q = 0), r: IIC number (r = 00, 01)





### Figure 11 - 2 Format of Serial data register mn (SDRmn) (mn = 00, 01)

Remark For the function of the higher 7 bits of the SDRmn register, see 11.3 Registers Controlling Serial Array Unit.



# 11.3 Registers Controlling Serial Array Unit

Serial array unit is controlled by the following registers.

- Peripheral enable register 0 (PER0)
- Peripheral reset control register 0 (PRR0)
- Serial clock select register m (SPSm)
- Serial mode register mn (SMRmn)
- Serial communication operation setting register mn (SCRmn)
- Serial data register mn (SDRmn)
- Serial flag clear trigger register mn (SIRmn)
- Serial status register mn (SSRmn)
- Serial channel start register m (SSm)
- Serial channel stop register m (STm)
- Serial channel enable status register m (SEm)
- Serial output enable register m (SOEm)
- Serial output level register m (SOLm)
- Serial output register m (SOm)
- Serial standby control register m (SSCm)
- Noise filter enable register 0 (NFEN0)
- Port input mode register 5 (PIM5)
- Port output mode register 5 (POM5)
- Port mode register 5 (PM5)
- Port register 5 (P5)

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1)



### 11.3.1 Peripheral enable register 0 (PER0)

PER0 is used to enable or disable supplying the clock to the peripheral hardware. Clock supply to a hardware macro that is not used is stopped in order to reduce the power consumption and noise.

When serial array unit 0 is used, be sure to set bit 2 (SAU0EN) of this register to 1.

The PER0 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears the PER0 register to 00H.

#### Figure 11 - 3 Format of Peripheral enable register 0 (PER0)

| Address | : F00F0H     | After reset: 00 | H R/W |         |   |        |   |        |
|---------|--------------|-----------------|-------|---------|---|--------|---|--------|
| Symbol  | <7>          | <6>             | <5>   | <4>     | 3 | <2>    | 1 | <0>    |
| PER0    | IICA2EN Note | IICA1EN         | ADCEN | IICA0EN | 0 | SAU0EN | 0 | TAU0EN |

| ſ | SAUmEN | Control of serial array unit m input clock supply                                     |
|---|--------|---------------------------------------------------------------------------------------|
|   | 0      | Stops supply of input clock.<br>• SFR used by serial array unit m cannot be written.  |
|   | 1      | Enables input clock supply.<br>• SFR used by serial array unit m can be read/written. |

**Note** This bit is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.

Caution 1. When setting serial array unit m, be sure to first set the following registers with the SAUmEN bit set to 1. If SAUmEN = 0, writing to a control register of serial array unit m is ignored (except for the noise filter enable register 0 (NFEN0), port input mode register 5 (PIM5), port output mode register 5 (POM5), port mode register 5 (PM5), and port register 5 (P5).

- Serial clock select register m (SPSm)
- Serial mode register mn (SMRmn)
- Serial communication operation setting register mn (SCRmn)
- Serial data register mn (SDRmn)
- Serial flag clear trigger register mn (SIRmn)
- Serial status register mn (SSRmn)
- Serial channel start register m (SSm)
- Serial channel stop register m (STm)
- Serial channel enable status register m (SEm)
- Serial output enable register m (SOEm)
- Serial output level register m (SOLm)
- Serial output register m (SOm)
- Serial standby control register m (SSCm)

Caution 2. Be sure to clear the following bits to 0.

Bits 1 and 3



## 11.3.2 Peripheral reset control register 0 (PRR0)

This register is used for individual reset control of each peripheral hardware.

The R9A02G015 controls reset and reset release of each peripheral hardware supported by the PRR0 register.

To reset the serial array unit, be sure to set bit 2 (SAU0RES) to 1.

The PRR0 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears the PRR0 register to 00H.

### Figure 11 - 4 Format of Peripheral reset control register 0 (PRR0)

| Address: | Address: F00F1H After rese |          | H R/W  |          |   |         |   |         |
|----------|----------------------------|----------|--------|----------|---|---------|---|---------|
| Symbol   | <7>                        | <6>      | <5>    | <4>      | 3 | <2>     | 1 | <0>     |
| PRR0     | IICA2RES <sup>Note</sup>   | IICA1RES | ADCRES | IICA0RES | 0 | SAU0RES | 0 | TAU0RES |

| SAU0RES | Reset control of serial array unit |
|---------|------------------------------------|
| 0       | Serial array unit reset release    |
| 1       | Serial array unit reset state      |

**Note** This bit is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.



## 11.3.3 Serial clock select register m (SPSm)

The SPSm register is a 16-bit register that is used to select two types of operation clocks (CKm0, CKm1) that are commonly supplied to each channel. CKm1 is selected by bits 7 to 4 of the SPSm register, and CKm0 is selected by bits 3 to 0.

Rewriting the SPSm register is prohibited when the register is in operation (when SEmn = 1).

The SPSm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the SPSm register can be set with an 8-bit memory manipulation instruction with SPSmL. Reset signal generation clears the SPSm register to 0000H.



| Address | After reset: 0000H |     |     |     | R/W                  |                      |            |            |            |            |            |            |            |            |            |            |
|---------|--------------------|-----|-----|-----|----------------------|----------------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
| Symbol  | 15                 | 14  | 13  | 12  | 11                   | 10                   | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
| SPSm    | 0                  | 0   | 0   | 0   | 0                    | 0                    | 0          | 0          | PRS<br>m13 | PRS<br>m12 | PRS<br>m11 | PRS<br>m10 | PRS<br>m03 | PRS<br>m02 | PRS<br>m01 | PRS<br>m00 |
|         | PRS                | PRS | PRS | PRS |                      |                      |            | Sec        | tion of o  | peratio    | n clock    | (CKmk)     | Note       |            |            |            |
|         | mk3                | mk2 | mk1 | mk0 |                      |                      | fc∟<br>2 N | к =<br>1Hz | fc∟<br>5 N | к =<br>IHz | -          | к =<br>ИНz | -          | к =<br>ИНz |            | к =<br>MHz |
|         | 0                  | 0   | 0   | 0   | fc                   | LK                   | 2 N        | 1Hz        | 5 N        | 1Hz        | 10         | MHz        | 20 1       | ИНz        | 24 I       | MHz        |
|         | 0                  | 0   | 0   | 1   | fcL                  | к/2                  | 1 N        | 1Hz        | 2.5        | MHz        | 5 N        | 1Hz        | 10 1       | ИНz        | 12         | MHz        |
|         | 0                  | 0   | 1   | 0   | fclł                 | 2<sup 2              | 500        | kHz        | 1.25       | 1.25 MHz   |            | MHz        | 5 MHz      |            | 6 N        | 1Hz        |
|         | 0                  | 0   | 1   | 1   | fclł                 | 2<sup 3              | 250 kHz    |            | 625 kHz    |            | 1.25 MHz   |            | 2.5 MHz    |            | 3 N        | 1Hz        |
|         | 0                  | 1   | 0   | 0   | fclł                 | 2<sup 4              | 125 kHz    |            | 313        | kHz        | 625        | kHz        | 1.25       | MHz        | 1.5        | MHz        |
|         | 0                  | 1   | 0   | 1   | fclk                 | 2<sup 5              | 62.5 kHz   |            | 156        | kHz        | 313        | kHz        | 625        | kHz        | 750        | kHz        |
|         | 0                  | 1   | 1   | 0   | fclł                 | 2<sup 6              | 31.3 kHz   |            | 78.1       | kHz        | 156        | kHz        | 313        | kHz        | 375        | kHz        |
|         | 0                  | 1   | 1   | 1   | fclk                 | 2<sup 7              | 15.6 kHz   |            | 39.1 kHz   |            | 78.1 kHz   |            | 156 kHz    |            | 187.       | 5 kHz      |
|         | 1                  | 0   | 0   | 0   | fclł                 | 2<sup 8              | 7.81 kHz   |            | 19.5 kHz   |            | 39.1 kHz   |            | 78.1 kHz   |            | 93.8       | kHz        |
|         | 1                  | 0   | 0   | 1   | fclł                 | 2<sup 9              | 3.91       | kHz        | 9.77 kHz   |            | 19.5 kHz   |            | 39.1 kHz   |            | 46.9       | kHz        |
|         | 1                  | 0   | 1   | 0   | fclk                 | /2 <sup>10</sup>     | 1.95       | kHz        | 4.88       | kHz        | 9.77 kHz   |            | 19.5 kHz   |            | 23.4       | kHz        |
|         | 1                  | 0   | 1   | 1   | fclк/2 <sup>11</sup> |                      | 977        | ' Hz       | 2.44       | kHz        | 4.88 kHz   |            | 9.77       | kHz        | 11.7       | kHz        |
|         | 1                  | 1   | 0   | 0   | fclк/2 <sup>12</sup> |                      | 488        | 6 Hz       | 1.22       | kHz        | 2.44 kHz   |            | 4.88       | kHz        | 5.86       | kHz        |
|         | 1                  | 1   | 0   | 1   | fclk/2 <sup>13</sup> |                      | 244 Hz     |            | 610 Hz     |            | 1.22 kHz   |            | 2.44 kHz   |            | 2.93       | kHz        |
|         | 1                  | 1   | 1   | 0   | fclk                 | fclк/2 <sup>14</sup> |            | 122 Hz     |            | 305 Hz     |            | 610 Hz     |            | 1.22 kHz   |            | kHz        |
|         | 1                  | 1   | 1   | 1   | fclk                 | /2 <sup>15</sup>     | 61         | Hz         | 153        | Hz         | 305        | 5 Hz       | 610        | ) Hz       | 732        | 2 Hz       |

### Figure 11 - 5 Format of Serial clock select register m (SPSm)

**Note** When changing the clock selected for fCLK (by changing the system clock control register (CKC) value), do so after having stopped (serial channel stop register m (STm) = 000FH) the operation of the serial array unit (SAU).

Caution Be sure to clear bits 15 to 8 to 0.

**Remark 1.** fcLK: CPU/peripheral hardware clock frequency **Remark 2.** m: Unit number (m = 0)

Remark 3. k = 0, 1



### 11.3.4 Serial mode register mn (SMRmn)

The SMRmn register is a register that sets an operation mode of channel n. It is also used to select an operation clock (fMCK), specify whether the serial clock (fSCK) may be input or not, set a start trigger, an operation mode (CSI, UART, or simplified I<sup>2</sup>C), and an interrupt source. This register is also used to invert the level of the receive data only in the UART mode.

Rewriting the SMRmn register is prohibited when the register is in operation (when SEmn = 1). However, the MDmn0 bit can be rewritten during operation.

The SMRmn register can be set by a 16-bit memory manipulation instruction.

Reset signal generation sets the SMRmn register to 0020H.

#### Figure 11 - 6 Format of Serial mode register mn (SMRmn) (1/2)

| Address: | F0110             | 10H, F0111H (SMR00) to F0112H, F0113H (SMR01), After reset: 0020H R/W |                                                                                                                                                                                                                                    |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|----------|-------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------|----------|-------------------------------|---------|-------|---|-----------|-----------|-----------|
| Symbol   | 15                | 14                                                                    | 13                                                                                                                                                                                                                                 | 12       | 11      | 10                                                                                                                                                  | 9         | 8                 | 7        | 6                             | 5       | 4     | 3 | 2         | 1         | 0         |
| SMRmn    | CKS<br>mn         | CCS<br>mn                                                             | 0                                                                                                                                                                                                                                  | 0        | 0       | 0                                                                                                                                                   | 0         | STS<br>mn<br>Note | 0        | SIS<br>mn0<br><sub>Note</sub> | 1       | 0     | 0 | MD<br>mn2 | MD<br>mn1 | MD<br>mn0 |
|          | CKS<br>mn         |                                                                       |                                                                                                                                                                                                                                    |          |         | Seleo                                                                                                                                               | ction of  | operatio          | on clocł | к (fмск)                      | of chan | nel n |   |           |           |           |
|          | 0                 | Operat                                                                | ration clock CKm0 set by the SPSm register                                                                                                                                                                                         |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|          | 1                 | Operat                                                                | eration clock CKm1 set by the SPSm register                                                                                                                                                                                        |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|          |                   |                                                                       | n clock (fмск) is used by the edge detector. In addition, depending on the setting of the CCSmn bit and the<br>bits of the SDRmn register, a transfer clock (frcLk) is generated.                                                  |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|          | CCS<br>mn         |                                                                       | Selection of transfer clock (fTCLK) of channel n                                                                                                                                                                                   |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|          | 0                 | Divideo                                                               | d operat                                                                                                                                                                                                                           | tion clo | ck fmck | specifie                                                                                                                                            | d by the  | e CKSm            | n bit    |                               |         |       |   |           |           |           |
|          | 1                 | Clock i                                                               | nput fso                                                                                                                                                                                                                           | ск from  | the SCI | <p (s<="" pin="" td=""><td>slave tra</td><td>ansfer ir</td><td>n CSI m</td><td>iode)</td><td></td><td></td><td></td><td></td><td></td><td></td></p> | slave tra | ansfer ir         | n CSI m  | iode)                         |         |       |   |           |           |           |
|          |                   | ontrolle                                                              | clock fTCLK is used for the shift register, communication controller, output controller, interrupt controller, and ntroller. When CCSmn = 0, the division ratio of operation clock (fMCK) is set by the higher 7 bits of the SDRmn |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|          | STS<br>mn<br>Note |                                                                       | Selection of start trigger source                                                                                                                                                                                                  |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
| ĺ        | 0                 | Only so                                                               | only software trigger is valid (selected for CSI, UART transmission, and simplified I <sup>2</sup> C).                                                                                                                             |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|          | 1                 | Valid e                                                               | Valid edge of the RxDq pin (selected for UART reception)                                                                                                                                                                           |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |
|          | Transf            | er is sta                                                             | s started when the above source is satisfied after 1 is set to the SSm register.                                                                                                                                                   |          |         |                                                                                                                                                     |           |                   |          |                               |         |       |   |           |           |           |

Note The SMR01 register only.

Caution Be sure to clear bits 13 to 9, 7, 4, and 3 (or bits 13 to 6, 4, and 3 for the SMR00 register) to 0. Be sure to set bit 5 to 1.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), q: UART number (q = 0), r: IIC number (r = 00, 01)



| dress: F0110H, F0111H (SMR00) to F0112H, F0113H (SMR0 |                                                                                                                           |           |                                                                                                        |                      |          |         |          |                   | After reset: 0020H R/W |                               |          |          |        |           |           |           |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------------------------------------------------------------------------------------|----------------------|----------|---------|----------|-------------------|------------------------|-------------------------------|----------|----------|--------|-----------|-----------|-----------|
| mbol                                                  | 15                                                                                                                        | 14        | 13                                                                                                     | 12                   | 11       | 10      | 9        | 8                 | 7                      | 6                             | 5        | 4        | 3      | 2         | 1         | 0         |
| Rmn                                                   | CKS<br>mn                                                                                                                 | CCS<br>mn | 0                                                                                                      | 0                    | 0        | 0       | 0        | STS<br>mn<br>Note | 0                      | SIS<br>mn0<br><sub>Note</sub> | 1        | 0        | 0      | MD<br>mn2 | MD<br>mn1 | MD<br>mn0 |
|                                                       | SIS<br>mn0<br>Note                                                                                                        |           |                                                                                                        | (                    | Controls | inversi | on of le | vel of re         | ceive d                | ata of cl                     | nannel i | n in UAI | RT mod | e         |           |           |
|                                                       | 0                                                                                                                         | -         | edge is detected as the start bit.<br>put communication data is captured as is.                        |                      |          |         |          |                   |                        |                               |          |          |        |           |           |           |
|                                                       | 1                                                                                                                         | -         | g edge is detected as the start bit.<br>nput communication data is inverted and captured.              |                      |          |         |          |                   |                        |                               |          |          |        |           |           |           |
| [                                                     | MD<br>mn2                                                                                                                 | MD<br>mn1 | Setting of operation mode of channel n                                                                 |                      |          |         |          |                   |                        |                               |          |          |        |           |           |           |
| ľ                                                     | 0                                                                                                                         | 0         | CSI m                                                                                                  | ode                  |          |         |          |                   |                        |                               |          |          |        |           |           |           |
|                                                       | 0                                                                                                                         | 1         | UART                                                                                                   | mode                 |          |         |          |                   |                        |                               |          |          |        |           |           |           |
| Ī                                                     | 1                                                                                                                         | 0         | Simplif                                                                                                | ied I <sup>2</sup> C | mode     |         |          |                   |                        |                               |          |          |        |           |           |           |
|                                                       | 1                                                                                                                         | 1         | Setting                                                                                                | j prohib             | ited     |         |          |                   |                        |                               |          |          |        |           |           |           |
| [                                                     | MD<br>mn0                                                                                                                 |           |                                                                                                        |                      |          | S       | electior | n of inter        | rupt so                | urce of o                     | channel  | n        |        |           |           |           |
|                                                       | 0                                                                                                                         | Transf    | er end i                                                                                               | nterrupt             |          |         |          |                   |                        |                               |          |          |        |           |           |           |
|                                                       | 1                                                                                                                         |           | ffer empty interrupt<br>ccurs when data is transferred from the SDRmn register to the shift register.) |                      |          |         |          |                   |                        |                               |          |          |        |           |           |           |
|                                                       | For successive transmission, the next transmit data is written by setting the MDmn0 bit to 1 when SDRmn data has run out. |           |                                                                                                        |                      |          |         |          |                   |                        |                               |          |          |        |           |           |           |
|                                                       | Note<br>Cautio                                                                                                            |           | e SMR(                                                                                                 | -                    |          |         | 4, and   | 3 (or b           | its 13 t               | o 6, 4, a                     | und 3 fo | or the S | MR00 I | register  | ) to 0. I | 3e sur    |

### Figure 11 - 7 Format of Serial mode register mn (SMRmn) (2/2)

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), q: UART number (q = 0), r: IIC number (r = 00, 01)

### 11.3.5 Serial communication operation setting register mn (SCRmn)

The SCRmn register is a communication operation setting register of channel n. It is used to set a data transmission/reception mode, phase of data and clock, whether an error signal is to be masked or not, parity bit, start bit, stop bit, and data length.

Rewriting the SCRmn register is prohibited when the register is in operation (when SEmn = 1).

The SCRmn register can be set by a 16-bit memory manipulation instruction.

Reset signal generation sets the SCRmn register to 0087H.

to set bit 5 to 1.

Symbol

15

14

#### Figure 11 - 8 Format of Serial communication operation setting register mn (SCRmn) (1/2)

9

10

Address: F0118H, F0119H (SCR00) to F011AH, F011BH (SCR01)

12

11

13

After reset: 0087H

5

4

6

7

R/W 3 2

0

1

| SCRmn | TXE | RXE | DAP | СКР | 0 | EOC | PTC | PTC | DIR | 0 | SLCm<br>n1 | SLC | 0 | 1 | DLSm | DLS |
|-------|-----|-----|-----|-----|---|-----|-----|-----|-----|---|------------|-----|---|---|------|-----|
|       | mn  | mn  | mn  | mn  |   | mn  | mn1 | mn0 | mn  |   | Note 1     | mn0 |   |   | n1   | mn0 |

8

| TXE<br>mn | RXE<br>mn | Setting of operation mode of channel n |
|-----------|-----------|----------------------------------------|
|           |           |                                        |
| 0         | 0         | Disable communication.                 |
| 0         | 1         | Reception only                         |
| 1         | 0         | Transmission only                      |
| 1         | 1         | Transmission/reception                 |

| DAP<br>mn | CKP<br>mn | Selection of data and clock phase in CSI mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Туре |
|-----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 0         | 0         | SCKp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1    |
| 0         | 1         | SCKp          SOp          SIp input timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 2    |
| 1         | 0         | SCKp         Image: Constraint of the second se | 3    |
| 1         | 1         | SCKp            SOp         XD7 X D6 X D5 X D4 X D3 X D2 X D1 X D0           SIp input timing            DAPmn_CKPmn = 0_0 in the LIABT mode and simplified I2C mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 4    |

Be sure to set DAPmn, CKPmn = 0, 0 in the UART mode and simplified  $I^{2}C$  mode.

| EOC<br>mn | Mask control of error interrupt signal (INTSREx (x = 0))                                              |  |  |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0         | Disables generation of error interrupt INTSREx (INTSRx is generated).                                 |  |  |  |  |  |  |  |
| 1         | Enables generation of error interrupt INTSREx (INTSRx is not generated if an error occurs).           |  |  |  |  |  |  |  |
| Set EC    | Set EOCmn = 0 in the CSI mode, simplified I <sup>2</sup> C mode, and during UART transmission Note 2. |  |  |  |  |  |  |  |

**Note 1.** The SCR00 register only.

Note 2. When using CSImn not with EOCmn = 0, error interrupt INTSREn may be generated.

Caution Be sure to clear bits 3, 6, and 11 to 0 (Also clear bit 5 of the SCR01 register to 0). Be sure to set bit 2 to 1.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01)



#### Figure 11 - 9 Format of Serial communication operation setting register mn (SCRmn) (2/2)

Address: F0118H, F0119H (SCR00) to F011AH, F011BH (SCR01)

After reset: 0087H R/W

Symbol 4 0 15 14 13 12 11 10 9 8 7 6 5 3 2 1 SLCm PTC RXE DAP PTC DLS TXE CKP EOC DIR SLC DLSm SCRmn 0 0 0 n1 1 mn mn mn mn mn mn1 mn0 mn mn0 n1 mn0 Note 1

| DTC mp1                                                                          | PTC mn0                                                 | Setting of parity bit in UART mode   |                         |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------|-------------------------|--|--|--|--|--|--|--|--|--|
| FICILIT                                                                          | FICILII                                                 | Transmission                         | Reception               |  |  |  |  |  |  |  |  |  |
| 0                                                                                | 0                                                       | Does not output the parity bit.      | Receives without parity |  |  |  |  |  |  |  |  |  |
| 0                                                                                | 1                                                       | Outputs 0 parity <sup>Note 2</sup> . | No parity judgment      |  |  |  |  |  |  |  |  |  |
| 1                                                                                | 0                                                       | Outputs even parity.                 | Judged as even parity.  |  |  |  |  |  |  |  |  |  |
| 1                                                                                | 1     1     Outputs odd parity.   Judges as odd parity. |                                      |                         |  |  |  |  |  |  |  |  |  |
| Be sure to set PTCmn1, PTCmn0 = 0, 0 in the CSI mode and simplified $I^2C$ mode. |                                                         |                                      |                         |  |  |  |  |  |  |  |  |  |

| DIR mn     | Selection of data transfer sequence in CSI and UART modes |
|------------|-----------------------------------------------------------|
| 0          | Inputs/outputs data with MSB first.                       |
| 1          | Inputs/outputs data with LSB first.                       |
| Be sure to | clear DIRmn = 0 in the simplified I <sup>2</sup> C mode.  |

| SLCmn1<br>Note 1 | SLC mn0     | Setting of stop bit in UART mode                                                          |
|------------------|-------------|-------------------------------------------------------------------------------------------|
| 0                | 0           | No stop bit                                                                               |
| 0                | 1           | Stop bit length = 1 bit                                                                   |
| 1                | 0           | Stop bit length = 2 bits (mn = 00 only)                                                   |
| 1                | 1           | Setting prohibited                                                                        |
| When the t       | ransfer end | interrupt is selected, the interrupt is generated when all stop bits have been completely |
| transferred      |             |                                                                                           |

Set 1 bit (SLCmn1, SLCmn0 = 0, 1) during UART reception and in the simplified I<sup>2</sup>C mode.

Set no stop bit (SLCmn1, SLCmn0 = 0, 0) in the CSI mode.

Set 1 bit (SLCmn1, SLCmn0 = 0, 1) or 2 bits (SLCmn1, SLCmn0 = 1, 0) during UART transmission.

| DLSmn1                                                                   | DLS mn0 | Setting of data length in CSI and UART modes                                                 |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------|---------|----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0                                                                        | 1       | 9-bit data length (stored in bits 0 to 8 of the SDRmn register) (settable in UART mode only) |  |  |  |  |  |  |  |
| 1                                                                        | 0       | 7-bit data length (stored in bits 0 to 6 of the SDRmn register)                              |  |  |  |  |  |  |  |
| 1                                                                        | 1       | 8-bit data length (stored in bits 0 to 7 of the SDRmn register)                              |  |  |  |  |  |  |  |
| Other than above Setting prohibited                                      |         |                                                                                              |  |  |  |  |  |  |  |
| Be sure to set $DLSmn1$ , $DLSmn0 = 1, 1$ in the simplified $l^2C$ mode. |         |                                                                                              |  |  |  |  |  |  |  |

Note 1. The SCR00 register only.

**Note 2.** 0 is always added regardless of the data contents.

Caution Be sure to clear bits 3, 6, and 11 to 0 (Also clear bit 5 of the SCR01 register to 0). Be sure to set bit 2 to 1.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01)



## 11.3.6 Serial data register mn (SDRmn)

The SDRmn register is the transmit/receive data register (16 bits) of channel n.

Bits 8 to 0 (lower 9 bits) of SDR00 and SDR01 as a transmit/receive buffer register, and bits 15 to 9 (higher 7 bits) are used as a register that sets the division ratio of the operation clock (fMCK).

If the CCSmn bit of serial mode register mn (SMRmn) is cleared to 0, the clock set by dividing the operating clock by the higher 7 bits of the SDRmn register is used as the transfer clock.

If the CCSmn bit of serial mode register mn (SMRmn) is set to 1, set bits 15 to 9 (upper 7 bits) of SDR00 and SDR01 to 0000000B. The input clock fsck (slave transfer in CSI mode) from the SCKp pin is used as the transfer clock.

The lower 8/9 bits of the SDRmn register function as a transmit/receive buffer register. During reception, the parallel data converted by the shift register is stored in the lower 8/9 bits, and during transmission, the data to be transmitted to the shift register is set to the lower 8/9 bits.

The SDRmn register can be read or written in 16-bit units.

However, the higher 7 bits can be written or read only when the operation is stopped (SEmn = 0). During operation (SEmn = 1), a value is written only to the lower 8/9 bits of the SDRmn register. When the SDRmn register is read during operation, the higher 7 bits are always read as 0.

Reset signal generation clears the SDRmn register to 0000H.

ŝ

1

1

1

1

1

1

#### Figure 11 - 10 Format of Serial data register mn (SDRmn)

| Address | : FFF10 | )H, FFF | 11H (SI | DR00), I | FFF12H | I, FFF1: | 3H (SDI | R01) After reset: 0000H R/W                        |   |   |   |                |       |    |   |   |  |  |
|---------|---------|---------|---------|----------|--------|----------|---------|----------------------------------------------------|---|---|---|----------------|-------|----|---|---|--|--|
|         |         |         | F       | FF11H    | (SDR0( | ))       |         |                                                    |   |   | F | FF10H          | (SDR0 | 0) |   |   |  |  |
| I       | 15      | 14      | 13      | 12       | 11     | 10       | 9       | 8                                                  | 7 | 6 | 5 | 4              | 3     | 2  | 1 | 0 |  |  |
| SDRmn   |         |         |         |          |        |          |         |                                                    |   |   |   |                |       |    |   |   |  |  |
|         |         |         | SD      | Rmn[1    | 5:9]   |          |         | Transfer clock set by dividing the operating clock |   |   |   |                |       |    |   |   |  |  |
|         | 0       | 0       | 0       | 0        | 0      | 0        | 0       |                                                    |   |   |   | fмск/2         |       |    |   |   |  |  |
|         | 0       | 0       | 0       | 0        | 0      | 0        | 1       |                                                    |   |   |   | fмск/4         |       |    |   |   |  |  |
|         | 0       | 0       | 0       | 0        | 0      | 1        | 0       |                                                    |   |   |   | <b>f</b> мск/6 |       |    |   |   |  |  |
|         | 0       | 0       | 0       | 0        | 0      | 1        | 1       |                                                    |   |   |   | fмск/8         |       |    |   |   |  |  |

Caution 1. Setting SDRmn[15:9] = (0000000B, 0000001B) is prohibited when UART is used.

ŝ

0

1

ì

1

1

Caution 2. Setting SDRmn[15:9] = 0000000B is prohibited when simplified I<sup>2</sup>C is used. Set SDRmn[15:9] to 0000001B or greater.

fмск/254

fмск/256

Caution 3. Using an 8-bit memory manipulation instruction to write to the SDRmn[7:0] bits while operation is stopped (SEmn = 0) is prohibited (doing so clears the SDRmn[15:9] bits to 0).

**Remark 1.** For the function of the lower 8/9 bits of the SDRmn register, see **11.2 Configuration of Serial Array Unit**. **Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0, 1)

1

1

1

1



### 11.3.7 Serial flag clear trigger register mn (SIRmn)

The SIRmn register is a trigger register that is used to clear each error flag of channel n.

When each bit (FECTmn, PECTmn, OVCTmn) of this register is set to 1, the corresponding bit (FEFmn, PEFmn, OVFmn) of serial status register mn is cleared to 0. Because the SIRmn register is a trigger register, it is cleared immediately when the corresponding bit of the SSRmn register is cleared.

The SIRmn register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the SIRmn register can be set with an 8-bit memory manipulation instruction with SIRmnL. Reset signal generation clears the SIRmn register to 0000H.

| Address | : F0108            | 8H, F010    | )9H (SII                                    | R00) to | F010AH   | H, F010 | BH (SIF   | R01)               | Afte      | er reset: | 0000H    | I     | R/W |  |  |  |  |
|---------|--------------------|-------------|---------------------------------------------|---------|----------|---------|-----------|--------------------|-----------|-----------|----------|-------|-----|--|--|--|--|
| Symbol  | 15                 | 14          |                                             |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |
| SIRmn   | 0                  | 0           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0       |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |
|         | FEC<br>Tmn<br>Note |             | Clear trigger of framing error of channel n |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |
|         | 0                  | Not cleared |                                             |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |
|         | 1                  | Clears      | the FE                                      | Fmn bit | of the S | SSRmn   | register  | <sup>-</sup> to 0. |           |           |          |       |     |  |  |  |  |
|         |                    |             |                                             |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |
|         | PEC<br>Tmn         |             |                                             |         |          | Cle     | ear trigg | er of pa           | rity erro | or flag o | f channe | el n  |     |  |  |  |  |
|         | 0                  | Not cle     | eared                                       |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |
|         | 1                  | Clears      | the PE                                      | Fmn bit | of the S | SSRmn   | register  | r to 0.            |           |           |          |       |     |  |  |  |  |
|         |                    |             |                                             |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |
|         | OVC<br>Tmn         |             |                                             |         |          | Clea    | ar trigge | er of ove          | errun err | or flag o | of chanr | nel n |     |  |  |  |  |
|         | 0                  | Not cle     | eared                                       |         |          |         |           |                    |           |           |          |       |     |  |  |  |  |

#### Figure 11 - 11 Format of Serial flag clear trigger register mn (SIRmn)

Note The SIR01 register only.

1

#### Caution Be sure to clear bits 15 to 3 (or bits 15 to 2 for the SIR00 register) to 0.

**Remark 1.** m: Unit number (m = 0), n: Channel number (n = 0, 1) **Remark 2.** When the SIRmn register is read, 0000H is always read.

Clears the OVFmn bit of the SSRmn register to 0.



### 11.3.8 Serial status register mn (SSRmn)

The SSRmn register is a register that indicates the communication status and error occurrence status of channel n. The errors indicated by this register are a framing error, parity error, and overrun error.

The SSRmn register can be read by a 16-bit memory manipulation instruction.

The lower 8 bits of the SSRmn register can be set with an 8-bit memory manipulation instruction with SSRmnL. Reset signal generation clears the SSRmn register to 0000H.

#### Figure 11 - 12 Format of Serial status register mn (SSRmn) (1/2)

| Address: F0100H, F0101H (SSR00) to F0102H, F0103H (SSR01) |    |    |    |    |    |    |   |   |   | After reset: 0000H R |           |   |   |                   |           |           |
|-----------------------------------------------------------|----|----|----|----|----|----|---|---|---|----------------------|-----------|---|---|-------------------|-----------|-----------|
| Symbol                                                    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                    | 5         | 4 | 3 | 2                 | 1         | 0         |
| SSRmn                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | TSF<br>mn            | BFF<br>mn | 0 | 0 | FEF<br>mn<br>Note | PEF<br>mn | OVF<br>mn |

| ISE | Communication status indication flag of channel n |
|-----|---------------------------------------------------|
| mn  |                                                   |
| 0   | Communication is stopped or suspended.            |
| 1   | Communication is in progress.                     |

<Clear conditions>

TOF

• The STmn bit of the STm register is set to 1 (communication is stopped) or the SSmn bit of the SSm register is set to 1 (communication is suspended).

- Communication ends.
- <Set condition>
- Communication starts.

| BFF<br>mn                                                       | Buffer register status indication flag of channel n |  |  |  |  |  |  |  |  |  |
|-----------------------------------------------------------------|-----------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0                                                               | Valid data is not stored in the SDRmn register.     |  |  |  |  |  |  |  |  |  |
| 1                                                               | Valid data is stored in the SDRmn register.         |  |  |  |  |  |  |  |  |  |
| <clear< td=""><td colspan="10">ear conditions&gt;</td></clear<> | ear conditions>                                     |  |  |  |  |  |  |  |  |  |

• Transferring transmit data from the SDRmn register to the shift register ends during transmission.

- Reading receive data from the SDRmn register ends during reception.
- The STmn bit of the STm register is set to 1 (communication is stopped) or the SSmn bit of the SSm register is set to 1 (communication is enabled).

<Set conditions>

- Transmit data is written to the SDRmn register while the TXEmn bit of the SCRmn register is set to 1 (transmission or transmission and reception mode in each communication mode).
- Receive data is stored in the SDRmn register while the RXEmn bit of the SCRmn register is set to 1 (reception or transmission and reception mode in each communication mode).
- A reception error occurs.

#### Note The SSR01 register only.

Caution When the CSI is performing reception operations in the SNOOZE mode (SWCm = 1), the BFFmn flag will not change.

**Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3)



| ddress | : F0100                                                                                                                                                                                                                                                                                                                                                    | H, F010                               | 01H (SS                      | R00) to   | F0102   | H, F010  | )3H (SS   | R01)     | 1) After reset: 0000H R |           |                      |          |         |                       |   |           |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------------------|-----------|---------|----------|-----------|----------|-------------------------|-----------|----------------------|----------|---------|-----------------------|---|-----------|
| Symbol | 15                                                                                                                                                                                                                                                                                                                                                         | 14                                    | 13                           | 12        | 11      | 10       | 9         | 8        | 7                       | 6         | 5                    | 4        | 3       | 2                     | 1 | 0         |
| SRmn   | 0                                                                                                                                                                                                                                                                                                                                                          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                              |           |         |          |           |          |                         |           |                      |          |         |                       |   | OVF<br>mn |
|        | FEF       mn       Framing error detection flag of channel n         Note       0       No error occurs.         1       An error occurs (during UART reception). <clear condition="">       • 1 is written to the FECTmn bit of the SIRmn register.         <set condition="">       • A stop bit is not detected when UART reception ends.</set></clear> |                                       |                              |           |         |          |           |          |                         |           |                      |          |         |                       |   |           |
|        | A stop bit is not detected when UART reception ends.      PEF     Parity error detection flag of channel n                                                                                                                                                                                                                                                 |                                       |                              |           |         |          |           |          |                         |           |                      |          |         |                       |   |           |
|        | 0                                                                                                                                                                                                                                                                                                                                                          | No err                                | or occui                     | s.        |         |          |           |          |                         |           |                      |          |         |                       |   |           |
|        | 1                                                                                                                                                                                                                                                                                                                                                          | An erro                               | or occur                     | rs (durin | g UAR   | Г recept | tion) or  | ACK is   | not dete                | ected (d  | uring I <sup>2</sup> | C transi | mission | ).                    |   |           |
|        | • 1 is v<br><set c<br="">• The j<br/>• No A</set>                                                                                                                                                                                                                                                                                                          |                                       | o the PE<br>i><br>f the trai | nsmit da  | ata and | the pari | ty bit do | o not ma |                         |           |                      |          |         | ty error).<br>nission |   | not       |
|        | OVF<br>mn                                                                                                                                                                                                                                                                                                                                                  |                                       |                              |           |         | С        | verrun    | error de | etection                | flag of o | channel              | n        |         |                       |   |           |
|        | 0                                                                                                                                                                                                                                                                                                                                                          | No erre                               | or occui                     | s.        |         |          |           |          |                         |           |                      |          |         |                       |   |           |
|        | 1 An error occurs                                                                                                                                                                                                                                                                                                                                          |                                       |                              |           |         |          |           |          |                         |           |                      |          |         |                       |   |           |
|        | <ul> <li><clear condition=""></clear></li> <li>1 is written to the OVCTmn bit of the SIRmn register.</li> <li><set condition=""></set></li> </ul>                                                                                                                                                                                                          |                                       |                              |           |         |          |           |          |                         |           |                      |          |         |                       |   |           |

#### Figure 11 - 13 Format of Serial status register mn (SSRmn) (2/2)

Transmit data is not ready for slave transmission or transmission and reception in CSI mode.

Note The SSR01 register only.

each communication mode).

Caution 1. If data is written to the SDRmn register when BFFmn = 1, the transmit/receive data stored in the register is discarded and an overrun error (OVEmn = 1) is detected.

• Even though receive data is stored in the SDRmn register, that data is not read and transmit data or the next receive data is written while the RXEmn bit of the SCRmn register is set to 1 (reception or transmission and reception mode in

Caution 2. When the CSI is performing reception operations in the SNOOZE mode (SWCm = 1), the OVFmn flag will not change.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1)



### 11.3.9 Serial channel start register m (SSm)

The SSm register is a trigger register that is used to enable starting communication/count by each channel. When 1 is written a bit of this register (SSmn), the corresponding bit (SEmn) of serial channel enable status register m (SEm) is set to 1 (Operation is enabled). Because the SSmn bit is a trigger bit, it is cleared immediately when SEmn = 1.

The SSm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the SSm register can be set with an 1-bit or 8-bit memory manipulation instruction with SSmL. Reset signal generation clears the SSm register to 0000H.

| Address: | F0122 | H, F012                                                                             | 23H (SS                              | 60) |   | Afte | er reset: | 0000H | R/W |   |   |   |   |   |      |        |
|----------|-------|-------------------------------------------------------------------------------------|--------------------------------------|-----|---|------|-----------|-------|-----|---|---|---|---|---|------|--------|
| Symbol   | 15    | 14 13 12 11 10 9 8 7 6 5 4 3 2 1                                                    |                                      |     |   |      |           |       |     |   |   |   |   |   |      | 0      |
| SS0      | 0     | 0                                                                                   | 0                                    | 0   | 0 | 0    | 0         | 0     | 0   | 0 | 0 | 0 | 0 | 0 | SS01 | SS00   |
| г        |       |                                                                                     |                                      |     |   |      |           |       |     |   |   |   |   |   |      | ·<br>1 |
|          | SSm   |                                                                                     | Operation start trigger of channel n |     |   |      |           |       |     |   |   |   |   |   |      |        |
|          | n     |                                                                                     |                                      |     |   |      |           |       |     |   |   |   |   |   |      |        |
|          | 0     | No trig                                                                             | No trigger operation                 |     |   |      |           |       |     |   |   |   |   |   |      |        |
|          | 1     | 1 Sets the SEmn bit to 1 and enters the communication wait status <sup>Note</sup> . |                                      |     |   |      |           |       |     |   |   |   |   |   |      |        |

#### Figure 11 - 14 Format of Serial channel start register m (SSm)

At this time, holding status value of control register and shift register, SCKmn and SOmn pins, and FEFmn, PEFmn, OVFmn flags.

If set the SSmn = 1 to during a communication operation, will wait status to stop the communication.

Caution 1. Be sure to clear bits 15 to 2 of the SS0 register to 0.

Caution 2. For the UART reception, set the RXEmn bit of SCRmn register to 1, and then be sure to set SSmn to 1 after 4 or more fmck clocks have elapsed.

- **Remark 1.** m: Unit number (m = 0), n: Channel number (n = 0, 1)
- **Remark 2.** When the SSm register is read, 0000H is always read.

Note



### 11.3.10 Serial channel stop register m (STm)

The STm register is a trigger register that is used to enable stopping communication/count by each channel. When 1 is written a bit of this register (STmn), the corresponding bit (SEmn) of serial channel enable status register m (SEm) is cleared to 0 (operation is stopped). Because the STmn bit is a trigger bit, it is cleared immediately when SEmn = 0.

The STm register can set written by a 16-bit memory manipulation instruction.

The lower 8 bits of the STm register can be set with a 1-bit or 8-bit memory manipulation instruction with STmL. Reset signal generation clears the STm register to 0000H.

#### Figure 11 - 15 Format of Serial channel stop register m (STm)

| Address: | F0124    | H, F012 | 25H (ST                                                              | <sup>-</sup> 0) |  | Afte | r reset: | 0000H | R/W |  |  |  |  |  |  |      |
|----------|----------|---------|----------------------------------------------------------------------|-----------------|--|------|----------|-------|-----|--|--|--|--|--|--|------|
| Symbol   | 15       | 14      | 14 13 12 11 10 9 8 7 6 5 4 3 2 1                                     |                 |  |      |          |       |     |  |  |  |  |  |  |      |
| ST0      | 0        | 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ST01 S                                   |                 |  |      |          |       |     |  |  |  |  |  |  | ST00 |
|          | STm<br>n |         | Operation stop trigger of channel n                                  |                 |  |      |          |       |     |  |  |  |  |  |  |      |
|          | 0        | No trig | No trigger operation                                                 |                 |  |      |          |       |     |  |  |  |  |  |  |      |
|          | 1        | Clears  | Clears the SEmn bit to 0 and stops the communication operation Note. |                 |  |      |          |       |     |  |  |  |  |  |  |      |

**Note** Holding status value of the control register and shift register, the SCKmn and SOmn pins, and FEFmn, PEFmn, OVFmn flags.

#### Caution Be sure to clear bits 15 to 2 of the ST0 register to 0.

**Remark 1.** m: Unit number (m = 0), n: Channel number (n = 0, 1) **Remark 2.** When the STm register is read, 0000H is always read.



### 11.3.11 Serial channel enable status register m (SEm)

The SEm register indicates whether data transmission/reception operation of each channel is enabled or stopped.

When 1 is written a bit of serial channel start register m (SSm), the corresponding bit of this register is set to 1. When 1 is written a bit of serial channel stop register m (STm), the corresponding bit is cleared to 0.

Channel n that is enabled to operate cannot rewrite by software the value of the CKOmn bit (serial clock output of channel n) of serial output register m (SOm) to be described below, and a value reflected by a communication operation is output from the serial clock pin.

Channel n that stops operation can set the value of the CKOmn bit of the SOm register by software and output its value from the serial clock pin. In this way, any waveform, such as that of a start condition/stop condition, can be created by software.

The SEm register can be read by a 16-bit memory manipulation instruction.

The lower 8 bits of the SEm register can be set with a 1-bit or 8-bit memory manipulation instruction with SEmL. Reset signal generation clears the SEm register to 0000H.

| Address: | F0120    | H, F012 | , F0121H (SE0) After reset: 0000H R |         |    |           |         |         |          |          |          |        |   |   |      |      |
|----------|----------|---------|-------------------------------------|---------|----|-----------|---------|---------|----------|----------|----------|--------|---|---|------|------|
| Symbol   | 15       | 14      | 13                                  | 12      | 11 | 10        | 9       | 8       | 7        | 6        | 5        | 4      | 3 | 2 | 1    | 0    |
| SE0      | 0        | 0       | 0                                   | 0       | 0  | 0         | 0       | 0       | 0        | 0        | 0        | 0      | 0 | 0 | SE01 | SE00 |
|          | SEm<br>n |         |                                     |         |    | Indicatio | n of op | eration | enable/s | stop sta | tus of c | hannel | n |   |      |      |
|          | 0        | Operat  | tion stop                           | os      |    |           |         |         |          |          |          |        |   |   |      |      |
|          | 1        | Operat  | tion is e                           | nabled. |    |           |         |         |          |          |          |        |   |   |      |      |

#### Figure 11 - 16 Format of Serial channel enable status register m (SEm)

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1)



# 11.3.12 Serial output enable register m (SOEm)

The SOEm register is a register that is used to enable or stop output of the serial communication operation of each channel.

Channel n that enables serial output cannot rewrite by software the value of the SOmn bit of serial output register m (SOm) to be described below, and a value reflected by a communication operation is output from the serial data output pin.

For channel n, whose serial output is stopped, the SOmn bit value of the SOm register can be set by software, and that value can be output from the serial data output pin. In this way, any waveform of the start condition and stop condition can be created by software.

The SOEm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the SOEm register can be set with a 1-bit or 8-bit memory manipulation instruction with SOEmL.

Reset signal generation clears the SOEm register to 0000H.

| Address: F012AH, F012BH After reset: 0000H R/W |           |          |                                                  |    |    |    |   |   |   |   |   |   |   |   |           |           |
|------------------------------------------------|-----------|----------|--------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|-----------|-----------|
| Symbol                                         | 15        | 14       | 13                                               | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0         |
| SOE0                                           | 0         | 0        | 0                                                | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SOE<br>01 | SOE<br>00 |
|                                                | SOE<br>mn |          | Serial output enable/stop of channel n           |    |    |    |   |   |   |   |   |   |   |   |           |           |
|                                                | 0         | Stops of | tops output by serial communication operation.   |    |    |    |   |   |   |   |   |   |   |   |           |           |
|                                                | 1         | Enable   | nables output by serial communication operation. |    |    |    |   |   |   |   |   |   |   |   |           |           |

#### Figure 11 - 17 Format of Serial output enable register m (SOEm)

Caution Be sure to clear bits 15 to 2 of the SOE0 register, bits 15 to 2 to 0.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1)



### 11.3.13 Serial output register m (SOm)

The SOm register is a buffer register for serial output of each channel.

The value of the SOmn bit of this register is output from the serial data output pin of channel n.

The value of the CKOmn bit of this register is output from the serial clock output pin of channel n.

The SOmn bit of this register can be rewritten by software only when serial output is disabled (SOEmn = 0). When serial output is enabled (SOEmn = 1), rewriting by software is ignored, and the value of the register can be changed only by a serial communication operation.

The CKOmn bit of this register can be rewritten by software only when the channel operation is stopped (SEmn = 0). While channel operation is enabled (SEmn = 1), rewriting by software is ignored, and the value of the CKOmn bit can be changed only by a serial communication operation.

To use a pin for the serial interface as a port function pin other than a serial interface function pin, set the corresponding the CKOmn and SOmn bits to 1.

The SOm register can be set by a 16-bit memory manipulation instruction.

Reset signal generation clears the SOm register to 0303H.

| Address | : F0128   | H, F012 | 29H      |           | A        | After res | set: 0303 | BH        |        | R/W      |       |   |   |   |          |          |
|---------|-----------|---------|----------|-----------|----------|-----------|-----------|-----------|--------|----------|-------|---|---|---|----------|----------|
| Symbol  | 15        | 14      | 13       | 12        | 11       | 10        | 9         | 8         | 7      | 6        | 5     | 4 | 3 | 2 | 1        | 0        |
| SO0     | 0         | 0       | 0        | 0         | 0        | 0         | СКО<br>01 | СКО<br>00 | 0      | 0        | 0     | 0 | 0 | 0 | SO<br>01 | SO<br>00 |
|         | CKO<br>mn |         |          |           |          |           | Seria     | al clock  | output | of chanr | nel n |   |   |   |          |          |
|         | 0         | Serial  | clock ou | utput val | ue is 0. |           |           |           |        |          |       |   |   |   |          |          |
|         | 1         | Serial  | clock ou | utput val | ue is 1. | •         |           |           |        |          |       |   |   |   |          |          |
|         |           |         |          |           |          |           |           |           |        |          |       |   |   |   |          |          |
|         | SO<br>mn  |         |          |           |          |           | Seri      | al data ( | output | of chanr | nel n |   |   |   |          |          |
|         | 0         | Serial  | data ou  | tput valı | ue is 0. |           |           |           |        |          |       |   |   |   |          |          |

### Figure 11 - 18 Format of Serial output register m (SOm)

Caution Be sure to clear bits 15 to 10 and 7 to 2 of the SO0 register to 0.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1)

Serial data output value is 1.

1



## 11.3.14 Serial output level register m (SOLm)

The SOLm register is a register that is used to set inversion of the data output level of each channel.

This register can be set only in the UART mode. Be sure to set 0 for corresponding bit in the CSI mode and simplifies I<sup>2</sup>C mode.

Inverting channel n by using this register is reflected on pin output only when serial output is enabled (SOEmn = 1). When serial output is disabled (SOEmn = 0), the value of the SOmn bit is output as is.

Rewriting the SOLm register is prohibited when the register is in operation (when SEmn = 1).

The SOLm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the SOLm register can be set with an 8-bit memory manipulation instruction with SOLmL. Reset signal generation clears the SOLm register to 0000H.



| Address | F0134     | H, F013 | 85H (SC  | DL0)      |                            | Afte     | r reset: | 0000H     | R/W    |           |          |          |        |      |   |           |
|---------|-----------|---------|----------|-----------|----------------------------|----------|----------|-----------|--------|-----------|----------|----------|--------|------|---|-----------|
| Symbol  | 15        | 14      | 13       | 12        | 11 10 9 8 7 6 5 4 3 2 1 0  |          |          |           |        |           |          |          |        |      | 0 |           |
| SOL0    | 0         | 0       | 0        | 0         | 0                          | 0        | 0        | 0         | 0      | 0         | 0        | 0        | 0      | 0    | 0 | SOL<br>00 |
|         | SOL<br>mn |         |          | Sele      | cts inve                   | rsion of | the leve | el of the | transm | it data o | of chanr | nel n in | UART n | node |   |           |
|         | 0         | Comm    | unicatio | on data i | a is output as is.         |          |          |           |        |           |          |          |        |      |   |           |
|         | 1         | Comm    | unicatio | on data i | ta is inverted and output. |          |          |           |        |           |          |          |        |      |   |           |
| -       |           |         |          |           |                            |          |          |           |        |           |          |          |        |      |   |           |

#### Caution Be sure to clear bits 15 to 1 of the SOL0 register to 0.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0)

Figure 11 - 20 shows examples in which the level of transmit data is reversed during UART transmission.







**Remark** m: Unit number (m = 0), n: Channel number (n = 0)



### 11.3.15 Serial standby control register m (SSCm)

The SSC0 register is used to control the startup of reception (the SNOOZE mode) while in the STOP mode when receiving CSI00 or UART0 serial data.

The SSCm register can be set by a 16-bit memory manipulation instruction.

The lower 8 bits of the SSCm register can be set with an 8-bit memory manipulation instruction with SSCmL. Reset signal generation clears the SSCm register to 0000H.

#### Caution The maximum transfer rate in the SNOOZE mode is as follows.

#### • When using CSI00: Up to 1 Mbps

• When using UART0: 4800 bps only

| Address: | : F0138                                                                                                                                                                                                                                           | H (SSC | :0)                                                   | After   | reset: 0 | 000H      | R/W       | 1        |                   |   |   |         |           |          |            |     |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------|---------|----------|-----------|-----------|----------|-------------------|---|---|---------|-----------|----------|------------|-----|
| Symbol   | 15                                                                                                                                                                                                                                                | 14     | 13                                                    | 12      | 11       | 10        | 9         | 8        | 7                 | 6 | 5 | 4       | 3         | 2        | 1          | 0   |
| SSCm     | 0                                                                                                                                                                                                                                                 | 0      | 0                                                     |         |          |           |           |          |                   |   |   |         |           |          | SWC<br>m   |     |
|          | SSE                                                                                                                                                                                                                                               | Cm     | Se                                                    | lection | of wheth | ner to er | nable or  |          | e the ge<br>SNOOZ |   |   | imunica | ition err | or inter | rupts in t | the |
|          | (                                                                                                                                                                                                                                                 | )      | Enable                                                | the ge  | neratior | n of erro | r interru | ıpts (IN | TSRE0)            | - |   |         |           |          |            |     |
|          | 1                                                                                                                                                                                                                                                 | 1      | Disable the generation of error interrupts (INTSRE0). |         |          |           |           |          |                   |   |   |         |           |          |            |     |
|          | <ul> <li>The SSECm bit can be set to 1 or 0 only when both the SWCm and EOCmn bits are set to 1 during UART reception in the SNOOZE mode. In other cases, clear the SSECm bit to 0.</li> <li>Setting SSECm, SWCm = 1, 0 is prohibited.</li> </ul> |        |                                                       |         |          |           |           |          |                   |   |   |         |           |          |            |     |

| Figure 11 - 21 Format of Serial standby | control register m | (SSCm) |
|-----------------------------------------|--------------------|--------|
|-----------------------------------------|--------------------|--------|

SWCm Setting of the SNOOZE m

| SWCm       | Setting of the SNOOZE mode                                                                    |
|------------|-----------------------------------------------------------------------------------------------|
| 0          | Do not use the SNOOZE mode function.                                                          |
| 1          | Use the SNOOZE mode function.                                                                 |
| When there | is a hardware trigger signal in the STOP mode, the STOP mode is exited, and A/D conversion is |

performed without operating the CPU (the SNOOZE mode).

• The SNOOZE mode function can only be specified when the high-speed on-chip oscillator clock is selected for the CPU/peripheral hardware clock (fcLK). If any other clock is selected, specifying this mode is prohibited.

• Even when using SNOOZE mode, be sure to set the SWCm bit to 0 in normal operation mode and change it to 1 just before shifting to STOP mode.

Also, be sure to change the SWCm bit to 0 after returning from STOP mode to normal operation mode.

Caution Setting SSECm, SWCm = 1, 0 is prohibited.



| EOCmn Bit | SSECm Bit | Reception Ended Successfully | Reception Ended in an Error |
|-----------|-----------|------------------------------|-----------------------------|
| 0         | 0         | INTSRx is generated.         | INTSRx is generated.        |
| 0         | 1         | INTSRx is generated.         | INTSRx is generated.        |
| 1         | 0         | INTSRx is generated.         | INTSREx is generated.       |
| 1         | 1         | INTSRx is generated.         | No interrupt is generated.  |

### Figure 11 - 22 Interrupt in UART Reception Operation in SNOOZE Mode



## 11.3.16 Noise filter enable register 0 (NFEN0)

The NFEN0 register is used to set whether the noise filter can be used for the input signal from the serial data input pin to each channel.

Disable the noise filter of the pin used for CSI or simplified I<sup>2</sup>C communication, by clearing the corresponding bit of this register to 0.

Enable the noise filter of the pin used for UART communication, by setting the corresponding bit of this register to 1.

When the noise filter is enabled, after synchronization is performed with the operation clock (fMCK) of the target channel, 2-clock match detection is performed. When the noise filter is OFF, only synchronization is performed with the Operation clock of target channel (fMCK).

The NFEN0 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears the NFEN0 register to 00H.

#### Figure 11 - 23 Format of Noise filter enable register 0 (NFEN0)

| Address | : F0070H     | After reset: 00H  | H R/W            |        |                   |         |   |         |  |  |  |  |
|---------|--------------|-------------------|------------------|--------|-------------------|---------|---|---------|--|--|--|--|
| Symbol  | 7            | 6                 | 5                | 4      | 3                 | 2       | 1 | 0       |  |  |  |  |
| NFEN0   | 0            | 0                 | 0                | 0      | 0                 | 0       | 0 | SNFEN00 |  |  |  |  |
|         | SNFEN00      |                   |                  | Use of | noise filter of R | xD0 pin |   |         |  |  |  |  |
|         | 0            | Noise filter OF   | Noise filter OFF |        |                   |         |   |         |  |  |  |  |
|         | 1            | Noise filter ON   |                  |        |                   |         |   |         |  |  |  |  |
|         | Set the SNFE | N00 bit to 1 to u | ise the RxD0 p   | in.    |                   |         |   |         |  |  |  |  |

Clear the SNFEN00 bit to 0 to use the other than RxD0 pin.

Caution Be sure to clear bits 7 to 1 to 0.



### **11.3.17** Registers controlling port functions of serial input/output pins

Using the serial array unit requires setting of the registers that control the port functions multiplexed on the target channel (port mode register (PMxx), port register (Pxx), port input mode register (PIMxx), and port output mode register (POMxx)).

For details, see **4.3.1 Port mode registers (PMxx)**, **4.3.2 Port registers (Pxx)**, **4.3.4 Port input mode registers (PIMxx)**, and **4.3.5 Port output mode registers (POMxx)**.

Specifically, using a port pin with a multiplexed serial data or serial clock output function (e.g. P52/INTP8/TI01/TO01/SO00/TXD0/TOOLTXD/UVBUSEN1) for serial data or serial clock output, requires setting the corresponding bits in the port mode register (PMxx) to 0, and the corresponding bit in the port register (Pxx) to 1.

When using the port pin in N-ch open-drain output (VDD tolerance) mode, set the corresponding bit in the port output mode register (POMxx) to 1. When connecting an external device operating on a different potential (1.8 V, 2.5 V, or 3 V), see **4.4.4 Handling different potential (1.8 V, 2.5 V) by using I/O buffers**.

Example When P52/INTP8/TI01/TO01/SO00/TXD0/TOOLTXD/UVBUSEN1 is to be used for serial data output Set the PM52 bit of port mode register 5 to 0. Set the P52 bit of port register 5 to 1.

Specifically, using a port pin with a multiplexed serial data or serial clock input function (e.g. P51/INTP7/TI00/TO00/SDA00/SI00/RXD0/TOOLRXD) for serial data or serial clock input, requires setting the corresponding bit in the port mode register (PMxx) to 1. In this case, the corresponding bit in the port register (Pxx) can be set to 0 or 1.

When the TTL input buffer is selected, set the corresponding bit in the port input mode register (PIMxx) to 1. When connecting an external device operating on a different potential (1.8 V, 2.5 V or 3 V), see **4.4.4 Handling different potential (1.8 V, 2.5 V) by using I/O buffers**.

Example When P51/INTP7/TI00/TO00/SDA00/SI00/RXD0/TOOLRXD is to be used for serial data input Set the PM51 bit of port mode register 5 to 1. Set the P51 bit of port register 5 to 0 or 1.



### 11.4 Operation Stop Mode

Each serial interface of serial array unit has the operation stop mode.

In this mode, serial communication cannot be executed, thus reducing the power consumption.

In addition, the pin for serial interface can be used as port function pins in this mode.

# 11.4.1 Stopping the operation by units

The stopping of the operation by units is set by using peripheral enable register 0 (PER0). The PER0 register is used to enable or disable supplying the clock to the peripheral hardware. Clock supply to a hardware macro that is not used is stopped in order to reduce the power consumption and noise. To stop the operation of serial array unit 0, set bit 2 (SAU0EN) to 0.

### Figure 11 - 24 Peripheral Enable Register 0 (PER0) Setting When Stopping the Operation by Units

|      | 7                                                                                          | 6                                                        | 5                                                    | 4                            | 3               | 2                 | 1                | 0      |  |  |
|------|--------------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------|------------------------------|-----------------|-------------------|------------------|--------|--|--|
|      | IICA2EN Not                                                                                | e IICA1EN                                                | ADCEN                                                | IICA0EN                      |                 | SAU0EN            |                  | TAU0EN |  |  |
| PER0 | ×                                                                                          | ×                                                        | ×                                                    | ×                            | 0               | 0/1               | 0                | ×      |  |  |
|      |                                                                                            |                                                          | Control of SAU<br>0: Stops supply<br>1: Supplies inp | / of input clock<br>ut clock |                 |                   | 20450            |        |  |  |
|      | Note                                                                                       | This bit is incorp                                       | orated with R9A                                      | A02G0151, but i              | s not incorpora | ted with R9A020   | G0150.           |        |  |  |
|      | Caution 1. If SAUmEN = 0, writing to a control register of serial array unit m is ignored. |                                                          |                                                      |                              |                 |                   |                  |        |  |  |
|      |                                                                                            | Note that this d                                         |                                                      |                              | g registers.    |                   |                  |        |  |  |
|      |                                                                                            | Noise filter en                                          | •                                                    | · ,                          |                 |                   |                  |        |  |  |
|      |                                                                                            | Port input mo     Port output mo                         | •                                                    |                              |                 |                   |                  |        |  |  |
|      |                                                                                            | <ul> <li>Port output m</li> <li>Port mode reg</li> </ul> | •                                                    |                              |                 |                   |                  |        |  |  |
|      |                                                                                            | Port register 5                                          |                                                      |                              |                 |                   |                  |        |  |  |
|      | Caution 2.                                                                                 | Be sure to clear                                         | . ,                                                  | bits to 0.                   |                 |                   |                  |        |  |  |
|      |                                                                                            | Bits 1 and 3                                             | -                                                    |                              |                 |                   |                  |        |  |  |
|      | Remark                                                                                     | ×: Bits not used<br>0/1: Set to 0 or 1                   |                                                      | · ·                          | •               | gs of other perip | bheral functions | ;)     |  |  |

(a) Peripheral enable register 0 (PER0)... Set only the bit of SAUm to be stopped to 0.



### 11.4.2 Stopping the operation by channels

The stopping of the operation by channels is set using each of the following registers.

### Figure 11 - 25 Each Register Setting When Stopping the Operation by Channels

(a) Serial channel stop register m (STm)... This register is a trigger register that is used to enable stopping communication/count by each channel.

|      | con          | nmunic    | ation/c     | ount by      | / each      | channe      | el.        |            |              |            |            |           |            |            |             |             |
|------|--------------|-----------|-------------|--------------|-------------|-------------|------------|------------|--------------|------------|------------|-----------|------------|------------|-------------|-------------|
|      | 15           | 14        | 13          | 12           | 11          | 10          | 9          | 8          | 7            | 6          | 5          | 4         | 3          | 2          | 1           | 0           |
| STm  | 0            | 0         | 0           | 0            | 0           | 0           | 0          | 0          | 0            | 0          | 0          | 0         | 0          | 0          | STm1<br>0/1 | STm0<br>0/1 |
| _    |              |           |             |              | 1: Cle      | ars the S   | Emn bit t  | o 0 and s  | stops the    | e commur   | nication c | peration  |            |            |             |             |
|      | * Bec        | ause the  | STmn b      | it is a trig | iger bit, i | t is cleare | ed immed   | diately wh | nen SEm      | ın = 0.    |            |           |            |            |             |             |
| (1-) | 0            |           |             |              |             | <b>D</b>    |            |            | <b>T</b> I.: |            | !! 4 -     |           |            |            |             |             |
| (b)  |              |           |             |              |             | -           |            |            |              | -          | ndicate    | s whet    | ner dai    | ia trans   | smissio     | n/          |
|      |              | •         | •           |              |             | annel i     |            |            |              |            | -          | 4         | 2          | 0          | 4           | 0           |
| Г    | 15           | 14        | 13          | 12           | 11          | 10          | 9          | 8          | 7            | 6          | 5          | 4         | 3          | 2          | 1<br>SEm1   | 0<br>SEm0   |
| SEm  | 0            | 0         | 0           | 0            | 0           | 0           | 0          | 0          | 0            | 0          | 0          | 0         | 0          | 0          | 0/1         | 0/1         |
|      |              |           |             |              |             |             |            |            |              | 0          | : Operati  | on stops  |            |            |             |             |
|      | * The        | e SEm re  | gister is a | a read-or    | ly status   | register,   | whose o    | peration   | is stoppe    | ed by usii | ng the S⊺  | Гm regist | er.        |            |             |             |
|      | Wit          | h a chan  | nel whos    | e operati    | on is sto   | pped, the   | value of   | the CKC    | Omn bit o    | of the SO  | m registe  | r can be  | set by so  | oftware.   |             |             |
| (c)  | Ser          | ial outr  | out ena     | ble rea      | ister m     | (SOFr       | n) Th      | nis reais  | ster is a    | a regist   | er that    | is used   | to ena     | able or    | stop or     | utput of    |
| (-)  |              | •         |             | •            |             | ation of    | ,          | •          |              |            |            |           |            |            |             |             |
|      | 15           | 14        | 13          | 12           | 11          | 10          | 9          | 8          | 7            | 6          | 5          | 4         | 3          | 2          | 1           | 0           |
| SOEm |              |           |             |              |             |             |            |            |              |            |            |           |            |            | SOEm1       | SOEm0       |
|      | 0            | 0         | 0           | 0            | 0           | 0           | 0          | 0          | 0            | 0          | 0          | 0         | 0          | 0          | 0/1         | 0/1         |
|      |              |           |             |              |             |             | 0: Stop    | os output  | by seria     | l commur   | nication c | peration  |            |            |             |             |
|      | * For        | channel   | n, whose    | e serial o   | utput is s  | stopped, t  | he SOmi    | n bit valu | e of the     | SOm reg    | ister can  | be set by | y softwar  | e.         |             |             |
| (d)  | ) Ser        | ial out   | out reai    | ster m       | (SOm)       | ) This      | reaiste    | er is a b  | ouffer r     | egister    | for ser    | ial outr  | out of e   | ach ch     | nannel.     |             |
| (-)  | , e.e.<br>15 | 14        | 13          | 12           | 11          | 10          | 9          | 8          | 7            | 6          | 5          | 4         | 3          | 2          | 1           | 0           |
| SOm  |              |           |             |              |             |             | CKOm1      |            |              | -          | -          |           | -          | _          | SOm1        | SOm0        |
| 5011 | 0            | 0         | 0           | 0            | 0           | 0           | 0/1        | 0/1        | 0            | 0          | 0          | 0         | 0          | 0          | 0/1         | 0/1         |
|      |              | 1:        | Serial clo  | ock outpu    | ut value i  | s "1"       |            |            |              | 1:         | Serial d   | ata outpu | ut value i | s "1"      |             |             |
|      | * When       | using pin | s corres    | oonding t    | o each c    | hannel a    | s port fur | nction pin | s, set the   | e corresp  | onding C   | KOmn, S   | SOmn bi    | ts to "1". |             |             |
|      | Rema         | ark 1. m  | n: Unit n   | umber (      | m = 0).     | n: Char     | nel nun    | nber (n    | = 0, 1)      |            |            |           |            |            |             |             |
|      |              |           |             | ```          | ,,          |             |            | `          | . ,          |            |            |           |            |            |             |             |

Remark 2. Setting disabled (set to the initial value)

0/1: Set to 0 or 1 depending on the usage of the user



# 11.5 Operation of 3-Wire Serial I/O (CSI00, CSI01) Communication

This is a clocked communication function that uses three lines: serial clock (SCK) and serial data (SI and SO) lines.

[Data transmission/reception]

- Data length of 7 or 8 bits
- Phase control of transmit/receive data
- MSB/LSB first selectable

[Clock control]

- Master/slave selection
- Phase control of I/O clock
- Setting of transfer period by prescaler and internal counter of each channel
- Maximum transfer rate Note

| During master communication: | Max. fcLk/2 (CSI00 only) |
|------------------------------|--------------------------|
|                              | Max. fcLk/4              |
| During slave communication:  | Мах. fмск/6              |

[Interrupt function]

• Transfer end interrupt/buffer empty interrupt

[Error detection flag]

Overrun error

CSIs of the following channels supports the SNOOZE mode. When SCK input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. Only following CSIs can be specified.

• CSI00

NoteUse the clocks within a range satisfying the SCK cycle time (tKCY) characteristics. For details, seeELECTRICAL SPECIFICATIONS in the R9A02G015 Data Sheet (R19DS0101E).



The channels supporting 3-wire serial I/O (CSI00, CSI01) are channels 0 and 1 of SAU0.

• 32-pin products

| Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C |  |
|------|---------|-------------|--------------|-------------------------------------|--|
| 0    | 0       | CSI00       | CSI00 UART0  |                                     |  |
|      | 1       | CSI01       |              | IIC01                               |  |

3-wire serial I/O (CSI00, CSI01) performs the following seven types of communication operations.

| <ul> <li>Master transmission</li> </ul>           | (See <b>11.5.1</b> .) |                       |
|---------------------------------------------------|-----------------------|-----------------------|
| <ul> <li>Master reception</li> </ul>              |                       | (See <b>11.5.2</b> .) |
| <ul> <li>Master transmission/reception</li> </ul> |                       | (See 11.5.3.)         |
| <ul> <li>Slave transmission</li> </ul>            |                       | (See 11.5.4.)         |
| <ul> <li>Slave reception</li> </ul>               |                       | (See <b>11.5.5</b> .) |
| <ul> <li>Slave transmission/reception</li> </ul>  | (See <b>11.5.6</b> .) |                       |
|                                                   |                       |                       |

• SNOOZE mode function (CSI00 only) (See **11.5.7**.)



# 11.5.1 Master transmission

Master transmission is that the R9A02G015 microcontroller outputs a transfer clock and transmits data to another device.

| 3-Wire Serial I/O                                                                                               | CSI00                                                                                      | CSI01                                               |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------|--|--|--|--|--|
| Target channel                                                                                                  | Channel 0 of SAU0                                                                          | Channel 1 of SAU0                                   |  |  |  |  |  |
| Pins used                                                                                                       | SCK00, SO00 SCK01, SO01                                                                    |                                                     |  |  |  |  |  |
| Interrupt                                                                                                       | INTCSI00                                                                                   | INTCSI01                                            |  |  |  |  |  |
| Transfer end interrupt (in single-transfer mode) or buffer empty interrupt (in continuous transfer be selected. |                                                                                            |                                                     |  |  |  |  |  |
| Error detection flag                                                                                            | None                                                                                       |                                                     |  |  |  |  |  |
| Transfer data length                                                                                            | 7 or 8 bits                                                                                |                                                     |  |  |  |  |  |
| Transfer rate Note                                                                                              | r rate Note Max. fcLk/2 [Hz] (CSI00 only), fcLk/4 [Hz]                                     |                                                     |  |  |  |  |  |
|                                                                                                                 | Min. fcLk/(2 × 2 <sup>15</sup> × 128) [Hz] fcLk: System clock frequency                    |                                                     |  |  |  |  |  |
| Data phase                                                                                                      | phase Selectable by the DAPmn bit of the SCRmn register                                    |                                                     |  |  |  |  |  |
|                                                                                                                 | • DAPmn = 0: Data output starts from the start of the                                      | rom the start of the operation of the serial clock. |  |  |  |  |  |
|                                                                                                                 | DAPmn = 1: Data output starts half a clock before the start of the serial clock operation. |                                                     |  |  |  |  |  |
| Clock phase                                                                                                     | Clock phase Selectable by the CKPmn bit of the SCRmn register                              |                                                     |  |  |  |  |  |
|                                                                                                                 | CKPmn = 0: Non-reverse                                                                     |                                                     |  |  |  |  |  |
|                                                                                                                 | • CKPmn = 1: Reverse                                                                       |                                                     |  |  |  |  |  |
| Data direction                                                                                                  | MSB or LSB first                                                                           |                                                     |  |  |  |  |  |

**Note** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



(1) Register setting

### Figure 11 - 26 Example of Contents of Registers for Master Transmission of 3-Wire Serial I/O (CSI00, CSI01)

| (a)                                                                                                                                                                                                                                                                                                                                                     | ) Seri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | al mod     | le regis     | ster mn              | (SMR     | mn)        |             |             |              |             |             |             |          |            |             |               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------------|----------------------|----------|------------|-------------|-------------|--------------|-------------|-------------|-------------|----------|------------|-------------|---------------|
| _                                                                                                                                                                                                                                                                                                                                                       | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 14         | 13           | 12                   | 11       | 10         | 9           | 8           | 7            | 6           | 5           | 4           | 3        | 2          | 1           | 0             |
| SMRmn                                                                                                                                                                                                                                                                                                                                                   | CKSmn<br>0/1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CCSmn<br>0 | 0            | 0                    | 0        | 0          | 0           | STSmn<br>0  | 0            | SISmn0<br>0 | 1           | 0           | 0        | MDmn2<br>0 | MDmn1<br>0  | MDmn0<br>0/1  |
| Operation clock (fmck) of channel n       Interrupt source of channel n         0: Prescaler output clock CKm0 set by the SPSm register       0: Transfer end interrupt         1: Prescaler output clock CKm1 set by the SPSm register       1: Buffer empty interrupt                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |              |                      |          |            |             |             |              | errupt      |             |             |          |            |             |               |
| (b)                                                                                                                                                                                                                                                                                                                                                     | ) Seri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | al com     | munica       | ation op             | peratio  | n settir   | ng regis    | ster mn     | (SCRr        | mn)         |             |             |          |            |             |               |
|                                                                                                                                                                                                                                                                                                                                                         | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 14         | 13           | 12                   | 11       | 10         | 9           | 8           | 7            | 6           | 5           | 4           | 3        | 2          | 1           | 0             |
| SCRmn                                                                                                                                                                                                                                                                                                                                                   | TXEmn<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RXEmn<br>0 | DAPmn<br>0/1 | CKPmn<br>0/1         | 0        | EOCmn<br>0 | PTCmn1<br>0 | PTCmn0<br>0 | DIRmn<br>0/1 | 0           | SLCmn1<br>0 | SLCmn0<br>0 | 0        | 1          | DLSmn1<br>1 | DLSmn0<br>0/1 |
| Selection of data transfer sequence       Setting of data length         Selection of the data and clock phase (For details about the setting, see 11.3       0: Inputs/outputs data with MSB first       0: 7-bit data length         Registers Controlling Serial Array Unit.)       1: Inputs/outputs data with LSB first       1: 8-bit data length |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |              |                      |          |            |             |             |              |             |             |             |          |            |             |               |
| (c)                                                                                                                                                                                                                                                                                                                                                     | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 14         | 13           | er mn (<br>12        | 11       | 10         | 9           | 8           | 5)<br>7      | 6           | 5           | 4           | 3        | 2          | 1           | 0             |
| SDRmn                                                                                                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            | Baud         | d rate se            | etting   | -          |             |             |              | -           | -           | Transm      | nit data |            |             |               |
| SDRIIII                                                                                                                                                                                                                                                                                                                                                 | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Operatio   | on clocl     | к (fмск)             | division | n setting  | )           | 0           |              |             | (Tra        | ansmit d    | ata sett | ing)       |             |               |
| (d) Serial output register m (SOm) Sets only the bits of the target channel.<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |              |                      |          |            |             |             |              |             |             |             |          |            |             |               |
| SOm                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |              |                      |          |            | CKOm1       | CKOm0       |              | -           |             |             |          |            | SOm1        | SOm0          |
| l                                                                                                                                                                                                                                                                                                                                                       | 0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 |            |              |                      |          |            |             |             |              |             |             |             |          |            |             |               |
| (e)                                                                                                                                                                                                                                                                                                                                                     | ) Seri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | al outp    | out ena      | ble reg              | ister m  | I (SOE     | m) Se       | ets only    | the bi       | ts of the   | •           | t chanr     | nel to 1 | •          |             |               |
| г                                                                                                                                                                                                                                                                                                                                                       | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 14         | 13           | 12                   | 11       | 10         | 9           | 8           | 7            | 6           | 5           | 4           | 3        | 2          | 1<br>SOEm1  | 0<br>SOEm0    |
| SOEm                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0          | 0            | 0                    | 0        | 0          | 0           | 0           | 0            | 0           | 0           | 0           | 0        | 0          | 0/1         | 0/1           |
| (f) Serial channel start register m (SSm) Sets only the bits of the target channel to 1.                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |              |                      |          |            |             |             |              |             |             |             |          |            |             |               |
| -                                                                                                                                                                                                                                                                                                                                                       | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 14         | 13           | 12                   | 11       | 10         | 9           | 8           | 7            | 6           | 5           | 4           | 3        | 2          | 1           | 0             |
| SSm                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0          | 0            | 0                    | 0        | 0          | 0           | 0           | 0            | 0           | 0           | 0           | 0        | 0          | SSm1<br>0/1 | SSm0<br>0/1   |
| <b>Remark 1.</b> m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |              |                      |          |            |             |             |              |             |             |             |          |            |             |               |
| <b>Remark 2.</b> Setting is fixed in the CSI master transmission mode,                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |              |                      |          |            |             |             |              |             |             |             |          |            |             |               |
|                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0/         | : Settir     | ng disab<br>o 0 or 1 | led (set | t to the i | nitial va   | lue)        |              |             |             |             |          |            |             |               |



### (2) Operation procedure

| Starting initial setting                 |                                                                                                                                          |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Setting the PER0 register                | Release the serial array unit from the reset status and start clock supply.                                                              |
| Setting the SPSm register                | Set the operation clock.                                                                                                                 |
| Setting the SMRmn register               | Set an operation mode, etc.                                                                                                              |
| Setting the SCRmn register               | Set a communication format.                                                                                                              |
| Setting the SDRmn register               | Set a transfer baud rate (setting the transfer clock by dividing the operation clock (fMCK)).                                            |
| Setting the SOm register                 | Set the initial output level of the serial clock (CKOmn) and serial data (SOmn).                                                         |
| Changing setting of the<br>SOEm register | Set the SOEmn bit to 1 and enable data output of the target channel.                                                                     |
| Setting port                             | Setting a port register and a port mode register (Enable data output and clock output of the target channel by).                         |
| Writing to the SSm register              | Set the SSmn bit of the target channel to 1 (SEmn bit = 1: to enable operation).                                                         |
| Completing initial setting               | Setting of SAU is completed.<br>Write transmit data to the SIOp register (bits 7 to 0<br>of the SDRmn register) and start communication. |

#### Figure 11 - 27 Initial Setting Procedure for Master Transmission





If there is any data being transferred, wait for their completion (If there is an urgent must stop, do not wait).

Write 1 to the STmn bit of the target channel. (SEmn = 0: to operation stop status)

Set the SOEmn bit to 0 and stop the output of the target channel.

The levels of the serial clock (CKOmn) and serial data (SOmn) on the target channel can be changed if necessitated by an emergency.

To use the STOP mode, reset the serial array unit by stopping the clock supply to it.

After the stop setting is completed, go to the next processing.





#### Figure 11 - 29 Procedure for Resuming Master Transmission

**Remark** If PER0 is rewritten while stopping the master transmission and the clock supply is stopped, wait until the transmission target (slave) stops or transmission finishes, and then perform initialization instead of restarting the transmission.

(3) Processing flow (in single-transmission mode)



| SSmn              |                        |                        |                       |
|-------------------|------------------------|------------------------|-----------------------|
| STmn              |                        |                        |                       |
| SEmn              |                        |                        |                       |
| SDRmn             | Transmit data 1        | Transmit data 2        | Transmit data 3       |
| SCKp pin          |                        |                        |                       |
| SOp pin           | Transmit data 1        | Transmit data 2        | Transmit data 3       |
| Shift register mn | XXX Shift operation XX | XXX Shift operation XX | XXX Shift operation X |
| INTCSIp           | <u>l</u>               | η_                     |                       |
|                   | Data transmission      | ■ Data transmission    | Data transmission     |
| TSFmn             |                        |                        |                       |

Remark m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01









(4) Processing flow (in continuous transmission mode)





- **Note** If transmit data is written to the SDRmn register while the BFFmn bit of serial status register mn (SSRmn) is 1 (valid data is stored in serial data register mn (SDRmn)), the transmit data is overwritten.
- Caution The MDmn0 bit of serial mode register mn (SMRmn) can be rewritten even during operation. However, rewrite it before transfer of the last bit is started, so that it will be rewritten before the transfer end interrupt of the last transmit data.
- **Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





#### Figure 11 - 33 Flowchart of Master Transmission (in Continuous Transmission Mode)

**Remark** <1> to <6> in the figure correspond to <1> to <6> in Figure 11 - 32 Timing Chart of Master Transmission (in Continuous Transmission Mode) (Type 1: DAPmn = 0, CKPmn = 0).

RENESAS

# 11.5.2 Master reception

Master reception is that the R9A02G015 microcontroller outputs a transfer clock and receives data from other device.

| 3-Wire Serial I/O    | CS100                                                                | CSI01                                                  |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------|--------------------------------------------------------|--|--|--|--|--|--|
| Target channel       | Channel 0 of SAU0                                                    | Channel 1 of SAU0                                      |  |  |  |  |  |  |
| Pins used            | SCK00, SI00                                                          | SCK01, SI01                                            |  |  |  |  |  |  |
| Interrupt            | INTCSI00                                                             | INTCSI01                                               |  |  |  |  |  |  |
|                      | Transfer end interrupt (in single-transfer mode) or but be selected. | ffer empty interrupt (in continuous transfer mode) can |  |  |  |  |  |  |
| Error detection flag | Overrun error detection flag (OVFmn) only                            |                                                        |  |  |  |  |  |  |
| Transfer data length | 7 or 8 bits                                                          |                                                        |  |  |  |  |  |  |
| Transfer rate Note   | Max. fcLk/2 [Hz] (CSI00 only), fcLk/4 [Hz]                           |                                                        |  |  |  |  |  |  |
|                      | Min. fcLk/(2 × 2 <sup>15</sup> × 128) [Hz] fcLk: System clock freq   | uency                                                  |  |  |  |  |  |  |
| Data phase           | Selectable by the DAPmn bit of the SCRmn register                    |                                                        |  |  |  |  |  |  |
|                      | DAPmn = 0: Data input starts from the start of the o                 | peration of the serial clock.                          |  |  |  |  |  |  |
|                      | DAPmn = 1: Data input starts half a clock before the                 | e start of the serial clock operation.                 |  |  |  |  |  |  |
| Clock phase          | Selectable by the CKPmn bit of the SCRmn register                    |                                                        |  |  |  |  |  |  |
|                      | • CKPmn = 0: Non-reverse                                             |                                                        |  |  |  |  |  |  |
|                      | • CKPmn = 1: Reverse                                                 |                                                        |  |  |  |  |  |  |
| Data direction       | MSB or LSB first                                                     |                                                        |  |  |  |  |  |  |

**Note** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01



(1) Register setting

# Figure 11 - 34 Example of Contents of Registers for Master Reception of 3-Wire Serial I/O (CSI00, CSI01)

| (a)                       | ) Ser                                                          | ial moo                                                                                | de regis                                                                                | ster mn                                                                                    | (SMR                                                                      | mn)                                                                 |                                                                                             |                                                                                |                                                                                                   |                                                                                                          |                                                                                                                    |                                                                                                  |                                                                                                 |                                                                     |                                                                                                             |                                                                            |
|---------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| -                         | 15                                                             | 14                                                                                     | 13                                                                                      | 12                                                                                         | 11                                                                        | 10                                                                  | 9                                                                                           | 8                                                                              | 7                                                                                                 | 6                                                                                                        | 5                                                                                                                  | 4                                                                                                | 3                                                                                               | 2                                                                   | 1                                                                                                           | 0                                                                          |
| SMRmn                     | CKSmn<br>0/1                                                   | CCSmn<br>0                                                                             | 0                                                                                       | 0                                                                                          | 0                                                                         | 0                                                                   | 0                                                                                           | STSmn<br>0                                                                     | 0                                                                                                 | SISmn0<br>0                                                                                              | 1                                                                                                                  | 0                                                                                                | 0                                                                                               | MDmn2<br>0                                                          | MDmn1<br>0                                                                                                  | MDmn0<br>0/1                                                               |
|                           | 0: Pres                                                        | scaler ou                                                                              | itput cloc                                                                              | channel n<br>k CKm0 s<br>k CKm1 s                                                          | set by th                                                                 |                                                                     | •                                                                                           |                                                                                | -                                                                                                 |                                                                                                          | -                                                                                                                  |                                                                                                  | 0:                                                                                              | rrupt sou<br>Transfer<br>Buffer ei                                  | end inte                                                                                                    | errupt                                                                     |
| (b)                       | ) Ser                                                          | ial com                                                                                | nmunic                                                                                  |                                                                                            | peratio                                                                   | n settin                                                            | ig regis                                                                                    | ster mn                                                                        | (SCRr                                                                                             | mn)                                                                                                      |                                                                                                                    |                                                                                                  |                                                                                                 |                                                                     |                                                                                                             |                                                                            |
| -                         | 15                                                             | 14                                                                                     | 13<br>DAPmn                                                                             | 12<br>CKPmn                                                                                | 11                                                                        | 10                                                                  | 9<br>DTCmr1                                                                                 | 8<br>PTCmn0                                                                    | 7<br>DIRmn                                                                                        | 6                                                                                                        | 5                                                                                                                  | 4                                                                                                | 3                                                                                               | 2                                                                   | 1                                                                                                           | 0<br>DLSmn0                                                                |
| SCRmn                     | TXEmn<br>0                                                     | RXEmn<br>1                                                                             | 0/1                                                                                     | 0/1                                                                                        | 0                                                                         | EOCmn<br>0                                                          | PTCmn1<br>0                                                                                 | 0<br>0                                                                         | 0/1                                                                                               | 0                                                                                                        | SLCmn1<br>0                                                                                                        | SLCmn0<br>0                                                                                      | 0                                                                                               | 1                                                                   | DLSmn1<br>1                                                                                                 | 0/1                                                                        |
|                           | details a<br><b>Registe</b> i                                  | bout the<br>r <b>s Contr</b>                                                           | setting, s<br>olling Se                                                                 | erial Arra                                                                                 | ay Unit.)                                                                 |                                                                     | 0:<br>1:                                                                                    | ection of o<br>Inputs/o<br>Inputs/o<br>ts: SIO                                 | utputs da<br>utputs da                                                                            | ata with N                                                                                               | ISB first                                                                                                          |                                                                                                  |                                                                                                 | 0: 7-bi                                                             | of data ler<br>t data ler<br>t data ler                                                                     | ngth                                                                       |
| (c)                       | 15                                                             | 14                                                                                     | 13 129151                                                                               | 12                                                                                         | 11                                                                        | 10 (IOW                                                             | 9                                                                                           | 8 8                                                                            | 5)<br>7                                                                                           | 6                                                                                                        | 5                                                                                                                  | 4                                                                                                | 3                                                                                               | 2                                                                   | 1                                                                                                           | 0                                                                          |
| SDRmn                     |                                                                |                                                                                        | -                                                                                       | d rate se                                                                                  |                                                                           |                                                                     | -                                                                                           | -                                                                              |                                                                                                   |                                                                                                          |                                                                                                                    | Receiv                                                                                           | -                                                                                               |                                                                     | -                                                                                                           | -                                                                          |
| SURIIII                   | (                                                              | Operati                                                                                | on cloc                                                                                 | k (fмск)                                                                                   | divisior                                                                  | n setting                                                           | )                                                                                           | 0                                                                              |                                                                                                   |                                                                                                          | (Write                                                                                                             | FFH as                                                                                           | dummy                                                                                           | / data.)                                                            |                                                                                                             |                                                                            |
|                           |                                                                |                                                                                        |                                                                                         |                                                                                            |                                                                           |                                                                     |                                                                                             |                                                                                |                                                                                                   |                                                                                                          |                                                                                                                    | SIG                                                                                              | Эр                                                                                              |                                                                     |                                                                                                             |                                                                            |
| (d)                       |                                                                | -                                                                                      | -                                                                                       |                                                                                            |                                                                           |                                                                     | -                                                                                           | he bits                                                                        |                                                                                                   | -                                                                                                        |                                                                                                                    |                                                                                                  |                                                                                                 |                                                                     |                                                                                                             |                                                                            |
|                           | ) Ser<br>15                                                    | ial outp<br>14                                                                         | out regi<br>13                                                                          | ster m<br>12                                                                               | (SOm)<br>11                                                               | Sets<br>10                                                          | 9                                                                                           | 8                                                                              | of the 1<br>7                                                                                     | arget c<br>6                                                                                             | hannel<br>5                                                                                                        | 4                                                                                                | 3                                                                                               | 2                                                                   | 1<br>SOm1                                                                                                   | 0<br>SOm0                                                                  |
| (d<br>SOm                 |                                                                | -                                                                                      | -                                                                                       |                                                                                            |                                                                           |                                                                     | -                                                                                           |                                                                                |                                                                                                   | -                                                                                                        |                                                                                                                    |                                                                                                  | 3                                                                                               | 2                                                                   | 1<br>SOm1<br>×                                                                                              | 0<br>SOm0<br>×                                                             |
|                           | 0                                                              | 0                                                                                      | 13<br>0                                                                                 | 0                                                                                          | 0                                                                         | 10<br>0                                                             | 9<br>CKOm1<br>0/1                                                                           | 8<br>CKOm0                                                                     | 7<br>0<br>Commu<br>non-reve<br>reversed                                                           | 6<br>0<br>nication s<br>ersed (the<br>d (CKPm                                                            | 5<br>otarts whe<br>cKPmn<br>n = 1), co                                                                             | 4<br>0<br>en these<br>bit of the<br>ommunica                                                     | 0<br>bits are<br>SCRmr<br>ation sta                                                             |                                                                     | SOm1<br>×<br>ock phas                                                                                       | SOm0<br>×<br>e is<br>phase is                                              |
| SOm                       | 0                                                              | 0                                                                                      | 13<br>0                                                                                 | 0                                                                                          | 0                                                                         | 10<br>0                                                             | 9<br>CKOm1<br>0/1                                                                           | 8<br>CKOm0<br>0/1                                                              | 7<br>0<br>Commu<br>non-reve<br>reversed                                                           | 6<br>0<br>nication s<br>ersed (the<br>d (CKPm                                                            | 5<br>otarts whe<br>cKPmn<br>n = 1), co                                                                             | 4<br>0<br>en these<br>bit of the<br>ommunica                                                     | 0<br>bits are<br>SCRmr<br>ation sta                                                             | 0<br>1 if the cl<br>n = 0). If th                                   | SOm1<br>×<br>ock phas<br>he clock p<br>these bits                                                           | SOm0<br>×<br>we is<br>phase is<br>s are 0.                                 |
| SOm                       | 15<br>0                                                        | 14<br>0<br>ial outp                                                                    | 13<br>0<br>Dut ena                                                                      | 12<br>0<br>ble reg                                                                         | 11<br>0<br>ister m                                                        | 10<br>0<br>(SOEr                                                    | 9<br>CKOm1<br>0/1                                                                           | 8<br>CKOm0<br>0/1                                                              | 7<br>0<br>Commu<br>non-reve<br>reversed                                                           | 6<br>nication s<br>ersed (the<br>d (CKPmi<br>at not us                                                   | 5<br>o<br>starts whe<br>e CKPmn<br>n = 1), co<br>sed in t                                                          | 4<br>o<br>en these<br>bit of the<br>ommunica                                                     | 0<br>bits are<br>sCRmr<br>ation star<br>de.                                                     | 0<br>1 if the clo<br>n = 0). If the<br>rts when                     | SOm1<br>×<br>ock phas<br>he clock p<br>these bits                                                           | SOm0<br>×<br>he is<br>phase is<br>s are 0.                                 |
| SOm<br>(e                 | 15<br>0<br>) Ser<br>15<br>0                                    | 14<br>0<br>ial outp<br>14<br>0                                                         | 13<br>0<br>0<br>0<br>0                                                                  | 12<br>0<br>ble reg<br>12<br>0                                                              | 11<br>0<br>ister m<br>11<br>0                                             | 10<br>0<br>(SOEr<br>10<br>0                                         | 9<br>CKOm1<br>0/1<br>m) Th<br>9                                                             | 8<br>CKOm0<br>0/1                                                              | 7<br>0<br>Communon-reversed<br>reversed<br>ster that<br>7<br>0                                    | 6<br>0<br>nication s<br>ersed (the<br>d (CKPmi<br>at not us<br>6<br>0                                    | 5<br>o<br>e CKPmn<br>n = 1), cc<br>sed in t<br>5<br>o                                                              | 4<br>o<br>en these<br>bit of the<br>ommunica<br>this mo<br>4<br>o                                | 0<br>bits are<br>s SCRmr<br>ation sta<br>de.<br>3<br>0                                          | 0<br>1 if the clu<br>n = 0). If the<br>rts when<br>2                | SOm1<br>×<br>ock phas<br>he clock p<br>these bits<br>1<br>SOEm1                                             | SOm0<br>×<br>we is<br>phase is<br>s are 0.<br>0<br>SOEm0                   |
| SOm<br>(e<br>SOEm         | 15<br>0<br>) Ser<br>15<br>0                                    | 14<br>0<br>ial outp<br>14<br>0                                                         | 13<br>0<br>0<br>0<br>0                                                                  | 12<br>0<br>ble reg<br>12<br>0                                                              | 11<br>0<br>ister m<br>11<br>0                                             | 10<br>0<br>(SOEr<br>10<br>0                                         | 9<br>CKOm1<br>0/1<br>m) Th<br>9                                                             | 8<br>CKOm0<br>0/1<br>ne regis<br>8<br>0                                        | 7<br>0<br>Communon-reversed<br>reversed<br>ster that<br>7<br>0                                    | 6<br>0<br>nication s<br>ersed (the<br>d (CKPmi<br>at not us<br>6<br>0                                    | 5<br>o<br>e CKPmn<br>n = 1), cc<br>sed in t<br>5<br>o                                                              | 4<br>o<br>en these<br>bit of the<br>ommunica<br>this mo<br>4<br>o                                | 0<br>bits are<br>s SCRmr<br>ation sta<br>de.<br>3<br>0                                          | 0<br>1 if the clu<br>n = 0). If the<br>rts when<br>2                | SOm1<br>×<br>ock phas<br>he clock p<br>these bits<br>1<br>SOEm1                                             | SOm0<br>×<br>we is<br>phase is<br>s are 0.<br>0<br>SOEm0                   |
| SOm<br>(e<br>SOEm         | 15<br>0<br>) Ser<br>15<br>0<br>Ser                             | 14<br>0<br>ial outp<br>14<br>0<br>ial cha                                              | 13<br>0<br>out ena<br>13<br>0<br>nnel sta                                               | 12<br>0<br>ble reg<br>12<br>0<br>art regis                                                 | 11<br>0<br>ister m<br>11<br>0<br>ster m                                   | 10<br>0<br>(SOEr<br>10<br>0<br>(SSm).                               | 9<br>CKOm1<br>0/1<br>m) Th<br>9<br>0                                                        | 8<br>CKOm0<br>0/1<br>ne regis<br>8<br>0<br>only th                             | 7<br>0<br>Communon-reversed<br>reversed<br>ster that<br>7<br>0<br>0                               | 6<br>0<br>nication s<br>ersed (the<br>d (CKPm<br>at not us<br>6<br>0<br>0<br>of the ta                   | 5<br>o<br>starts whe<br>cKPmn<br>n = 1), cc<br>sed in t<br>5<br>o<br>arget cl                                      | 4<br>o<br>en these<br>bit of the<br>ommunica<br>this mo<br>4<br>0<br>hannel                      | 0<br>bits are<br>s SCRmr<br>ation star<br>de.<br>3<br>0<br>to 1.                                | 0<br>1 if the cl<br>n = 0). If the<br>rts when<br>2<br>0            | SOm1<br>×<br>ock phas<br>he clock p<br>these bits<br>1<br>SOEm1<br>×                                        | SOm0<br>×<br>ee is<br>obhase is<br>s are 0.<br>0<br>SOEm0<br>×             |
| SOm<br>(e)<br>SOEm<br>(f) | 15<br>0<br>) Seri<br>15<br>0<br>Seri<br>15<br>0<br><b>Rema</b> | 14<br>0<br>ial outp<br>14<br>0<br>ial char<br>14<br>0<br><b>rk 1.</b> m                | 13<br>0<br>0<br>13<br>0<br>13<br>0<br>13<br>0<br>13<br>0<br>1<br>2<br>: Setti           | 12<br>0<br>ble reg<br>12<br>0<br>art regis<br>12<br>0<br>umber (<br>ng is fixe             | 11<br>0<br>ister m<br>11<br>0<br>ster m<br>11<br>0<br>m = 0),<br>ed in th | 10<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 9<br>CKOm1<br>0/1<br>m) Th<br>9<br>0<br>Sets<br>9<br>0<br>nnel nur<br>aster re              | 8<br>CKOm0<br>0/1<br>0<br>ne regis<br>8<br>0<br>only th<br>8<br>0<br>nber (n : | 7<br>0<br>Commu<br>non-reve<br>reversed<br>ster that<br>7<br>0<br>e bits of<br>7<br>0<br>= 0, 1), | 6<br>0<br>nication s<br>ersed (the<br>d (CKPm<br>at not us<br>6<br>0<br>0<br>0<br>0                      | 5<br>0<br>c CKPmn<br>n = 1), cc<br>sed in t<br>5<br>0<br>arget cl $50$                                             | 4<br>o<br>bit of the<br>bit of the<br>ommunica<br>this mo<br>4<br>o<br>hannel<br>4<br>0          | 0<br>bits are<br>s SCRmr<br>ation star<br>de.<br>3<br>0<br>to 1.<br>3<br>0                      | 0<br>1 if the cl<br>n = 0). If the<br>rts when<br>2<br>0<br>2<br>0  | SOm1<br>×<br>ock phas<br>he clock p<br>these bits<br>1<br>SOEm1<br>×<br>1<br>SOEm1<br>v<br>1<br>SSm1<br>0/1 | SOm0<br>×<br>ee is<br>phase is<br>s are 0.<br>0<br>SOEm0<br>×<br>0<br>SSm0 |
| SOm<br>(e)<br>SOEm<br>(f) | 15<br>0<br>) Seri<br>15<br>0<br>Seri<br>15<br>0<br><b>Rema</b> | 14<br>0<br>ial outr<br>14<br>0<br>ial cha<br>14<br>0<br><b>rk 1.</b> m<br><b>rk 2.</b> | 13<br>0<br>out ena<br>13<br>0<br>nnel sta<br>13<br>0<br>n: Unit n<br>: Setti<br>: Setti | 12<br>o<br>ble reg<br>12<br>o<br>art regis<br>12<br>o<br>umber (<br>ng is fixe<br>ng disab | 11<br>0<br>ister m<br>11<br>0<br>ster m<br>11<br>0<br>m = 0),<br>ed in th | 10<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 9<br>CKOm1<br>0/1<br>m) Th<br>9<br>0<br>Sets<br>9<br>0<br>nnel nur<br>aster re<br>nitial va | 8<br>CKOm0<br>0/1<br>0<br>ne regis<br>8<br>0<br>only th<br>8<br>0<br>nber (n : | 7<br>0<br>Communon-reversed<br>ster that<br>7<br>0<br>ne bits of<br>7<br>0<br>= 0, 1),<br>mode,   | 6<br>0<br>nication s<br>ersed (the<br>d (CKPm)<br>at not us<br>6<br>0<br>of the ta<br>6<br>0<br>p: CSI r | 5<br>0<br>starts whe<br>CKPmn<br>n = 1), cc<br>sed in t<br>5<br>0<br>arget cl<br>5<br>0<br>n<br>arget cl<br>5<br>0 | 4<br>0<br>en these<br>bit of the<br>mmunica<br>this mo<br>4<br>0<br>hannel<br>4<br>0<br>(p = 00, | 0<br>bits are<br>s SCRmr<br>ation star<br>de.<br>3<br>0<br>to 1.<br>3<br>0<br>0<br>0<br>01), mr | 0<br>1 if the cl<br>n = 0). If the<br>2<br>0<br>2<br>0<br>n = 00, 0 | SOm1<br>×<br>ock phas<br>he clock p<br>these bits<br>1<br>SOEm1<br>×<br>1<br>SOEm1<br>v<br>1<br>SSm1<br>0/1 | SOm0<br>×<br>ee is<br>phase is<br>s are 0.<br>0<br>SOEm0<br>×<br>0<br>SSm0 |



## (2) Operation procedure

Figure 11 - 35 Initial Setting Procedure for Master Reception







If there is any data being transferred, wait for their completion. (If there is an urgent must stop, do not wait.)

Write 1 to the STmn bit of the target channel. (SEmn = 0: to operation stop status)

Set the SOEmn bit to 0 and stop the output of the target channel.

The levels of the serial clock (CKOmn) on the target channel can be changed if necessitated by an emergency.

Reset the serial array unit by stopping the clock supply to it.

After the stop setting is completed, go to the next processing.





#### Figure 11 - 37 Procedure for Resuming Master Reception

**Remark** If PER0 is rewritten while stopping the master transmission and the clock supply is stopped, wait until the transmission target (slave) stops or transmission finishes, and then perform initialization instead of restarting the transmission.



(3) Processing flow (in single-reception mode)





Remark m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





#### Figure 11 - 39 Flowchart of Master Reception (in Single-Reception Mode)



(4) Processing flow (in continuous reception mode)



| SSmn<             | 1>                                  |                               |                                 |    |
|-------------------|-------------------------------------|-------------------------------|---------------------------------|----|
| STmn              |                                     |                               | <8>                             | ſĹ |
| SEmn_             |                                     |                               | Receive data 3 ¬                |    |
| SDRmn             | ∑ Dummy data ∑ Dummy data           | Receive data 1 Dummy data     |                                 |    |
|                   | $<2> \Delta Write <2> \Delta Write$ | <2> ∆Write<br>▲Read           | ▲Read Read▲                     |    |
| SCKp pin          |                                     |                               |                                 |    |
| SIp pin           | Receive data 1                      | Receive data 2                | Receive data 3                  |    |
| Shift register mn | X Reception & shift operation       | X Reception & shift operation | X Reception & shift operation X |    |
| INTCSIp           | ſ                                   | Π                             |                                 |    |
|                   | Data reception                      | Data reception                | Data reception                  |    |
| MDmn0             |                                     |                               | <5>                             |    |
| TSFmn             |                                     |                               |                                 |    |
| BFFmn             |                                     |                               |                                 |    |
|                   | <3> <:                              | <br>}> <4> <3                 | 3> <4> <6><7>                   |    |

- Caution The MDmn0 bit can be rewritten even during operation. However, rewrite it before receive of the last bit is started, so that it has been rewritten before the transfer end interrupt of the last receive data.
- **Remark 1.** <1> to <8> in the figure correspond to <1> to <8> in Figure 11 41 Flowchart of Master Reception (in Continuous Reception Mode).
- **Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





Figure 11 - 41 Flowchart of Master Reception (in Continuous Reception Mode)

**Remark** <1> to <8> in the figure correspond to <1> to <8> in Figure 11 - 40 Timing Chart of Master Reception (in Continuous Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0).

RENESAS

# 11.5.3 Master transmission/reception

Master transmission/reception is that the R9A02G015 microcontroller outputs a transfer clock and transmits/receives data to/from another device.

| 3-Wire Serial I/O    | CSI00                                                                | CSI01                                                 |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|--|
| Target channel       | Channel 0 of SAU0                                                    | Channel 1 of SAU0                                     |  |  |  |  |  |  |
| Pins used            | SCK00, SI00, SO00                                                    | SCK01, SI01, SO01                                     |  |  |  |  |  |  |
| Interrupt            | INTCSI00                                                             | INTCSI01                                              |  |  |  |  |  |  |
|                      | Transfer end interrupt (in single-transfer mode) or buf be selected. | fer empty interrupt (in continuous transfer mode) can |  |  |  |  |  |  |
| Error detection flag | Overrun error detection flag (OVFmn) only                            |                                                       |  |  |  |  |  |  |
| Transfer data length | 7 or 8 bits                                                          |                                                       |  |  |  |  |  |  |
| Transfer rate Note   | Max. fc∟к/2 [Hz] (CSI00 only), fc∟к/4 [Hz]                           |                                                       |  |  |  |  |  |  |
|                      | Min. fcLk/(2 × 2 <sup>15</sup> × 128) [Hz] fcLk: System clock freq   | uency                                                 |  |  |  |  |  |  |
| Data phase           | Selectable by the DAPmn bit of the SCRmn register                    |                                                       |  |  |  |  |  |  |
|                      | DAPmn = 0: Data I/O starts at the start of the operation             | tion of the serial clock.                             |  |  |  |  |  |  |
|                      | DAPmn = 1: Data I/O starts half a clock before the s                 | start of the serial clock operation.                  |  |  |  |  |  |  |
| Clock phase          | Selectable by the CKPmn bit of the SCRmn register                    |                                                       |  |  |  |  |  |  |
|                      | • CKPmn = 0: Non-reverse                                             |                                                       |  |  |  |  |  |  |
|                      | • CKPmn = 1: Reverse                                                 |                                                       |  |  |  |  |  |  |
| Data direction       | MSB or LSB first                                                     |                                                       |  |  |  |  |  |  |

**Note** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

Remark m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01



(1) Register setting

# Figure 11 - 42 Example of Contents of Registers for Master Transmission/Reception of 3-Wire Serial I/O (CSI00, CSI01)

| (a)   | ) Seri                        | ial moc               | le regis                | ster mn                       | (SMR        | mn)        |              |                                                  |                        |                        |                       |                        |                       |                          |                                          |               |
|-------|-------------------------------|-----------------------|-------------------------|-------------------------------|-------------|------------|--------------|--------------------------------------------------|------------------------|------------------------|-----------------------|------------------------|-----------------------|--------------------------|------------------------------------------|---------------|
| _     | 15                            | 14                    | 13                      | 12                            | 11          | 10         | 9            | 8                                                | 7                      | 6                      | 5                     | 4                      | 3                     | 2                        | 1                                        | 0             |
| SMRmn | CKSmn<br>0/1                  | CCSmn<br>0            | 0                       | 0                             | 0           | 0          | 0            | STSmn<br>0                                       | 0                      | SISmn0<br>0            | 1                     | 0                      | 0                     | MDmn2<br>0               | MDmn1<br>0                               | MDmn0<br>0/1  |
|       | 0: Pres                       | scaler ou             | tput cloc               | channel r<br>k CKm0<br>k CKm1 | set by th   |            | •            |                                                  |                        |                        |                       |                        | 0:                    | Transfe                  | rce of ch<br>r end inte<br>mpty inte     | rrupt         |
| (b)   | ) Seri                        | al com                | munica                  | ation o                       | peratio     | n settin   | ig regis     | ster mn                                          | (SCRr                  | mn)                    |                       |                        |                       |                          |                                          |               |
|       | 15                            | 14                    | 13                      | 12                            | 11          | 10         | 9            | 8                                                | 7                      | 6                      | 5                     | 4                      | 3                     | 2                        | 1                                        | 0             |
| SCRmn | TXEmn<br>1                    | RXEmn<br>1            | DAPmn<br>0/1            | CKPmn<br>0/1                  | 0           | EOCmn<br>0 | PTCmn1<br>0  | PTCmn0<br>0                                      | DIRmn<br>0/1           | 0                      | SLCmn1<br>0           | SLCmn0<br>0            | 0                     | 1                        | DLSmn1<br>1                              | DLSmn0<br>0/1 |
|       | details al<br><b>Register</b> | bout the<br>rs Contro | setting, s<br>olling Se | erial Arra                    | ay Unit.)   |            | 0:<br>1:     | ection of o<br>Inputs/or<br>Inputs/or<br>ts: SIO | utputs da<br>utputs da | ata with N             | ISB first             |                        |                       | 0: 7-b                   | of data le<br>it data ler<br>bit data le | ngth          |
| (0)   | 15                            | 14                    | 13                      | 12                            | 11          | 10 10      | 9            | 8                                                | 5)<br>7                | 6                      | 5                     | 4                      | 3                     | 2                        | 1                                        | 0             |
| SDRmn | (                             | Operati               |                         | d rate se<br>k (fмск)         | -           | n setting  | )            | 0                                                |                        | Trans                  | mit data              | setting                | /receive              | e data re                | egister                                  |               |
| (d)   | ) Seri<br>15                  | al outp<br>14         | out regi<br>13          | ster m<br>12                  | (SOm)<br>11 | Sets<br>10 | only ti<br>9 | he bits                                          | of the t               | target c<br>6          | hanne<br>5            | sic<br>I.<br>4         | Op<br>3               | 2                        | 1                                        | 0             |
| SOm   | 15                            | 14                    | 15                      | 12                            |             |            | CKOm1        | CKOm0                                            | ,                      | 0                      | 5                     | 4                      | 5                     | 2                        | SOm1                                     | SOm0          |
| 0011  | 0                             | 0                     | 0                       | 0                             | 0           | 0          | 0/1          | 0/1                                              | 0                      | 0                      | 0                     | 0                      | 0                     | 0                        | 0/1                                      | 0/1           |
| (e)   | ) Seri                        | al outp               | out ena                 | ble reg                       | ister m     | ı (SOEı    | m) Se        |                                                  | non-reve<br>reversed   | ersed (the<br>d (CKPmi | e CKPmr<br>n = 1), co | bit of the<br>ommunica | e SCRmr<br>ation star | n = 0). If t<br>rts when | lock phas<br>he clock  <br>these bits    | ohase is      |
| г     | 15                            | 14                    | 13                      | 12                            | 11          | 10         | 9            | 8                                                | 7                      | 6                      | 5                     | 4                      | 3                     | 2                        | 1<br>SOEm1                               | 0<br>SOEm0    |
| SOEm  | 0                             | 0                     | 0                       | 0                             | 0           | 0          | 0            | 0                                                | 0                      | 0                      | 0                     | 0                      | 0                     | 0                        | 0/1                                      | 0/1           |
| (f)   | Seri                          | ial chai              | nnel sta                | art regi                      | ster m      | (SSm).     | Sets         | only th                                          | e bits o               | of the ta              | arget c               | hannel                 | to 1.                 |                          |                                          |               |
|       | 15                            | 14                    | 13                      | 12                            | 11          | 10         | 9            | 8                                                | 7                      | 6                      | 5                     | 4                      | 3                     | 2                        | 1                                        | 0             |
| SSm   | 0                             | 0                     | 0                       | 0                             | 0           | 0          | 0            | 0                                                | 0                      | 0                      | 0                     | 0                      | 0                     | 0                        | SSm1<br>0/1                              | SSm0<br>0/1   |
| L     | Rema                          | <b>rk 1.</b> m        | : Unit n                | umber (                       | m = 0).     | n: Char    | nel nur      | nber (n :                                        | = 0, 1).               | p: CSI r               | number                | (p = 00.               | 01). mr               | n = 00.                  | 01                                       |               |
|       |                               | _                     |                         |                               | -           |            |              | ansmiss                                          |                        |                        |                       |                        | ,,                    | ,                        |                                          |               |
|       |                               | 0/                    |                         | ng disab<br>o 0 or 1          | ``          |            |              | lue)<br>ge of the                                | euser                  |                        |                       |                        |                       |                          |                                          |               |



## (2) Operation procedure



## Figure 11 - 43 Initial Setting Procedure for Master Transmission/Reception

### Figure 11 - 44 Procedure for Stopping Master Transmission/Reception



If there is any data being transferred, wait for their completion. (If there is an urgent must stop, do not wait.)

Write 1 to the STmn bit of the target channel. (SEmn = 0: to operation stop status)

Set the SOEmn bit to 0 and stop the output of the target channel.

The levels of the serial clock (CKOmn) and serial data (SOmn) on the target channel can be changed if necessitated by an emergency.

Reset the serial array unit by stopping the clock supply to it.

After the stop setting is completed, go to the next processing.





#### Figure 11 - 45 Procedure for Resuming Master Transmission/Reception



(3) Processing flow (in single-transmission/reception mode)





Remark m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





#### Figure 11 - 47 Flowchart of Master Transmission/Reception (in Single- Transmission/Reception Mode)



(4) Processing flow (in continuous transmission/reception mode)





- **Note 1.** If transmit data is written to the SDRmn register while the BFFmn bit of serial status register mn (SSRmn) is 1 (valid data is stored in serial data register mn (SDRmn)), the transmit data is overwritten.
- **Note 2.** The transmit data can be read by reading the SDRmn register during this period. At this time, the transfer operation is not affected.
- Caution The MDmn0 bit of serial mode register mn (SMRmn) can be rewritten even during operation. However, rewrite it before transfer of the last bit is started, so that it has been rewritten before the transfer end interrupt of the last transmit data.
- **Remark 1.** <1> to <8> in the figure correspond to <1> to <8> in Figure 11 49 Flowchart of Master Transmission/Reception (in Continuous Transmission/Reception Mode).
- Remark 2. m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





### Figure 11 - 49 Flowchart of Master Transmission/Reception (in Continuous Transmission/Reception Mode)

**Remark** <1> to <8> in the figure correspond to <1> to <8> in Figure 11 - 48 Timing Chart of Master Transmission/Reception (in Continuous Transmission/Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0).

RENESAS

# 11.5.4 Slave transmission

Slave transmission is that the R9A02G015 microcontroller transmits data to another device in the state of a transfer clock being input from another device.

| 3-Wire Serial I/O    | CSI00                                                                                                                                                                | CSI01                                                 |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|
| Target channel       | Channel 0 of SAU0                                                                                                                                                    | Channel 1 of SAU0                                     |  |  |  |  |  |
| Pins used            | SCK00, SO00                                                                                                                                                          | SCK01, SO01                                           |  |  |  |  |  |
| Interrupt            | INTCSI00                                                                                                                                                             | INTCSI01                                              |  |  |  |  |  |
|                      | Transfer end interrupt (in single-transfer mode) or buf be selected.                                                                                                 | fer empty interrupt (in continuous transfer mode) can |  |  |  |  |  |
| Error detection flag | Overrun error detection flag (OVFmn) only                                                                                                                            |                                                       |  |  |  |  |  |
| Transfer data length | 7 or 8 bits                                                                                                                                                          |                                                       |  |  |  |  |  |
| Transfer rate        | Max. fмск/6 [Hz] <sup>Notes 1, 2</sup> .                                                                                                                             |                                                       |  |  |  |  |  |
| Data phase           | Selectable by the DAPmn bit of the SCRmn register<br>• DAPmn = 0: Data output starts from the start of the<br>• DAPmn = 1: Data output starts half a clock before th |                                                       |  |  |  |  |  |
| Clock phase          | Selectable by the CKPmn bit of the SCRmn register<br>• CKPmn = 0: Non-reverse<br>• CKPmn = 1: Reverse                                                                |                                                       |  |  |  |  |  |
| Data direction       | MSB or LSB first                                                                                                                                                     |                                                       |  |  |  |  |  |

**Note 1.** Because the external serial clock input to the SCK00 and SCK01 pins is sampled internally and used, the fastest transfer rate is fMcK/6 [Hz].

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

Remark 1. fMCK: Operation clock frequency of target channel

**Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



(1) Register setting

# Figure 11 - 50 Example of Contents of Registers for Slave Transmission of 3-Wire Serial I/O (CSI00, CSI01)

| (a                       | ) Sei                                               | ial mod                                                                    | de regi                                                                                | ster mn                                                                                    | (SMR                                                                                 | (mn)                                                                             |                                                                              |                                                                         |                                                                   |                                                             |                                                            |                                                               |                                                 |                                        |                                                      |                                          |
|--------------------------|-----------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------|----------------------------------------|------------------------------------------------------|------------------------------------------|
|                          | 15                                                  | 14                                                                         | 13                                                                                     | 12                                                                                         | 11                                                                                   | 10                                                                               | 9                                                                            | 8                                                                       | 7                                                                 | 6                                                           | 5                                                          | 4                                                             | 3                                               | 2                                      | 1                                                    | 0                                        |
| SMRmn                    | CKSmn<br>0/1                                        | CCSmn<br>1                                                                 | 0                                                                                      | 0                                                                                          | 0                                                                                    | 0                                                                                | 0                                                                            | STSmn<br>0                                                              | 0                                                                 | SISmn0<br>0                                                 | 1                                                          | 0                                                             | 0                                               | MDmn2<br>0                             | MDmn1<br>0                                           | MDmn0<br>0/1                             |
|                          | 0: Pre                                              | scaler ou                                                                  | utput cloc                                                                             | channel r<br>k CKm0<br>k CKm1                                                              | set by th                                                                            |                                                                                  | •                                                                            |                                                                         |                                                                   |                                                             |                                                            |                                                               | 0                                               | : Transfe                              | urce of ch<br>er end inte<br>empty inte              | errupt                                   |
| (b                       | ) Sei                                               | ial con                                                                    | nmunic                                                                                 | ation o                                                                                    | peratio                                                                              | n settir                                                                         | ng regis                                                                     | ster mn                                                                 | (SCRr                                                             | mn)                                                         |                                                            |                                                               |                                                 |                                        |                                                      |                                          |
|                          | 15                                                  | 14                                                                         | 13                                                                                     | 12                                                                                         | 11                                                                                   | 10                                                                               | 9                                                                            | 8                                                                       | 7                                                                 | 6                                                           | 5                                                          | 4                                                             | 3                                               | 2                                      | 1                                                    | 0                                        |
| SCRmn                    | TXEmn<br>1                                          | RXEmn<br>0                                                                 | DAPmn<br>0/1                                                                           | CKPmn<br>0/1                                                                               | 0                                                                                    | EOCmn<br>0                                                                       | PTCmn1<br>0                                                                  | PTCmn0<br>0                                                             | DIRmn<br>0/1                                                      | 0                                                           | SLCmn1<br>0                                                | SLCmn0<br>0                                                   | 0                                               | 1                                      | DLSmn1<br>1                                          | DLSmn0<br>0/1                            |
|                          | details a                                           | bout the                                                                   | setting,                                                                               | clock pha<br>see 11.3<br>erial Arra                                                        |                                                                                      |                                                                                  | 0:                                                                           | ection of c<br>Inputs/ou<br>Inputs/ou                                   | utputs da                                                         | ata with N                                                  | ISB first                                                  |                                                               |                                                 | 0: 7-b                                 | of data le<br>vit data ler<br>vit data ler           | ngth                                     |
| (c)                      | ) Sei                                               | ial data                                                                   | a regist                                                                               | er mn (                                                                                    | SDRm                                                                                 | nn) (low                                                                         | ver 8 bi                                                                     | ts: SIOp                                                                | <b>)</b> )                                                        |                                                             |                                                            |                                                               |                                                 |                                        |                                                      |                                          |
|                          | 15                                                  | 14                                                                         | 13                                                                                     | 12                                                                                         | 11                                                                                   | 10                                                                               | 9                                                                            | 8                                                                       | 7                                                                 | 6                                                           | 5                                                          | 4                                                             | 3                                               | 2                                      | 1                                                    | 0                                        |
| SDRmn                    |                                                     |                                                                            |                                                                                        | 0000000<br>d rate se                                                                       |                                                                                      |                                                                                  |                                                                              | 0                                                                       |                                                                   |                                                             | Tra                                                        | ansmit d                                                      | ata set                                         | ting                                   |                                                      |                                          |
|                          |                                                     |                                                                            |                                                                                        |                                                                                            |                                                                                      |                                                                                  |                                                                              |                                                                         |                                                                   |                                                             |                                                            |                                                               |                                                 |                                        |                                                      |                                          |
|                          |                                                     |                                                                            |                                                                                        |                                                                                            |                                                                                      |                                                                                  |                                                                              |                                                                         |                                                                   |                                                             |                                                            | sic                                                           | Op                                              |                                        |                                                      |                                          |
| (d                       | ) Sei                                               | ial out                                                                    | out regi                                                                               | ister m                                                                                    | (SOm)                                                                                | ) Sets                                                                           | s only ti                                                                    | he bits o                                                               | of the t                                                          | target c                                                    | hannel                                                     |                                                               | Эр                                              |                                        |                                                      |                                          |
| (d                       | ) Sei<br>15                                         | ial outp<br>14                                                             | out regi<br>13                                                                         | ister m<br>12                                                                              | (SOm)<br>11                                                                          | ) Sets<br>10                                                                     | s only tl<br>9                                                               | he bits o<br>8                                                          | of the t                                                          | target c<br>6                                               | hannel<br>5                                                |                                                               | Op<br>3                                         | 2                                      | 1                                                    | 0                                        |
| (d<br>SOm                |                                                     | -                                                                          | -                                                                                      |                                                                                            |                                                                                      |                                                                                  | -                                                                            |                                                                         |                                                                   | -                                                           |                                                            | l.                                                            |                                                 | 2                                      | 1<br>SOm1<br>0/1                                     | 0<br>SOm0<br>0/1                         |
|                          | 15<br>0                                             | 14<br>0                                                                    | 13<br>0                                                                                | 12<br>0                                                                                    | 0                                                                                    | 10<br>0                                                                          | 9<br>CKOm1<br>×                                                              | 8<br>CKOm0                                                              | 7<br>0                                                            | 6                                                           | 5<br>0                                                     | . 4                                                           | 3                                               | 0                                      | SOm1                                                 | SOm0                                     |
| SOm                      | 15<br>0                                             | 14<br>0                                                                    | 13<br>0                                                                                | 12<br>0                                                                                    | 0                                                                                    | 10<br>0                                                                          | 9<br>CKOm1<br>×                                                              | 8<br>CKOm0<br>×                                                         | 7<br>0                                                            | 6                                                           | 5<br>0                                                     | . 4                                                           | 3                                               | 0                                      | SOm1                                                 | SOm0                                     |
| SOm                      | 15<br>0<br>) Sei                                    | 14<br>0<br>rial outp                                                       | 13<br>0<br>out ena                                                                     | 12<br>0<br>Ible reg                                                                        | 11<br>0<br>ister m                                                                   | 10<br>0<br>1 (SOE                                                                | 9<br>CKOm1<br>×<br>m) Se                                                     | 8<br>CKOm0<br>×<br>ets only                                             | 7<br>0<br>the bi                                                  | 6<br>0<br>ts of the                                         | 5<br>0<br>e targe                                          | 4<br>0<br>t chanr                                             | 3<br>0<br>nel to 1                              | 0                                      | SOm1<br>0/1                                          | SOm0<br>0/1                              |
| SOm<br>(e                | 15<br>0<br>) Sei<br>15<br>0                         | 14<br>0<br>ial out;<br>14<br>0                                             | 13<br>0<br>out ena<br>13<br>0                                                          | 12<br>o<br>able reg<br>12<br>o                                                             | 11<br>0<br>ister m<br>11<br>0                                                        | 10<br>0<br>10<br>10<br>0                                                         | 9<br>CKOm1<br>×<br>m) Se<br>9                                                | 8<br>CKOm0<br>×<br>ets only<br>8                                        | 7<br>0<br>the bi<br>7<br>0                                        | 6<br>0<br>ts of the<br>6<br>0                               | 5<br>o<br>e targe<br>5<br>o                                | 4<br>0<br>t chanr<br>4<br>0                                   | 3<br>0<br>nel to 1<br>3<br>0                    | 0<br>1.<br>2                           | SOm1<br>0/1<br>1<br>SOEm1                            | SOm0<br>0/1<br>0<br>SOEm0                |
| SOm<br>(e<br>SOEm        | 15<br>0<br>) Sei<br>15<br>0                         | 14<br>0<br>ial out;<br>14<br>0                                             | 13<br>0<br>out ena<br>13<br>0                                                          | 12<br>o<br>able reg<br>12<br>o                                                             | 11<br>0<br>ister m<br>11<br>0                                                        | 10<br>0<br>10<br>10<br>0                                                         | 9<br>CKOm1<br>×<br>m) Se<br>9                                                | 8<br>CKOm0<br>×<br>ets only<br>8<br>0                                   | 7<br>0<br>the bi<br>7<br>0                                        | 6<br>0<br>ts of the<br>6<br>0                               | 5<br>o<br>e targe<br>5<br>o                                | 4<br>0<br>t chanr<br>4<br>0                                   | 3<br>0<br>nel to 1<br>3<br>0                    | 0<br>1.<br>2                           | SOm1<br>0/1<br>1<br>SOEm1<br>0/1                     | SOm0<br>0/1<br>0<br>SOEm0                |
| SOm<br>(e<br>SOEm        | 15<br>0<br>) Sei<br>15<br>0<br>Sei                  | 14<br>0<br>ial outr<br>14<br>0<br>ial cha                                  | 13<br>0<br>out ena<br>13<br>0<br>nnel st                                               | 12<br>o<br>ble reg<br>12<br>o<br>art regi                                                  | 11<br>0<br>ister m<br>11<br>0<br>ster m                                              | 10<br>0<br>10 (SOE<br>10<br>0<br>(SSm)                                           | 9<br>CKOm1<br>×<br>9<br>0<br>Sets                                            | 8<br>CKOm0<br>×<br>ets only<br>8<br>0<br>only th                        | 7<br>0<br>the bi<br>7<br>0<br>e bits 0                            | 6<br>0<br>ts of the<br>6<br>0                               | 5<br>o<br>e targe<br>5<br>o<br>arget c                     | 4<br>t chanr<br>4<br>0<br>hannel                              | 3<br>0<br>nel to 1<br>3<br>0<br>to 1.           | 0<br>1.<br>2<br>0                      | SOm1<br>0/1<br>1<br>SOEm1<br>0/1                     | SOm0<br>0/1<br>SOEm0<br>0/1              |
| SOm<br>(e<br>SOEm<br>(f) | 15<br>0<br>Sei<br>15<br>0<br>Sei<br>15<br>0<br>Rema | 14<br>0<br>ial out;<br>14<br>0<br>ial cha<br>14<br>0<br>ark 1. m<br>ark 2. | 13<br>0<br>out ena<br>13<br>0<br>nnel st<br>13<br>0<br>n: Unit n<br>: Setti<br>: Setti | 12<br>o<br>ble reg<br>12<br>o<br>art regi:<br>12<br>0<br>umber (<br>ing is fix<br>ng disab | 11<br>0<br>ister m<br>11<br>0<br>ster m<br>11<br>0<br>m = 0),<br>ed in th<br>led (se | 10<br>0<br>(SOE<br>10<br>0<br>(SSm)<br>10<br>0<br>n: Char<br>e CSI s<br>t to the | 9<br>CKOm1<br>×<br>m) Se<br>9<br>0<br>Sets<br>9<br>0<br>nnel nur<br>ave tran | 8<br>CKOm0<br>×<br>ets only<br>8<br>0<br>only th<br>8<br>0<br>nber (n = | 7<br>0<br>the bi<br>7<br>e bits 0<br>7<br>0<br>= 0, 1),<br>n mode | 6<br>0<br>ts of the<br>6<br>of the ta<br>6<br>0<br>p: CSI r | 5<br>0<br>e targe<br>5<br>0<br>arget c<br>5<br>0<br>number | . 4<br>0<br>t chanr<br>4<br>0<br>hannel<br>4<br>0<br>(p = 00, | 3<br>nel to 1<br>3<br>0<br>to 1.<br>3<br>0<br>0 | 0<br>1.<br>2<br>0<br>2<br>0<br>n = 00, | SOm1<br>0/1<br>1<br>SOEm1<br>0/1<br>1<br>SSm1<br>0/1 | SOm0<br>0/1<br>SOEm0<br>0/1<br>0<br>SSm0 |



## (2) Operation procedure

Figure 11 - 51 Initial Setting Procedure for Slave Transmission





## Figure 11 - 52 Procedure for Stopping Slave Transmission

If there is any data being transferred, wait for their completion. (If there is an urgent must stop, do not wait.)

Write 1 to the STmn bit of the target channel (SEmn = 0: to operation stop status).

Set the SOEmn bit to 0 and stop the output of the target channel.

The levels of the serial data (SOmn) on the target channel can be changed if necessitated by an emergency.

Reset the serial array unit by stopping the clock supply to it.

After the stop setting is completed, go to the next processing.





#### Figure 11 - 53 Procedure for Resuming Slave Transmission

**Remark** If PER0 is rewritten while stopping the master transmission and the clock supply is stopped, wait until the transmission target (master) stops or transmission finishes, and then perform initialization instead of restarting the transmission.

(3) Processing flow (in single-transmission mode)





Remark m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





Figure 11 - 55 Flowchart of Slave Transmission (in Single-Transmission Mode)



(4) Processing flow (in continuous transmission mode)





- **Note** If transmit data is written to the SDRmn register while the BFFmn bit of serial status register mn (SSRmn) is 1 (valid data is stored in serial data register mn (SDRmn)), the transmit data is overwritten.
- Caution The MDmn0 bit of serial mode register mn (SMRmn) can be rewritten even during operation. However, rewrite it before transfer of the last bit is started.
- **Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





Figure 11 - 57 Flowchart of Slave Transmission (in Continuous Transmission Mode)

**Remark** <1> to <6> in the figure correspond to <1> to <6> in Figure 11 - 56 Timing Chart of Slave Transmission (in Continuous Transmission Mode) (Type 1: DAPmn = 0, CKPmn = 0).



# 11.5.5 Slave reception

Slave reception is that the R9A02G015 microcontroller receives data from another device in the state of a transfer clock being input from another device.

| 3-Wire Serial I/O    | CSI00                                                                                                                                                                  | CSI01                    |  |  |  |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--|--|--|--|--|
| Target channel       | Channel 0 of SAU0                                                                                                                                                      | Channel 1 of SAU0        |  |  |  |  |  |
| Pins used            | SCK00, SI00                                                                                                                                                            | SCK01, SI01              |  |  |  |  |  |
| Interrupt            | INTCSI00                                                                                                                                                               | INTCSI01                 |  |  |  |  |  |
|                      | Transfer end interrupt only (Setting the buffer empty in                                                                                                               | nterrupt is prohibited.) |  |  |  |  |  |
| Error detection flag | Overrun error detection flag (OVFmn) only                                                                                                                              |                          |  |  |  |  |  |
| Transfer data length | 7 or 8 bits                                                                                                                                                            |                          |  |  |  |  |  |
| Transfer rate        | Max. fмск/6 [Hz] <sup>Notes 1, 2</sup>                                                                                                                                 |                          |  |  |  |  |  |
| Data phase           | Selectable by the DAPmn bit of the SCRmn register<br>• DAPmn = 0: Data input starts from the start of the op<br>• DAPmn = 1: Data input starts half a clock before the |                          |  |  |  |  |  |
| Clock phase          | Selectable by the CKPmn bit of the SCRmn register<br>• CKPmn = 0: Non-reverse<br>• CKPmn = 1: Reverse                                                                  |                          |  |  |  |  |  |
| Data direction       | MSB or LSB first                                                                                                                                                       |                          |  |  |  |  |  |

**Note 1.** Because the external serial clock input to the SCK00 and SCK011 pins is sampled internally and used, the fastest transfer rate is fMck/6 [Hz].

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

Remark 1. fMCK: Operation clock frequency of target channel

**Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



(1) Register setting

# Figure 11 - 58 Example of Contents of Registers for Slave Reception of 3-Wire Serial I/O (CSI00, CSI01)

| (a)                | ) Seri                               | al moc                                   | de regis                                              | ster mn                                              | (SMR                                   | mn)                                     |                                    |                                                      |                                          |                                        |                                       |                                        |                                     |             |                                          |                         |
|--------------------|--------------------------------------|------------------------------------------|-------------------------------------------------------|------------------------------------------------------|----------------------------------------|-----------------------------------------|------------------------------------|------------------------------------------------------|------------------------------------------|----------------------------------------|---------------------------------------|----------------------------------------|-------------------------------------|-------------|------------------------------------------|-------------------------|
|                    | 15                                   | 14                                       | 13                                                    | 12                                                   | 11                                     | 10                                      | 9                                  | 8                                                    | 7                                        | 6                                      | 5                                     | 4                                      | 3                                   | 2           | 1                                        | 0                       |
| SMRmn              | CKSmn<br>0/1                         | CCSmn<br>1                               | 0                                                     | 0                                                    | 0                                      | 0                                       | 0                                  | STSmn<br>0                                           | 0                                        | SISmn0<br>0                            | 1                                     | 0                                      | 0                                   | MDmn2<br>0  | MDmn1<br>0                               | MDmn0<br>0              |
|                    | 0: Pres                              | caler ou                                 | itput cloc                                            | channel r<br>k CKm0<br>k CKm1                        | set by th                              |                                         | -                                  |                                                      |                                          |                                        |                                       |                                        |                                     | -           | urce of ch<br>r end inte                 |                         |
| (b)                | ) Seri                               | al com                                   | nmunic                                                | ation o                                              | oeratio                                | n settin                                | ig regis                           | ster mn                                              | (SCRr                                    | nn)                                    |                                       |                                        |                                     |             |                                          |                         |
| _                  | 15                                   | 14                                       | 13                                                    | 12                                                   | 11                                     | 10                                      | 9                                  | 8                                                    | 7                                        | 6                                      | 5                                     | 4                                      | 3                                   | 2           | 1                                        | 0                       |
| SCRmn              | TXEmn<br>0                           | RXEmn<br>1                               | DAPmn<br>0/1                                          | CKPmn<br>0/1                                         | 0                                      | EOCmn<br>0                              | PTCmn1<br>0                        | PTCmn0<br>0                                          | DIRmn<br>0/1                             | 0                                      | SLCmn1<br>0                           | SLCmn0<br>0                            | 0                                   | 1           | DLSmn1<br>1                              | DLSmn0<br>0/1           |
|                    | details al                           | oout the                                 | setting, s                                            | clock pha<br>see 11.3<br>erial Arra                  |                                        |                                         | 0:                                 | Inputs/o                                             | utputs da                                | sfer sequ<br>ata with M<br>ata with La | SB first                              |                                        |                                     | 0: 7-b      | of data le<br>it data ler<br>it data ler | ngth                    |
| (c)                | Seri                                 | al data                                  | a regist                                              | er mn (                                              | SDRm                                   | n) (low                                 | er 8 bi                            | ts: SIO                                              | o)                                       |                                        |                                       |                                        |                                     |             |                                          |                         |
| F                  | 15                                   | 14                                       | 13                                                    | 12                                                   | 11                                     | 10                                      | 9                                  | 8                                                    | 7                                        | 6                                      | 5                                     | 4                                      | 3                                   | 2           | 1                                        | 0                       |
| SDRmn              |                                      |                                          |                                                       | 0000000                                              |                                        |                                         |                                    | 0                                                    |                                          |                                        |                                       | Receiv                                 | e data                              |             |                                          |                         |
|                    |                                      |                                          | Baud                                                  | d rate se                                            | aung                                   |                                         |                                    | 0                                                    |                                          |                                        |                                       |                                        |                                     |             |                                          |                         |
| l                  |                                      |                                          | Baud                                                  |                                                      | aung                                   |                                         |                                    | 0                                                    |                                          |                                        |                                       | sic                                    | Op                                  |             |                                          |                         |
| (d)                | ) Seri                               | al outp                                  |                                                       |                                                      |                                        | The                                     | Regist                             |                                                      | not use                                  | ed in th                               | is mod                                |                                        | Op                                  |             |                                          |                         |
| (d)                | ) Seri<br>15                         | al outp<br>14                            |                                                       |                                                      |                                        | The<br>10                               | Regist<br>9                        |                                                      | not use                                  | ed in th<br>6                          | is mod<br>5                           |                                        | Op<br>3                             | 2           | 1                                        | 0                       |
| (d)<br>SOm         |                                      | -                                        | out regi                                              | ster m                                               | (SOm)                                  |                                         | -                                  | er that                                              |                                          |                                        |                                       | e.                                     |                                     | 2           | 1<br>SOm1<br>×                           | 0<br>SOm0<br>×          |
| ſ                  | 15<br>0                              | 14<br>0                                  | out regi<br>13<br>0                                   | ster m<br>12<br>0                                    | (SOm)<br>11<br>0                       | 10<br>0                                 | 9<br>CKOm1<br>×                    | er that<br>8<br><sup>СКОт0</sup><br>×                | <b>7</b>                                 | 6                                      | 5<br>0                                | e.<br>4                                | 3                                   |             | SOm1                                     | SOm0                    |
| SOm                | 15<br>0                              | 14<br>0                                  | out regi<br>13<br>0                                   | ster m<br>12<br>0                                    | (SOm)<br>11<br>0                       | 10<br>0                                 | 9<br>CKOm1<br>×                    | er that<br>8<br><sup>СКОт0</sup><br>×                | <b>7</b>                                 | 6<br>0                                 | 5<br>0                                | e.<br>4                                | 3                                   |             | SOm1                                     | SOm0                    |
| SOm                | 15<br>0<br>) Seri                    | 14<br>0<br>al outp                       | out regi<br>13<br>0<br>out ena                        | ister m<br>12<br>0<br>ble reg                        | (SOm)<br>11<br>o<br>ister m            | 10<br>0<br>(SOEr                        | 9<br>CKOm1<br>×<br>m) Tł           | er that<br>8<br>ското<br>×                           | 7<br>0<br>ister th                       | 6<br>0<br>at not u                     | 5<br>0<br>sed in                      | e.<br>4<br>0<br>this mo                | 3<br>0<br>ode.                      | 0           | SOm1<br>×                                | SOm0<br>×               |
| SOm<br>(e)<br>SOEm | 15<br>0<br>) Seri<br>15<br>0         | 14<br>0<br>al outp<br>14<br>0            | out regi<br>13<br>0<br>out ena<br>13<br>0             | ster m<br>12<br>0<br>ble reg<br>12<br>0              | (SOm)<br>11<br>0<br>ister m<br>11<br>0 | 10<br>0<br>(SOEr<br>10<br>0             | 9<br>CKOm1<br>×<br>m) Tr<br>9      | er that<br>8<br>CKOm0<br>×<br>ne Regi<br>8           | 7<br>0<br>ister th<br>7<br>0             | 6<br>0<br>at not u<br>6<br>0           | 5<br>0<br>sed in<br>5<br>0            | e.<br>4<br>this mo<br>4                | 3<br>0<br>ode.<br>3<br>0            | 0           | SOm1<br>×<br>1<br>SOEm1                  | SOm0<br>×<br>0<br>SOEm0 |
| SOm<br>(e)         | 15<br>0<br>) Seri<br>15<br>0         | 14<br>0<br>al outp<br>14<br>0            | out regi<br>13<br>0<br>out ena<br>13<br>0             | ster m<br>12<br>0<br>ble reg<br>12<br>0              | (SOm)<br>11<br>0<br>ister m<br>11<br>0 | 10<br>0<br>(SOEr<br>10<br>0             | 9<br>CKOm1<br>×<br>m) Tr<br>9      | er that<br>8<br>CKOm0<br>×<br>ne Regi<br>8           | 7<br>0<br>ister th<br>7<br>0             | 6<br>o<br>at not u<br>6                | 5<br>0<br>sed in<br>5<br>0            | e.<br>4<br>this mo<br>4                | 3<br>0<br>ode.<br>3<br>0            | 0           | SOm1<br>×<br>1<br>SOEm1                  | SOm0<br>×<br>0<br>SOEm0 |
| SOm<br>(e)<br>SOEm | 15<br>0<br>) Seri<br>15<br>0<br>Seri | 14<br>0<br>al outp<br>14<br>0<br>al chai | out regi<br>13<br>0<br>out ena<br>13<br>0<br>nnel sta | ister m<br>12<br>0<br>ble reg<br>12<br>0<br>art regi | (SOm)<br>11<br>0<br>ister m<br>11<br>0 | 10<br>0<br>1 (SOEr<br>10<br>0<br>(SSm). | 9<br>CKOm1<br>×<br>m) Th<br>9<br>0 | er that<br>8<br>CKOM0<br>×<br>ne Regi<br>8<br>0<br>0 | 7<br>0<br>ister th<br>7<br>0<br>e bits 0 | 6<br>o<br>at not u<br>6<br>of the ta   | 5<br>o<br>sed in<br>5<br>o<br>arget c | e.<br>4<br>this mo<br>4<br>0<br>hannel | 3<br>0<br>0<br>0<br>3<br>0<br>to 1. | 0<br>2<br>0 | SOm1<br>×<br>1<br>SOEm1<br>×             | O<br>SOEm0<br>×         |

×: Bit that cannot be used in this mode (set to the initial value when not used in any mode)

0/1: Set to 0 or 1 depending on the usage of the user



## (2) Operation procedure





### Figure 11 - 60 Procedure for Stopping Slave Reception



If there is any data being transferred, wait for their completion. (If there is an urgent must stop, do not wait.)

Write 1 to the STmn bit of the target channel. (SEmn = 0: to operation stop status)

Set the SOEmn bit to 0 and stop the output of the target channel.

Reset the serial array unit by stopping the clock supply to it.

After the stop setting is completed, go to the next processing.





#### Figure 11 - 61 Procedure for Resuming Slave Reception

**Remark** If PER0 is rewritten while stopping the master transmission and the clock supply is stopped, wait until the transmission target (master) stops or transmission finishes, and then perform initialization instead of restarting the transmission.



(3) Processing flow (in single-reception mode)



# Figure 11 - 62 Timing Chart of Slave Reception (in Single-Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0)

Remark m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





#### Figure 11 - 63 Flowchart of Slave Reception (in Single-Reception Mode)



# 11.5.6 Slave transmission/reception

Slave transmission/reception is that the R9A02G015 microcontroller transmits/receives data to/from another device in the state of a transfer clock being input from another device.

| 3-Wire Serial I/O    | CSI00                                                                                                                                                                 | CSI01                                                 |  |  |  |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|
| Target channel       | Channel 0 of SAU0                                                                                                                                                     | Channel 1 of SAU0                                     |  |  |  |  |  |
| Pins used            | SCK00, SI00, SO00                                                                                                                                                     | SCK01, SI01, SO01                                     |  |  |  |  |  |
| Interrupt            | INTCSI00                                                                                                                                                              | INTCSI01                                              |  |  |  |  |  |
|                      | Transfer end interrupt (in single-transfer mode) or buf be selected.                                                                                                  | fer empty interrupt (in continuous transfer mode) can |  |  |  |  |  |
| Error detection flag | Overrun error detection flag (OVFmn) only                                                                                                                             |                                                       |  |  |  |  |  |
| Transfer data length | 7 or 8 bits                                                                                                                                                           |                                                       |  |  |  |  |  |
| Transfer rate        | Max. fмск/6 [Hz] <sup>Notes 1, 2</sup> .                                                                                                                              |                                                       |  |  |  |  |  |
| Data phase           | Selectable by the DAPmn bit of the SCRmn register<br>• DAPmn = 0: Data I/O starts from the start of the ope<br>• DAPmn = 1: Data I/O starts half a clock before the s |                                                       |  |  |  |  |  |
| Clock phase          | Selectable by the CKPmn bit of the SCRmn register<br>• CKPmn = 0: Non-reverse<br>• CKPmn = 1: Reverse                                                                 |                                                       |  |  |  |  |  |
| Data direction       | MSB or LSB first                                                                                                                                                      |                                                       |  |  |  |  |  |

**Note 1.** Because the external serial clock input to the SCK00 and SCK01 pins is sampled internally and used, the fastest transfer rate is fMCK/6 [Hz].

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

Remark 1. fMCK: Operation clock frequency of target channel

Remark 2. m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



(1) Register setting

# Figure 11 - 64 Example of Contents of Registers for Slave Transmission/Reception of 3-Wire Serial I/O (CSI00, CSI01)

| (a)      | ) Seri                         | ial moo                      | de regis                             | ster mn                | (SMR        | mn)                                   |             |                      |                        |                                       |             |             |         |            |                                          |              |
|----------|--------------------------------|------------------------------|--------------------------------------|------------------------|-------------|---------------------------------------|-------------|----------------------|------------------------|---------------------------------------|-------------|-------------|---------|------------|------------------------------------------|--------------|
|          | 15                             | 14                           | 13                                   | 12                     | 11          | 10                                    | 9           | 8                    | 7                      | 6                                     | 5           | 4           | 3       | 2          | 1                                        | 0            |
| SMRmn    | CKSmn<br>0/1                   | CCSmn<br>1                   | 0                                    | 0                      | 0           | 0                                     | 0           | STSmn<br>0           | 0                      | SISmn0<br>0                           | 1           | 0           | 0       | MDmn2<br>0 | MDmn1<br>0                               | MDmn0<br>0/1 |
|          | 0: Pres                        | scaler ou                    | •                                    | k CKm0                 | set by th   | e SPSm<br>e SPSm                      | •           |                      |                        |                                       |             |             | 0:      | Transfe    | rce of ch<br>r end inte<br>mpty inte     | rrupt        |
| (b)      |                                |                              |                                      | -                      |             | n settin                              |             |                      | •                      |                                       | _           |             | -       |            |                                          |              |
|          | 15<br>TXEmn                    | 14<br>RXEmn                  | 13<br>DAPmn                          | 12<br>CKPmn            | 11          | 10<br>EOCmn                           | 9<br>PTCmn1 | 8<br>PTCmn0          | 7<br>DIRmn             | 6                                     | 5<br>SLCmn1 | 4<br>SLCmn0 | 3       | 2          | 1<br>DLSmn1                              | 0<br>DLSmn0  |
| SCRmn    | 1                              | 1                            | 0/1                                  | 0/1                    | 0           | 0                                     | 0           | 0                    | 0/1                    | 0                                     | 0           | 0           | 0       | 1          | 1                                        | 0/1          |
|          | details al<br><b>Registe</b> r | bout the<br>r <b>s Contr</b> | data and<br>setting, s<br>colling Se | see 11.3<br>erial Arra | y Unit.)    | ın) (low                              | 0:<br>1:    | Inputs/o<br>Inputs/o | utputs da<br>utputs da | sfer sequ<br>ata with N<br>ata with L | ISB first   |             |         | 0: 7-b     | of data le<br>it data ler<br>it data ler | ngth         |
| (c)      | 15                             | 14                           | 13 100                               | 12                     | 11          | 10 (IOW                               | 9           | 8                    | P)<br>7                | 6                                     | 5           | 4           | 3       | 2          | 1                                        | 0            |
| SDRmn    | -                              |                              |                                      | 0000000<br>d rate se   |             | -                                     | -           | 0                    |                        | Trans                                 |             | setting     |         |            | egister                                  |              |
| L        |                                |                              |                                      |                        | 0           |                                       |             |                      |                        |                                       |             | si          |         |            |                                          |              |
| (d)      |                                | ial outr                     | out rogi                             | ctor m                 | (SOm)       | ) Sets                                | oply t      | ha hita              | of tho t               | torgot c                              | hannal      | I           | •       |            |                                          |              |
| (u)      | , OCH<br>15                    | 14                           | 13                                   | 12                     | (00m)<br>11 | 10 10                                 | 9           | 8                    | 7                      | 6                                     | 5           | 4           | 3       | 2          | 1                                        | 0            |
| SOm      | 0                              | 0                            | 0                                    | 0                      | 0           | 0                                     | CKOm1<br>×  | CKOm0<br>×           | 0                      | 0                                     | 0           | 0           | 0       | 0          | SOm1<br>0/1                              | SOm0<br>0/1  |
| l<br>(e) |                                |                              |                                      |                        |             | n (SOEr                               |             |                      |                        |                                       |             |             |         |            | 0,1                                      | 0,1          |
| (e)      | 15                             | ող օու<br>14                 | 13                                   | 12                     | 11          | 10 10                                 | 9           | 8 8                  | 7 T                    | 6                                     | 5 5         | 4           | 3       | 2          | 1                                        | 0            |
| SOEm     | 0                              | 0                            | 0                                    | 0                      | 0           | 0                                     | 0           | 0                    | 0                      | 0                                     | 0           | 0           | 0       | 0          | SOEm1<br>0/1                             | SOEm0<br>0/1 |
| (f)      | Seri                           | ial cha                      | nnel sta                             | art regi               | ster m      | (SSm).                                | Sets        | only th              | ne bits                | of the t                              | arget c     | hannel      | to 1.   |            |                                          |              |
| (•)      | 15                             | 14                           | 13                                   | 12                     | 11          | 10                                    | 9           | 8                    | 7                      | 6                                     | 5           | 4           | 3       | 2          | 1                                        | 0            |
| SSm      | 0                              | 0                            | 0                                    | 0                      | 0           | 0                                     | 0           | 0                    | 0                      | 0                                     | 0           | 0           | 0       | 0          | SSm1<br>0/1                              | SSm0<br>0/1  |
| -        | Cautio                         | on B                         | e sure                               | to set ti              | ransmit     | t data to                             | the SI      | Op regi              | ster be                | fore the                              | clock       | from th     | e mast  | er is sta  | arted.                                   |              |
|          |                                | rk 2.                        | : Setti                              | ng is fix              | ed in th    | n: Char<br>e CSI m                    | aster tra   | ansmiss              | . ,.                   | •                                     |             | (p = 00,    | 01), m  | n = 00,    | 01                                       |              |
|          |                                | ×                            | : Bit that                           | t cannot               | be use      | t to the i<br>ed in this<br>ding on t | mode        | (set to th           |                        | l value v                             | vhen no     | t used ir   | n any m | node)      |                                          |              |



#### (2) Operation procedure

| Starting initial setting              |                                                                                                                                                         |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Setting the PER0 register             | Release the serial array unit from the reset status and start clock supply.                                                                             |
| Setting the SPSm register             | Set the operation clock.                                                                                                                                |
| Setting the SMRmn register            | Set an operation mode, etc.                                                                                                                             |
| Setting the SCRmn register            | Set a communication format.                                                                                                                             |
| Setting the SDRmn register            | Set bits 15 to 9 to 0000000B for baud rate setting.                                                                                                     |
| Setting the SOm register              | Set the initial output level of the serial data (SOmn).                                                                                                 |
| Changing setting of the SOEm register | Set the SOEmn bit to 1 and enable data output of the target channel.                                                                                    |
| Setting port                          | Enable data output of the target channel by setting a port register and a port mode register.                                                           |
| Writing to the SSm register           | Set the SSmn bit of the target channel to 1<br>(SEmn bit = 1: to enable operation).                                                                     |
| Completing initial setting            | Initial setting is completed.<br>Set transmit data to the SIOp register (bits 7 to 0 of<br>the SDRmn register) and wait for a clock from the<br>master. |

### Figure 11 - 65 Initial Setting Procedure for Slave Transmission/Reception

Caution Be sure to set transmit data to the SIOp register before the clock from the master is started.









#### Figure 11 - 67 Procedure for Resuming Slave Transmission/Reception

Caution 1. Be sure to set transmit data to the SIOp register before the clock from the master is started.

Caution 2. If PER0 is rewritten while stopping the master transmission and the clock supply is stopped, wait until the transmission target (master) stops or transmission finishes, and then perform initialization instead of restarting the transmission.



(3) Processing flow (in single-transmission/reception mode)





**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01







Caution Be sure to set transmit data to the SIOp register before the clock from the master is started.



(4) Processing flow (in continuous transmission/reception mode)





- **Note 1.** If transmit data is written to the SDRmn register while the BFFmn bit of serial status register mn (SSRmn) is 1 (valid data is stored in serial data register mn (SDRmn)), the transmit data is overwritten.
- Note 2. The transmit data can be read by reading the SDRmn register during this period. At this time, the transfer operation is not affected.
- Caution The MDmn0 bit of serial mode register mn (SMRmn) can be rewritten even during operation. However, rewrite it before transfer of the last bit is started, so that it has been rewritten before the transfer end interrupt of the last transmit data.
- **Remark 1.** <1> to <8> in the figure correspond to <1> to <8> in Figure 11 71 Flowchart of Slave Transmission/Reception (in Continuous Transmission/Reception Mode).
- **Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0, 1), p: CSI number (p = 00, 01), mn = 00, 01





#### Figure 11 - 71 Flowchart of Slave Transmission/Reception (in Continuous Transmission/Reception Mode)

Caution Be sure to set transmit data to the SIOp register before the clock from the master is started.

**Remark** <1> to <8> in the figure correspond to <1> to <8> in Figure 11 - 70 Timing Chart of Slave Transmission/Reception (in Continuous Transmission/Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0).



# 11.5.7 SNOOZE mode function

SNOOZE mode makes CSI operate reception by SCKp pin input detection while the STOP mode. Normally CSI stops communication in the STOP mode. But, using the SNOOZE mode makes reception CSI operate unless the CPU operation by detecting SCKp pin input. Only the following channels can be set to the SNOOZE mode. • CSI00

When using the CSI in SNOOZE mode, make the following setting before switching to the STOP mode (see Figure 11 - 73 and Figure 11 - 75 Flowchart of SNOOZE Mode Operation).

• When using the SNOOZE mode function, set the SWCm bit of serial standby control register m (SSCm) to 1 just before switching to the STOP mode. After the initial setting has been completed, set the SSm0 bit of serial channel start register m (SSm) to 1.

The CPU shifts to the SNOOZE mode on detecting the valid edge of the SCKp signal following a transition to the STOP mode. A CSIp starts reception on detecting input of the serial clock on the SCKp pin.

# Caution 1. The SNOOZE mode can only be specified when the high-speed on-chip oscillator clock (fiH) is selected for fcLk.

Caution 2. The maximum transfer rate when using CSIp in the SNOOZE mode is 1 Mbps.

(1) SNOOZE mode operation (once startup)

| CPU operation -<br>status -               | Normal operation STOP mode | SNOOZE mode                 |                              | Normal operation            |
|-------------------------------------------|----------------------------|-----------------------------|------------------------------|-----------------------------|
| SS00                                      | <3>                        |                             | <11>                         |                             |
| ST00 ST00                                 |                            |                             | <9>                          |                             |
| SE00                                      |                            |                             |                              |                             |
| SWC0                                      |                            |                             | <10>                         |                             |
| SSEC0                                     | L                          |                             |                              |                             |
| Clock request signal<br>(internal signal) |                            |                             |                              |                             |
| (internal signal)                         |                            |                             |                              | Receive data 2 7            |
| SDR00                                     |                            |                             | X                            | Receive data 1              |
|                                           |                            |                             | <8><br>▲Read <sup>Note</sup> |                             |
| SCK00 pin                                 |                            |                             |                              |                             |
| SI00 pin                                  |                            | Receive data 1              |                              | Receive data 2              |
| Shift register 00                         |                            | Reception & shift operation |                              | Reception & shift operation |
| INTCSI00                                  |                            |                             |                              |                             |
|                                           |                            | Data reception              | -                            | Data reception              |
| TSF00                                     |                            |                             |                              |                             |
|                                           | <2> <5                     | ><6> <                      | 7>                           |                             |

#### Figure 11 - 72 Timing Chart of SNOOZE Mode Operation (once startup) (Type 1: DAPmn = 0, CKPmn = 0)

**Note** Only read received data while SWCm = 1 and before the next valid edge of the SCKp pin input is detected.

Caution 1. Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the STm0 bit to 1 (clear the SEm0 bit, and stop the operation).

And after completion the receive operation, also clearing SWCm bit to 0 (SNOOZE mode release).

- Caution 2. When SWCm = 1, the BFFm1 and OVFm1 flags will not change.
- Remark 1. <1> to <11> in the figure correspond to <1> to <11> in Figure 11 73 Flowchart of SNOOZE Mode Operation (once startup).

Remark 2. m = 0; p = 00



#### Figure 11 - 73 Flowchart of SNOOZE Mode Operation (once startup)

Remark 1. <1> to <11> in the figure correspond to <1> to <11> in Figure 11 - 72 Timing Chart of SNOOZE Mode Operation (once startup) (Type 1: DAPmn = 0, CKPmn = 0).
 Remark 2. m = 0; p = 00



(2) SNOOZE mode operation (continuous startup)

#### Figure 11 - 74 Timing Chart of SNOOZE Mode Operation (continuous startup) (Type 1: DAPmn = 0, CKPmn = 0)

| CPU operation           | Normal aparatio |              | SNOOZE mode                 | Normal operation              | STOP mode | SNOOZE mode                 |
|-------------------------|-----------------|--------------|-----------------------------|-------------------------------|-----------|-----------------------------|
| CPU operation<br>status | Normai operatio | on STOP mode | SNOOZE Mode                 | Normal operation              | STOP mode | SINOUZE IIIOUE              |
|                         |                 | <4>          |                             | -05 <b>—</b>                  | <4>       |                             |
| SS00                    | <3>             |              |                             | <3>                           |           |                             |
| ST00                    | <1>             |              |                             | <9>                           |           |                             |
| SE00                    |                 |              |                             |                               |           |                             |
| SWC0                    |                 |              |                             | <10>                          |           |                             |
| SSEC0                   | L               |              |                             |                               |           |                             |
| Clock request signal    |                 |              |                             |                               |           |                             |
| (internal signal)       |                 |              |                             |                               |           |                             |
|                         |                 |              |                             |                               |           | Receive data 2              |
| SDR00                   |                 |              |                             | X                             |           | Receive data 1              |
|                         |                 |              |                             | <8><br>▲ Read <sup>Note</sup> |           |                             |
| SCK00 pin               |                 |              |                             |                               |           |                             |
| SI00 pin                |                 |              | Receive data 1              |                               |           | Receive data 2              |
| Shift register 00       |                 |              | Reception & shift operation |                               |           | Reception & shift operation |
| INTCSI00                |                 |              |                             |                               |           |                             |
|                         |                 |              | Data reception              |                               |           | Data reception              |
| TSF00                   |                 |              |                             |                               |           |                             |
|                         | <2>             | <5           | ><6> <                      | <br>7> <2>                    | <5        | ><6>                        |

Note Only read received data while SWCm = 1 and before the next valid edge of the SCKp pin input is detected.

Caution 1. Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the STm0 bit to 1 (clear the SEm0 bit, and stop the operation).

And after completion the receive operation, also clearing SWCm bit to 0 (SNOOZE release).

- Caution 2. When SWCm = 1, the BFFm1 and OVFm1 flags will not change.
- **Remark 1.** <1> to <10> in the figure correspond to <1> to <10> in Figure 11 75 Flowchart of SNOOZE Mode Operation (continuous startup).
- Remark 2. m = 0; p = 00





Figure 11 - 75 Flowchart of SNOOZE Mode Operation (continuous startup)

Remark 1. <1> to <10> in the figure correspond to <1> to <10> in Figure 11 - 74 Timing Chart of SNOOZE Mode Operation (continuous startup) (Type 1: DAPmn = 0, CKPmn = 0).
 Remark 2. m = 0; p = 00

# 11.5.8 Calculating transfer clock frequency

The transfer clock frequency for 3-wire serial I/O (CSI00, CSI01) communication can be calculated by the following expressions.

#### (1) Master

(Transfer clock frequency) = {Operation clock (fмск) frequency of target channel} ÷ (SDRmn[15:9] + 1) ÷ 2 [Hz]

#### (2) Slave

(Transfer clock frequency) = {Frequency of serial clock (SCK) supplied by master} <sup>Note</sup> [Hz]

- **Note** The permissible maximum transfer clock frequency is fMCK/6.
- **Remark** The value of SDRmn[15:9] is the value of bits 15 to 9 of serial data register mn (SDRmn) (0000000B to 1111111B) and therefore is 0 to 127.

The operation clock (fMCK) is determined by serial clock select register m (SPSm) and bit 15 (CKSmn) of serial mode register mn (SMRmn).



| SMRmn<br>Register |            |            |            |            | Operation Clock (fмск) <sup>Note</sup> |            |            |            |                      |               |
|-------------------|------------|------------|------------|------------|----------------------------------------|------------|------------|------------|----------------------|---------------|
| CKSmn             | PRS<br>m13 | PRS<br>m12 | PRS<br>m11 | PRS<br>m10 | PRS<br>m03                             | PRS<br>m02 | PRS<br>m01 | PRS<br>m00 |                      | fclк = 24 MHz |
| 0                 | ×          | ×          | ×          | ×          | 0                                      | 0          | 0          | 0          | fclк                 | 24 MHz        |
|                   | ×          | ×          | ×          | ×          | 0                                      | 0          | 0          | 1          | fclk/2               | 12 MHz        |
|                   | ×          | ×          | ×          | ×          | 0                                      | 0          | 1          | 0          | fcLк/2 <sup>2</sup>  | 6 MHz         |
|                   | ×          | ×          | ×          | ×          | 0                                      | 0          | 1          | 1          | fcLк/2 <sup>3</sup>  | 3 MHz         |
|                   | ×          | ×          | ×          | ×          | 0                                      | 1          | 0          | 0          | fclk/2 <sup>4</sup>  | 1.5 MHz       |
|                   | ×          | ×          | ×          | ×          | 0                                      | 1          | 0          | 1          | fcLк/2 <sup>5</sup>  | 750 kHz       |
|                   | ×          | ×          | ×          | ×          | 0                                      | 1          | 1          | 0          | fcLк/2 <sup>6</sup>  | 375 kHz       |
|                   | ×          | ×          | ×          | ×          | 0                                      | 1          | 1          | 1          | fcLк/2 <sup>7</sup>  | 187.5 kHz     |
|                   | ×          | ×          | ×          | ×          | 1                                      | 0          | 0          | 0          | fcLк/2 <sup>8</sup>  | 93.8 kHz      |
|                   | ×          | ×          | ×          | ×          | 1                                      | 0          | 0          | 1          | fclк/2 <sup>9</sup>  | 46.9 kHz      |
|                   | ×          | ×          | ×          | ×          | 1                                      | 0          | 1          | 0          | fclk/2 <sup>10</sup> | 23.4 kHz      |
|                   | ×          | ×          | ×          | ×          | 1                                      | 0          | 1          | 1          | fclк/2 <sup>11</sup> | 11.7 kHz      |
|                   | ×          | ×          | ×          | ×          | 1                                      | 1          | 0          | 0          | fclk/2 <sup>12</sup> | 5.86 kHz      |
|                   | ×          | ×          | ×          | ×          | 1                                      | 1          | 0          | 1          | fclk/2 <sup>13</sup> | 2.93 kHz      |
|                   | ×          | ×          | ×          | ×          | 1                                      | 1          | 1          | 0          | fclk/2 <sup>14</sup> | 1.46 kHz      |
|                   | ×          | ×          | ×          | ×          | 1                                      | 1          | 1          | 1          | fclk/2 <sup>15</sup> | 732 Hz        |
| 1                 | 0          | 0          | 0          | 0          | ×                                      | ×          | ×          | ×          | fclk                 | 24 MHz        |
|                   | 0          | 0          | 0          | 1          | ×                                      | ×          | ×          | ×          | fclk/2               | 12 MHz        |
|                   | 0          | 0          | 1          | 0          | ×                                      | ×          | ×          | ×          | fclк/2 <sup>2</sup>  | 6 MHz         |
|                   | 0          | 0          | 1          | 1          | ×                                      | ×          | ×          | ×          | fclк/2 <sup>3</sup>  | 3 MHz         |
|                   | 0          | 1          | 0          | 0          | ×                                      | ×          | ×          | ×          | fclk/24              | 1.5 MHz       |
|                   | 0          | 1          | 0          | 1          | ×                                      | ×          | ×          | ×          | fcLк/2 <sup>5</sup>  | 750 kHz       |
|                   | 0          | 1          | 1          | 0          | ×                                      | ×          | ×          | ×          | fcLк/2 <sup>6</sup>  | 375 kHz       |
|                   | 0          | 1          | 1          | 1          | ×                                      | ×          | ×          | ×          | fcLк/2 <sup>7</sup>  | 187.5 kHz     |
|                   | 1          | 0          | 0          | 0          | ×                                      | ×          | ×          | ×          | fcLк/2 <sup>8</sup>  | 93.8 kHz      |
|                   | 1          | 0          | 0          | 1          | ×                                      | ×          | ×          | ×          | fcLк/2 <sup>9</sup>  | 46.9 kHz      |
|                   | 1          | 0          | 1          | 0          | ×                                      | ×          | ×          | ×          | fclk/2 <sup>10</sup> | 23.4 kHz      |
|                   | 1          | 0          | 1          | 1          | ×                                      | ×          | ×          | ×          | fclк/2 <sup>11</sup> | 11.7 kHz      |
|                   | 1          | 1          | 0          | 0          | ×                                      | ×          | ×          | ×          | fclk/2 <sup>12</sup> | 5.86 kHz      |
|                   | 1          | 1          | 0          | 1          | ×                                      | ×          | ×          | ×          | fclк/2 <sup>13</sup> | 2.93 kHz      |
|                   | 1          | 1          | 1          | 0          | ×                                      | ×          | ×          | ×          | fclk/2 <sup>14</sup> | 1.46 kHz      |
|                   | 1          | 1          | 1          | 1          | ×                                      | ×          | ×          | ×          | fclk/2 <sup>15</sup> | 732 Hz        |

Table 11 - 2 Selection of Operation Clock For 3-Wire Serial I/O

**Note** When changing the clock selected for fcLK (by changing the system clock control register (CKC) value), do so after having stopped (serial channel stop register m (STm) = 000FH) the operation of the serial array unit (SAU).

Remark 1. ×: Don't care

Remark 2. m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01

# 11.5.9 Procedure for processing errors that occurred during 3-wire serial I/O (CSI00, CSI01) communication

The procedure for processing errors that occurred during 3-wire serial I/O (CSI00, CSI01) communication is described in Figure 11 - 76.

| Figure 11 - 76 | Processing | Procedure in | Case of Overrun | Error |
|----------------|------------|--------------|-----------------|-------|
|----------------|------------|--------------|-----------------|-------|

| Software Manipulation                     | Hardware Status                                                                           | Remark                                                                                                                                           |
|-------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Reads serial data register mn (SDRmn).→   | The BFFmn bit of the SSRmn register is set to 0 and channel n is enabled to receive data. | This is to prevent an overrun error if the next reception is completed during error processing.                                                  |
| Reads serial status register mn (SSRmn).  |                                                                                           | Error type is identified and the read value is used to clear error flag.                                                                         |
| Writes 1 to serial flag clear trigger ——— | Error flag is cleared.                                                                    | Error can be cleared only during reading,<br>by writing the value read from the SSRmn<br>register to the SIRmn register without<br>modification. |

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



# 11.6 Operation of UART (UART0) Communication

This is a start-stop synchronization function using two lines: serial data transmission (TxD) and serial data reception (RxD) lines. By using these two communication lines, each data frame, which consist of a start bit, data, parity bit, and stop bit, is transferred asynchronously (using the internal baud rate) between the microcontroller and the other communication party. Full-duplex UART communication can be performed by using a channel dedicated to transmission (even-numbered channel) and a channel dedicated to reception (odd-numbered channel).

[Data transmission/reception]

- Data length of 7, 8, or 9 bits
- Select the MSB/LSB first
- Level setting of transmit/receive data (selecting whether to reverse the level)
- Parity bit appending and parity check functions
- Stop bit appending, stop bit check function
- [Interrupt function]
- Transfer end interrupt/buffer empty interrupt
- Error interrupt in case of framing error, parity error, or overrun error
- [Error detection flag]
- Framing error, parity error, or overrun error

In addition, UARTs of the following channels supports the SNOOZE mode. When RxD input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. Only the following UART can be specified.

• UART0



UART0 uses channels 0 and 1 of SAU0.

• 32-pin products

|   | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C |
|---|------|---------|-------------|--------------|-------------------------------------|
| ſ | 0    | 0       | CSI00       | UART0        | IIC00                               |
|   |      | 1       | CSI01       |              | IIC01                               |

Select any function for each channel. Only the selected function is possible. If UART0 is selected for channels 0 and 1 of unit 0, for example, these channels cannot be used for CSI00 and IIC00.

# Caution When using a serial array unit for UART, both the transmitter side (even-numbered channel) and the receiver side (odd-numbered channel) can only be used for UART.

UART performs the following four types of communication operations.

| <ul> <li>UART transmission</li> </ul> | (See <b>11.6.1</b> .) |
|---------------------------------------|-----------------------|
|---------------------------------------|-----------------------|

• UART reception (See 11.6.2.)



# 11.6.1 UART transmission

UART transmission is an operation to transmit data from the R9A02G015 microcontroller to another device asynchronously (start-stop synchronization).

Of two channels used for UART, the even channel is used for UART transmission.

| UART                 | UART0                                                                                                                                               |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Target channel       | Channel 0 of SAU0                                                                                                                                   |
| Pins used            | TxD0                                                                                                                                                |
| Interrupt            | INTST0                                                                                                                                              |
|                      | Transfer end interrupt (in single-transfer mode) or buffer empty interrupt (in continuous transfer mode) can be selected.                           |
| Error detection flag | None                                                                                                                                                |
| Transfer data length | 7, 8, or 9 bits <sup>Note 1</sup>                                                                                                                   |
| Transfer rate        | Max. fмск/6 [bps] (SDRmn [15:9] = 2 or more), Min. fcLк/(2 × 2 <sup>15</sup> × 128) [bps] <sup>Note 2</sup>                                         |
| Data phase           | Non-reverse output (default: high level)<br>Reverse output (default: low level)                                                                     |
| Parity bit           | The following selectable <ul> <li>No parity bit</li> <li>Appending 0 parity</li> <li>Appending even parity</li> <li>Appending odd parity</li> </ul> |
| Stop bit             | The following selectable <ul> <li>Appending 1 bit</li> <li>Appending 2 bits</li> </ul>                                                              |
| Data direction       | MSB or LSB first                                                                                                                                    |

Note 1. Only the following UARTs can be specified for the 9-bit data length. • UART0

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)). For UART transmission, use the high-speed system clock or high-speed on-chip oscillator.

Remark 1. fMCK: Operation clock frequency of target channel

fclk: System clock frequency

Remark 2. m: Unit number (m = 0), n: Channel number (n = 0), mn = 00



(1) Register setting

## Figure 11 - 77 Example of Contents of Registers for UART Transmission of UART (UART0) (1/2)

| (a)   | ) Seri           | al moo         | de regis       | ster mn                                                      | ı (SMR                         | (mn)                |               |                                            |              |            |                       |                    |         |                                   |                                         |               |
|-------|------------------|----------------|----------------|--------------------------------------------------------------|--------------------------------|---------------------|---------------|--------------------------------------------|--------------|------------|-----------------------|--------------------|---------|-----------------------------------|-----------------------------------------|---------------|
|       | 15               | 14             | 13             | 12                                                           | 11                             | 10                  | 9             | 8                                          | 7            | 6          | 5                     | 4                  | 3       | 2                                 | 1                                       | 0             |
| SMRmn | CKSmn<br>0/1     | CCSmn<br>0     | 0              | 0                                                            | 0                              | 0                   | 0             | 0                                          | 0            | 0          | 1                     | 0                  | 0       | MDmn2<br>0                        | MDmn1                                   | MDmn0<br>0/1  |
|       |                  | caler ou       | itput cloc     | k CKm0                                                       | set by th                      | ie SPSm<br>ie SPSm  | •             |                                            |              |            |                       |                    | 0:      | Transfe                           | urce of ch<br>er end inte<br>empty inte | errupt        |
| (b)   | ) Seri           | al com         | nmunica        | ation o                                                      | peratio                        | n settir            | ng regis      | ster mn                                    | (SCRr        | mn)        |                       |                    |         |                                   |                                         |               |
| _     | 15               | 14             | 13             | 12                                                           | 11                             | 10                  | 9             | 8                                          | 7            | 6          | 5                     | 4                  | 3       | 2                                 | 1                                       | 0             |
| SCRmn | TXEmn<br>1       | RXEmn<br>0     | DAPmn<br>0     | CKPmn<br>0                                                   | 0                              | EOCmn<br>0          | PTCmn1<br>0/1 | PTCmn0<br>0/1                              | DIRmn<br>0/1 | 0          | SLCmn1<br>0/1         | SLCmn0<br>0/1      | 0       | 1                                 | DLSmn1<br>0/1 Note 1                    | DLSmn0<br>0/1 |
| -     |                  |                | 00<br>01<br>10 | ing of pa<br>)B: No pa<br>IB: Apper<br>)B: Apper<br>B: Apper | arity<br>nding 0 p<br>nding Ev | en parity           | sec<br>0:     | ection o<br>juence<br>Inputs/o<br>Inputs/o | utputs da    | ata with I |                       |                    |         | of stop b<br>Appendir<br>Appendir | ng 1 bit                                |               |
| (c)   | ) Seri           | al data        | a regist       | er mn (                                                      | (SDRm                          | nn) (low            | er 8 bi       | ts: TXD                                    | (p           |            |                       |                    |         |                                   |                                         |               |
| -     | 15               | 14             | 13             | 12                                                           | 11                             | 10                  | 9             | 8                                          | 7            | 6          | 5                     | 4                  | 3       | 2                                 | 1                                       | 0             |
| SDRmn |                  |                | Baud           | d rate se                                                    | etting                         |                     |               | 0 Note 2                                   |              |            | Tra                   | ansmit d           | ata set | ting                              |                                         |               |
|       |                  |                |                |                                                              |                                |                     |               |                                            |              |            |                       | тх                 | Dq      |                                   |                                         |               |
| (d)   | ) Seri           | al outp        | out leve       | el regis                                                     | ter m (                        | SOLm)               | Sets          | only th                                    | ne bits      | of the t   | target c              | hannel             |         |                                   |                                         |               |
|       | 15               | 14             | 13             | 12                                                           | 11                             | 10                  | 9             | 8                                          | 7            | 6          | 5                     | 4                  | 3       | 2                                 | 1                                       | 0             |
| SOLm  | 0                | 0              | 0              | 0                                                            | 0                              | 0                   | 0             | 0                                          | 0            | 0          | 0                     | 0                  | 0       | 0                                 | 0                                       | SOLm0<br>0/1  |
| -     |                  |                |                |                                                              |                                |                     |               |                                            |              |            | rse (norm<br>ransmiss | ial) transi<br>ion | mission |                                   |                                         |               |
|       | Note 1<br>Note 2 | 2. V<br>d      |                | rforming                                                     |                                | CR00 reg<br>communi |               |                                            |              |            |                       | Ũ                  |         | specify                           | the trans                               | smission      |
|       | Remar            | <b>rk 1.</b> m | n: Unit n      | umber (                                                      | (m = 0),                       | n: Char             | nnel nur      | nber (n                                    | = 0), q:     | UART ı     | number                | (q = 0),           | mn = 0  | 0                                 |                                         |               |
|       | Remar            | rk 2.          | : Setti        | ng is fix                                                    | ed in th                       | e UART              | transm        | ission n                                   | node         |            |                       |                    |         |                                   |                                         |               |
|       |                  | Ē              | : Settir       |                                                              |                                |                     |               |                                            |              |            |                       |                    |         |                                   |                                         |               |



| (e)  | Ser  | ial outp | out regi  | ster m   | (SOm)    | Sets       | only th    | ne bits    | of the t   | arget c                | hanne   |          |          |       |            |                             |
|------|------|----------|-----------|----------|----------|------------|------------|------------|------------|------------------------|---------|----------|----------|-------|------------|-----------------------------|
| _    | 15   | 14       | 13        | 12       | 11       | 10         | 9          | 8          | 7          | 6                      | 5       | 4        | 3        | 2     | 1          | 0                           |
| SOm  | 0    | 0        | 0         | 0        | 0        | 0          | CKOm1<br>× | CKOm0<br>× | 0          | 0                      | 0       | 0        | 0        | 0     | SOm1<br>×  | SOm0<br>0/1 <sup>Note</sup> |
|      |      |          |           |          |          |            |            |            |            | 0: Serial<br>1: Serial |         |          |          |       |            |                             |
| (f)  | Ser  | ial outp | out ena   | ble reg  | ister m  | (SOE       | m) Se      | ets only   | / the bi   | ts of th               | e targe | t chanr  | nel to 1 | •     |            |                             |
| _    | 15   | 14       | 13        | 12       | 11       | 10         | 9          | 8          | 7          | 6                      | 5       | 4        | 3        | 2     | 1          | 0                           |
| SOEm | 0    | 0        | 0         | 0        | 0        | 0          | 0          | 0          | 0          | 0                      | 0       | 0        | 0        | 0     | SOEm1<br>× | SOEm0<br>0/1                |
| (g)  | Ser  | ial cha  | nnel sta  | art regi | ster m   | (SSm)      | Sets       | only th    | ne bits (  | of the ta              | arget c | hannel   | to 1.    |       |            |                             |
|      | 15   | 14       | 13        | 12       | 11       | 10         | 9          | 8          | 7          | 6                      | 5       | 4        | 3        | 2     | 1          | 0                           |
| SSm  | 0    | 0        | 0         | 0        | 0        | 0          | 0          | 0          | 0          | 0                      | 0       | 0        | 0        | 0     | SSm1<br>×  | SSm0<br>0/1                 |
|      | Note | S        | et to 0   | when t   | he SOL   | _mn bit    |            | target     | channe     |                        |         |          | 0        |       |            | o 0, and<br>on the          |
|      | Rema | ark 1. m | n: Unit n | umber (  | m = 0),  | n: Char    | nnel nun   | nber (n    | = 0), q:   | UART n                 | umber   | (q = 0), | mn = 00  | )     |            |                             |
|      | Rema | ark 2. 🗌 | : Settir  | ng disab | led (set | t to the i | nitial va  | lue)       |            |                        |         |          |          |       |            |                             |
|      |      | ×        | : Bit tha | t cannot | t be use | d in this  | mode (     | (set to th | ne initial | value v                | vhen no | t used i | n any m  | iode) |            |                             |

Figure 11 - 78 Example of Contents of Registers for UART Transmission of UART (UART0) (2/2)

0/1: Set to 0 or 1 depending on the usage of the user

# R19UH0112EJ0100 Rev.1.00

Mar 29, 2019



#### (2) Operation procedure

| Starting initial setting              |                                                                                                                                                                  |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Setting the PER0 register             | Release the serial array unit from the reset status and start clock supply.                                                                                      |
| Setting the SPSm register             | Set the operation clock.                                                                                                                                         |
| Setting the SMRmn register            | Set an operation mode, etc.                                                                                                                                      |
| Setting the SCRmn register            | Set a communication format.                                                                                                                                      |
| Setting the SDRmn register            | Set a transfer baud rate (setting the transfer clock by dividing the operation clock (fмск)).                                                                    |
| Changing setting of the SOLm register | Set an output data level.                                                                                                                                        |
| Setting the SOm register              | Set the initial output level of the serial data (SOmn).                                                                                                          |
| Changing setting of the SOEm register | Set the SOEmn bit to 1 and enable data output of the target channel.                                                                                             |
| Setting port                          | Enable data output of the target channel by setting a port register and a port mode register.                                                                    |
| Writing to the SSm register           | Set the SSmn bit of the target channel to 1 and set the SEmn bit to 1 (to enable operation).                                                                     |
| Completing initial setting            | Initial setting is completed.<br>Set transmit data to the SDRmn [7:0] bits (TXDq register)<br>(8 bits) or the SDRmn [8:0] bits (9 bits) and start communication. |

#### Figure 11 - 79 Initial Setting Procedure for UART Transmission





If there is any data being transferred, wait for their completion. (If there is an urgent must stop, do not wait.)

Write 1 to the STmn bit of the target channel. (SEmn = 0: to operation stop status)

Set the SOEmn bit to 0 and stop the output of the target channel.

The levels of the serial data (SOmn) on the target channel can be changed if necessitated by an emergency.

Reset the serial array unit by stopping the clock supply to it.

After the stop setting is completed, go to the next processing.





#### Figure 11 - 81 Procedure for Resuming UART Transmission

**Remark** If PER0 is rewritten while stopping the master transmission and the clock supply is stopped, wait until the transmission target stops or transmission finishes, and then perform initialization instead of restarting the transmission.



(3) Processing flow (in single-transmission mode)





**Remark** m: Unit number (m = 0), n: Channel number (n = 0), q: UART number (q = 0), mn = 00









(4) Processing flow (in continuous transmission mode)



#### Figure 11 - 84 Timing Chart of UART Transmission (in Continuous Transmission Mode)

- **Note** If transmit data is written to the SDRmn register while the BFFmn bit of serial status register mn (SSRmn) is 1 (valid data is stored in serial data register mn (SDRmn)), the transmit data is overwritten.
- Caution The MDmn0 bit of serial mode register mn (SSRmn) can be rewritten even during operation. However, rewrite it before transfer of the last bit is started, so that it will be rewritten before the transfer end interrupt of the last transmit data.

Remark 1. m: Unit number (m = 0), n: Channel number (n = 0), q: UART number (q = 0), mn = 00





#### Figure 11 - 85 Flowchart of UART Transmission (in Continuous Transmission Mode)

**Remark** <1> to <6> in the figure correspond to <1> to <6> in Figure 11 - 84 Timing Chart of UART Transmission (in Continuous Transmission Mode).

RENESAS

# 11.6.2 UART reception

UART reception is an operation wherein the R9A02G015 microcontroller asynchronously receives data from another device (start-stop synchronization).

For UART reception, the odd-number channel of the two channels used for UART is used. The SMR register of both the odd- and even-numbered channels must be set.

| UART                 | UART0                                                                                                                                                                                            |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Target channel       | Channel 1 of SAU0                                                                                                                                                                                |
| Pins used            | RxD0                                                                                                                                                                                             |
| Interrupt            | INTSR0                                                                                                                                                                                           |
|                      | Transfer end interrupt only (Setting the buffer empty interrupt is prohibited.)                                                                                                                  |
| Error interrupt      | INTSRE0                                                                                                                                                                                          |
| Error detection flag | <ul> <li>Framing error detection flag (FEFmn)</li> <li>Parity error detection flag (PEFmn)</li> <li>Overrun error detection flag (OVFmn)</li> </ul>                                              |
| Transfer data length | 7, 8 or 9 bits Note 1                                                                                                                                                                            |
| Transfer rate Note 2 | Max. fмск/6 [bps] (SDRmn [15:9] = 2 or more), Min. fcLк/(2 × 2 <sup>15</sup> × 128) [bps]                                                                                                        |
| Data phase           | Non-reverse output (default: high level)<br>Reverse output (default: low level)                                                                                                                  |
| Parity bit           | <ul> <li>The following selectable</li> <li>No parity bit (no parity check)</li> <li>Appending 0 parity (no parity check)</li> <li>Appending even parity</li> <li>Appending odd parity</li> </ul> |
| Stop bit             | Appending 1 bit                                                                                                                                                                                  |
| Data direction       | MSB or LSB first                                                                                                                                                                                 |

**Note 1.** Only the following UARTs can be specified for the 9-bit data length.

• UART0

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)). For UART reception, use the high-speed system clock or high-speed on-chip oscillator.

Remark 1. fMCK: Operation clock frequency of target channel fCLK: System clock frequency

Remark 2. m: Unit number (m = 0), n: Channel number (n = 1), mn = 01



(1) Register setting

### Figure 11 - 86 Example of Contents of Registers for UART Reception of UART (UART0) (1/2)





| Figure 11 - 87 Example of Contents of Registers for UART Reception of UART (UART0) (2/2) |    |    |    |    |    |    |            |            |   |   |   |   |   |   |             |            |
|------------------------------------------------------------------------------------------|----|----|----|----|----|----|------------|------------|---|---|---|---|---|---|-------------|------------|
| (e) Serial output register m (SOm) The register that not used in this mode.              |    |    |    |    |    |    |            |            |   |   |   |   |   |   |             |            |
|                                                                                          | 15 | 14 | 13 | 12 | 11 | 10 | 9          | 8          | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0          |
| SOm                                                                                      | 0  | 0  | 0  | 0  | 0  | 0  | CKOm1<br>× | CKOm0<br>× | 0 | 0 | 0 | 0 | 0 | 0 | SOm1<br>×   | SOm0<br>×  |
| (f) Serial output enable register m (SOEm) The register that not used in this mode.      |    |    |    |    |    |    |            |            |   |   |   |   |   |   |             |            |
| _                                                                                        | 15 | 14 | 13 | 12 | 11 | 10 | 9          | 8          | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0          |
| SOEm                                                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0          | 0 | 0 | 0 | 0 | 0 | 0 | SOEm1<br>×  | SOEm0<br>× |
| (g) Serial channel start register m (SSm) Sets only the bits of the target channel is 1. |    |    |    |    |    |    |            |            |   |   |   |   |   |   |             |            |
| _                                                                                        | 15 | 14 | 13 | 12 | 11 | 10 | 9          | 8          | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0          |
| SSm                                                                                      | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0          | 0 | 0 | 0 | 0 | 0 | 0 | SSm1<br>0/1 | SSm0<br>×  |
| <b>Remark 1.</b> m: Unit number (m = 0)                                                  |    |    |    |    |    |    |            |            |   |   |   |   |   |   |             |            |
| Remark 2: Setting disabled (set to the initial value)                                    |    |    |    |    |    |    |            |            |   |   |   |   |   |   |             |            |

×: Bit that cannot be used in this mode (set to the initial value when not used in any mode)

 $0/1 {\rm :} \ {\rm Set} \ {\rm to} \ 0 \ {\rm or} \ 1 \ {\rm depending} \ {\rm on} \ {\rm the} \ {\rm usage} \ {\rm of} \ {\rm the} \ {\rm usar}$ 



#### (2) Operation procedure



#### Figure 11 - 88 Initial Setting Procedure for UART Reception

# Caution Set the RXEmn bit of SCRmn register to 1, and then be sure to set SSmn to 1 after 4 or more fmck clocks have elapsed.









#### Figure 11 - 90 Procedure for Resuming UART Reception

#### Caution After is set RXEmn bit to 1 of SCRmn register, set the SSmn = 1 from an interval of at least four clocks of fmck.

**Remark** If PER0 is rewritten while stopping the communication target and the clock supply is stopped, wait until the communication target stops or communication finishes, and then perform initialization instead of restarting the communication.



(3) Processing flow

| SSmn _           | Γ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STmn_            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SEmn _           | Receive data 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SDRmn            | Receive data 1     Receive data 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RxDq pin Shift - | ST/ Receive data 1 X P/SP ST/ Receive data 2 X P/SP ST/ Receive data 3 X P/SP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| - register mn    | X         Shift operation         X         Shift operation |
| INTSRq           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                  | Data reception Data reception Data reception                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TSFmn_           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Figure 11 - 91 Timing Chart of UART Reception

Remark m: Unit number (m = 0), n: Channel number (n = 1), mn = 01, r: Channel number (r = n - 1), q: UART number (q = 0)





Figure 11 - 92 Flowchart of UART Reception



# 11.6.3 SNOOZE mode function

The SNOOZE mode makes the UART perform reception operations upon RxDq pin input detection while in the STOP mode. Normally the UART stops communication in the STOP mode. However, using the SNOOZE mode enables the UART to perform reception operations without CPU operation. Only the following UART can be specified.

• UART0

When using UARTq in the SNOOZE mode, make the following settings before entering the STOP mode (See **Figures 11 - 95** and **11 - 97** Flowchart of SNOOZE Mode Operation).

- In the SNOOZE mode, the baud rate setting for UART reception needs to be changed to a value different from that in normal operation. Set the SPSm register and bits 15 to 9 of the SDRmn register with reference to Table 11 3.
- Set the EOCmn and SSECmn bits. This is for enabling or stopping generation of an error interrupt (INTSRE0) when a communication error occurs.
- When using the SNOOZE mode function, set the SWCm bit of serial standby control register m (SSCm) to 1 just before switching to the STOP mode. After the initial setting has completed, set the SSm1 bit of serial channel start register m (SSm) to 1.

A UARTq starts reception in SNOOZE mode on detecting input of the start bit on the RxDq pin following a transition of the CPU to the STOP mode.

Caution 1. SNOOZE mode can be used only when the high-speed on-chip oscillator clock (fiH) is selected as fcLK.

Caution 2. The transfer rate in the SNOOZE mode is only 4800 bps.

- Caution 3. When SWCm = 1, UARTq can be used only when the reception operation is started in the STOP mode. When used simultaneously with another SNOOZE mode function or interrupt, if the reception operation is started in a state other than the STOP mode, such as those given below, data may not be received correctly and a framing error or parity error may be generated.
  - When after the SWCm bit has been set to 1, the reception operation is started before the STOP mode is entered
  - When the reception operation is started while another function is in the SNOOZE mode
  - When after returning from the STOP mode to normal operation due to an interrupt or other cause, the reception operation is started before the SWCm bit is returned to 0
- Caution 4. If a parity error, framing error, or overrun error occurs while the SSECm bit is set to 1, the PEFmn, FEFmn, or OVFmn flag is not set and an error interrupt (INTSREq) is not generated. Therefore, when the setting of SSECm = 1 is made, clear the PEFmn, FEFmn, or OVFmn flag before setting the SWC0 bit to 1 and read the value in bits 7 to 0 (RxDq register) of the SDRm1 register.
- Caution 5. When using UART reception to transition from STOP mode to SNOOZE mode, use the highspeed on-chip oscillator.



|                               | Baud Rate for UART Reception in SNOOZE Mode |              |                              |                              |  |  |  |  |  |
|-------------------------------|---------------------------------------------|--------------|------------------------------|------------------------------|--|--|--|--|--|
| High-speed On-chip            | Baud Rate of 4800 bps                       |              |                              |                              |  |  |  |  |  |
| Oscillator (fiн)              | Operation Clock<br>(fмск)                   | SDRmn [15:9] | Maximum Permissible<br>Value | Minimum Permissible<br>Value |  |  |  |  |  |
| 24 MHz ± 1.0% <sup>Note</sup> | fclк/2 <sup>5</sup>                         | 79           | 1.60%                        | -2.18%                       |  |  |  |  |  |
| 16 MHz ± 1.0% <sup>Note</sup> | fclк/2 <sup>4</sup>                         | 105          | 2.27%                        | -1.53%                       |  |  |  |  |  |
| 12 MHz ± 1.0% <sup>Note</sup> | fclk/24                                     | 79           | 1.60%                        | -2.19%                       |  |  |  |  |  |
| 8 MHz ± 1.0% <sup>Note</sup>  | fськ/2 <sup>3</sup>                         | 105          | 2.27%                        | -1.53%                       |  |  |  |  |  |
| 6 MHz ± 1.0% <sup>Note</sup>  | fclк/2 <sup>3</sup>                         | 79           | 1.60%                        | -2.19%                       |  |  |  |  |  |
| 4 MHz ± 1.0% <sup>Note</sup>  | fclк/2 <sup>2</sup>                         | 105          | 2.27%                        | -1.53%                       |  |  |  |  |  |
| 3 MHz ± 1.0% <sup>Note</sup>  | fclк/2 <sup>2</sup>                         | 79           | 1.60%                        | -2.19%                       |  |  |  |  |  |
| 2 MHz ± 1.0% <sup>Note</sup>  | fcLк/2                                      | 105          | 2.27%                        | -1.54%                       |  |  |  |  |  |
| 1 MHz ± 1.0% <sup>Note</sup>  | fclk                                        | 105          | 2.27%                        | -1.57%                       |  |  |  |  |  |

### Table 11 - 3 Baud Rate Setting for UART Reception in SNOOZE Mode

**Note** When the accuracy of the clock frequency of the high-speed on-chip oscillator is ±1.5% or ±2.0%, the permissible range becomes smaller as shown below.

• In the case of fiH  $\pm$  1.5%, perform (Maximum permissible value - 0.5%) and (Minimum permissible value + 0.5%) to the values in the above table.

• In the case of fiH ± 2.0%, perform (Maximum permissible value - 1.0%) and (Minimum permissible value + 1.0%) to the values in the above table.

**Remark** The maximum permissible value and minimum permissible value are permissible values for the baud rate in UART reception. The baud rate on the transmitting side should be set to fall inside this range.



(1) SNOOZE mode operation (EOCm1 = 0, SSECm = 0/1)

Because of the setting of EOCm1 = 0, even though a communication error occurs, an error interrupt (INTSREq) is not generated, regardless of the setting of the SSECm bit. A transfer end interrupt (INTSRq) will be generated.

| PU operation status Normal operation STOP mode |     | SNOOZE m | Normal operation                 |                |           |                   |        |                 |              |
|------------------------------------------------|-----|----------|----------------------------------|----------------|-----------|-------------------|--------|-----------------|--------------|
| SS01                                           | <3> | <4>      |                                  |                | <         | :12>              |        |                 |              |
| ST01                                           | <1> |          |                                  |                | <10>      |                   |        |                 |              |
| SE01                                           |     |          |                                  |                |           |                   |        |                 |              |
| SWC0                                           |     |          |                                  |                | <11>      |                   |        |                 |              |
| EOC01                                          | L   |          |                                  |                |           |                   |        |                 |              |
| SSEC0                                          | L   |          |                                  |                |           |                   |        |                 |              |
| Clock request signal<br>(internal signal)      |     |          |                                  |                |           |                   |        |                 |              |
| (internal signal)                              |     |          |                                  |                |           |                   |        | Recei           | ive data 2 _ |
| SDR01                                          |     |          |                                  |                | X         |                   | Receiv | /e data 1       |              |
|                                                |     |          |                                  |                | <9> ▲ Rea | d <sup>Note</sup> |        |                 |              |
| RxD0 pin                                       |     |          | ST/ Receive data                 | <u>1 Хр</u> /ś | ŠP        |                   | \st/   | Receive data 2  | <u> </u>     |
| Shift register 01                              |     |          | XXShift operation                | x_x            |           |                   | ±x     | Shift operation | χ            |
| INTSR0                                         |     |          |                                  |                | 1         |                   |        |                 | h            |
| INTSRE0                                        | L   |          | <ul> <li>Receive data</li> </ul> | a <7>          |           |                   | -      | Receive data    |              |
| TSF01                                          |     |          | <6>                              |                |           |                   |        |                 |              |
|                                                | <2> | <        | 5>                               | <br> >         | 3>        |                   |        |                 |              |

#### Figure 11 - 93 Timing Chart of SNOOZE Mode Operation (EOCm1 = 0, SSECm = 0/1)

Note Read the received data when SWCm is 1.

Caution Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the STm1 bit to 1 (clear the SEm1 bit, and stop the operation). And after completion the receive operation, also clearing SWCm bit to 0 (SNOOZE mode release).

Remark 1. <1> to <12> in the figure correspond to <1> to <12> in Figure 11 - 95 Flowchart of SNOOZE Mode Operation (EOCm1 = 0, SSECm = 0/1 or EOCm1 = 1, SSECm = 0).

**Remark 2.** m = 0; q = 0



(2) SNOOZE mode operation (EOCm1 = 1, SSECm = 0: Error interrupt (INTSREq) generation is enabled) Because EOCm1 = 1 and SSECm = 0, an error interrupt (INTSREq) is generated when a communication error occurs.



Figure 11 - 94 Timing Chart of SNOOZE Mode Operation (EOCm1 = 1, SSECm = 0)

**Note** Read the received data when SWCm = 1.

Caution Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the STm1 bit to 1 (clear the SEm1 bit, and stop the operation).
 And after completion the receive operation, also clearing SWCm bit to 0 (SNOOZE mode release).

**Remark 1.** <1> to <12> in the figure correspond to <1> to <12> in Figure 11 - 95 Flowchart of SNOOZE Mode Operation (EOCm1 = 0, SSECm = 0/1 or EOCm1 = 1, SSECm = 0).

**Remark 2.** m = 0; q = 0





### Figure 11 - 95 Flowchart of SNOOZE Mode Operation (EOCm1 = 0, SSECm = 0/1 or EOCm1 = 1, SSECm = 0)

Remark 1. <1> to <12> in the figure correspond to <1> to <12> in Figure 11 - 93 Timing Chart of SNOOZE Mode Operation (EOCm1 = 0, SSECm = 0/1) and Figure 11 - 94 Timing Chart of SNOOZE Mode Operation (EOCm1 = 1, SSECm = 0).
 Remark 2. m = 0; q = 0

(3) SNOOZE mode operation (EOCm1 = 1, SSECm = 1: Error interrupt (INTSREq) generation is stopped) Because EOCm1 = 1 and SSECm = 1, an error interrupt (INTSREq) is not generated when a communication error occurs.



Figure 11 - 96 Timing Chart of SNOOZE Mode Operation (EOCm1 = 1, SSECm = 1)

**Note** Only read received data while SWCm = 1.

Caution 1. Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the STm1 bit to 1 (clear the SEm1 bit, and stop the operation).

And after completion the receive operation, also clearing SWCm bit to 0 (SNOOZE mode release).

- Caution 2. If a parity error, framing error, or overrun error occurs while the SSECm bit is set to 1, the PEFm1, FEFm1, or OVFm1 flag is not set and an error interrupt (INTSREq) is not generated. Therefore, when the setting of SSECm = 1 is made, clear the PEFm1, FEFm1, or OVFm1 flag before setting the SWCm bit to 1 and read the value in SDRm1[7:0] (RxDq register) (8 bits) or SDRm1[8:0] (9 bits).
- Remark 1. <1> to <11> in the figure correspond to <1> to <11> in Figure 11 97 Flowchart of SNOOZE Mode Operation (EOCm1 = 1, SSECm = 1).

**Remark 2.** m = 0; q = 0







(Caution and Remarks are listed on the next page.)



- Caution If a parity error, framing error, or overrun error occurs while the SSECm bit is set to 1, the PEFm1, FEFm1, or OVFm1 flag is not set and an error interrupt (INTSREq) is not generated. Therefore, when the setting of SSECm = 1 is made, clear the PEFm1, FEFm1, or OVFm1 flag before setting the SWCm bit to 1 and read the value in SDRm1[7:0] (RxDq register) (8 bits) or SDRm1[8:0] (9 bits).
- **Remark 1.** <1> to <11> in the figure correspond to <1> to <11> in Figure 11 96 Timing Chart of SNOOZE Mode Operation (EOCm1 = 1, SSECm = 1).

Remark 2. m = 0; q = 0



## 11.6.4 Calculating baud rate

Baud rate calculation expression
 The baud rate for UART (UART0 to UART3) communication can be calculated by the following expressions.

(Baud rate) = {Operation clock (fMCK) frequency of target channel} ÷ (SDRmn[15:9] + 1) ÷ 2 [bps]

#### Caution Setting serial data register mn (SDRmn) SDRmn[15:9] = (0000000B, 0000001B) is prohibited.

**Remark 1.** When UART is used, the value of SDRmn[15:9] is the value of bits 15 to 9 of the SDRmn register (0000010B to 111111B) and therefore is 2 to 127.

**Remark 2.** m: Unit number (m = 0), n: Channel number (n = 1), mn = 01

The operation clock (fMCK) is determined by serial clock select register m (SPSm) and bit 15 (CKSmn) of serial mode register mn (SMRmn).



| SMRmn<br>Register |            |            |            | Operation C | Operation Clock (fMCK) Note |            |            |            |                      |               |
|-------------------|------------|------------|------------|-------------|-----------------------------|------------|------------|------------|----------------------|---------------|
| CKSmn             | PRS<br>m13 | PRS<br>m12 | PRS<br>m11 | PRS<br>m10  | PRS<br>m03                  | PRS<br>m02 | PRS<br>m01 | PRS<br>m00 |                      | fclk = 24 MHz |
| 0                 | ×          | ×          | ×          | ×           | 0                           | 0          | 0          | 0          | fclк                 | 24 MHz        |
|                   | ×          | ×          | ×          | ×           | 0                           | 0          | 0          | 1          | fclk/2               | 12 MHz        |
|                   | ×          | ×          | ×          | ×           | 0                           | 0          | 1          | 0          | fcLк/2 <sup>2</sup>  | 6 MHz         |
|                   | ×          | ×          | ×          | ×           | 0                           | 0          | 1          | 1          | fcLк/2 <sup>3</sup>  | 3 MHz         |
|                   | ×          | ×          | ×          | ×           | 0                           | 1          | 0          | 0          | fclk/2 <sup>4</sup>  | 1.5 MHz       |
|                   | ×          | ×          | ×          | ×           | 0                           | 1          | 0          | 1          | fclк/2 <sup>5</sup>  | 750 kHz       |
|                   | ×          | ×          | ×          | ×           | 0                           | 1          | 1          | 0          | fclк/2 <sup>6</sup>  | 375 kHz       |
|                   | ×          | ×          | ×          | ×           | 0                           | 1          | 1          | 1          | fcLк/2 <sup>7</sup>  | 187.5 kHz     |
|                   | ×          | ×          | ×          | ×           | 1                           | 0          | 0          | 0          | fclк/2 <sup>8</sup>  | 93.8 kHz      |
|                   | ×          | ×          | ×          | ×           | 1                           | 0          | 0          | 1          | fcLк/2 <sup>9</sup>  | 46.9 kHz      |
|                   | ×          | ×          | ×          | ×           | 1                           | 0          | 1          | 0          | fclk/2 <sup>10</sup> | 23.4 kHz      |
|                   | ×          | ×          | ×          | ×           | 1                           | 0          | 1          | 1          | fclк/2 <sup>11</sup> | 11.7 kHz      |
|                   | ×          | ×          | ×          | ×           | 1                           | 1          | 0          | 0          | fclk/2 <sup>12</sup> | 5.86 kHz      |
|                   | ×          | ×          | ×          | ×           | 1                           | 1          | 0          | 1          | fclк/2 <sup>13</sup> | 2.93 kHz      |
|                   | ×          | ×          | ×          | ×           | 1                           | 1          | 1          | 0          | fclк/2 <sup>14</sup> | 1.46 kHz      |
|                   | ×          | ×          | ×          | ×           | 1                           | 1          | 1          | 1          | fclк/2 <sup>15</sup> | 732 Hz        |
| 1                 | 0          | 0          | 0          | 0           | ×                           | ×          | ×          | ×          | fclk                 | 24 MHz        |
|                   | 0          | 0          | 0          | 1           | ×                           | ×          | ×          | ×          | fclk/2               | 12 MHz        |
|                   | 0          | 0          | 1          | 0           | ×                           | ×          | ×          | ×          | fclк/2 <sup>2</sup>  | 6 MHz         |
|                   | 0          | 0          | 1          | 1           | ×                           | ×          | ×          | ×          | fcLк/2 <sup>3</sup>  | 3 MHz         |
|                   | 0          | 1          | 0          | 0           | ×                           | ×          | ×          | ×          | fclk/24              | 1.5 MHz       |
|                   | 0          | 1          | 0          | 1           | ×                           | ×          | ×          | ×          | fcLк/2 <sup>5</sup>  | 750 kHz       |
|                   | 0          | 1          | 1          | 0           | ×                           | ×          | ×          | ×          | fcLк/2 <sup>6</sup>  | 375 kHz       |
|                   | 0          | 1          | 1          | 1           | ×                           | ×          | ×          | ×          | fcLк/2 <sup>7</sup>  | 187.5 kHz     |
|                   | 1          | 0          | 0          | 0           | ×                           | ×          | ×          | ×          | fcLк/2 <sup>8</sup>  | 93.8 kHz      |
|                   | 1          | 0          | 0          | 1           | ×                           | ×          | ×          | ×          | fcLк/2 <sup>9</sup>  | 46.9 kHz      |
|                   | 1          | 0          | 1          | 0           | ×                           | ×          | ×          | ×          | fclk/2 <sup>10</sup> | 23.4 kHz      |
|                   | 1          | 0          | 1          | 1           | ×                           | ×          | ×          | ×          | fclк/2 <sup>11</sup> | 11.7 kHz      |
|                   | 1          | 1          | 0          | 0           | ×                           | ×          | ×          | ×          | fclk/2 <sup>12</sup> | 5.86 kHz      |
|                   | 1          | 1          | 0          | 1           | ×                           | ×          | ×          | ×          | fclк/2 <sup>13</sup> | 2.93 kHz      |
|                   | 1          | 1          | 1          | 0           | ×                           | ×          | ×          | ×          | fclk/2 <sup>14</sup> | 1.46 kHz      |
|                   | 1          | 1          | 1          | 1           | ×                           | ×          | ×          | ×          | fclk/2 <sup>15</sup> | 732 Hz        |

**Note** When changing the clock selected for fcLK (by changing the system clock control register (CKC) value), do so after having stopped (serial channel stop register m (STm) = 000FH) the operation of the serial array unit (SAU).

Remark 1. ×: Don't care

Remark 2. m: Unit number (m = 0), n: Channel number (n = 1), mn = 01

## (2) Baud rate error during transmission

The baud rate error of UART (UART0) communication during transmission can be calculated by the following expression. Make sure that the baud rate at the transmission side is within the permissible baud rate range at the reception side.

(Baud rate error) = (Calculated baud rate value) ÷ (Target baud rate) × 100 - 100 [%]

|                    | Inple of setting a OAICI |             |                      |                             |
|--------------------|--------------------------|-------------|----------------------|-----------------------------|
| UART Baud Rate     |                          | fc          | ικ <b>= 24 MHz</b>   |                             |
| (Target Baud Rate) | Operation Clock (fмск)   | SDRmn[15:9] | Calculated Baud Rate | Error from Target Baud Rate |
| 300 bps            | fськ/2 <sup>9</sup>      | 77          | 300.48 bps           | +0.16%                      |
| 600 bps            | fclк/2 <sup>8</sup>      | 77          | 600.96 bps           | +0.16%                      |
| 1200 bps           | fclк/2 <sup>7</sup>      | 77          | 1201.92 bps          | +0.16%                      |
| 2400 bps           | fclк/2 <sup>6</sup>      | 77          | 2403.85 bps          | +0.16%                      |
| 4800 bps           | fclк/2 <sup>5</sup>      | 77          | 4807.69 bps          | +0.16%                      |
| 9600 bps           | fclk/2 <sup>4</sup>      | 77          | 9615.38 bps          | +0.16%                      |
| 19200 bps          | fclк/2 <sup>3</sup>      | 77          | 19230.8 bps          | +0.16%                      |
| 31250 bps          | fclк/2 <sup>3</sup>      | 47          | 31250.0 bps          | ±0.0%                       |
| 38400 bps          | fclk/2 <sup>2</sup>      | 77          | 38461.5 bps          | +0.16%                      |
| 76800 bps          | fclk/2                   | 77          | 76923.1 bps          | +0.16%                      |
| 153600 bps         | fclk                     | 77          | 153846 bps           | +0.16%                      |
| 312500 bps         | fclk                     | 37          | 315789 bps           | ±1.05%                      |

Here is an example of setting a UART baud rate at fCLK = 24 MHz.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0), mn = 00



(3) Permissible baud rate range for reception

The permissible baud rate range for reception during UART (UART0) communication can be calculated by the following expression. Make sure that the baud rate at the transmission side is within the permissible baud rate range at the reception side.

(Maximum receivable baud rate) = 
$$\frac{2 \times k \times Nfr}{2 \times k \times Nfr - k + 2} \times Brate$$

(Minimum receivable baud rate) =  $\frac{2 \times k \times (Nfr - 1)}{2 \times k \times Nfr - k - 2} \times Brate$ 

Brate: Calculated baud rate value at the reception side (See 11.6.4 (1) Baud rate calculation expression.)

k: SDRmn[15:9] + 1

- Nfr: 1 data frame length [bits]
  - = (Start bit) + (Data length) + (Parity bit) + (Stop bit)

**Remark** m: Unit number (m = 0, 1), n: Channel number (n = 1), mn = 01





As shown in Figure 11 - 98, the timing of latching receive data is determined by the division ratio set by bits 15 to 9 of serial data register mn (SDRmn) after the start bit is detected. If the last data (stop bit) is received before this latch timing, the data can be correctly received.



# 11.6.5 Procedure for processing errors that occurred during UART (UART0) communication

The procedure for processing errors that occurred during UART (UART0) communication is described in Figures 11 - 99 and 11 - 100.

| Software Manipulation                         | Hardware Status                                                                           | Remark                                                                                                                                           |  |  |  |
|-----------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Reads serial data register mn ————<br>(SDRmn) | The BFFmn bit of the SSRmn register is set to 0 and channel n is enabled to receive data. | This is to prevent an overrun error if the next reception is completed during error processing.                                                  |  |  |  |
| Reads serial status register mn (SSRmn).      |                                                                                           | Error type is identified and the read value is used to clear error flag.                                                                         |  |  |  |
| Writes 1 to serial flag clear trigger ———     | Error flag is cleared.                                                                    | Error can be cleared only during reading,<br>by writing the value read from the SSRmn<br>register to the SIRmn register without<br>modification. |  |  |  |

#### Figure 11 - 99 Processing Procedure in Case of Parity Error or Overrun Error

#### Figure 11 - 100 Processing Procedure in Case of Framing Error

| Software Manipulation                                             | Hardware Status                                                                                          | Remark                                                                                                                                                                                                                 |
|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reads serial data register mn ————<br>(SDRmn).                    | The BFFmn bit of the SSRmn register is set to 0 and channel n is enabled to receive data.                | This is to prevent an overrun error if the next reception is completed during error processing.                                                                                                                        |
| Reads serial status register mn (SSRmn).                          |                                                                                                          | Error type is identified and the read value is used to clear error flag.                                                                                                                                               |
| Writes serial flag clear trigger register mn <b>→</b><br>(SIRmn). | Error flag is cleared.                                                                                   | Error can be cleared only during reading,<br>by writing the value read from the SSRmn<br>register to the SIRmn register without<br>modification.                                                                       |
| Sets the STmn bit of serial channel stop → register m (STm) to 1. | The SEmn bit of serial channel enable status register m (SEm) is set to 0 and channel n stops operating. |                                                                                                                                                                                                                        |
| Synchronization with other party of communication                 |                                                                                                          | Synchronization with the other party of<br>communication is re-established and<br>communication is resumed because it is<br>considered that a framing error has<br>occurred because the start bit has been<br>shifted. |
| Sets the SSmn bit of serial channel start -                       | The SEmn bit of serial channel enable                                                                    |                                                                                                                                                                                                                        |
| register m (SSm) to 1.                                            | status register m (SEm) is set to 1 and channel n is enabled to operate.                                 |                                                                                                                                                                                                                        |

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



# 11.7 Operation of Simplified I<sup>2</sup>C (IIC00, IIC01) Communication

This is a clocked communication function to communicate with two or more devices by using two lines: serial clock (SCL) and serial data (SDA). This communication function is designed to execute single communication with devices such as EEPROM, flash memory, and A/D converter, and therefore, can be used only by the master.

Make sure by using software, as well as operating the control registers, that the AC specifications of the start and stop conditions are observed.

[Data transmission/reception]

- Master transmission, master reception (only master function with a single master)
- ACK output function Note and ACK detection function
- Data length of 8 bits

(When an address is transmitted, the address is specified by the higher 7 bits, and the least significant bit is used for R/W control.)

· Generation of start condition and stop condition for software

[Interrupt function]

Transfer end interrupt

[Error detection flag]

- Overrun error
- ACK error
- \* [Functions not supported by simplified I<sup>2</sup>C]
- Slave transmission, slave reception
- Multi-master function (arbitration loss detection function)
- Wait detection function
- **Note** When receiving the last data, ACK will not be output if 0 is written to the SOEmn (SOEm register) bit and serial communication data output is stopped. See the processing flow in **11.7.3 (2)** for details.

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



The channel supporting simplified  $I^{2}C$  (IIC00, IIC01) is channels 0 and 1 of SAU0.

• 32-pin products

| Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C |
|------|---------|-------------|--------------|-------------------------------------|
| 0    | 0       | CSI00       | UART0        | IIC00                               |
|      | 1       | CSI01       | OANTO        | IIC01                               |

Simplified I<sup>2</sup>C (IIC00, IIC01) performs the following four types of communication operations.

- Address field transmission (See 11.7.1.)
- • Data transmission
   (See 11.7.2.)

   • Data reception
   (See 11.7.3.)
- Stop condition generation (See **11.7.4**.)



# 11.7.1 Address field transmission

Address field transmission is a transmission operation that first executes in I<sup>2</sup>C communication to identify the target for transfer (slave). After a start condition is generated, an address (7 bits) and a transfer direction (1 bit) are transmitted in one frame.

| Simplified I <sup>2</sup> C | IIC00                                                                                                                                                                                                        | IIC01               |  |  |  |  |  |  |  |  |  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--|--|--|--|--|--|--|--|--|
| Target channel              | Channel 0 of SAU0                                                                                                                                                                                            | Channel 1 of SAU0   |  |  |  |  |  |  |  |  |  |
| Pins used                   | SCL00, SDA00 Note 1                                                                                                                                                                                          | SCL01, SDA01 Note 1 |  |  |  |  |  |  |  |  |  |
| Interrupt                   | INTIIC00                                                                                                                                                                                                     | INTIIC01            |  |  |  |  |  |  |  |  |  |
|                             | Transfer end interrupt only (Setting the buffer empty interrupt is prohibited.)                                                                                                                              |                     |  |  |  |  |  |  |  |  |  |
| Error detection flag        | CK error detection flag (PEFmn)                                                                                                                                                                              |                     |  |  |  |  |  |  |  |  |  |
| Transfer data length        | 8 bits (transmitted with specifying the higher 7 bits as address and the least significant bit as R/W control)                                                                                               |                     |  |  |  |  |  |  |  |  |  |
| Transfer rate Note 2        | Max. fмcк/4 [Hz] (SDRmn[15:9] = 1 or more) fмcк:<br>However, the following condition must be satisfied in e<br>• Max. 1 MHz (fast mode plus)<br>• Max. 400 kHz (fast mode)<br>• Max. 100 kHz (standard mode) |                     |  |  |  |  |  |  |  |  |  |
| Data level                  | Non-reversed output (default: high level)                                                                                                                                                                    |                     |  |  |  |  |  |  |  |  |  |
| Parity bit                  | No parity bit                                                                                                                                                                                                |                     |  |  |  |  |  |  |  |  |  |
| Stop bit                    | Appending 1 bit (for ACK reception timing)                                                                                                                                                                   |                     |  |  |  |  |  |  |  |  |  |
| Data direction              | MSB first                                                                                                                                                                                                    |                     |  |  |  |  |  |  |  |  |  |

Note 1.To perform communication via simplified I2C, set the N-ch open-drain output (VDD tolerance) mode (POMxx = 1) with the<br/>port output mode register (POMxx). For details, see 4.3 Registers Controlling Port Function and 4.5 Register<br/>Settings When Using Alternate Function.

When IIC00 is communicating with an external device with a different potential, set the N-ch open-drain output (VDD tolerance) mode (POMxx = 1) also for the clock input/output pins (SCL00).

For details, see 4.4.4 Handling different potential (1.8 V, 2.5 V) by using I/O buffers.

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



(1) Register setting

## Figure 11 - 101 Example of Contents of Registers for Address Field Transmission of Simplified I<sup>2</sup>C (IIC00, IIC01)

| (a)     | ) Ser                                                                                                 | ial moo        | de regis        | ster mn              | (SMR                  | mn)            |               |                   |                                       |                    |             |             |           |            |              |              |  |  |
|---------|-------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------|-----------------------|----------------|---------------|-------------------|---------------------------------------|--------------------|-------------|-------------|-----------|------------|--------------|--------------|--|--|
|         | 15                                                                                                    | 14             | 13              | 12                   | 11                    | 10             | 9             | 8                 | 7                                     | 6                  | 5           | 4           | 3         | 2          | 1            | 0            |  |  |
| SMRmn   | CKSmn<br>0/1                                                                                          | CCSmn<br>0     | 0               | 0                    | 0                     | 0              | 0             | STSmn<br>0 Note 1 | 0                                     | SISmn0<br>0 Note 1 | 1           | 0           | 0         | MDmn2<br>1 | MDmn1<br>0   | MDmn0<br>0   |  |  |
|         | Operatio                                                                                              | n clock (      | -<br>fмск) of a | channel r            | ı                     |                | -             |                   |                                       |                    | _           |             | Оре       | ration m   | ode of cł    | annel n      |  |  |
|         |                                                                                                       |                | -               | k CKm0<br>k CKm1     | -                     |                | -             |                   |                                       |                    |             |             | 0:        | Transfe    | end inte     | errupt       |  |  |
| /h.)    |                                                                                                       |                |                 |                      | -                     |                | -             |                   |                                       |                    |             |             |           |            |              |              |  |  |
| (b)     | ) Ser<br>15                                                                                           | iai com<br>14  | 13              | alion oj<br>12       | peralio<br>11         | n settin<br>10 | ig regis<br>9 | ster mn<br>8      | (SCRI<br>7                            | mn)<br>6           | 5           | 4           | 3         | 2          | 1            | 0            |  |  |
| SCRmn   | TXEmn                                                                                                 | RXEmn          | DAPmn           | CKPmn                |                       | EOCmn          | 9<br>PTCmn1   | O<br>PTCmn0       | <i>i</i><br>DIRmn                     | 0                  | SLCmn1      | 4<br>SLCmn0 | 5         | 2          | ו<br>DLSmn1  | DLSmn0       |  |  |
| ooranin | 1                                                                                                     | 0              | 0               | 0                    | 0                     | 0              | 0             | 0                 | 0                                     | 0                  | 0 Note 2    | 1           | 0         | 1          | 1            | 1            |  |  |
|         |                                                                                                       |                |                 |                      | ing of pa<br>B: No pa | -              |               |                   |                                       |                    |             |             | Setting o | •          |              | CK)          |  |  |
| ( )     | 00B: No parity 01B: Appending 1 bit (ACK)<br>(c) Serial data register mn (SDRmn) (lower 8 bits: SIOr) |                |                 |                      |                       |                |               |                   |                                       |                    |             |             |           |            |              |              |  |  |
| (c)     |                                                                                                       |                |                 | er mn (<br>12        | SDRm<br>11            |                | er 8 bi<br>9  |                   |                                       | c                  | 5           | 4           | 2         | 2          | 1            | 0            |  |  |
| [       | 15                                                                                                    | 14             | 13              |                      |                       | 10             | 9             | 8                 | 7                                     | 6                  |             | 4           | 3         | 2          |              | 0            |  |  |
| SDRmn   |                                                                                                       |                | Baud            | d rate se            | etting                |                |               | 0                 | Transmit data setting (address + R/W) |                    |             |             |           |            |              |              |  |  |
|         |                                                                                                       |                |                 |                      |                       |                |               |                   | $\subseteq$                           |                    |             | si          | Or        |            |              |              |  |  |
| ( a)    | (d) Serial output register m (SOm)                                                                    |                |                 |                      |                       |                |               |                   |                                       |                    |             |             |           |            |              |              |  |  |
| (d)     | ) Ser<br>15                                                                                           | iai outp<br>14 | 13              | ster m<br>12         | (SOM)<br>11           | 10             | 9             | 8                 | 7                                     | 6                  | 5           | 4           | 3         | 2          | 1            | 0            |  |  |
| SOm     | 15                                                                                                    | 14             | 15              | 12                   |                       | 10             | 5             | 0                 | '                                     |                    | 5           | 4           | 5         | 2          | SOm1         | SOm0         |  |  |
| 3011    | 0                                                                                                     | 0              | 0               | 0                    | 0                     | 0              | 0             | 0                 | 0                                     | 0                  | 0           | 0           | 0         | 0          | 0/1          | 0/1          |  |  |
|         |                                                                                                       |                |                 |                      |                       |                |               |                   |                                       | Start o            | condition   | is genera   | ated by m | anipulat   | ing the S    | Omn bit.     |  |  |
| (e)     | ) Ser                                                                                                 | ial outp       | out ena         | ble reg              | ister m               | (SOE           | m)            |                   |                                       |                    |             |             |           |            |              |              |  |  |
| ſ       | 15                                                                                                    | 14             | 13              | 12                   | 11                    | 10             | 9             | 8                 | 7                                     | 6                  | 5           | 4           | 3         | 2          | 1            | 0            |  |  |
| SOEm    | 0                                                                                                     | 0              | 0               | 0                    | 0                     | 0              | 0             | 0                 | 0                                     | 0                  | 0           | 0           | 0         | 0          | SOEm1<br>0/1 | SOEm0<br>0/1 |  |  |
| L       |                                                                                                       |                |                 |                      |                       |                | SOE           | Emn = 0 ι         | intil the s                           | start cond         | dition is g | enerated    | , and SC  | Emn = 1    | after ge     | neration.    |  |  |
| (f)     | Ser                                                                                                   | ial cha        | nnel sta        | art regi             | ster m                | (SSm)          | Sets          | only th           | e bits                                | of the t           | arget c     | hannel      | is 1.     |            |              |              |  |  |
| .,      | 15                                                                                                    | 14             | 13              | 12                   | 11                    | 10             | 9             | 8                 | 7                                     | 6                  | 5           | 4           | 3         | 2          | 1            | 0            |  |  |
| SSm     | 0                                                                                                     | 0              | 0               | 0                    | 0                     | 0              | 0             | 0                 | 0                                     | 0                  | 0           | 0           | 0         | 0          | SSm1<br>0/1  | SSm0<br>0/1  |  |  |
| L       | Note '                                                                                                | 1 0            |                 | /ided fo             | r the SM              | 1R00 ro        | aistor        |                   |                                       |                    |             |             |           |            | L            | <b>I</b>     |  |  |
|         | Note 2                                                                                                |                |                 | /ided for            |                       |                | -             |                   |                                       |                    |             |             |           |            |              |              |  |  |
|         | _                                                                                                     |                |                 |                      |                       | 0              |               |                   | <b>•</b> • •                          |                    |             |             |           |            |              |              |  |  |
|         |                                                                                                       |                | _               | umber (<br>ng is fix |                       |                |               | nber (n           | = 0, 1),                              | r: IIC ni          | ımber (r    | = 00, 0     | 1), mn =  | = 00, 01   |              |              |  |  |
|         | Rema                                                                                                  |                | _               | ng disab             |                       |                |               | lue)              |                                       |                    |             |             |           |            |              |              |  |  |
|         |                                                                                                       | ×              |                 | -                    |                       |                |               |                   | ne initia                             | l value v          | when no     | t used i    | n any m   | ode)       |              |              |  |  |
|         |                                                                                                       | 0/             | /1: Set t       | o 0 or 1             | depend                | ling on t      | the usa       | ge of the         | e user                                |                    |             |             |           |            |              |              |  |  |



(2) Operation procedure



## Figure 11 - 102 Initial Setting Procedure for Address Field Transmission

**Remark** At the end of the initial setting, the simplified I<sup>2</sup>C (IIC00, IIC01) must be set so that output is disabled and operations are stopped.



## (3) Processing flow



## Figure 11 - 103 Timing Chart of Address Field Transmission

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), r: IIC number (r = 00, 01), mn = 00, 01





Figure 11 - 104 Flowchart of Address Field Transmission



# 11.7.2 Data transmission

Data transmission is an operation to transmit data to the target for transfer (slave) after transmission of an address field. After all data are transmitted to the slave, a stop condition is generated and the bus is released.

| Simplified I <sup>2</sup> C     | IIC00                                                                                                                                                                                                        | IIC01                                                                      |  |  |  |  |  |  |  |  |  |  |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| Target channel                  | Channel 0 of SAU0                                                                                                                                                                                            | Channel 1 of SAU0                                                          |  |  |  |  |  |  |  |  |  |  |
| Pins used                       | SCL00, SDA00 Note 1                                                                                                                                                                                          | SCL01, SDA01 Note 1                                                        |  |  |  |  |  |  |  |  |  |  |
| Interrupt                       | INTIIC00                                                                                                                                                                                                     | INTIIC01                                                                   |  |  |  |  |  |  |  |  |  |  |
|                                 | Transfer end interrupt only (Setting the buffer empty interrupt is prohibited.)                                                                                                                              |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Error detection flag            | CK error flag (PEFmn)                                                                                                                                                                                        |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Transfer data length            | 8 bits                                                                                                                                                                                                       |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Transfer rate <sup>Note 2</sup> | Max. fмск/4 [Hz] (SDRmn[15:9] = 1 or more) fмск:<br>However, the following condition must be satisfied in a<br>• Max. 1 MHz (fast mode plus)<br>• Max. 400 kHz (fast mode)<br>• Max. 100 kHz (standard mode) | Operation clock frequency of target channel each mode of I <sup>2</sup> C. |  |  |  |  |  |  |  |  |  |  |
| Data level                      | Non-reverse output (default: high level)                                                                                                                                                                     |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Parity bit                      | No parity bit                                                                                                                                                                                                |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Stop bit                        | Appending 1 bit (for ACK reception timing)                                                                                                                                                                   |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Data direction                  | MSB first                                                                                                                                                                                                    |                                                                            |  |  |  |  |  |  |  |  |  |  |

Note 1. To perform communication via simplified I<sup>2</sup>C, set the N-ch open-drain output (VDD tolerance) mode (POMxx = 1) with the port output mode register (POMxx). For details, see 4.3 Registers Controlling Port Function and 4.5 Register Settings When Using Alternate Function.

When IIC00 is communicating with an external device with a different potential, set the N-ch open-drain output (VDD tolerance) mode (POMxx = 1) also for the clock input/output pins (SCL00).

For details, see 4.4.4 Handling different potential (1.8 V, 2.5 V) by using I/O buffers.

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



(1) Register setting

## Figure 11 - 105 Example of Contents of Registers for Data Transmission of Simplified I<sup>2</sup>C (IIC00, IIC01)

| (a)         | Sei                    | iai moo                        | ae regis                       | ster mn                        | (SMR              | mn) I             | Do not                         | manipu                         | late th          | is regis           | ster dur           | ing dat           | a trans           | missio           | n/recep                       | otion.                        |
|-------------|------------------------|--------------------------------|--------------------------------|--------------------------------|-------------------|-------------------|--------------------------------|--------------------------------|------------------|--------------------|--------------------|-------------------|-------------------|------------------|-------------------------------|-------------------------------|
|             | 15                     | 14                             | 13                             | 12                             | 11                | 10                | 9                              | 8                              | 7                | 6                  | 5                  | 4                 | 3                 | 2                | 1                             | 0                             |
| SMRmn       | CKSmn<br>0/1           | CCSmn<br>0                     | 0                              | 0                              | 0                 | 0                 | 0                              | STSmn<br>0 Note 1              | 0                | SISmn0<br>0 Note 1 | 1                  | 0                 | 0                 | MDmn2<br>1       | MDmn1<br>0                    | MDmn0<br>0                    |
| (b)         |                        |                                |                                |                                |                   |                   |                                | ster mn                        | •                | ,                  |                    |                   | late the          | e bits c         | of this re                    | egister,                      |
|             |                        | •                              |                                |                                |                   |                   | •                              | data tra                       |                  |                    | •                  |                   |                   |                  |                               |                               |
|             | 15                     | 14                             | 13                             | 12                             | 11                | 10                | 9                              | 8                              | 7                | 6                  | 5                  | 4                 | 3                 | 2                | 1                             | 0                             |
| SCRmn       | TXEmn<br>1             | RXEmn<br>0                     | DAPmn<br>0                     | CKPmn<br>0                     | 0                 | EOCmn<br>0        | PTCmn1<br>0                    | PTCmn0<br>0                    | DIRmn<br>0       | 0                  | SLCmn1<br>0 Note 2 | SLCmn0<br>1       | 0                 | 1                | DLSmn1<br>1                   | DLSmn0<br>1                   |
| (c)         |                        |                                | a regis<br>ts (SIO             |                                | (SDR              | mn) (lo           | ower 8                         | bits: S                        | lOr)             | During             | i data 1           | transm            | ission/           | recepti          | on, val                       | id only                       |
| _           | 15                     | 14                             | 13                             | 12                             | 11                | 10                | 9                              | 8                              | 7                | 6                  | 5                  | 4                 | 3                 | 2                | 1                             | 0                             |
| SDRmn       |                        |                                | Baud ra                        | ate setti                      | ng Note 3         |                   |                                | 0                              |                  |                    | Tra                | ansmit d          | ata sett          | ing              |                               |                               |
| SIOr        |                        |                                |                                |                                |                   |                   |                                |                                |                  |                    |                    |                   | Or                |                  |                               |                               |
| (d)         | Ser                    | ial outp                       | out regi                       | ster m                         | (SOm)             | ) Do r            | not mai                        | nipulate                       | e this re        | egister            | during             | data tra          | ansmis            | sion/re          | eception                      | า.                            |
|             | 15                     | 14                             | 13                             | 12                             | 11                | 10                | 9                              | 8                              | 7                | 6                  | 5                  | 4                 | 3                 | 2                | 1                             | 0                             |
| SOm         | 0                      | 0                              | 0                              | 0                              | 0                 | 0                 | CKOm1<br>0/1 <sup>Note 4</sup> | CKOm0<br>0/1 <sup>Note 4</sup> | 0                | 0                  | 0                  | 0                 | 0                 | 0                | SOm1<br>0/1 <sup>Note 4</sup> | SOm0<br>0/1 <sup>Note 4</sup> |
|             |                        |                                |                                |                                |                   |                   |                                |                                |                  |                    |                    |                   |                   |                  |                               |                               |
| (e)         | Ser                    | ial ou                         | itput (                        | enable                         | regis             | ster m            | n (SO                          | Em)                            | Do               | not m              | nanipula           | ate th            | is re             | gister           | during                        | data                          |
| (e)         |                        |                                | utput<br>on/rece               |                                | regis             | ster m            | n (SO                          | Em)                            | Do               | not m              | nanipula           | ate th            | is re             | gister           | during                        | data                          |
| (e)         |                        |                                | •                              |                                | regis             | ster m            | n (SO<br>9                     | Em)<br>8                       | Do<br>7          | not m<br>6         | nanipula<br>5      | ate th<br>4       | iis reę<br>3      | gister<br>2      | during<br>1                   | data<br>0                     |
| (e)<br>SOEm | trar                   | ismissi                        | on/rece                        | eption                         | -                 |                   |                                | ,                              |                  |                    |                    |                   |                   | -                | 0                             |                               |
| SOEm        | tran<br>15<br>0        | nsmissi<br>14<br>0             | on/rece<br>13<br>0             | eption<br>12<br>0              | 11                | 10                | 9                              | 8                              | 7                | 6                  | 5                  | 4                 | 3                 | 2                | 1<br>SOEm1<br>1               | 0<br>SOEm0<br>1               |
| ſ           | tran<br>15<br>0        | nsmissi<br>14<br>0             | on/rece<br>13<br>0             | eption<br>12<br>0              | 11                | 10                | 9                              | 8                              | 7                | 6                  | 5                  | 4                 | 3                 | 2                | 1<br>SOEm1<br>1               | 0<br>SOEm0<br>1               |
| SOEm        | tran<br>15<br>0<br>Ser | nsmissi<br>14<br>0<br>ial chai | on/rece<br>13<br>0<br>nnel sta | eption<br>12<br>0<br>art regis | 11<br>0<br>ster m | 10<br>0<br>(SSm). | 9<br>0<br>Do n                 | 8<br>0<br>ot mani              | 7<br>0<br>pulate | 6<br>0<br>this reg | 5<br>0<br>gister d | 4<br>0<br>uring d | 3<br>0<br>ata tra | 2<br>0<br>nsmiss | 1<br>SOEm1<br>1<br>sion/rec   | 0<br>SOEm0<br>1               |



## (2) Processing flow



## Figure 11 - 106 Timing Chart of Data Transmission





# 11.7.3 Data reception

Data reception is an operation to receive data to the target for transfer (slave) after transmission of an address field. After all data are received to the slave, a stop condition is generated and the bus is released.

| Simplified I <sup>2</sup> C | IIC00                                                                                                                                                                                                        | IIC01                                                                      |  |  |  |  |  |  |  |  |  |  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| Target channel              | Channel 0 of SAU0                                                                                                                                                                                            | Channel 1 of SAU0                                                          |  |  |  |  |  |  |  |  |  |  |
| Pins used                   | SCL00, SDA00 Note 1                                                                                                                                                                                          | SCL01, SDA01 Note 1                                                        |  |  |  |  |  |  |  |  |  |  |
| Interrupt                   | INTIIC00                                                                                                                                                                                                     | INTIIC01                                                                   |  |  |  |  |  |  |  |  |  |  |
|                             | Transfer end interrupt only (Setting the buffer empty interrupt is prohibited.)                                                                                                                              |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Error detection flag        | verrun error detection flag (OVFmn) only                                                                                                                                                                     |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Transfer data length        | 8 bits                                                                                                                                                                                                       |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Transfer rate Note 2        | Max. fMck/4 [Hz] (SDRmn[15:9] = 1 or more) fMck:<br>However, the following condition must be satisfied in e<br>• Max. 1 MHz (fast mode plus)<br>• Max. 400 kHz (fast mode)<br>• Max. 100 kHz (standard mode) | Operation clock frequency of target channel each mode of I <sup>2</sup> C. |  |  |  |  |  |  |  |  |  |  |
| Data level                  | Non-reverse output (default: high level)                                                                                                                                                                     |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Parity bit                  | No parity bit                                                                                                                                                                                                |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Stop bit                    | Appending 1 bit (ACK transmission)                                                                                                                                                                           |                                                                            |  |  |  |  |  |  |  |  |  |  |
| Data direction              | MSB first                                                                                                                                                                                                    |                                                                            |  |  |  |  |  |  |  |  |  |  |

Note 1. To perform communication via simplified I<sup>2</sup>C, set the N-ch open-drain output (VDD tolerance) mode (POMxx = 1) with the port output mode register (POMxx). For details, see 4.3 Registers Controlling Port Function and 4.5 Register Settings When Using Alternate Function.

When IIC00 is communicating with an external device with a different potential, set the N-ch open-drain output (VDD tolerance) mode (POMxx = 1) also for the clock input/output pins (SCL00).

For details, see 4.4.4 Handling different potential (1.8 V, 2.5 V) by using I/O buffers.

**Note 2.** Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see **ELECTRICAL SPECIFICATIONS** in the R9A02G015 Data Sheet (R19DS0101E)).

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01



(1) Register setting

| Figu  | re 11 -                                                 | 108 Ex                                                                                                                                                                                                                                                       | kample     | e of Co                | ntents                                  | of Re      | gisters                        | for Da                         | ita Ree    | ceptio             | n of Sir           | nplifie     | d I <sup>2</sup> C ( | IIC00,     | IIC01)                        |                               |
|-------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------------------|-----------------------------------------|------------|--------------------------------|--------------------------------|------------|--------------------|--------------------|-------------|----------------------|------------|-------------------------------|-------------------------------|
| (a)   | ) Ser                                                   | ial mod                                                                                                                                                                                                                                                      | le regi    | ster mn                | (SMR                                    | mn) I      | Do not                         | manipu                         | late th    | is regi            | ster dur           | ring dat    | a trans              | missio     | n/recep                       | otion.                        |
|       | 15                                                      | 14                                                                                                                                                                                                                                                           | 13         | 12                     | 11                                      | 10         | 9                              | 8                              | 7          | 6                  | 5                  | 4           | 3                    | 2          | 1                             | 0                             |
| SMRmn | CKSmn<br>0/1                                            | CCSmn<br>0                                                                                                                                                                                                                                                   | 0          | 0                      | 0                                       | 0          | 0                              | STSmn<br>0 Note 1              | 0          | SISmn0<br>0 Note 1 | 1                  | 0           | 0                    | MDmn2<br>1 | MDmn1<br>0                    | MDmn0<br>0                    |
| (b)   | ) Ser                                                   | ial com                                                                                                                                                                                                                                                      | munic      | ation o                | oeratio                                 | n settir   | ig regis                       | ster mn                        | (SCR       | mn) l              | Do not i           | manipu      | late th              | e bits c   | of this re                    | egister,                      |
|       | exc                                                     | ept the                                                                                                                                                                                                                                                      | TXEn       | nn and I               | RXEmı                                   | n bits, d  | during                         | data tra                       | nsmis      | sion/re            | ception            | <b>).</b>   |                      |            |                               |                               |
|       | 15                                                      | 14                                                                                                                                                                                                                                                           | 13         | 12                     | 11                                      | 10         | 9                              | 8                              | 7          | 6                  | 5                  | 4           | 3                    | 2          | 1                             | 0                             |
| SCRmn | TXEmn<br>0                                              | RXEmn<br>1                                                                                                                                                                                                                                                   | DAPmn<br>0 | CKPmn<br>0             | 0                                       | EOCmn<br>0 | PTCmn1<br>0                    | PTCmn0<br>0                    | DIRmn<br>0 | 0                  | SLCmn1<br>0 Note 2 | SLCmn0<br>1 | 0                    | 1          | DLSmn1<br>1                   | DLSmn0<br>1                   |
| (c)   | c) Serial data register mn (SDRmn) (lower 8 bits: SIOr) |                                                                                                                                                                                                                                                              |            |                        |                                         |            |                                |                                |            |                    |                    |             |                      |            |                               |                               |
|       | 15                                                      | 14                                                                                                                                                                                                                                                           | 13         | 12                     | 11                                      | 10         | 9                              | 8                              | 7          | 6                  | 5                  | 4           | 3                    | 2          | 1                             | 0                             |
| SDRmn |                                                         |                                                                                                                                                                                                                                                              | Baud r     | ate setti              | ng Note 3                               |            |                                | 0                              |            | D                  | ummy tr            | ansmit o    | lata set             | ting (FF   | FH)                           |                               |
| -     |                                                         |                                                                                                                                                                                                                                                              |            |                        |                                         |            |                                |                                |            |                    |                    | SI          | Or                   |            |                               |                               |
| (d)   | ) Ser                                                   | ial outr                                                                                                                                                                                                                                                     | out rea    | ister m                | (SOm)                                   | Do r       | not mar                        | nipulate                       | this re    | eaister            | durina             | data tra    | ansmis               | sion/re    | eceptior                      | ۱.                            |
|       | 15                                                      | 14                                                                                                                                                                                                                                                           | 13         | 12                     | , í í í í í í í í í í í í í í í í í í í | 10         | 9                              | 8                              | 7          | 6                  | 5                  | 4           | 3                    | 2          | 1                             | 0                             |
| SOm   | 0                                                       | 0                                                                                                                                                                                                                                                            | 0          | 0                      | 0                                       | 0          | CKOm1<br>0/1 <sup>Note 4</sup> | CKOm0<br>0/1 <sup>Note 4</sup> | 0          | 0                  | 0                  | 0           | 0                    | 0          | SOm1<br>0/1 <sup>Note 4</sup> | SOm0<br>0/1 <sup>Note 4</sup> |
| (e)   | ) Ser                                                   | ial ou                                                                                                                                                                                                                                                       | ıtput      | enable                 | regis                                   | ter m      | (SO                            | Em)                            | Do         | not n              | nanipula           | ate th      | is re                | gister     | during                        | data                          |
|       | tran                                                    | smissi                                                                                                                                                                                                                                                       | on/rec     | eption.                |                                         |            |                                |                                |            |                    |                    |             |                      |            |                               |                               |
|       | 15                                                      | 14                                                                                                                                                                                                                                                           | 13         | 12                     | 11                                      | 10         | 9                              | 8                              | 7          | 6                  | 5                  | 4           | 3                    | 2          | 1                             | 0                             |
| SOEm  | 0                                                       | 0                                                                                                                                                                                                                                                            | 0          | 0                      | 0                                       | 0          | 0                              | 0                              | 0          | 0                  | 0                  | 0           | 0                    | 0          | SOEm1<br>0/1                  | SOEm0<br>0/1                  |
| (f)   | Ser                                                     | ial chai                                                                                                                                                                                                                                                     | nnel st    | art regi               | ster m                                  | (SSm).     | Do n                           | ot mani                        | pulate     | this re            | gister d           | luring d    | ata tra              | nsmiss     | sion/rec                      | eption.                       |
|       | 15                                                      | 14                                                                                                                                                                                                                                                           | 13         | 12                     | 11                                      | 10         | 9                              | 8                              | 7          | 6                  | 5                  | 4           | 3                    | 2          | 1                             | 0                             |
| SSm   | 0                                                       | 0                                                                                                                                                                                                                                                            | 0          | 0                      | 0                                       | 0          | 0                              | 0                              | 0          | 0                  | 0                  | 0           | 0                    | 0          | SSm1<br>0/1                   | SSm0<br>0/1                   |
|       |                                                         | <ul> <li>te 1. Only provided for the SMR01 register.</li> <li>te 2. Only provided for the SCR00 register.</li> <li>te 3. The baud rate setting is not required because the baud rate has already been set when the address field was transmitted.</li> </ul> |            |                        |                                         |            |                                |                                |            |                    |                    |             |                      |            |                               |                               |
|       | кета                                                    | Irk 2.                                                                                                                                                                                                                                                       | _          | ing is fix<br>ng disab |                                         |            |                                | lue)                           |            |                    |                    |             |                      |            |                               |                               |
|       |                                                         |                                                                                                                                                                                                                                                              | : Bit tha  | at cannot              | be use                                  | d in this  | mode (                         | (set to th                     |            | l value v          | when no            | ot used i   | n any m              | iode)      |                               |                               |
|       |                                                         | 0/                                                                                                                                                                                                                                                           | 1: Set     | to 0 or 1              | depend                                  | aing on t  | ine usa                        | ge of the                      | user       |                    |                    |             |                      |            |                               |                               |



## (2) Processing flow

| (a)                      | When starting data recepti                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                     |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| SSmr                     | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| STmr                     | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| SEmr                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | _                                   |
| SOEmr                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| TXEmn<br>RXEmr           | 7TXEmn = 1 / RXEmn = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | TXEmn = 0 / RXEmn = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                     |
| SDRmr                    | ۱                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Dummy data (FFH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Receive data                        |
| SCLr outpu               | t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| SDAr outpu               | t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ск                                  |
| SDAr inpu                | t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                     |
| Shif<br>register mr      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X     X <td></td> |                                     |
| INTIIC                   | r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| TSFmr                    | ١                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | _                                   |
|                          | When receiving last data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
|                          | When receiving last data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| STmn_                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| SEmn -<br>SOEmn          | Output is enabled by serial                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Output is stopped by serial communication operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                     |
| TXEmn, –                 | communication operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | TXEmn = 0 / RXEmn = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                     |
| RXEmn –                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| SDRmn_                   | Dummy data (FFH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Dummy data (FFH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ceive data                          |
| SCLr output              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| SDAr output              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                     |
| SDAr input               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                     |
| – Shift<br>– register mn | X Shift Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | X X X Shift X X X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                     |
| INTIICr                  | у <u>сторования (странятия) (странати</u> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| _                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
| TSFmn                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                     |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reception of last byte SOmn I maniput                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | bit SOmn bit<br>lation manipulation |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ⊥<br>∆<br>IIC operation sto                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | י<br>∆<br>CKOmn bit<br>manipulation |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Sto                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | op condition                        |

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), r: IIC number (r = 00, 01), mn = 00, 01

R19UH0112EJ0100 Rev.1.00 Mar 29, 2019



#### Figure 11 - 110 Flowchart of Data Reception



Caution ACK is not output when the last data is received (NACK). Communication is then completed by setting 1 to the STmn bit of serial channel stop register m (STm) to stop operation and generating a stop condition.



## 11.7.4 Stop condition generation

After all data are transmitted to or received from the target slave, a stop condition is generated and the bus is released.

(1) Processing flow



#### Figure 11 - 111 Timing Chart of Stop Condition Generation

**Note** During a receive operation, the SOEmn bit of serial output enable register m (SOEm) is cleared to 0 before receiving the last data.







# 11.7.5 Calculating transfer rate

The transfer rate for simplified I<sup>2</sup>C (IIC00, IIC01) communication can be calculated by the following expressions.

(Transfer rate) = {Operation clock (fмск) frequency of target channel} ÷ (SDRmn[15:9] + 1) ÷ 2

- Caution SDRmn[15:9] must not be set to 0000000B. Be sure to set a value of 0000001B or greater for SDRmn[15:9]. The duty ratio of the SCL signal output by the simplified I<sup>2</sup>C is 50%. The I<sup>2</sup>C bus specifications define that the low-level width of the SCL signal is longer than the high-level width. If 400 kbps (fast mode) or 1 Mbps (fast mode plus) is specified, therefore, the low-level width of the SCL output signal becomes shorter than the value specified in the I<sup>2</sup>C bus specifications. In addition, it may be required to set an appropriate transfer rate so that the data setup time (reception) of R9A02G015 meet the I2C bus specifications. Make sure that the SDRmn[15:9] value satisfies the I<sup>2</sup>C bus specifications.
- **Remark 1.** The value of SDRmn[15:9] is the value of bits 15 to 9 of the SDRmn register (0000001B to 111111B) and therefore is 1 to 127.
- **Remark 2.** m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01

The operation clock (fMCK) is determined by serial clock select register m (SPSm) and bit 15 (CKSmn) of serial mode register mn (SMRmn).



| SMRmn<br>Register | SPSm Register |            |            |            |            |            |            | Operation Cl | оск (fмск) <sup>Note</sup> |               |
|-------------------|---------------|------------|------------|------------|------------|------------|------------|--------------|----------------------------|---------------|
| CKSmn             | PRS<br>m13    | PRS<br>m12 | PRS<br>m11 | PRS<br>m10 | PRS<br>m03 | PRS<br>m02 | PRS<br>m01 | PRS<br>m00   |                            | fclк = 24 MHz |
| 0                 | ×             | ×          | ×          | ×          | 0          | 0          | 0          | 0            | fclк                       | 24 MHz        |
|                   | ×             | ×          | ×          | ×          | 0          | 0          | 0          | 1            | fclk/2                     | 12 MHz        |
|                   | ×             | ×          | ×          | ×          | 0          | 0          | 1          | 0            | fclk/2 <sup>2</sup>        | 6 MHz         |
|                   | ×             | ×          | ×          | ×          | 0          | 0          | 1          | 1            | fclk/2 <sup>3</sup>        | 3 MHz         |
|                   | ×             | ×          | ×          | ×          | 0          | 1          | 0          | 0            | fclk/24                    | 1.5 MHz       |
|                   | ×             | ×          | ×          | ×          | 0          | 1          | 0          | 1            | fcLк/2 <sup>5</sup>        | 750 kHz       |
|                   | ×             | ×          | ×          | ×          | 0          | 1          | 1          | 0            | fcLк/2 <sup>6</sup>        | 375 kHz       |
|                   | ×             | ×          | ×          | ×          | 0          | 1          | 1          | 1            | fclk/27                    | 187.5 kHz     |
|                   | ×             | ×          | ×          | ×          | 1          | 0          | 0          | 0            | fcLк/2 <sup>8</sup>        | 93.8 kHz      |
|                   | ×             | ×          | ×          | ×          | 1          | 0          | 0          | 1            | fclк/2 <sup>9</sup>        | 46.9 kHz      |
|                   | ×             | ×          | ×          | ×          | 1          | 0          | 1          | 0            | fcLK/2 <sup>10</sup>       | 23.4 kHz      |
|                   | ×             | ×          | ×          | ×          | 1          | 0          | 1          | 1            | fclk/2 <sup>11</sup>       | 11.7 kHz      |
| 1                 | 0             | 0          | 0          | 0          | ×          | ×          | ×          | ×            | fclк                       | 24 MHz        |
|                   | 0             | 0          | 0          | 1          | ×          | ×          | ×          | ×            | fclk/2                     | 12 MHz        |
|                   | 0             | 0          | 1          | 0          | ×          | ×          | ×          | ×            | fclк/2 <sup>2</sup>        | 6 MHz         |
|                   | 0             | 0          | 1          | 1          | ×          | ×          | ×          | ×            | fcLк/2 <sup>3</sup>        | 3 MHz         |
|                   | 0             | 1          | 0          | 0          | ×          | ×          | ×          | ×            | fclк/2 <sup>4</sup>        | 1.5 MHz       |
|                   | 0             | 1          | 0          | 1          | ×          | ×          | ×          | ×            | fcLк/2 <sup>5</sup>        | 750 kHz       |
|                   | 0             | 1          | 1          | 0          | ×          | ×          | ×          | ×            | fclк/2 <sup>6</sup>        | 375 kHz       |
|                   | 0             | 1          | 1          | 1          | ×          | ×          | ×          | ×            | fclk/2 <sup>7</sup>        | 187.5 kHz     |
|                   | 1             | 0          | 0          | 0          | ×          | ×          | ×          | ×            | fcLк/2 <sup>8</sup>        | 93.8 kHz      |
|                   | 1             | 0          | 0          | 1          | ×          | ×          | ×          | ×            | fськ/2 <sup>9</sup>        | 46.9 kHz      |
|                   | 1             | 0          | 1          | 0          | ×          | ×          | ×          | ×            | fcLк/2 <sup>10</sup>       | 23.4 kHz      |
|                   | 1             | 0          | 1          | 1          | ×          | ×          | ×          | ×            | fclк/2 <sup>11</sup>       | 11.7 kHz      |
|                   |               |            | Othe       | r than abo | ove        |            |            |              | Setting p                  | prohibited    |

**Note** When changing the clock selected for fcLk (by changing the system clock control register (CKC) value), do so after having stopped (serial channel stop register m (STm) = 000FH) the operation of the serial array unit (SAU).

Remark 1. ×: Don't care Remark 2. m: Unit number (m = 0), n: Channel number (n = 0, 1), mn = 00, 01

Here is an example of setting an I<sup>2</sup>C transfer rate where  $f_{MCK} = f_{CLK} = 24$  MHz.

| I <sup>2</sup> C Transfer Mode | fclk = 24 MHz          |             |                          |                                     |  |  |
|--------------------------------|------------------------|-------------|--------------------------|-------------------------------------|--|--|
| (Desired Transfer<br>Rate)     | Operation Clock (fмск) | SDRmn[15:9] | Calculated Transfer Rate | Error from Desired<br>Transfer Rate |  |  |
| 100 kHz                        | fclk/2                 | 59          | 100 kHz                  | 0.0%                                |  |  |
| 400 kHz                        | fclk                   | 31          | 375 kHz                  | 6.25% Note                          |  |  |
| 1 MHz                          | fclk                   | 14          | 0.80 MHz                 | 20.0% Note                          |  |  |

Note The error cannot be set to about 0% because the duty ratio of the SCL signal is 50%.

# 11.7.6 Procedure for processing errors that occurred during simplified I<sup>2</sup>C (IIC00, IIC01) communication

The procedure for processing errors that occurred during simplified  $I^2C$  (IIC00, IIC01) communication is described in **Figures 11 - 113** and **11 - 114**.

| Software Manipulation                                        | Hardware Status                                                                           | Remark                                                                                                                                               |  |  |
|--------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Reads serial data register mn → (SDRmn).                     | The BFFmn bit of the SSRmn register is set to 0 and channel n is enabled to receive data. | This is to prevent an overrun error if the next reception is completed during error processing.                                                      |  |  |
| Reads serial status register mn (SSRmn).                     |                                                                                           | The error type is identified and the read value is used to clear the error flag.                                                                     |  |  |
| Writes 1 to serial flag clear trigger → register mn (SIRmn). | The error flag is cleared.                                                                | The error only during reading can be<br>cleared, by writing the value read from the<br>SSRmn register to the SIRmn register<br>without modification. |  |  |

#### Figure 11 - 113 Processing Procedure in Case of Overrun Error

## Figure 11 - 114 Processing Procedure in Case of ACK error in Simplified I<sup>2</sup>C Mode

| Software Manipulation                                                 | Hardware Status                                                                                                      | Remark                                                                                                                                           |
|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Reads serial status register mn (SSRmn).                              |                                                                                                                      | Error type is identified and the read value is used to clear error flag.                                                                         |
| Writes serial flag clear trigger register mn <b>⊣</b><br>(SIRmn).     | Error flag is cleared.                                                                                               | Error can be cleared only during reading,<br>by writing the value read from the SSRmn<br>register to the SIRmn register without<br>modification. |
| Sets the STmn bit of serial channel stop →<br>register m (STm) to 1.  | The SEmn bit of serial channel enable<br>status register m (SEm) is set to 0 and<br>channel n stops operation.       | Slave is not ready for reception because<br>ACK is not returned. Therefore, a stop<br>condition is created, the bus is released,                 |
| Creates stop condition.                                               |                                                                                                                      | and communication is started again from                                                                                                          |
| Creates start condition.                                              |                                                                                                                      | the start condition. Or, a restart condition<br>is generated and transmission can be<br>redone from address transmission.                        |
| Sets the SSmn bit of serial channel start –<br>register m (SSm) to 1. | The SEmn bit of serial channel enable<br>status register m (SEm) is set to 1 and<br>channel n is enabled to operate. |                                                                                                                                                  |

**Remark** m: Unit number (m = 0), n: Channel number (n = 0, 1), r: IIC number (r = 00, 01), mn = 00, 01



# CHAPTER 12 SERIAL INTERFACE IICA

The number of channels of the serial Interface IICA differs, depending on the product.

|          | With USB | Without USB |
|----------|----------|-------------|
|          | 32-pin   | 32-pin      |
| Channels | 2 ch     | 3 ch        |

# 12.1 Functions of Serial Interface IICA

Serial interface IICA has the following three modes.

(1) Operation stop mode

This mode is used when serial transfers are not performed. It can therefore be used to reduce power consumption.

(2) I<sup>2</sup>C bus mode (multimaster supported)

This mode is used for 8-bit data transfers with several devices via two lines: a serial clock (SCLAn) line and a serial data bus (SDAAn) line.

This mode complies with the I<sup>2</sup>C bus format and the master device can generated "start condition", "address", "transfer direction specification", "data", and "stop condition" data to the slave device, via the serial data bus. The slave device automatically detects these received status and data by hardware. This function can simplify the part of application program that controls the I<sup>2</sup>C bus.

Since the SCLAn and SDAAn pins are used for open drain outputs, serial interface IICA requires pull-up resistors for the serial clock line and the serial data bus line.

(3) Wakeup mode

The STOP mode can be released by generating an interrupt request signal (INTIICAn) when an extension code from the master device or a local address has been received while in STOP mode. This can be set by using the WUPn bit of IICA control register n1 (IICCTLn1).

Figure 12 - 1 shows a block diagram of serial interface IICA





Figure 12 - 1 Block Diagram of Serial Interface IICA



Figure 12 - 2 shows a serial bus configuration example.







# 12.2 Configuration of Serial Interface IICA

Serial interface IICA includes the following hardware.

| Table 12 - 1 Configuration of Serial Interface IICA |
|-----------------------------------------------------|
|-----------------------------------------------------|

| Item              | Configuration                                     |  |  |  |
|-------------------|---------------------------------------------------|--|--|--|
| Registers         | IICA shift register n (IICAn)                     |  |  |  |
|                   | Slave address register n (SVAn)                   |  |  |  |
| Control registers | Peripheral enable register 0 (PER0)               |  |  |  |
|                   | IICA control register n0 (IICCTLn0)               |  |  |  |
|                   | IICA status register n (IICSn)                    |  |  |  |
|                   | IICA flag register n (IICFn)                      |  |  |  |
|                   | IICA control register n1 (IICCTLn1)               |  |  |  |
|                   | IICA low-level width setting register n (IICWLn)  |  |  |  |
|                   | IICA high-level width setting register n (IICWHn) |  |  |  |
|                   | Port mode registers 6, 7 (PM6, PM7)               |  |  |  |
|                   | Port registers 6, 7 (P6, P7)                      |  |  |  |

Remark n = 0 to 2

(1) IICA shift register n (IICAn)

The IICAn register is used to convert 8-bit serial data to 8-bit parallel data and vice versa in synchronization with the serial clock. The IICAn register can be used for both transmission and reception.

The actual transmit and receive operations can be controlled by writing and reading operations to the IICAn register.

Cancel the wait state and start data transfer by writing data to the IICAn register during the wait period.

The IICAn register can be set by an 8-bit memory manipulation instruction.

Reset signal generation clears IICAn to 00H.

## Figure 12 - 3 Format of IICA shift register n (IICAn)

| Address: FFF50H (IICA0), FFF54H (IICA1), FFF60H (IICA2) |   |   |   | (IICA2) | After reset: | 00H R/W |   |   |
|---------------------------------------------------------|---|---|---|---------|--------------|---------|---|---|
| Symbol                                                  | 7 | 6 | 5 | 4       | 3            | 2       | 1 | 0 |
| llCAn                                                   |   |   |   |         |              |         |   |   |

Caution 1. Do not write data to the IICAn register during data transfer.

Caution 2. Write or read the IICAn register only during the wait period. Accessing the IICAn register in a communication state other than during the wait period is prohibited. When the device serves as the master, however, the IICAn register can be written only once after the communication trigger bit (STTn) is set to 1.

Caution 3. When communication is reserved, write data to the IICAn register after the interrupt triggered by a stop condition is detected.



(2) Slave address register n (SVAn)

This register stores seven bits of local addresses {A6, A5, A4, A3, A2, A1, A0} when in slave mode. The SVAn register can be set by an 8-bit memory manipulation instruction. However, rewriting to this register is prohibited while STDn = 1 (while the start condition is detected). Reset signal generation clears the SVAn register to 00H.

## Figure 12 - 4 Format of Slave address register n (SVAn)

| Address: F0234H (SVA0), F023CH (SVA1), F0244H (SVA2) |    |    |    | After reset | 00H R/W |    |    |        |
|------------------------------------------------------|----|----|----|-------------|---------|----|----|--------|
| Symbol                                               | 7  | 6  | 5  | 4           | 3       | 2  | 1  | 0      |
| SVAn                                                 | A6 | A5 | A4 | A3          | A2      | A1 | A0 | 0 Note |

Note Bit 0 is fixed to 0.

#### (3) SO latch

The SO latch is used to retain the SDAAn pin's output level.

(4) Wakeup controller

This circuit generates an interrupt request (INTIICAn) when the address received by this register matches the address value set to the slave address register n (SVAn) or when an extension code is received.

(5) Serial clock counter

This counter counts the serial clocks that are output or input during transmit/receive operations and is used to verify that 8-bit data was transmitted or received.

#### (6) Interrupt request signal generator

This circuit controls the generation of interrupt request signals (INTIICAn).

An I<sup>2</sup>C interrupt request is generated by the following two triggers.

- Falling edge of eighth or ninth clock of the serial clock (set by the WTIMn bit)
- Interrupt request generated when a stop condition is detected (set by the SPIEn bit)

 Remark
 WTIMn bit:
 Bit 3 of IICA control register n0 (IICCTLn0)

 SPIEn bit:
 Bit 4 of IICA control register n0 (IICCTLn0)

(7) Serial clock controller

In master mode, this circuit generates the clock output via the SCLAn pin from a sampling clock.

(8) Serial clock wait controller This circuit controls the wait timing.



- (9) ACK generator, stop condition detector, start condition detector, and ACK detector These circuits generate and detect each status.
- (10) Data hold time correction circuit

This circuit generates the hold time for data corresponding to the falling edge of the serial clock.

(11) Start condition generator

This circuit generates a start condition when the STTn bit is set to 1. However, in the communication reservation disabled status (IICRSVn bit = 1), when the bus is not released (IICBSYn bit = 1), start condition requests are ignored and the STCFn bit is set to 1.

#### (12) Stop condition generator

This circuit generates a stop condition when the SPTn bit is set to 1.

## (13) Bus status detector

This circuit detects whether or not the bus is released by detecting start conditions and stop conditions. However, as the bus status cannot be detected immediately following operation, the initial status is set by the STCENn bit.

| Remark 1.  | STTn bit:    | Bit 1 of IICA control register n0 (IICCTLn0) |
|------------|--------------|----------------------------------------------|
|            | SPTn bit:    | Bit 0 of IICA control register n0 (IICCTLn0) |
|            | IICRSVn bit: | Bit 0 of IICA flag register n (IICFn)        |
|            | IICBSYn bit: | Bit 6 of IICA flag register n (IICFn)        |
|            | STCFn bit:   | Bit 7 of IICA flag register n (IICFn)        |
|            | STCENn bit:  | Bit 1 of IICA flag register n (IICFn)        |
| Dama all 0 | - 0 to 0     |                                              |



# 12.3 Registers Controlling Serial Interface IICA

Serial interface IICA is controlled by the following eight registers.

- Peripheral enable register 0 (PER0)
- IICA control register n0 (IICCTLn0)
- IICA flag register n (IICFn)
- IICA status register n (IICSn)
- IICA control register n1 (IICCTLn1)
- IICA low-level width setting register n (IICWLn)
- IICA high-level width setting register n (IICWHn)
- Port mode registers 6, 7 (PM6, PM7)
- Port registers 6, 7 (P6, P7)



# 12.3.1 Peripheral enable register 0 (PER0)

This register is used to enable or disable supplying the clock to the peripheral hardware. Clock supply to a hardware macro that is not used is stopped in order to reduce the power consumption and noise.

When serial interface IICAn is used, be sure to set bits 7, 6, 4 (IICA2EN, IICA1EN, IICA0EN) of this register to 1. The PER0 register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

## Figure 12 - 5 Format of Peripheral enable register 0 (PER0)

| Address: | F00F0H       | After reset: 00 | H R/W |         |   |        |   |        |
|----------|--------------|-----------------|-------|---------|---|--------|---|--------|
| Symbol   | <7>          | <6>             | <5>   | <4>     | 3 | <2>    | 1 | <0>    |
| PER0     | IICA2EN Note | IICA1EN         | ADCEN | IICA0EN | 0 | SAU0EN | 0 | TAU0EN |

| IICAnEN | Control of serial interface IICAn input clock supply                                                                                                        |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Stops input clock supply. <ul> <li>SFR used by serial interface IICAn cannot be written.</li> <li>Serial interface IICAn is in the reset status.</li> </ul> |
| 1       | Enables input clock supply.<br>• SFR used by serial interface IICAn can be read/written.                                                                    |

**Note** 32-pin product without USB only.

- Caution 1. When setting serial interface IICA, be sure to set the following registers first while the IICAnEN bit is set to 1. If IICAnEN = 0, the control registers of serial interface IICA are set to their initial values, and writing to them is ignored (except for port mode registers 6, 7 (PM6, PM7), and port registers 6, 7 (P6, P7)).
  - IICA control register n0 (IICCTLn0)
  - IICA flag register n (IICFn)
  - IICA status register n (IICSn)
  - IICA control register n1 (IICCTLn1)
  - IICA low-level width setting register n (IICWLn)
  - IICA high-level width setting register n (IICWHn)

Caution 2. Be sure to clear the following bits to 0.

32-pin product with USB: bit 7

Remark n = 0 to 2

# 12.3.2 IICA control register n0 (IICCTLn0)

This register is used to enable/stop I<sup>2</sup>C operations, set wait timing, and set other I<sup>2</sup>C operations.

The IICCTLn0 register can be set by a 1-bit or 8-bit memory manipulation instruction. However, set the SPIEn, WTIMn, and ACKEn bits while IICEn = 0 or during the wait period. These bits can be set at the same time when the IICEn bit is set from "0" to "1".

Reset signal generation clears this register to 00H.



#### Figure 12 - 6 Format of IICA control register n0 (IICCTLn0) (1/4)

Address: F0230H (IICCTL00), F0238H (IICCTL10), F0240H (IICCTL20) After reset: 00H R/W

| Symbol   | <7>                                                                            | <6>                                                                                       | <5>                               | <4>   | <3>   | <2>   | <1>  | <0>  |
|----------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------|-------|-------|-------|------|------|
| IICCTLn0 | llCEn                                                                          | LRELn                                                                                     | WRELn                             | SPIEn | WTIMn | ACKEn | STTn | SPTn |
|          |                                                                                |                                                                                           |                                   |       |       |       |      |      |
|          | llCEn                                                                          |                                                                                           | I <sup>2</sup> C operation enable |       |       |       |      |      |
|          | 0                                                                              | Stop operation. Reset the IICA status register n (IICSn) Note 1. Stop internal operation. |                                   |       |       |       |      |      |
|          | 1                                                                              | 1 Enable operation.                                                                       |                                   |       |       |       |      |      |
|          | Be sure to set this bit (1) while the SCLAn and SDAAn lines are at high level. |                                                                                           |                                   |       |       |       |      |      |

| <ul> <li>Cleared</li> </ul> | by | instruction |
|-----------------------------|----|-------------|

Reset

Condition for clearing (IICEn = 0)

| LRELn<br>Notes 2, 3 | Exit from communications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0                   | Normal operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 5                   | This exits from the current communications and sets standby mode. This setting is automatically cleared to 0 after being executed.         Its uses include cases in which a locally irrelevant extension code has been received.         The SCLAn and SDAAn lines are set to high impedance.         The following flags of IICA control register n0 (IICCTLn0) and the IICA status register n (IICSn) are cleared to 0.         • STTn       • SPTn         • SPTn       • MSTSn       • EXCn         • collowing exit from communications remains in effect until the following communications entry |  |  |
| After a stop        | <ul><li>conditions are met.</li><li>After a stop condition is detected, restart is in master mode.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                     | match or extension code reception occurs after the start condition.<br>clearing (LRELn = 0) Condition for setting (LRELn = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|                     | ly cleared after execution • Set by instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |

Condition for setting (IICEn = 1)

Set by instruction

| WRELn<br>Notes 2, 3                                                   | Wait cancellation                                                                                                                                                                              |                    |  |
|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--|
| 0                                                                     | Do not cancel wait                                                                                                                                                                             |                    |  |
| 1                                                                     | Cancel wait. This setting is automatically cleared after wait is canceled.                                                                                                                     |                    |  |
|                                                                       | When the WRELn bit is set (wait canceled) during the wait period at the ninth clock pulse in the transmission status (TRCn = 1), the SDAAn line goes into the high impedance state (TRCn = 0). |                    |  |
| Condition for o                                                       | Condition for clearing (WRELn = 0) Condition for setting (WRELn = 1)                                                                                                                           |                    |  |
| <ul><li>Automatically cleared after execution</li><li>Reset</li></ul> |                                                                                                                                                                                                | Set by instruction |  |

**Note 1.** The IICA shift register n (IICAn), the STCFn and IICBSYn bits of the IICA flag register n (IICFn), and the CLDn and DADn bits of IICA control register n1 (IICCTLn1) are reset.

Note 2. The signal of this bit is invalid while IICEn is 0.

**Note 3.** When the LRELn and WRELn bits are read, 0 is always read.

Caution If the operation of I<sup>2</sup>C is enabled (IICEn = 1) when the SCLAn line is high level, the SDAAn line is low level, and the digital filter is turned on (DFCn bit of IICCTLn1 register = 1), a start condition will be inadvertently detected immediately. In this case, set (1) the LRELn bit by using a 1-bit memory manipulation instruction immediately after enabling operation of I<sup>2</sup>C (IICEn = 1).

| SPIEn<br>Note 1                    | Enable/disable generation of interrupt request when stop condition is detected                                                |                                   |  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|
| 0                                  | Disable                                                                                                                       |                                   |  |
| 1                                  | Enable                                                                                                                        |                                   |  |
| If the WUPn b                      | If the WUPn bit of IICA control register n1 (IICCTLn1) is 1, no stop condition interrupt will be generated even if SPIEn = 1. |                                   |  |
| Condition for clearing (SPIEn = 0) |                                                                                                                               | Condition for setting (SPIEn = 1) |  |
| Cleared by instruction             |                                                                                                                               | Set by instruction                |  |

Reset

| WTIMn<br>Note 1                                                      | Control of wait and interrupt request generation                                                                              |                                                              |  |
|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|
| 0                                                                    | Interrupt request is generated at the eighth of                                                                               | clock's falling edge.                                        |  |
|                                                                      | Master mode: After output of eight clocks, cl                                                                                 | ock output is set to low level and wait is set.              |  |
|                                                                      | Slave mode: After input of eight clocks, the o                                                                                | clock is set to low level and wait is set for master device. |  |
| 1                                                                    | Interrupt request is generated at the ninth clo                                                                               | ock's falling edge.                                          |  |
|                                                                      | Master mode: After output of nine clocks, clo                                                                                 | ock output is set to low level and wait is set.              |  |
|                                                                      | Slave mode: After input of nine clocks, the clock is set to low level and wait is set for master device.                      |                                                              |  |
| An interrupt is                                                      | An interrupt is generated at the falling edge of the ninth clock during address transfer independently of the setting of this |                                                              |  |
| bit. The setting                                                     | bit. The setting of this bit is valid when the address transfer is completed. When in master mode, a wait is inserted at the  |                                                              |  |
| falling edge of                                                      | falling edge of the ninth clock during address transfers. For a slave device that has received a local address, a wait is     |                                                              |  |
| inserted at the                                                      | e falling edge of the ninth clock after an ackno                                                                              | wledge (ACK) is issued. However, when the slave device       |  |
| has received                                                         | an extension code, a wait is inserted at the fal                                                                              | lling edge of the eighth clock.                              |  |
| Condition for clearing (WTIMn = 0) Condition for setting (WTIMn = 1) |                                                                                                                               |                                                              |  |
| Cleared by instruction                                               |                                                                                                                               | Set by instruction                                           |  |
| • Reset                                                              |                                                                                                                               |                                                              |  |

| ACKEn<br>Notes 1, 2                                    | Acknowledgment control                                                                    |                                   |  |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------|--|
| 0                                                      | Disable acknowledgment.                                                                   |                                   |  |
| 1                                                      | Enable acknowledgment. During the ninth clock period, the SDAAn line is set to low level. |                                   |  |
| Condition for clearing (ACKEn = 0)                     |                                                                                           | Condition for setting (ACKEn = 1) |  |
| <ul><li>Cleared by instruction</li><li>Reset</li></ul> |                                                                                           | Set by instruction                |  |

Note 1. The signal of this bit is invalid while IICEn is 0. Set this bit during that period.

Note 2. The set value is invalid during address transfer and if the code is not an extension code. When the device serves as a slave and the addresses match, an acknowledgment is generated regardless of the set value.

n = 0 to 2 Remark



| STTn<br>Notes 1, 2                                                                                              | Start condition trigger                                                     |                                                           |  |
|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------|--|
| 0                                                                                                               | Do not generate a start condition.                                          |                                                           |  |
| 1                                                                                                               | When bus is released (in standby state, whe                                 | n IICBSYn = 0):                                           |  |
|                                                                                                                 | If this bit is set (1), a start condition is gene                           | rated (startup as the master).                            |  |
|                                                                                                                 | When a third party is communicating:                                        |                                                           |  |
|                                                                                                                 | When communication reservation function                                     | is enabled (IICRSVn = 0)                                  |  |
|                                                                                                                 | Functions as the start condition reservation                                | flag. When set to 1, automatically generates a start      |  |
|                                                                                                                 | condition after the bus is released.                                        |                                                           |  |
|                                                                                                                 | When communication reservation function                                     | is disabled (IICRSVn = 1)                                 |  |
|                                                                                                                 | Even if this bit is set (1), the STTn bit is cle<br>condition is generated. | ared and the STTn clear flag (STCFn) is set (1). No start |  |
|                                                                                                                 | In the wait state (when master device):                                     |                                                           |  |
|                                                                                                                 | Generates a restart condition after releasin                                | g the wait.                                               |  |
| Cautions cond                                                                                                   | cerning set timing                                                          |                                                           |  |
| • For master reception: Cannot be set to 1 during transfer. Can be set to 1 only in the waiting period when the |                                                                             |                                                           |  |
|                                                                                                                 | ACKEn bit has been cleared to (                                             | ) and slave has been notified of final reception.         |  |
| <ul> <li>For master t</li> </ul>                                                                                | ransmission: A start condition cannot be gene                               | rated normally during the acknowledge period. Set to 1    |  |
|                                                                                                                 | during the wait period that follow                                          | rs output of the ninth clock.                             |  |
| Cannot be s                                                                                                     | et to 1 at the same time as stop condition trigg                            | ger (SPTn).                                               |  |
| Once STTn                                                                                                       | is set (1), setting it again (1) before the clear o                         | condition is met is not allowed.                          |  |
| Condition for o                                                                                                 | clearing (STTn = 0)                                                         | Condition for setting (STTn = 1)                          |  |
| Cleared by s                                                                                                    | etting the STTn bit to 1 while communication                                | Set by instruction                                        |  |
| reservation i                                                                                                   | s prohibited.                                                               |                                                           |  |
| Cleared by left                                                                                                 | oss in arbitration                                                          |                                                           |  |
| Cleared after start condition is generated by master device                                                     |                                                                             |                                                           |  |
| Cleared by L                                                                                                    | RELn = 1 (exit from communications)                                         |                                                           |  |
| When IICEn                                                                                                      | = 0 (operation stop)                                                        |                                                           |  |
| Reset                                                                                                           |                                                                             |                                                           |  |

| Figure 12 - 8 Format of IICA control register n0 (I | IICCTLn0) (3/4) |
|-----------------------------------------------------|-----------------|
|-----------------------------------------------------|-----------------|

Note 1. The signal of this bit is invalid while IICEn is 0.

Note 2. The STTn bit is always read as 0.

 Remark 1. Bit 1 (STTn) becomes 0 when it is read after data setting.

 Remark 2. IICRSVn:
 Bit 0 of IICA flag register n (IICFn)

 STCFn:
 Bit 7 of IICA flag register n (IICFn)



| SPTn Note                                                                                                                   | Stop condition trigger                                                 |                                  |                                  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------|----------------------------------|--|--|
| 0                                                                                                                           | Stop condition is not generated.                                       |                                  |                                  |  |  |
| 1                                                                                                                           | Stop condition is generated (termination of master device's transfer). |                                  |                                  |  |  |
| Cautions con                                                                                                                | Cautions concerning set timing                                         |                                  |                                  |  |  |
| • For master reception: Cannot be set to 1 during transfer.                                                                 |                                                                        | Cannot be set to 1 during transf | er.                              |  |  |
| Can be set to 1 only in the waiting period when the ACKEn bit has been cleared to 0 and                                     |                                                                        |                                  |                                  |  |  |
| slave has been notified of final reception.                                                                                 |                                                                        |                                  |                                  |  |  |
| • For master transmission: A stop condition cannot be generated normally during the acknowledge period. Therefore,          |                                                                        |                                  |                                  |  |  |
| set it during the wait period that follows output of the ninth clock.                                                       |                                                                        |                                  |                                  |  |  |
| <ul> <li>Cannot be set to 1 at the same time as start condition trigger (STTn).</li> </ul>                                  |                                                                        |                                  |                                  |  |  |
| The SPTn bit can be set to 1 only when in master mode.                                                                      |                                                                        |                                  |                                  |  |  |
| • When the WTIMn bit has been cleared to 0, if the SPTn bit is set to 1 during the wait period that follows output of eight |                                                                        |                                  |                                  |  |  |
| clocks, note that a stop condition will be generated during the high-level period of the ninth clock. The WTIMn bit         |                                                                        |                                  |                                  |  |  |
| should be changed from 0 to 1 during the wait period following the output of eight clocks, and the SPTn bit should be       |                                                                        |                                  |                                  |  |  |
| set to 1 during the wait period that follows the output of the ninth clock.                                                 |                                                                        |                                  |                                  |  |  |
| • Once SPTn is set (1), setting it again (1) before the clear condition is met is not allowed.                              |                                                                        |                                  |                                  |  |  |
| Condition for clearing (SPTn = 0)                                                                                           |                                                                        | PTn = 0)                         | Condition for setting (SPTn = 1) |  |  |
| Cleared by loss in arbitration                                                                                              |                                                                        | ation                            | Set by instruction               |  |  |
| <ul> <li>Automatically cleared after stop condition is detected</li> </ul>                                                  |                                                                        | fter stop condition is detected  |                                  |  |  |
| <ul> <li>Cleared by LRELn = 1 (exit from communications)</li> </ul>                                                         |                                                                        | exit from communications)        |                                  |  |  |
| <ul> <li>When IICEn = 0 (operation stop)</li> </ul>                                                                         |                                                                        | tion stop)                       |                                  |  |  |
| • Reset                                                                                                                     |                                                                        |                                  |                                  |  |  |

## Figure 12 - 9 Format of IICA control register n0 (IICCTLn0) (4/4)

Note When the SPTn register is read, 0 is always read.

Caution When bit 3 (TRCn) of the IICA status register n (IICSn) is set to 1 (transmission status), bit 5 (WRELn) of IICA control register n0 (IICCTLn0) is set to 1 during the ninth clock and wait is canceled, after which the TRCn bit is cleared (reception status) and the SDAAn line is set to high impedance. Release the wait performed while the TRCn bit is 1 (transmission status) by writing to the IICA shift register n.

n = 0 to 2 Remark



# 12.3.3 IICA status register n (IICSn)

This register indicates the status of I<sup>2</sup>C.

The IICSn register is read by a 1-bit or 8-bit memory manipulation instruction only when STTn = 1 and during the wait period.

Reset signal generation clears this register to 00H.

Caution Reading the IICSn register while the address match wakeup function is enabled (WUPn = 1) in STOP mode is prohibited. When the WUPn bit is changed from 1 to 0 (wakeup operation is stopped), regardless of the INTIICAn interrupt request, the change in status is not reflected until the next start condition or stop condition is detected. To use the wakeup function, therefore, enable (SPIEn = 1) the interrupt generated by detecting a stop condition and read the IICSn register after the interrupt has been detected.

#### Figure 12 - 10 Format of IICA status register n (IICSn) (1/3)

| Address: FFF51H (IICS0), FFF55H (IICS1), FFF61H (IICS2) |       |      |      | After reset: 00H R |      |       |      |      |
|---------------------------------------------------------|-------|------|------|--------------------|------|-------|------|------|
| Symbol                                                  | <7>   | <6>  | <5>  | <4>                | <3>  | <2>   | <1>  | <0>  |
| llCSn                                                   | MSTSn | ALDn | EXCn | COIn               | TRCn | ACKDn | STDn | SPDn |

| MSTSn                                          | Master status check flag                                                                                                                    |                                       |  |  |  |
|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--|--|--|
| 0                                              | Slave device status or communication standby status                                                                                         |                                       |  |  |  |
| 1                                              | Master device communication status                                                                                                          |                                       |  |  |  |
| Condition for clearing (MSTSn = 0)             |                                                                                                                                             | Condition for setting (MSTSn = 1)     |  |  |  |
| <ul><li>When ALDr</li><li>Cleared by</li></ul> | p condition is detected<br>n = 1 (arbitration loss)<br>LRELn = 1 (exit from communications)<br>CEn bit changes from 1 to 0 (operation stop) | When a start condition is generated ) |  |  |  |

| ALDn            | Detection of arbitration loss                                                                              |                                          |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------|------------------------------------------|--|--|--|--|
| 0               | This status means either that there was no arbitration or that the arbitration result was a "win".         |                                          |  |  |  |  |
| 1               | This status indicates the arbitration result was a "loss". The MSTSn bit is cleared.                       |                                          |  |  |  |  |
| Condition for o | clearing (ALDn = 0)                                                                                        | Condition for setting (ALDn = 1)         |  |  |  |  |
|                 | y cleared after the IICSn register is read <sup>Note</sup><br>CEn bit changes from 1 to 0 (operation stop) | When the arbitration result is a "loss". |  |  |  |  |

 Note
 This register is also cleared when a 1-bit memory manipulation instruction is executed for bits other than the

 IICSn register. Therefore, when using the ALDn bit, read the data of this bit before the data of the other bits.

 Remark 1. LRELn:
 Bit 6 of IICA control register n0 (IICCTLn0)

 IICEn:
 Bit 7 of IICA control register n0 (IICCTLn0)

 Remark 2. n = 0 to 2
 State of the state of the



Remark
 STTn:
 bit 1 of IICA control register n0 (IICCTLn0)

 WUPn:
 bit 7 of IICA control register n1 (IICCTLn1)

### Figure 12 - 11 Format of IICA status register n (IICSn) (2/3)

| EXCn                                                                                                                                                                                                                        | Detection of extension code reception |                                                                                                                                   |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0                                                                                                                                                                                                                           | Extension code was not received.      | Extension code was not received.                                                                                                  |  |  |  |  |
| 1                                                                                                                                                                                                                           | Extension code was received.          |                                                                                                                                   |  |  |  |  |
| Condition for clearing (EXCn = 0)                                                                                                                                                                                           |                                       | Condition for setting (EXCn = 1)                                                                                                  |  |  |  |  |
| <ul> <li>When a start condition is detected</li> <li>When a stop condition is detected</li> <li>Cleared by LRELn = 1 (exit from communications)</li> <li>When the IICEn bit changes from 1 to 0 (operation stop)</li> </ul> |                                       | • When the higher four bits of the received address data is either "0000" or "1111" (set at the rising edge of the eighth clock). |  |  |  |  |
| • Reset                                                                                                                                                                                                                     |                                       |                                                                                                                                   |  |  |  |  |

| COIn                                                                                                                                                | Detectio                                              | Detection of matching addresses                                                                                                             |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0                                                                                                                                                   | Addresses do not match.                               | Addresses do not match.                                                                                                                     |  |  |  |  |  |
| 1                                                                                                                                                   | Addresses match.                                      | Addresses match.                                                                                                                            |  |  |  |  |  |
| Condition fo                                                                                                                                        | r clearing (COIn = 0)                                 | Condition for setting (COIn = 1)                                                                                                            |  |  |  |  |  |
| When a ste                                                                                                                                          | art condition is detected<br>op condition is detected | • When the received address matches the local address<br>(slave address register n (SVAn))<br>(set at the rising edge of the eighth clock). |  |  |  |  |  |
| <ul> <li>Cleared by LRELn = 1 (exit from communications)</li> <li>When the IICEn bit changes from 1 to 0 (operation stop)</li> <li>Reset</li> </ul> |                                                       | (set at the fishing edge of the eighth clock).                                                                                              |  |  |  |  |  |

| TRCn                                                                                                                                                                                                                                                   | Detection                                                                                                                                                                                                                                                                                                                                                                                                 | of transmit/receive status                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0                                                                                                                                                                                                                                                      | Receive status (other than transmit status). The SDAAn line is set for high impedance.                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 1                                                                                                                                                                                                                                                      | Transmit status. The value in the SOn latch is enabled for output to the SDAAn line (valid starting at the falling edge of the first byte's ninth clock).                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Condition for                                                                                                                                                                                                                                          | clearing (TRCn = 0)                                                                                                                                                                                                                                                                                                                                                                                       | Condition for setting (TRCn = 1)                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| <ul> <li>Cleared by I</li> <li>When the III</li> <li>Cleared by V</li> <li>When the A</li> <li>Reset</li> <li>When not us = 0)</li> <li><master></master></li> <li>When "1" is direction spot</li> <li><slave></slave></li> <li>When a star</li> </ul> | p condition is detected<br>LRELn = 1 (exit from communications)<br>CEn bit changes from 1 to 0 (operation stop)<br>WRELn = 1 <sup>Note</sup> (wait cancel)<br>LDn bit changes from 0 to 1 (arbitration loss)<br>sed for communication (MSTSn, EXCn, COIn<br>output to the first byte's LSB (transfer<br>ecification bit)<br>rt condition is detected<br>input to the first byte's LSB (transfer direction | <master>     When a start condition is generated     When 0 (master transmission) is output to the LSB     (transfer direction specification bit) of the first byte     (during address transfer)     <slave>     When 1 (slave transmission) is input to the LSB (transfer     direction specification bit) of the first byte from the master     (during address transfer)</slave></master> |  |  |  |  |

Note When bit 3 (TRCn) of the IICA status register n (IICSn) is set to 1 (transmission status), bit 5 (WRELn) of IICA control register n0 (IICCTLn0) is set to 1 during the ninth clock and wait is canceled, after which the TRCn bit is cleared (reception status) and the SDAAn line is set to high impedance. Release the wait performed while the TRCn bit is 1 (transmission status) by writing to the IICA shift register n.

 Remark 1. LRELn:
 Bit 6 of IICA control register n0 (IICCTLn0)

 IICEn:
 Bit 7 of IICA control register n0 (IICCTLn0)

 Remark 2. n = 0 to 2
 State 100 (IICCTLn0)



## Figure 12 - 12 Format of IICA status register n (IICSn) (3/3)

| ACKDn                                                | Detection of acknowledge (ACK)                                                                                                                         |                                                                                                                 |  |  |  |  |
|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0                                                    | Acknowledge was not detected.                                                                                                                          |                                                                                                                 |  |  |  |  |
| 1                                                    | Acknowledge was detected.                                                                                                                              |                                                                                                                 |  |  |  |  |
| Condition for                                        | clearing (ACKDn = 0)                                                                                                                                   | Condition for setting (ACKDn = 1)                                                                               |  |  |  |  |
| <ul><li>At the rising</li><li>Cleared by I</li></ul> | o condition is detected<br>edge of the next byte's first clock<br>.RELn = 1 (exit from communications)<br>CEn bit changes from 1 to 0 (operation stop) | <ul> <li>After the SDAAn line is set to low level at the rising edge<br/>of SCLAn line's ninth clock</li> </ul> |  |  |  |  |

| STDn                                                                     | Detection of start condition                                                                                                                                              |                                      |  |  |  |  |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|--|--|
| 0                                                                        | Start condition was not detected.                                                                                                                                         |                                      |  |  |  |  |
| 1                                                                        | Start condition was detected. This indicates that the address transfer period is in effect.                                                                               |                                      |  |  |  |  |
| Condition for                                                            | clearing (STDn = 0)                                                                                                                                                       | Condition for setting (STDn = 1)     |  |  |  |  |
| <ul> <li>At the rising<br/>address tran</li> <li>Cleared by I</li> </ul> | o condition is detected<br>edge of the next byte's first clock following<br>nsfer<br>LRELn = 1 (exit from communications)<br>CEn bit changes from 1 to 0 (operation stop) | • When a start condition is detected |  |  |  |  |

| SPDn                                      | Detection of stop condition                                                                                                                                                   |                                     |  |  |  |  |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--|--|--|--|
| 0                                         | Stop condition was not detected.                                                                                                                                              |                                     |  |  |  |  |
| 1                                         | Stop condition was detected. The master device's communication is terminated and the bus is released.                                                                         |                                     |  |  |  |  |
| Condition for                             | clearing (SPDn = 0)                                                                                                                                                           | Condition for setting (SPDn = 1)    |  |  |  |  |
| following se<br>condition<br>• When the W | edge of the address transfer byte's first clock<br>tting of this bit and detection of a start<br>/UPn bit changes from 1 to 0<br>CEn bit changes from 1 to 0 (operation stop) | • When a stop condition is detected |  |  |  |  |

 Remark 1. LRELn:
 Bit 6 of IICA control register n0 (IICCTLn0)

 IICEn:
 Bit 7 of IICA control register n0 (IICCTLn0)

 Remark 2. n = 0 to 2
 IICEN

# 12.3.4 IICA flag register n (IICFn)

This register sets the operation mode of I<sup>2</sup>C and indicates the status of the I<sup>2</sup>C bus.

The IICFn register can be set by a 1-bit or 8-bit memory manipulation instruction. However, the STTn clear flag (STCFn) and I<sup>2</sup>C bus status flag (IICBSYn) bits are read-only.

The IICRSVn bit can be used to enable/disable the communication reservation function.

The STCENn bit can be used to set the initial value of the IICBSYn bit.

The IICRSVn and STCENn bits can be written only when the operation of  $I^2C$  is disabled (bit 7 (IICEn) of IICA control register n0 (IICCTLn0) = 0). When operation is enabled, the IICFn register can be read. Reset signal generation clears this register to 00H.



| ess: I | FFF52H (IICF                                                                           | 60), FFF56H (IIC                 | CF1), FFF62H (    | IICF2)           | After reset                                                                                        | :: 00H R/W       | Note                                               |              |  |
|--------|----------------------------------------------------------------------------------------|----------------------------------|-------------------|------------------|----------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------|--------------|--|
| ool    | <7>                                                                                    | <6>                              | 5                 | 4                | 3                                                                                                  | 2                | <1>                                                | <0>          |  |
| Fn     | STCFn                                                                                  | IICBSYn                          | 0                 | 0                | 0                                                                                                  | 0                | STCENn                                             | llCRSVr      |  |
| Г      | STCFn                                                                                  |                                  |                   |                  | STTn clear flag                                                                                    | ]                |                                                    |              |  |
|        | 0                                                                                      | Generate star                    | condition         |                  |                                                                                                    |                  |                                                    |              |  |
| _      | 1                                                                                      | Start condition                  | generation uns    | successful: cle  | ear the STTn flag                                                                                  | g                |                                                    |              |  |
| (      | Condition for                                                                          | clearing (STCF                   | n = 0)            |                  | Condition for                                                                                      | setting (STCF    | n = 1)                                             |              |  |
| •      | • Cleared by \$<br>• When IICEn<br>• Reset                                             | STTn = 1<br>= 0 (operation       | stop)             |                  | -                                                                                                  | when commu       | unsuccessful an<br>nication reservati              |              |  |
|        | llCBSYn                                                                                |                                  |                   |                  | <sup>2</sup> C bus status fl                                                                       | ag               |                                                    |              |  |
|        | 0                                                                                      | Bus release st                   | atus (communi     | cation initial s | tatus when STC                                                                                     | ENn = 1)         |                                                    |              |  |
|        | 1                                                                                      | Bus communie                     | cation status (co | ommunication     | initial status wh                                                                                  | en STCENn =      | 0)                                                 |              |  |
| (      | Condition for                                                                          | clearing (IICBS)                 | rn = 0)           |                  | Condition for                                                                                      | setting (IICBS   | Yn = 1)                                            |              |  |
| •      |                                                                                        | stop condition<br>= 0 (operation | stop)             |                  | <ul> <li>Detection of start condition</li> <li>Setting of the IICEn bit when STCENn = 0</li> </ul> |                  |                                                    |              |  |
|        | STCENn                                                                                 |                                  |                   | Initi            | al start enable ti                                                                                 | rigger           |                                                    |              |  |
|        | 0                                                                                      | After operation condition.       | n is enabled (IIC | CEn = 1), enal   | ole generation o                                                                                   | f a start condit | ion upon detectio                                  | on of a stop |  |
|        | 1                                                                                      | After operation condition.       | n is enabled (IIC | CEn = 1), enal   | ole generation o                                                                                   | f a start condit | ion without deteo                                  | ting a stop  |  |
| (      | Condition for                                                                          | clearing (STCE                   | Nn = 0)           |                  | Condition for                                                                                      | setting (STCE    | Nn = 1)                                            |              |  |
| •      | <ul> <li>Cleared by i</li> <li>Detection of</li> <li>Reset</li> </ul>                  | nstruction<br>start condition    |                   |                  | Set by instru                                                                                      | uction           |                                                    |              |  |
| Г      | llCRSVn                                                                                |                                  | C                 | Communicatio     | n reservation fu                                                                                   | nction disable   | bit                                                |              |  |
| ┝      | 0                                                                                      | Enable comm                      | unication reserv  | ation            |                                                                                                    |                  |                                                    |              |  |
| ╞      | 1                                                                                      | Disable comm                     | unication reser   | vation           |                                                                                                    |                  |                                                    |              |  |
| (      | Condition for                                                                          | l<br>clearing (IICRS)            | /n = 0)           |                  | Condition for setting (IICRSVn = 1)                                                                |                  |                                                    |              |  |
| ŀ      | Cleared by instruction     Reset                                                       |                                  |                   |                  | Set by instruction                                                                                 |                  |                                                    |              |  |
| с      | Note Bits 6 and 7 are read-only. Caution 1. Write to the STCENn bit only when the oper |                                  |                   |                  |                                                                                                    |                  |                                                    |              |  |
| С      | ST                                                                                     | CENn = 1, whe                    | n generating t    | he first start   | condition (STT                                                                                     | n = 1), it is ne | the actual bus<br>cessary to verif<br>ommunication | y that no t  |  |

## Figure 12 - 13 Format of IICA flag register n (IICFn)

destroyed.

Caution 3. Write to IICRSVn only when the operation is stopped (IICEn = 0).

| Remark 1. STTn: | Bit 1 of IICA control register n0 (IICCTLn0) |
|-----------------|----------------------------------------------|
|                 |                                              |

IICEn: Bit 7 of IICA control register n0 (IICCTLn0)

# 12.3.5 IICA control register n1 (IICCTLn1)

This register is used to set the operation mode of I<sup>2</sup>C and detect the statuses of the SCLAn and SDAAn pins. The IICCTLn1 register can be set by a 1-bit or 8-bit memory manipulation instruction. However, the CLDn and DADn bits are read-only.

Set the IICCTLn1 register, except the WUPn bit, while operation of I<sup>2</sup>C is disabled (bit 7 (IICEn) of IICA control register n0 (IICCTLn0) is 0).

Reset signal generation clears this register to 00H.

## Figure 12 - 14 Format of IICA control register n1 (IICCTLn1) (1/2)

Address: F0231H (IICCTL01), F0239H (IICCTL11), F0241H (IICCTL21) After reset: 00H R/W Note 1

| Symbol   | <7>  | 6 | <5>  | <4>  | <3>  | <2>  | 1 | <0>  |
|----------|------|---|------|------|------|------|---|------|
| IICCTLn1 | WUPn | 0 | CLDn | DADn | SMCn | DFCn | 0 | PRSn |

| WUPn                            | Control of address match wakeup                                                                                 |                                                                                                                                  |  |  |  |  |  |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0                               | Stops operation of address match wakeup function in STOP mode.                                                  |                                                                                                                                  |  |  |  |  |  |
| 1                               | Enables operation of address match wakeup                                                                       | o function in STOP mode.                                                                                                         |  |  |  |  |  |
| To shift to STO                 | OP mode when WUPn = 1, execute the STOF                                                                         | P instruction at least three fмск clocks after setting (1) the                                                                   |  |  |  |  |  |
| WUPn bit (see                   | e Figure 12 - 30 Flow When Setting WUPn :                                                                       | = 1).                                                                                                                            |  |  |  |  |  |
| Clear (0) the \                 | Clear (0) the WUPn bit after the address has matched or an extension code has been received. The subsequent     |                                                                                                                                  |  |  |  |  |  |
| communicatio                    | communication can be entered by the clearing (0) WUPn bit. (The wait must be released and transmit data must be |                                                                                                                                  |  |  |  |  |  |
| written after th                | ne WUPn bit has been cleared (0).)                                                                              |                                                                                                                                  |  |  |  |  |  |
| The interrupt t                 | timing when the address has matched or when                                                                     | n an extension code has been received, while WUPn = 1, is                                                                        |  |  |  |  |  |
| identical to the                | e interrupt timing when WUPn = 0. (A delay of                                                                   | f the difference of sampling by the clock will occur.)                                                                           |  |  |  |  |  |
| Furthermore,                    | Furthermore, when WUPn = 1, a stop condition interrupt is not generated even if the SPIEn bit is set to 1.      |                                                                                                                                  |  |  |  |  |  |
| Condition for o                 | clearing (WUPn = 0)                                                                                             | Condition for setting (WUPn = 1)                                                                                                 |  |  |  |  |  |
| Cleared by in<br>code reception | nstruction (after address match or extension<br>ion)                                                            | • Set by instruction (when the MSTSn, EXCn, and COIn bits are "0", and the STDn bit also "0" (communication not entered)) Note 2 |  |  |  |  |  |

Note 1. Bits 4 and 5 are read-only.

**Note 2.** The status of the IICA status register n (IICSn) must be checked and the WUPn bit must be set during the period shown below.



Check the IICSn operation status and set WUPn during this period.



## Figure 12 - 15 Format of IICA control register n1 (IICCTLn1) (2/2)

| CLDn                                                | Detection of SCLAn pin level (valid only when IICEn = 1) |                                     |  |  |  |
|-----------------------------------------------------|----------------------------------------------------------|-------------------------------------|--|--|--|
| 0                                                   | The SCLAn pin was detected at low level.                 |                                     |  |  |  |
| 1                                                   | The SCLAn pin was detected at high level.                |                                     |  |  |  |
| Condition for clearing (CLDn = 0)                   |                                                          | Condition for setting (CLDn = 1)    |  |  |  |
| When the SCLAn pin is at low level                  |                                                          | When the SCLAn pin is at high level |  |  |  |
| <ul> <li>When IICEn = 0 (operation stop)</li> </ul> |                                                          |                                     |  |  |  |
| • Reset                                             |                                                          |                                     |  |  |  |

| DADn                               | Detection of SDAAn pin level (valid only when IICEn = 1) |                                     |  |  |  |
|------------------------------------|----------------------------------------------------------|-------------------------------------|--|--|--|
| 0                                  | The SDAAn pin was detected at low level.                 |                                     |  |  |  |
| 1                                  | The SDAAn pin was detected at high level.                |                                     |  |  |  |
| Condition for clearing (DADn = 0)  |                                                          | Condition for setting (DADn = 1)    |  |  |  |
| When the SDAAn pin is at low level |                                                          | When the SDAAn pin is at high level |  |  |  |
| When IICEn                         | = 0 (operation stop)                                     |                                     |  |  |  |
| • Reset                            |                                                          |                                     |  |  |  |

| ſ | SMCn | Operation mode switching                                                                                   |  |  |  |
|---|------|------------------------------------------------------------------------------------------------------------|--|--|--|
|   | 0    | Operates in standard mode (fastest transfer rate: 100 kbps).                                               |  |  |  |
|   | 1    | Operates in fast mode (fastest transfer rate: 400 kbps) or fast mode plus (fastest transfer rate: 1 Mbps). |  |  |  |

| DFCn | Digital filter operation control |
|------|----------------------------------|
| 0    | Digital filter off.              |
| 1    | Digital filter on.               |

Use the digital filter only in fast mode and fast mode plus.

The digital filter is used for noise elimination.

The transfer clock does not vary, regardless of the DFCn bit being set (1) or cleared (0).

| PRSn | IICA operation clock (fмск) control            |  |
|------|------------------------------------------------|--|
| 0    | Selects fclk (1 MHz $\leq$ fclk $\leq$ 20 MHz) |  |
| 1    | Selects fcLk/2 (20 MHz $\leq$ fcLk)            |  |

Caution 1. The maximum operating frequency of the IICA operating clock (fMcK) is 20 MHz (Max.). Only when fcLK exceeds 20 MHz, set bit 0 (PRSn) of IICA control register n1 (IICCTLn1) to 1.

Caution 2. Note the minimum fcLk operating frequency when setting the transfer clock. The minimum fcLk operating frequency for serial interface IICA is determined according to the mode.

| Fast mode:      | fclк = 3.5 MHz (MIN.) |
|-----------------|-----------------------|
| Fast mode plus: | fclк = 10 MHz (MIN.)  |
| Normal mode:    | fclк = 1 MHz (MIN.)   |

Remark 1. IICEn: Bit 7 of IICA control register n0 (IICCTLn0) Remark 2. n = 0 to 2



## 12.3.6 IICA low-level width setting register n (IICWLn)

This register is used to set the low-level width (tLow) of the SCLAn pin signal that is output by serial interface IICA and to control the SDAAn pin signal.

The IICWLn register can be set by an 8-bit memory manipulation instruction.

Set the IICWLn register while operation of I<sup>2</sup>C is disabled (bit 7 (IICEn) of IICA control register n0 (IICCTLn0) is 0).

Reset signal generation sets this register to FFH.

For details about setting the IICWLn register, see **12.4.2 Setting transfer clock by using IICWLn and IICWHn registers**.

The data hold time is one-quarter of the time set by the IICWLn register.

### Figure 12 - 16 Format of IICA low-level width setting register n (IICWLn)

| Address: F | 0232H (IICWL | .0), F023AH (I | ICWL1), F0242 | H (IICWL2) | After reset: | FFH R/W |   |   |
|------------|--------------|----------------|---------------|------------|--------------|---------|---|---|
| Symbol     | 7            | 6              | 5             | 4          | 3            | 2       | 1 | 0 |
| IICWLn     |              |                |               |            |              |         |   |   |

# 12.3.7 IICA high-level width setting register n (IICWHn)

This register is used to set the high-level width of the SCLAn pin signal that is output by serial interface IICA and to control the SDAAn pin signal.

The IICWHn register can be set by an 8-bit memory manipulation instruction.

Set the IICWHn register while operation of I<sup>2</sup>C is disabled (bit 7 (IICEn) of IICA control register n0 (IICCTLn0) is 0).

Reset signal generation sets this register to FFH.

#### Figure 12 - 17 Format of IICA high-level width setting register n (IICWHn)

| Address: F0233H (IICWH0), F023BH (IICWH1), F0243H (IICWH2) |   |   |   |   | After reset | FFH R/W |   |   |
|------------------------------------------------------------|---|---|---|---|-------------|---------|---|---|
| Symbol                                                     | 7 | 6 | 5 | 4 | 3           | 2       | 1 | 0 |
| llCWHn                                                     |   |   |   |   |             |         |   |   |

Remark 1. For setting procedures of the transfer clock on master side and of the IICWLn and IICWHn registers on slave side, see 12.4.2 (1) and 12.4.2 (2), respectively.



# 12.3.8 Port mode registers 6, 7 (PM6, PM7)

These registers set the input/output of ports 6 and 7 in 1-bit units.

When using the P60/SCLA0 (P62/SCLA1, P70/SCLA2) pin as clock I/O and the P61/SDAA0 (P63/SDAA1, P71/SDAA2) pin as serial data I/O, clear PM60 (PM62, PM70) and PM61 (PM63, PM71), and the output latches of P60 (P62, P70) and P61 (P63, P71) to 0.

Set the IICEn bit (bit 7 of IICA control register n0 (IICCTLn0)) to 1 before setting the output mode because the P60/SCLA0 (P62/SCLA1, P70/SCLA2) and P61/SDAA0 (P63/SDAA1, P71/SDAA2) pins output a low level (fixed) when the IICEn bit is 0.

The PM6 and PM7 registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation sets this register to FFH.

| Address: FFF26H |          | After reset: FFI | H R/W             |               |                |                |      |      |
|-----------------|----------|------------------|-------------------|---------------|----------------|----------------|------|------|
| Symbol          | 7        | 6                | 5                 | 4             | 3              | 2              | 1    | 0    |
| PM6             | 1        | 1                | 1                 | 1             | PM63           | PM62           | PM61 | PM60 |
|                 | PM6x     |                  |                   | P6x pin I/O   | mode selection | n (x = 0 to 3) |      |      |
|                 | 0        | Output mode (    | output buffer o   | n)            |                |                |      |      |
|                 | 1        | Input mode (or   | utput buffer off) |               |                |                |      |      |
|                 |          | Figure 1         | 12 - 19 Form      | at of Port mo | ode register 7 | 7 (PM7)        |      |      |
| Address         | : FFF27H | After reset: FFI | H R/W             |               |                |                |      |      |
| Symbol          | 7        | 6                | 5                 | 4             | 3              | 2              | 1    | 0    |
| PM7             | 1        | 1                | 1                 | 1             | 1              | 1              | PM71 | PM70 |

#### Figure 12 - 18 Format of Port mode register 6 (PM6)

| PM7x | P7x pin I/O mode selection ( $x = 0, 1$ ) |
|------|-------------------------------------------|
| 0    | Output mode (output buffer on)            |
| 1    | Input mode (output buffer off)            |



# 12.4 I<sup>2</sup>C Bus Mode Functions

## 12.4.1 Pin configuration

The serial clock pin (SCLAn) and the serial data bus pin (SDAAn) are configured as follows.

- SCLAn..... This pin is used for serial clock input and output. This pin is an N-ch open-drain output for both master and slave devices. Input is Schmitt input.
- (2) SDAAn ..... This pin is used for serial data input and output.

This pin is an N-ch open-drain output for both master and slave devices. Input is Schmitt input.

Since outputs from the serial clock line and the serial data bus line are N-ch open-drain outputs, an external pull-up resistor is required.



Figure 12 - 20 Pin Configuration Diagram



# 12.4.2 Setting transfer clock by using IICWLn and IICWHn registers

(1) Setting transfer clock on master side

Transfer clock = \_\_\_\_\_\_ IICWL + IICWH + fмск (tR + tF)

At this time, the optimal setting values of the IICWLn and IICWHn registers are as follows. (The fractional parts of all setting values are rounded up.)

• When the fast mode

 $IICWLn = \frac{0.52}{\text{Transfer clock}} \times \text{fMCK}$ 

IICWHn = 
$$(\frac{0.48}{\text{Transfer clock}} - \text{tR} - \text{tF}) \times \text{fMCK}$$

When the standard mode

$$\text{IICWLn} = \frac{0.47}{\text{Transfer clock}} \times \text{fMCK}$$

$$IICWHn = \left(\frac{0.53}{\text{Transfer clock}} - tR - tF\right) \times fMCK$$

• When the fast mode plus

$$IICWLn = \frac{0.50}{\text{Transfer clock}} \times \text{fMCK}$$

$$IICWHn = (\frac{0.50}{Transfer \ clock} - tR - tF) \times fMCK$$

- (2) Setting IICWLn and IICWHn registers on slave side (The fractional parts of all setting values are truncated.)
  - When the fast mode
     IICWLn = 1.3 μs × fMCK
     IICWHn = (1.2 μs tR tF) × fMCK
  - When the standard mode IICWLn = 4.7  $\mu$ s × fMCK IICWHn = (5.3  $\mu$ s – tR – tF) × fMCK
  - When the fast mode plus IICWLn = 0.50  $\mu s$  × fMCK IICWHn = (0.50  $\mu s$  – tR – tF) × fMCK

Caution 1.The maximum operating frequency of the IICA operating clock (fмcκ) is 20 MHz (Max.). Only when fcLκ exceeds 20 MHz, set bit 0 (PRSn) of IICA control register n1 (IICCTLn1) to 1.

Caution 2. Note the minimum fcLK operating frequency when setting the transfer clock. The minimum fcLK operating frequency for serial interface IICA is determined according to the mode.

| Fast mode:      | fclк = 3.5 MHz (MIN.) |
|-----------------|-----------------------|
| Fast mode plus: | fclк = 10 MHz (MIN.)  |
| Normal mode:    | fclk = 1 MHz (MIN.)   |

(**Remarks** are listed on the next page.)

- **Remark 1.** Calculate the rise time (tR) and fall time (tF) of the SDAAn and SCLAn signals separately, because they differ depending on the pull-up resistance and wire load.
- $\label{eq:result} \textbf{Remark 2.} \ \textbf{IICWLn:} \ \textbf{IICA} \ \textbf{low-level width setting register n}$ 
  - IICWHn: IICA high-level width setting register n
  - tF: SDAAn and SCLAn signal falling times
  - tR: SDAAn and SCLAn signal rising times
  - fMCK: IICA operating clock frequency
- Remark 3. n = 0 to 2



## 12.5 I<sup>2</sup>C Bus Definitions and Control Methods

The I<sup>2</sup>C bus's serial data communication format and the signals used by the I<sup>2</sup>C bus are described below. Figure 12 - 21 shows the transfer timing for the "start condition", "address", "data", and "stop condition" output via the I<sup>2</sup>C bus's serial data bus.





The master device generates the start condition, slave address, and stop condition.

The acknowledge (ACK) can be generated by either the master or slave device (normally, it is output by the device that receives 8-bit data).

The serial clock (SCLAn) is continuously output by the master device. However, in the slave device, the SCLAn pin low level period can be extended and a wait can be inserted.

## 12.5.1 Start conditions

A start condition is met when the SCLAn pin is at high level and the SDAAn pin changes from high level to low level. The start conditions for the SCLAn pin and SDAAn pin are signals that the master device generates to the slave device when starting a serial transfer. When the device is used as a slave, start conditions can be detected.





A start condition is output when bit 1 (STTn) of IICA control register n0 (IICCTLn0) is set (1) after a stop condition has been detected (SPDn: Bit 0 of the IICA status register n (IICSn) = 1). When a start condition is detected, bit 1 (STDn) of the IICSn register is set (1).



## 12.5.2 Addresses

The address is defined by the 7 bits of data that follow the start condition.

An address is a 7-bit data segment that is output in order to select one of the slave devices that are connected to the master device via the bus lines. Therefore, each slave device connected via the bus lines must have a unique address.

The slave devices include hardware that detects the start condition and checks whether or not the 7-bit address data matches the data values stored in the slave address register n (SVAn). If the address data matches the SVAn register values, the slave device is selected and communicates with the master device until the master device generates a start condition or stop condition.



Note INTIICAn is not issued if data other than a local address or extension code is received during slave device operation.

Addresses are output when a total of 8 bits consisting of the slave address and the transfer direction described in **12.5.3 Transfer direction specification** are written to the IICA shift register n (IICAn). The received addresses are written to the IICAn register.

The slave address is assigned to the higher 7 bits of the IICAn register.

# 12.5.3 Transfer direction specification

In addition to the 7-bit address data, the master device sends 1 bit that specifies the transfer direction. When this transfer direction specification bit has a value of "0", it indicates that the master device is transmitting data to a slave device. When the transfer direction specification bit has a value of "1", it indicates that the master device is receiving data from a slave device.



Note INTIICAn is not issued if data other than a local address or extension code is received during slave device operation.



# 12.5.4 Acknowledge (ACK)

ACK is used to check the status of serial data at the transmission and reception sides.

The reception side returns ACK each time it has received 8-bit data.

The transmission side usually receives ACK after transmitting 8-bit data. When ACK is returned from the reception side, it is assumed that reception has been correctly performed and processing is continued. Whether ACK has been detected can be checked by using bit 2 (ACKDn) of the IICA status register n (IICSn).

When the master receives the last data item, it does not return ACK and instead generates a stop condition. If a slave does not return ACK after receiving data, the master outputs a stop condition or restart condition and stops transmission. If ACK is not returned, the possible causes are as follows.

- <1> Reception was not performed normally.
- <2> The final data item was received.
- <3> The reception side specified by the address does not exist.

To generate ACK, the reception side makes the SDAAn line low at the ninth clock (indicating normal reception). Automatic generation of ACK is enabled by setting bit 2 (ACKEn) of IICA control register n0 (IICCTLn0) to 1. Bit 3 (TRCn) of the IICSn register is set by the data of the eighth bit that follows 7-bit address information. Usually, set the ACKEn bit to 1 for reception (TRCn = 0).

If a slave can receive no more data during reception (TRCn = 0) or does not require the next data item, then the slave must inform the master, by clearing the ACKEn bit to 0, that it will not receive any more data.

When the master does not require the next data item during reception (TRCn = 0), it must clear the ACKEn bit to 0 so that ACK is not generated. In this way, the master informs a slave at the transmission side that it does not require any more data (transmission will be stopped).



When the local address is received, ACK is automatically generated, regardless of the value of the ACKEn bit. When an address other than that of the local address is received, ACK is not generated (NACK). When an extension code is received, ACK is generated if the ACKEn bit is set to 1 in advance. How ACK is generated when data is received differs as follows depending on the setting of the wait timing.

- When 8-clock wait state is selected (bit 3 (WTIMn) of IICCTLn0 register = 0): By setting the ACKEn bit to 1 before releasing the wait state, ACK is generated at the falling edge of the eighth clock of the SCLAn pin.
- When 9-clock wait state is selected (bit 3 (WTIMn) of IICCTLn0 register = 1): ACK is generated by setting the ACKEn bit to 1 in advance.



## 12.5.5 Stop condition

When the SCLAn pin is at high level, changing the SDAAn pin from low level to high level generates a stop condition.

A stop condition is a signal that the master device generates to the slave device when serial transfer has been completed. When the device is used as a slave, stop conditions can be detected.

Figure 12 - 26 Stop Condition



A stop condition is generated when bit 0 (SPTn) of IICA control register n0 (IICCTLn0) is set to 1. When the stop condition is detected, bit 0 (SPDn) of the IICA status register n (IICSn) is set to 1 and INTIICAn is generated when bit 4 (SPIEn) of the IICCTLn0 register is set to 1.



## 12.5.6 Wait

The wait is used to notify the communication partner that a device (master or slave) is preparing to transmit or receive data (i.e., is in a wait state).

Setting the SCLAn pin to low level notifies the communication partner of the wait state. When wait state has been canceled for both the master and slave devices, the next data transfer can begin.



(1) When master device has a nine-clock wait and slave device has an eight-clock wait (master transmits, slave receives, and ACKEn = 1)



```
Remark n = 0 to 2
```





(2) When master and slave devices both have a nine-clock wait (master transmits, slave receives, and ACKEn = 1)



Generate according to previously set ACKEn value

 Remark
 ACKEn:
 Bit 2 of IICA control register n0 (IICCTLn0)

 WRELn:
 Bit 5 of IICA control register n0 (IICCTLn0)

A wait may be automatically generated depending on the setting of bit 3 (WTIMn) of IICA control register n0 (IICCTLn0).

Normally, the receiving side cancels the wait state when bit 5 (WRELn) of the IICCTLn0 register is set to 1 or when FFH is written to the IICA shift register n (IICAn), and the transmitting side cancels the wait state when data is written to the IICAn register.

The master device can also cancel the wait state via either of the following methods.

- By setting bit 1 (STTn) of the IICCTLn0 register to 1
- By setting bit 0 (SPTn) of the IICCTLn0 register to 1



# 12.5.7 Canceling wait

The I<sup>2</sup>C usually cancels a wait state by the following processing.

- Writing data to the IICA shift register n (IICAn)
- Setting bit 5 (WRELn) of IICA control register n0 (IICCTLn0) (canceling wait)
- Setting bit 1 (STTn) of the IICCTLn0 register (generating start condition) Note
- Setting bit 0 (SPTn) of the IICCTLn0 register (generating stop condition) Note

Note Master only

When the above wait canceling processing is executed, the I<sup>2</sup>C cancels the wait state and communication is resumed.

To cancel a wait state and transmit data (including addresses), write the data to the IICAn register.

To receive data after canceling a wait state, or to complete data transmission, set bit 5 (WRELn) of the IICCTLn0 register to 1.

To generate a restart condition after canceling a wait state, set bit 1 (STTn) of the IICCTLn0 register to 1.

To generate a stop condition after canceling a wait state, set bit 0 (SPTn) of the IICCTLn0 register to 1.

Execute the canceling processing only once for one wait state.

If, for example, data is written to the IICAn register after canceling a wait state by setting the WRELn bit to 1, an incorrect value may be output to SDAAn line because the timing for changing the SDAAn line conflicts with the timing for writing the IICAn register.

In addition to the above, communication is stopped if the IICEn bit is cleared to 0 when communication has been aborted, so that the wait state can be canceled.

If the I<sup>2</sup>C bus has deadlocked due to noise, processing is saved from communication by setting bit 6 (LRELn) of the IICCTLn0 register, so that the wait state can be canceled.

# Caution If a processing to cancel a wait state is executed when WUPn = 1, the wait state will not be canceled.



# 12.5.8 Interrupt request (INTIICAn) generation timing and wait control

The setting of bit 3 (WTIMn) of IICA control register n0 (IICCTLn0) determines the timing by which INTIICAn is generated and the corresponding wait control, as shown in Table 12 - 2.

|       |                               |                |                      | J                              |                |                      |
|-------|-------------------------------|----------------|----------------------|--------------------------------|----------------|----------------------|
| WTIMn | During Slave Device Operation |                |                      | During Master Device Operation |                |                      |
|       | Address                       | Data Reception | Data<br>Transmission | Address                        | Data Reception | Data<br>Transmission |
| 0     | g Notes 1, 2                  | 8 Note 2       | 8 Note 2             | 9                              | 8              | 8                    |
| 1     | g Notes 1, 2                  | g Note 2       | g Note 2             | 9                              | 9              | 9                    |

### Table 12 - 2 INTIICAn Generation Timing and Wait Control

Note 1. The slave device's INTIICAn signal and wait period occurs at the falling edge of the ninth clock only when there is a match with the address set to the slave address register n (SVAn). At this point, ACK is generated regardless of the value set to the IICCTLn0 register's bit 2 (ACKEn). For a slave device that has received an extension code, INTIICAn occurs at the falling edge of the eighth clock. However, if the address does not match after restart, INTIICAn is generated at the falling edge of the 9th clock, but wait does not occur.

Note 2. If the received address does not match the contents of the slave address register n (SVAn) and extension code is not received, neither INTIICAn nor a wait occurs.

# **Remark** The numbers in the table indicate the number of the serial clock's clock signals. Interrupt requests and wait control are both synchronized with the falling edge of these clock signals.

- (1) During address transmission/reception
  - Slave device operation: Interrupt and wait timing are determined depending on the conditions described in Notes 1 and 2 above, regardless of the WTIMn bit.
  - Master device operation: Interrupt and wait timing occur at the falling edge of the ninth clock regardless of the WTIMn bit.

#### (2) During data reception

• Master/slave device operation: Interrupt and wait timing are determined according to the WTIMn bit.

#### (3) During data transmission

• Master/slave device operation: Interrupt and wait timing are determined according to the WTIMn bit.



- (4) Wait cancellation method
  - The four wait cancellation methods are as follows.
  - Writing data to the IICA shift register n (IICAn)
  - Setting bit 5 (WRELn) of IICA control register n0 (IICCTLn0) (canceling wait)
  - Setting bit 1 (STTn) of IICCTLn0 register (generating start condition) Note
  - Setting bit 0 (SPTn) of IICCTLn0 register (generating stop condition) Note

Note Master only.

When an 8-clock wait has been selected (WTIMn = 0), the presence/absence of ACK generation must be determined prior to wait cancellation.

(5) Stop condition detection

INTIICAn is generated when a stop condition is detected (only when SPIEn = 1).

## 12.5.9 Address match detection method

In I<sup>2</sup>C bus mode, the master device can select a particular slave device by transmitting the corresponding slave address.

Address match can be detected automatically by hardware. An interrupt request (INTIICAn) occurs when the address set to the slave address register n (SVAn) matches the slave address sent by the master device, or when an extension code has been received.

# 12.5.10 Error detection

In I<sup>2</sup>C bus mode, the status of the serial data bus (SDAAn) during data transmission is captured by the IICA shift register n (IICAn) of the transmitting device, so the IICA data prior to transmission can be compared with the transmitted IICA data to enable detection of transmission errors. A transmission error is judged as having occurred when the compared data values do not match.



## 12.5.11 Extension code

- (1) When the higher 4 bits of the receive address are either "0000" or "1111", the extension code reception flag (EXCn) is set to 1 for extension code reception and an interrupt request (INTIICAn) is issued at the falling edge of the eighth clock. The local address stored in the slave address register n (SVAn) is not affected.
- (2) The settings below are specified if 11110xx0 is transferred from the master by using a 10-bit address transfer when the SVAn register is set to 11110xx0. Note that INTIICAn occurs at the falling edge of the eighth clock.
  - Higher four bits of data match: EXCn = 1
  - Seven bits of data match: COIn = 1

| Remark | EXCn: | Bit 5 of IICA status register n (IICSn) |
|--------|-------|-----------------------------------------|
|        | COIn: | Bit 4 of IICA status register n (IICSn) |

(3) Since the processing after the interrupt request occurs differs according to the data that follows the extension code, such processing is performed by software.

If the extension code is received while a slave device is operating, then the slave device is participating in communication even if its address does not match.

For example, after the extension code is received, if you do not wish to operate the target device as a slave device, set bit 6 (LRELn) of IICA control register n0 (IICCTLn0) to 1 to set the standby mode for the next communication operation.

| Slave Address | R/W Bit                                                              | Description                                                                           |  |
|---------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|
| 0000 000      | 0 General call address                                               |                                                                                       |  |
| 1111 0xx      | 0 10-bit slave address specification (during address authentication) |                                                                                       |  |
| 1111 0xx      | 1                                                                    | 10-bit slave address specification (after address match, when read command is issued) |  |

#### Table 12 - 3 Bit Definitions of Major Extension Codes

**Remark 1.** See the I<sup>2</sup>C bus specifications issued by NXP Semiconductors for details of extension codes other than those described above.



# 12.5.12 Arbitration

When several master devices simultaneously generate a start condition (when the STTn bit is set to 1 before the STDn bit is set to 1), communication among the master devices is performed as the number of clocks are adjusted until the data differs. This kind of operation is called arbitration.

When one of the master devices loses in arbitration, an arbitration loss flag (ALDn) in the IICA status register n (IICSn) is set (1) via the timing by which the arbitration loss occurred, and the SCLAn and SDAAn lines are both set to high impedance, which releases the bus.

The arbitration loss is detected based on the timing of the next interrupt request (the eighth or ninth clock, when a stop condition is detected, etc.) and the ALDn = 1 setting that has been made by software.

For details of interrupt request timing, see **12.5.8 Interrupt request (INTIICAn) generation timing and wait control**.

 Remark
 STDn:
 Bit 1 of IICA status register n (IICSn)

 STTn:
 Bit 1 of IICA control register n0 (IICCTLn0)







| Status During Arbitration                                                        | Interrupt Request Generation Timing                                                   |  |
|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|
| During address transmission                                                      | At falling edge of eighth or ninth clock following byte transfer Note 1               |  |
| Read/write data after address transmission                                       |                                                                                       |  |
| During extension code transmission                                               |                                                                                       |  |
| Read/write data after extension code transmission                                |                                                                                       |  |
| During data transmission                                                         |                                                                                       |  |
| During ACK transfer period after data transmission                               |                                                                                       |  |
| When restart condition is detected during data transfer                          |                                                                                       |  |
| When stop condition is detected during data transfer                             | When stop condition is generated (when SPIEn = 1)<br>Note 2                           |  |
| When data is at low level while attempting to generate a restart condition       | At falling edge of eighth or ninth clock following byte transfer Note 1               |  |
| When stop condition is detected while attempting to generate a restart condition | When stop condition is generated (when SPIEn = 1)<br>Note 2                           |  |
| When data is at low level while attempting to generate a stop condition          | At falling edge of eighth or ninth clock following byte<br>transfer <sup>Note 1</sup> |  |
| When SCLAn is at low level while attempting to generate a restart condition      |                                                                                       |  |

Table 12 - 4 Status During Arbitration and Interrupt Request Generation Timing

Note 1. When the WTIMn bit (bit 3 of IICA control register n0 (IICCTLn0)) = 1, an interrupt request occurs at the falling edge of the ninth clock. When WTIMn = 0 and the extension code's slave address is received, an interrupt request occurs at the falling edge of the eighth clock.

**Note 2.** When there is a chance that arbitration will occur, set SPIEn = 1 for master device operation.

Remark 1. SPIEn: Bit 4 of IICA control register n0 (IICCTLn0)



# 12.5.13 Wakeup function

The I<sup>2</sup>C bus slave function is a function that generates an interrupt request signal (INTIICAn) when a local address and extension code have been received.

This function makes processing more efficient by preventing unnecessary INTIICAn signal from occurring when addresses do not match.

When a start condition is detected, wakeup standby mode is set. This wakeup standby mode is in effect while addresses are transmitted due to the possibility that an arbitration loss may change the master device (which has generated a start condition) to a slave device.

To use the wakeup function in the STOP mode, set the WUPn bit to 1. Addresses can be received regardless of the operation clock. An interrupt request signal (INTIICAn) is also generated when a local address and extension code have been received. Operation returns to normal operation by using an instruction to clear (0) the WUPn bit after this interrupt has been generated.

Figure 12 - 30 shows the flow for setting WUPn = 1 and Figure 12 - 31 shows the flow for setting WUPn = 0 upon an address match.









## Figure 12 - 31 Flow When Setting WUPn = 0 upon Address Match (Including Extension Code Reception)

Use the following flows to perform the processing to release the STOP mode other than by an interrupt request (INTIICAn) generated from serial interface IICA.

• When operating as the master device for the next IIC communication: Flow shown in Figure 12 - 32

- When operating as a slave device for the next IIC communication:
  - When the INTIICAn interrupt is used to return from the mode:

Same as the flow in Figure 12 - 31

When an interrupt other than the INTIICAn interrupt is used to return from the mode: Continue operation while WUPn = 1 until an INTIICAn interrupt is generated.





#### Figure 12 - 32 When Operating as Master Device after Releasing STOP Mode other than by INTIICAn

Remark n = 0 to 2



# 12.5.14 Communication reservation

- (1) When communication reservation function is enabled (bit 0 (IICRSVn) of IICA flag register n (IICFn) = 0) To start master device communications when not currently using a bus, a communication reservation can be made to enable transmission of a start condition when the bus is released. There are two modes under which the bus is not used.
  - When arbitration results in neither master nor slave operation
  - When an extension code is received and slave operation is disabled (ACK is not returned and the bus was released by setting bit 6 (LRELn) of IICA control register n0 (IICCTLn0) to 1 and saving communication).

If bit 1 (STTn) of the IICCTLn0 register is set to 1 while the bus is not used (after a stop condition is detected), a start condition is automatically generated and wait state is set.

If an address is written to the IICA shift register n (IICAn) after bit 4 (SPIEn) of the IICCTLn0 register was set to 1, and it was detected by generation of an interrupt request signal (INTIICAn) that the bus was released (detection of the stop condition), then the device automatically starts communication as the master. Data written to the IICAn register before the stop condition is detected is invalid.

When the STTn bit has been set to 1, the operation mode (as start condition or as communication reservation) is determined according to the bus status.

- If the bus has been released.....a start condition is generated
- If the bus has not been released (standby mode).....communication reservation

Check whether the communication reservation operates or not by using the MSTSn bit (bit 7 of the IICA status register n (IICSn)) after the STTn bit is set to 1 and the wait time elapses. Use software to secure the wait time calculated by the following expression.

Wait time from setting STTn = 1 to checking the MSTSn flag: (IICWLn setting value + IICWHn setting value + 4)/fMCK + tF  $\times$  2

Remark 1. IICWLn: IICA low-level width setting register n

IICWHn: IICA high-level width setting register n

- tF: SDAAn and SCLAn signal falling times
- fмск: IICA operating clock frequency



Figure 12 - 33 shows the Communication Reservation Timing.



Figure 12 - 33 Communication Reservation Timing

Remark IICAn: IICA shift register n

- STTn: Bit 1 of IICA control register n0 (IICCTLn0)
- STDn: Bit 1 of IICA status register n (IICSn)
- SPDn: Bit 0 of IICA status register n (IICSn)

Communication reservations are accepted via the timing shown in Figure 12 - 34. After bit 1 (STDn) of the IICA status register n (IICSn) is set to 1, a communication reservation can be made by setting bit 1 (STTn) of IICA control register n0 (IICCTLn0) to 1 before a stop condition is detected.





Standby mode (Communication can be reserved by setting STTn to 1 during this period.)

Figure 12 - 35 shows the Communication Reservation Protocol.



Generate by master device with bus mastership





- Note 1. The wait time is calculated as follows.
  - (IICWLn setting value + IICWHn setting value + 4)/fMCK + tF imes 2
- Note 2. The communication reservation operation executes a write to the IICA shift register n (IICAn) when a stop condition interrupt request occurs.

| Remark1. | STTn:   | n: Bit 1 of IICA control register n0 (IICCTLn0 |  |
|----------|---------|------------------------------------------------|--|
|          | MSTSn:  | Bit 7 of IICA status register n (IICSn)        |  |
|          | IICAn:  | IICA shift register n                          |  |
|          | IICWLn: | IICA low-level width setting register n        |  |
|          | IICWHn: | IICA high-level width setting register n       |  |
|          | tF:     | SDAAn and SCLAn signal falling times           |  |
|          | fмск:   | IICA operating clock frequency                 |  |
|          |         |                                                |  |



- (2) When communication reservation function is disabled (bit 0 (IICRSVn) of IICA flag register n (IICFn) = 1) When bit 1 (STTn) of IICA control register n0 (IICCTLn0) is set to 1 when the bus is not used in a communication during bus communication, this request is rejected and a start condition is not generated. The following two statuses are included in the status where bus is not used.
  - When arbitration results in neither master nor slave operation
  - When an extension code is received and slave operation is disabled (ACK is not returned and the bus was released by setting bit 6 (LRELn) of the IICCTLn0 register to 1 and saving communication)

To confirm whether the start condition was generated or request was rejected, check STCFn (bit 7 of the IICFn register). It takes up to five fMCK clocks until the STCFn bit is set to 1 after setting STTn = 1. Therefore, secure this time by software.



# 12.5.15 Cautions

(1) When STCENn = 0

Immediately after  $I^2C$  operation is enabled (IICEn = 1), the bus communication status (IICBSYn = 1) is recognized regardless of the actual bus status. When changing from a mode in which no stop condition has been detected to a master device communication mode, first generate a stop condition to release the bus, then perform master device communication.

When using multiple masters, it is not possible to perform master device communication when the bus has not been released (when a stop condition has not been detected).

Use the following sequence for generating a stop condition.

- <1> Set IICA control register n1 (IICCTLn1).
- <2> Set bit 7 (IICEn) of IICA control register n0 (IICCTLn0) to 1.
- <3> Set bit 0 (SPTn) of the IICCTLn0 register to 1.
- (2) When STCENn = 1

Immediately after  $I^2C$  operation is enabled (IICEn = 1), the bus released status (IICBSYn = 0) is recognized regardless of the actual bus status. To generate the first start condition (STTn = 1), it is necessary to confirm that the bus has been released, so as to not disturb other communications.

(3) If other I<sup>2</sup>C communications are already in progress

If I<sup>2</sup>C operation is enabled and the device participates in communication already in progress when the SDAAn pin is low and the SCLAn pin is high, the macro of I<sup>2</sup>C recognizes that the SDAAn pin has gone low (detects a start condition). If the value on the bus at this time can be recognized as an extension code, ACK is returned, but this interferes with other I<sup>2</sup>C communications. To avoid this, start I<sup>2</sup>C in the following sequence.

- <1> Clear bit 4 (SPIEn) of the IICCTLn0 register to 0 to disable generation of an interrupt request signal (INTIICAn) when the stop condition is detected.
- <2> Set bit 7 (IICEn) of the IICCTLn0 register to 1 to enable the operation of I<sup>2</sup>C.
- <3> Wait for detection of the start condition.
- <4> Set bit 6 (LRELn) of the IICCTLn0 register to 1 before ACK is returned (4 to 72 fMCK clocks after setting the IICEn bit to 1), to forcibly disable detection.
- (4) Setting the STTn and SPTn bits (bits 1 and 0 of the IICCTLn0 register) again after they are set and before they are cleared to 0 is prohibited.
- (5) When transmission is reserved, set the SPIEn bit (bit 4 of the IICCTLn0 register) to 1 so that an interrupt request is generated when the stop condition is detected. Transfer is started when communication data is written to the IICA shift register n (IICAn) after the interrupt request is generated. Unless the interrupt is generated when the stop condition is detected, the device stops in the wait state because the interrupt request is not generated when communication is started. However, it is not necessary to set the SPIEn bit to 1 when the MSTSn bit (bit 7 of the IICA status register n (IICSn)) is detected by software.



# 12.5.16 Communication operations

The following shows three operation procedures with the flowchart.

(1) Master operation in single master system

The flowchart when using the R9A02G015 as the master in a single master system is shown below. This flowchart is broadly divided into the initial settings and communication processing. Execute the initial settings at startup. If communication with the slave is required, prepare the communication and then execute communication processing.

(2) Master operation in multimaster system

In the I<sup>2</sup>C bus multimaster system, whether the bus is released or used cannot be judged by the I<sup>2</sup>C bus specifications when the bus takes part in a communication. Here, when data and clock are at a high level for a certain period (1 frame), the R9A02G015 takes part in a communication with bus released state. This flowchart is broadly divided into the initial settings, communication waiting, and communication processing. The processing when the R9A02G015 looses in arbitration and is specified as the slave is omitted here, and only the processing as the master is shown. Execute the initial settings at startup to take part in a communication. Then, wait for the communication request as the master or wait for the specification as the slave. The actual communication is performed in the communication processing, and it supports the transmission/reception with the slave and the arbitration with other masters.

(3) Slave operation

An example of when the R9A02G015 is used as the  $I^2C$  bus slave is shown below.

When used as the slave, operation is started by an interrupt. Execute the initial settings at startup, then wait for the INTIICAn interrupt occurrence (communication waiting). When an INTIICAn interrupt occurs, the communication status is judged and its result is passed as a flag over to the main processing. By checking the flags, necessary communication processing is performed.



(1) Master operation in single master system





- **Note** Release (SCLAn and SDAAn pins = high level) the I<sup>2</sup>C bus in conformance with the specifications of the product that is communicating. If EEPROM is outputting a low level to the SDAAn pin, for example, set the SCLAn pin in the output port mode, and output a clock pulse from the output port until the SDAAn pin is constantly at high level.
- Remark1. Conform to the specifications of the product that is communicating, with respect to the transmission and reception formats.

(2) Master operation in multimaster system





 Note
 Confirm that the bus is released (CLDn bit = 1, DADn bit = 1) for a specific period (for example, for a period of one frame).

 If the SDAAn pin is constantly at low level, decide whether to release the l<sup>2</sup>C bus (SCLAn and SDAAn pins = high level) in conformance with the specifications of the product that is communicating.



#### Figure 12 - 38 Master Operation in Multi-Master System (2/3)



Figure 12 - 39 Master Operation in Multi-Master System (3/3)

- Remark 1. Conform to the specifications of the product that is communicating, with respect to the transmission and reception formats.
- **Remark 2.** To use the device as a master in a multi-master system, read the MSTSn bit each time interrupt INTIICAn has occurred to check the arbitration result.
- Remark 3. To use the device as a slave in a multi-master system, check the status by using the IICA status register n (IICSn) and IICA flag register n (IICFn) each time interrupt INTIICAn has occurred, and determine the processing to be performed next.
- Remark 4. n = 0 to 2

## (3) Slave operation

The processing procedure of the slave operation is as follows.

Basically, the slave operation is event-driven. Therefore, processing by the INTIICAn interrupt (processing that must substantially change the operation status such as detection of a stop condition during communication) is necessary.

In the following explanation, it is assumed that the extension code is not supported for data communication. It is also assumed that the INTIICAn interrupt servicing only performs status transition processing, and that actual data communication is performed by the main processing.



Therefore, data communication processing is performed by preparing the following three flags and passing them to the main processing instead of INTIICAn.

<1> Communication mode flag

This flag indicates the following two communication statuses.

•Clear mode: Status in which data communication is not performed

•Communication mode: Status in which data communication is performed (from valid address detection to stop condition detection, no detection of ACK from master, address mismatch)

## <2> Ready flag

This flag indicates that data communication is enabled. Its function is the same as the INTIICAn interrupt for ordinary data communication. This flag is set by interrupt servicing and cleared by the main processing. Clear this flag by interrupt servicing when communication is started. However, the ready flag is not set by interrupt servicing when the first data is transmitted. Therefore, the first data is transmitted without the flag being cleared (an address match is interpreted as a request for the next data).

<3> Communication direction flag

This flag indicates the direction of communication. Its value is the same as the TRCn bit.



The main processing of the slave operation is explained next.

Start serial interface IICA and wait until communication is enabled. When communication is enabled, execute communication by using the communication mode flag and ready flag (processing of the stop condition and start condition is performed by an interrupt. Here, check the status by using the flags).

The transmission operation is repeated until the master no longer returns ACK. If ACK is not returned from the master, communication is completed.

For reception, the necessary amount of data is received. When communication is completed, ACK is not returned as the next data. After that, the master generates a stop condition or restart condition. Exit from the communication status occurs in this way.





**Remark1.** Conform to the specifications of the product that is in communication, regarding the transmission and reception formats. **Remark2.** n = 0 to 2



An example of the processing procedure of the slave with the INTIICAn interrupt is explained below (processing is performed assuming that no extension code is used). The INTIICAn interrupt checks the status, and the following operations are performed.

- <1> Communication is stopped if the stop condition is issued.
- <2> If the start condition is issued, the address is checked and communication is completed if the address does not match. If the address matches, the communication mode is set, wait is cancelled, and processing returns from the interrupt (the ready flag is cleared).
- <3> For data transmit/receive, only the ready flag is set. Processing returns from the interrupt with the l<sup>2</sup>C bus remaining in the wait state.

**Remark** <1> to <3> above correspond to <1> to <3> in Figure 12 - 41 Slave Operation Flowchart (2).



Figure 12 - 41 Slave Operation Flowchart (2)



# 12.5.17 Timing of I<sup>2</sup>C interrupt request (INTIICAn) occurrence

The timing of transmitting or receiving data and generation of interrupt request signal INTIICAn, and the value of the IICA status register n (IICSn) when the INTIICAn signal is generated are shown below.

 Remark 1. ST:
 Start condition

 AD6 to AD0:
 Address

 R/W:
 Transfer direction specification

 ACK:
 Acknowledge

 D7 to D0:
 Data

 SP:
 Stop condition

 Remark 2. n = 0 to 2
 Start condition



- (1) Master device operation
  - (a) Start ~ Address ~ Data ~ Data ~ Stop (transmission/reception)

(i) When WTIMn = 0



(ii) When WTIMn = 1





(b) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop (restart)

(i) When WTIMn = 0

|            |            |                     |        |         |                   | STT                   | n = 1     |                  |         |         |                 | SPT        | 'n = 1<br>↓ |          |
|------------|------------|---------------------|--------|---------|-------------------|-----------------------|-----------|------------------|---------|---------|-----------------|------------|-------------|----------|
| ST         | AD6 to A   | D0 F                | R/W    | ACK     | D7 to D0          | ACK                   | ST        | AD6 to AD0       | R/W     | ACK     | D7 to D0        | ACK        | SP          | 7        |
| ▲1         | : IICSn =  | 1000×1′             | 10B    |         | 1                 | ▲2                    | 3         |                  |         |         | 4               | <b>▲</b> 5 | ▲6          | ∆7       |
| ▲2         | 2: IICSn = | 1000×0              | 00B    | (Sets t | he WTIMn bit t    | to 1) <sup>Note</sup> | e 1       |                  |         |         |                 |            |             |          |
| <b>▲</b> 3 | 3: IICSn = | 1000××              | 00B    | (Clears | s the WTIMn bi    | it to 0 <sup>No</sup> | ote 2, se | ets the STTn bit | to 1)   |         |                 |            |             |          |
| ▲4         | : IICSn =  | 1000×1 <sup>.</sup> | 10B    |         |                   |                       |           |                  |         |         |                 |            |             |          |
| ▲5         | 5: IICSn = | 1000×0              | 00B    | (Sets t | he WTIMn bit t    | to 1) <sup>Note</sup> | e 3       |                  |         |         |                 |            |             |          |
| ▲6         | 6: IICSn = | 1000××              | 00B    | (Sets t | he SPTn bit to    | 1)                    |           |                  |         |         |                 |            |             |          |
| ∆7         | : IICSn =  | 000000              | 01B    |         |                   |                       |           |                  |         |         |                 |            |             |          |
| No         |            | o gener<br>equest s |        |         | condition, set t  | he WTI                | Vn bit    | to 1 and change  | the tir | ning fo | r generating th | e INTII    | CAn ir      | nterrupt |
| No         |            |                     |        |         | to 0 to restore   |                       |           | 0                |         |         |                 |            |             |          |
| No         |            | o gener<br>equest s |        | •       | condition, set tl | he WTI                | Vin bit   | to 1 and change  | the tir | ning fo | r generating th | e INTII    | CAn ir      | nterrupt |
| Re         | mark A     | : Alwa              | ys ge  | enerate | ed                |                       |           |                  |         |         |                 |            |             |          |
|            | Z          | : Gene              | erateo | d only  | when SPIEn =      | 1                     |           |                  |         |         |                 |            |             |          |
|            |            | : Don't             |        | _       |                   |                       |           |                  |         |         |                 |            |             |          |

(ii) When WTIMn = 1



(c) Start ~ Code ~ Data ~ Data ~ Stop (extension code transmission)

(i) When WTIMn = 0

|             |                 |           |          |                   |                      |                 | SP         | Tn = 1   |                                            |
|-------------|-----------------|-----------|----------|-------------------|----------------------|-----------------|------------|----------|--------------------------------------------|
| ST          | AD6 to AD0      | R/W       | ACK      | D7 to D0          | ACK                  | D7 to D0        | ACK        | K SP     | ]                                          |
|             |                 |           | <b></b>  | .1                | ▲2                   |                 | <b>▲</b> 3 | ▲4       | 5                                          |
|             | 1: IICSn = 1010 | ×110B     |          |                   |                      |                 |            |          |                                            |
| ▲:          | 2: IICSn = 1010 | ×000B     |          |                   |                      |                 |            |          |                                            |
|             | 3: IICSn = 1010 | ×000B (   | Sets th  | ne WTIMn bit to   | o 1) <sup>Note</sup> | 9               |            |          |                                            |
| <b>A</b> 4  | 4: IICSn = 1010 | ××00B (   | (Sets tł | he SPTn bit to    | 1)                   |                 |            |          |                                            |
| $\triangle$ | 5: IICSn = 0000 | 0001B     |          |                   |                      |                 |            |          |                                            |
|             |                 |           |          |                   |                      |                 |            |          |                                            |
| No          | te To gei       | nerate a  | stop c   | condition, set th | e WTI                | In bit to 1 and | chang      | e the ti | ming for generating the INTIICAn interrupt |
|             | reque           | st signal | Ι.       |                   |                      |                 |            |          |                                            |
|             | ·               | Ū         |          |                   |                      |                 |            |          |                                            |
| Re          | mark ▲: Al      | ways ge   | enerate  | d                 |                      |                 |            |          |                                            |
|             | ∧ · Ge          | enerated  | 1 only v | when SPIEn =      | 1                    |                 |            |          |                                            |
|             |                 | on't care |          |                   |                      |                 |            |          |                                            |
|             | ^ . DC          | in care   |          |                   |                      |                 |            |          |                                            |
|             |                 |           |          |                   |                      |                 |            |          |                                            |

(ii) When WTIMn = 1





- (2) Slave device operation (slave address data reception)
  - (a) Start ~ Address ~ Data ~ Data ~ Stop
    - (i) When WTIMn = 0



(ii) When WTIMn = 1

| ST AD6   | to AD0    | R/W      | ACK      | D7 to D0     | ACK | D7 to D0 | ACK | SP         |
|----------|-----------|----------|----------|--------------|-----|----------|-----|------------|
|          |           |          |          | 1            |     | 2        |     | <b>3</b> Z |
| ▲1: IICS | n = 0001: | ×110B    |          |              |     |          |     |            |
| ▲2: IICS | n = 0001: | ×100B    |          |              |     |          |     |            |
| ▲3: IICS | n = 0001: | <×00B    |          |              |     |          |     |            |
| ∆4: IICS | n = 00000 | 0001B    |          |              |     |          |     |            |
| Remark   | ▲ : Alv   | vays ge  | enerate  | d            |     |          |     |            |
|          | ∆∶Ge      | nerate   | d only v | vhen SPIEn = | 1   |          |     |            |
|          | × · Do    | n't care | e.       |              |     |          |     |            |



### (b) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop

(i) When WTIMn = 0 (after restart, matches with SVAn)

| ST          | AD6 to     | AD0 R/      | W ACK     | D7 to D0     | ACK | ST | AD6 to AD0 | R/W | ACK | D7 to D0 | ACK | SP |
|-------------|------------|-------------|-----------|--------------|-----|----|------------|-----|-----|----------|-----|----|
|             |            |             |           | <b>▲</b> 1   | ▲2  |    |            |     |     | 3        | ▲4  | ∆5 |
| <b>A</b> '  | 1: IICSn = | 0001×110    | )B        |              |     |    |            |     |     |          |     |    |
| ▲2          | 2: IICSn = | 0001×000    | 0B        |              |     |    |            |     |     |          |     |    |
| <b>▲</b> 3  | 3: IICSn = | 0001×110    | )B        |              |     |    |            |     |     |          |     |    |
| <b>A</b> 4  | 4: IICSn = | 0001×000    | ОB        |              |     |    |            |     |     |          |     |    |
| $\triangle$ | 5: IICSn = | 0000000     | 1B        |              |     |    |            |     |     |          |     |    |
|             |            |             |           |              |     |    |            |     |     |          |     |    |
| Re          | mark       | ▲: Always   | s genera  | ted          |     |    |            |     |     |          |     |    |
|             |            | ∆: Genera   | ated only | when SPIEn = | 1   |    |            |     |     |          |     |    |
|             |            | × : Don't c |           |              |     |    |            |     |     |          |     |    |

(ii) When WTIMn = 1 (after restart, matches with SVAn)





(c) Start ~ Address ~ Data ~ Start ~ Code ~ Data ~ Stop

(i) When WTIMn = 0 (after restart, does not match address (= extension code))

| ST AL    | 06 to AD0  | R/W      | ACK      | D7 to D0    | ACK | ST | AD6 to AD0 | R/W | ACK | D7 to D0 | ACK | SP |         |
|----------|------------|----------|----------|-------------|-----|----|------------|-----|-----|----------|-----|----|---------|
|          |            |          | <b>A</b> | 1           | ▲2  |    |            |     | 3   |          | ▲4  |    | _<br>∆5 |
| ▲ 1: IIC | Sn = 0001  | ×110B    |          |             |     |    |            |     |     |          |     |    |         |
| ▲2: IIC  | Sn = 0001  | <000B    |          |             |     |    |            |     |     |          |     |    |         |
| ▲ 3: IIC | Sn = 0010  | ×010B    |          |             |     |    |            |     |     |          |     |    |         |
| ▲4: IIC  | Sn = 0010  | <000B    |          |             |     |    |            |     |     |          |     |    |         |
| ∆5: IIC  | Sn = 00000 | 0001B    |          |             |     |    |            |     |     |          |     |    |         |
|          |            |          |          |             |     |    |            |     |     |          |     |    |         |
| Remar    | k ≜:Alv    | vays ge  | enerated | ł           |     |    |            |     |     |          |     |    |         |
|          | ∆∶Ge       | nerate   | d only w | hen SPIEn = | 1   |    |            |     |     |          |     |    |         |
|          | × · Do     | n't care | e.       |             |     |    |            |     |     |          |     |    |         |

(ii) When WTIMn = 1 (after restart, does not match address (= extension code))





(d) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop

(i) When WTIMn = 0 (after restart, does not match address (= not extension code))

| ST  | AD6 to AD0     | R/W       | ACK      | D7 to D0     | ACK | ST | AD6 to AD0 | R/W | ACK | D7 to D0 | ACK | SP |
|-----|----------------|-----------|----------|--------------|-----|----|------------|-----|-----|----------|-----|----|
|     |                |           | <b></b>  | .1           | ▲2  |    |            |     |     | 3        |     | ∆4 |
| ▲1  | : IICSn = 000  | 1×110B    |          |              |     |    |            |     |     |          |     |    |
| ▲2  | : IICSn = 000  | 1×000B    |          |              |     |    |            |     |     |          |     |    |
| ▲3  | : IICSn = 000  | 00110B    |          |              |     |    |            |     |     |          |     |    |
| ∆4  | : IICSn = 000  | 00001B    |          |              |     |    |            |     |     |          |     |    |
|     |                |           |          |              |     |    |            |     |     |          |     |    |
| Rei | mark ▲:/       | lways g   | enerate  | d            |     |    |            |     |     |          |     |    |
|     | $\triangle: 0$ | Generate  | d only v | when SPIEn = | 1   |    |            |     |     |          |     |    |
|     | × : [          | )on't car | e        |              |     |    |            |     |     |          |     |    |

(ii) When WTIMn = 1 (after restart, does not match address (= not extension code))





- (3) Slave device operation (when receiving extension code)The device is always participating in communication when it receives an extension code.
  - (a) Start ~ Code ~ Data ~ Data ~ Stop

(i) When WTIMn = 0



(ii) When WTIMn = 1



Remark n = 0 to 2



(b) Start ~ Code ~ Data ~ Start ~ Address ~ Data ~ Stop

(i) When WTIMn = 0 (after restart, matches SVAn)



(ii) When WTIMn = 1 (after restart, matches SVAn)





### (c) Start ~ Code ~ Data ~ Start ~ Code ~ Data ~ Stop





(ii) When WTIMn = 1 (after restart, extension code reception)



Remark n = 0 to 2



### (d) Start ~ Code ~ Data ~ Start ~ Address ~ Data ~ Stop

### (i) When WTIMn = 0 (after restart, does not match address (= not extension code))

| ST AD6    | to AD0          | R/W     | ACK      | D7 to D0       | ACK | ST | AD6 to AD0 | R/W | ACK | D7 to D0 | ACK | SP |  |
|-----------|-----------------|---------|----------|----------------|-----|----|------------|-----|-----|----------|-----|----|--|
|           |                 |         | 1        |                | 2   |    |            |     |     | .3       |     | L  |  |
| ▲1: IICSr | n = 0010 ×      | < 010E  | 3        |                |     |    |            |     |     |          |     |    |  |
| ▲2: IICSr | n = 0010 ×      | < 000E  | 3        |                |     |    |            |     |     |          |     |    |  |
| ▲3: IICSr | n = 00000       | × 10E   | 3        |                |     |    |            |     |     |          |     |    |  |
| ∆4: IICSr | n = 000000      | 001B    |          |                |     |    |            |     |     |          |     |    |  |
| Remark    | <b>▲</b> : Alwa | ays ge  | enerate  | d              |     |    |            |     |     |          |     |    |  |
|           | ∆:Gen           | nerated | d only v | when SPIEn = 1 |     |    |            |     |     |          |     |    |  |
|           | × : Don         | 't oord |          |                |     |    |            |     |     |          |     |    |  |

(ii) When WTIMn = 1 (after restart, does not match address (= not extension code))

| ST          | AD6 to AD0      | R/W       | ACK     | D7 to D0                  | ACK | ST | AD6 to AD0 | R/W | ACK | D7 to D0 | ACK | SP |    |
|-------------|-----------------|-----------|---------|---------------------------|-----|----|------------|-----|-----|----------|-----|----|----|
|             |                 |           | 1       | .2                        |     | 3  |            |     | 4   | 4        |     | Z  | ∆5 |
| <b>A</b> '  | 1: IICSn = 0010 | × 010E    | 3       |                           |     |    |            |     |     |          |     |    |    |
| ▲2          | 2: IICSn = 0010 | × 110E    | 3       |                           |     |    |            |     |     |          |     |    |    |
| <b>▲</b> 3  | 3: IICSn = 0010 | × × 00    | В       |                           |     |    |            |     |     |          |     |    |    |
| <b>A</b> 4  | 4: IICSn = 0000 | 0 × 10E   | 3       |                           |     |    |            |     |     |          |     |    |    |
| $\triangle$ | 5: IICSn = 0000 | 0001B     |         |                           |     |    |            |     |     |          |     |    |    |
| Re          | mark ▲: Al      | ways ge   | enerate | d                         |     |    |            |     |     |          |     |    |    |
|             |                 |           |         | when SPIEn = <sup>2</sup> | 1   |    |            |     |     |          |     |    |    |
|             |                 | on't care | -       |                           |     |    |            |     |     |          |     |    |    |
|             |                 |           | -       | wnen SPIEn = ^            | I   |    |            |     |     |          |     |    |    |

Remark n = 0 to 2



- (4) Operation without communication
  - (a) Start ~ Code ~ Data ~ Data ~ Stop

| ST | AD6 to AD0         | R/W    | ACK    | D7 to D0       | ACK | D7 to D0 | ACK | SP |
|----|--------------------|--------|--------|----------------|-----|----------|-----|----|
| Δ. | 1: IICSn = 00000   | )001B  |        |                |     |          |     | 2  |
| Re | e <b>mark</b> ∆∶Ge | nerate | d only | when SPIEn = 1 | 1   |          |     |    |

- (5) Arbitration loss operation (operation as slave after arbitration loss) When the device is used as a master in a multi-master system, read the MSTSn bit each time interrupt request signal INTIICAn has occurred to check the arbitration result.
  - (a) When arbitration loss occurs during transmission of slave address data

(i) When WTIMn = 0

| ST AD6 t  | o AD0    | R/W     | ACK                   | D7 to D0    | ACK | D7 to D0 | ACK | SP |
|-----------|----------|---------|-----------------------|-------------|-----|----------|-----|----|
|           |          |         | <b>A</b> <sup>.</sup> | 1           | ▲2  |          | ▲3  | Z  |
| ▲1: IICSn | = 0101×1 | 110B    |                       |             |     |          |     |    |
| ▲2: IICSn | = 0001×0 | 000B    |                       |             |     |          |     |    |
| ▲3: IICSn | = 0001×0 | 000B    |                       |             |     |          |     |    |
| ∆4: IICSn | = 000000 | 001B    |                       |             |     |          |     |    |
| _         |          |         |                       |             |     |          |     |    |
| Remark    | ▲: Alwa  | ays ge  | enerated              | 1           |     |          |     |    |
|           | ∆:Gen    | erate   | d only w              | hen SPIEn = | = 1 |          |     |    |
|           | × : Don  | 't care | Э                     |             |     |          |     |    |



(ii) When WTIMn = 1

| ST            | AD6 to AD      | ) R/W                 | ACK | D7 to D0     | ACK | D7 to D0 | ACK | SP         |
|---------------|----------------|-----------------------|-----|--------------|-----|----------|-----|------------|
|               |                |                       |     | 1            |     | 2        |     | <b>3</b> ∠ |
| <b>A</b> '    | I: IICSn = 010 | )1×110B               |     |              |     |          |     |            |
| <b>A</b> 2    | 2: IICSn = 000 | )1×100B               |     |              |     |          |     |            |
| ▲:            | 3: IICSn = 000 | )1××00B               |     |              |     |          |     |            |
| $\triangle 4$ | 4: IICSn = 000 | 00001B                |     |              |     |          |     |            |
| Re            |                | Always g              |     |              | 4   |          |     |            |
|               |                | Jenerate<br>Don't car |     | vhen SPIEn = | 1   |          |     |            |
|               | ^              | Joint Car             | C   |              |     |          |     |            |

(b) When arbitration loss occurs during transmission of extension code

(i) When WTIMn = 0





(ii) When WTIMn = 1

| ST AD6    | to AD0  | R/W      | ACK      | D7 to D0     | ACK     | D7 to D0 | ACK | SP  |
|-----------|---------|----------|----------|--------------|---------|----------|-----|-----|
|           |         | 4        | ▲1 ▲     | 2            | <b></b> | 3        |     | 4 2 |
| ▲1: IICSr | = 0110× | 010B     |          |              |         |          |     |     |
| ▲2: IICSr | = 0010× | 110B     |          |              |         |          |     |     |
| ▲3: IICSr | = 0010× | 100B     |          |              |         |          |     |     |
| ▲4: IICSr | = 0010× | ×00B     |          |              |         |          |     |     |
| ∆5: IICSr | = 00000 | 001B     |          |              |         |          |     |     |
| _         |         |          |          |              |         |          |     |     |
| Remark    | ▲ : Alw | ays ge   | enerate  | d            |         |          |     |     |
|           | ∆:Ger   | nerated  | d only v | vhen SPIEn = | 1       |          |     |     |
|           | × : Dor | n't care | Э        |              |         |          |     |     |

- (6) Operation when arbitration loss occurs (no communication after arbitration loss) When the device is used as a master in a multi-master system, read the MSTSn bit each time interrupt request signal INTIICAn has occurred to check the arbitration result.
  - (a) When arbitration loss occurs during transmission of slave address data (when WTIMn = 1)



Remark n = 0 to 2



(b) When arbitration loss occurs during transmission of extension code

| ST            | AD6 to AD0      | R/W      | ACK      | D7 to D0       | ACK | D7 to D0 | ACK | SP |
|---------------|-----------------|----------|----------|----------------|-----|----------|-----|----|
|               |                 |          | ▲1       |                |     |          |     |    |
| ▲1            | : IICSn = 0110  | ×010B    |          |                |     |          |     |    |
| Se            | ts LRELn = 1 b  | / softwa | are      |                |     |          |     |    |
| $\triangle 2$ | 2: IICSn = 0000 | 0001B    |          |                |     |          |     |    |
|               |                 |          |          |                |     |          |     |    |
| Re            | mark ▲: Alv     | vays ge  | enerate  | ed             |     |          |     |    |
|               | ∆: Ge           | enerate  | d only v | when SPIEn = 1 | 1   |          |     |    |
|               | × : Do          | n't care | е        |                |     |          |     |    |
|               |                 |          |          |                |     |          |     |    |

- (c) When arbitration loss occurs during transmission of data
  - (i) When WTIMn = 0



Remark n = 0 to 2



(ii) When WTIMn = 1

| ST | AD6 to     | AD0 R            | /W A   | ACK     | D7 to D0       | ACK | D7 to D0 | ACK | SP |
|----|------------|------------------|--------|---------|----------------|-----|----------|-----|----|
|    |            | ·                |        |         | 1              |     | 2        |     |    |
| ▲1 | : IICSn =  | 1000111          | 0B     |         |                |     |          |     |    |
| ▲2 | 2: IICSn = | 0100010          | 00B    |         |                |     |          |     |    |
| ∆3 | 3: IICSn = | 0000000          | )1B    |         |                |     |          |     |    |
|    |            |                  |        |         |                |     |          |     |    |
| Re | mark       | <b>▲</b> : Alway | /s gen | nerated | ł              |     |          |     |    |
|    |            | ∆ : Genei        | rated  | only w  | /hen SPIEn = ´ | 1   |          |     |    |
|    |            |                  |        |         |                |     |          |     |    |

(d) When loss occurs due to restart condition during data transfer

(i) Not extension code (Example: unmatches with SVAn)





Г

(ii) Extension code

| ST AD6    | o AD0     | R/W      | ACK      | D7 to Dm       | ST | AD6 to AD0 | R/W | ACK | D7 to D0 | ACK | SP |
|-----------|-----------|----------|----------|----------------|----|------------|-----|-----|----------|-----|----|
|           |           |          |          | .1             |    |            |     | 2   |          |     | Z  |
| ▲1: IICSn | = 1000×   | 4110B    |          |                |    |            |     |     |          |     |    |
| ▲2: IICSn | = 01100   | 010B     |          |                |    |            |     |     |          |     |    |
| Sets LREL | .n = 1 by | softwa   | are      |                |    |            |     |     |          |     |    |
| ∆3: IICSn | = 00000   | 001B     |          |                |    |            |     |     |          |     |    |
|           |           |          |          |                |    |            |     |     |          |     |    |
| Remark    | ▲: Alw    | /ays ge  | enerate  | d              |    |            |     |     |          |     |    |
|           | ∆:Ge      | nerate   | d only v | when SPIEn = 1 |    |            |     |     |          |     |    |
|           | × : Doi   | n't care | Э        |                |    |            |     |     |          |     |    |
|           | m = 6 t   | io 0     |          |                |    |            |     |     |          |     |    |

(e) When loss occurs due to stop condition during data transfer

| ST | AD6 to AD0              | R/W      | ACK     | D7 to Dm       | SP |
|----|-------------------------|----------|---------|----------------|----|
|    |                         |          |         | 1              | 2  |
| ▲1 | : IICSn = 100           | 00110B   |         |                |    |
| ∆2 | : IICSn = 010           | 00001B   |         |                |    |
|    |                         |          |         |                |    |
| Re | mark ▲: A               | lways g  | enerate | ed             |    |
|    | $\triangle: \mathbf{C}$ | Generate | d only  | when SPIEn = 1 |    |
|    | × : [                   | on't car | е       |                |    |
|    | m =                     | 6 to 0   |         |                |    |
|    |                         |          |         |                |    |



(f) When arbitration loss occurs due to low-level data when attempting to generate a restart condition

(i) When WTIMn = 0



(ii) When WTIMn = 1





(g) When arbitration loss occurs due to a stop condition when attempting to generate a restart condition

(i) When WTIMn = 0



(ii) When WTIMn = 1





(h) When arbitration loss occurs due to low-level data when attempting to generate a stop condition

(i) When WTIMn = 0



(ii) When WTIMn = 1





## 12.6 Timing Charts

When using the I<sup>2</sup>C bus mode, the master device outputs an address via the serial bus to select one of several slave devices as its communication partner.

After outputting the slave address, the master device transmits the TRCn bit (bit 3 of the IICA status register n (IICSn)), which specifies the data transfer direction, and then starts serial communication with the slave device. Figures 12 - 42 to 12 - 48 show timing charts of the data communication.

The IICA shift register n (IICAn)'s shift operation is synchronized with the falling edge of the serial clock (SCLAn). The transmit data is transferred to the SO latch and is output (MSB first) via the SDAAn pin.

Data input via the SDAAn pin is captured into IICAn at the rising edge of SCLAn.





(1) Start condition ~ address ~ data



**Note 1.** Write data to IICAn, not setting the WRELn bit, in order to cancel a wait state during transmission by a master device.

Note 2. Make sure that the time between the fall of the SDAAn pin signal and the fall of the SCLAn pin signal is at least 4.0 μs when specifying standard mode and at least 0.6 μs when specifying fast mode.

- **Note 3.** For releasing wait state during reception of a slave device, write "FFH" to IICAn or set the WRELn bit.
- Remark n = 0 to 2

The meanings of <1> to <6> in (1) Start condition ~ address ~ data in Figure 12 - 42 are explained below.

- <1> The start condition trigger is set by the master device (STTn = 1) and a start condition (i.e. SCLAn = 1 changes SDAAn from 1 to 0) is generated once the bus data line goes low (SDAAn). When the start condition is subsequently detected, the master device enters the master device communication status (MSTSn = 1). The master device is ready to communicate once the bus clock line goes low (SCLAn = 0) after the hold time has elapsed.
- <2> The master device writes the address + W (transmission) to the IICA shift register n (IICAn) and transmits the slave address.
- <3> In the slave device if the address received matches the address (SVAn value) of a slave device <sup>Note</sup>, that slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <4> The master device issues an interrupt (INTIICAn: end of address transmission) at the falling edge of the 9th clock. The slave device whose address matched the transmitted slave address sets a wait status (SCLAn = 0) and issues an interrupt (INTIICAn: address match) <sup>Note</sup>.
- <5> The master device writes the data to transmit to the IICAn register and releases the wait status that it set by the master device.
- <6> If the slave device releases the wait status (WRELn = 1), the master device starts transferring data to the slave device.
- Note If the transmitted address does not match the address of the slave device, the slave device does not return an ACK to the master device (NACK: SDAAn = 1). The slave device also does not issue the INTIICAn interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICAn interrupt (end of address transmission) regardless of whether it receives an ACK or NACK.
- Remark 1. <1> to <15> in Figures 12 42 to 12 44 represent the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12 42 (1) Start condition ~ address ~ data shows the processing from <1> to <6>, Figure 12 43 (3) Address ~ data ~ data shows the processing from <3> to <10>, and Figure 12 44 (3) Data ~ data ~ stop condition shows the processing from <7> to <15>.



## Figure 12 - 43 Example of Master to Slave Communication (When 9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (2/4)

(3) Address ~ data ~ data



Note 1. Write data to IICAn, not setting the WRELn bit, in order to cancel a wait state during transmission by a master device. For releasing wait state during reception of a slave device, write "FFH" to IICAn or set the WRELn bit.

Note 2.

n = 0 to 2 Remark

The meanings of <3> to <10> in (3) Address ~ data ~ data in Figure 12 - 43 are explained below.

- <3> In the slave device if the address received matches the address (SVAn value) of a slave device <sup>Note</sup>, that slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <4> The master device issues an interrupt (INTIICAn: end of address transmission) at the falling edge of the 9th clock. The slave device whose address matched the transmitted slave address sets a wait status (SCLAn = 0) and issues an interrupt (INTIICAn: address match) <sup>Note</sup>.
- <5> The master device writes the data to transmit to the IICA shift register n (IICAn) and releases the wait status that it set by the master device.
- <6> If the slave device releases the wait status (WRELn = 1), the master device starts transferring data to the slave device.
- <7> After data transfer is completed, because of ACKEn = 1, the slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <8> The master device and slave device set a wait status (SCLAn = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICAn: end of transfer).
- <9> The master device writes the data to transmit to the IICAn register and releases the wait status that it set by the master device.
- <10>The slave device reads the received data and releases the wait status (WRELn = 1). The master device then starts transferring data to the slave device.
- **Note** If the transmitted address does not match the address of the slave device, the slave device does not return an ACK to the master device (NACK: SDAAn = 1). The slave device also does not issue the INTIICAn interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICAn interrupt (end of address transmission) regardless of whether it receives an ACK or NACK.
- Remark 1. <1> to <15> in Figures 12 42 to 12 44 represent the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12 42 (1) Start condition ~ address ~ data shows the processing from <1> to <6>, Figure 12 43 (3) Address ~ data ~ data shows the processing from <3> to <10>, and Figure 12 44 (3) Data ~ data ~ stop condition shows the processing from <7> to <15>.





(3) Data ~ data ~ stop condition



Note 1. Write data to IICAn, not setting the WRELn bit, in order to cancel a wait state during transmission by a master device.
 Note 2. Make sure that the time between the rise of the SCLAn pin signal and the generation of the stop condition after a stop condition has been issued is at least 4.0 μs when specifying standard mode and at least 0.6 μs when specifying fast mode.

Note 3.For releasing wait state during reception of a slave device, write "FFH" to IICAn or set the WRELn bit.Remarkn = 0 to 2

The meanings of <7> to <15> in (3) Data ~ data ~ stop condition in Figure 12 - 44 are explained below.

- <7> After data transfer is completed, because of ACKEn = 1, the slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <8> The master device and slave device set a wait status (SCLAn = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICAn: end of transfer).
- <9> The master device writes the data to transmit to the IICA shift register n (IICAn) and releases the wait status that it set by the master device.
- <10>The slave device reads the received data and releases the wait status (WRELn = 1). The master device then starts transferring data to the slave device.
- <11>When data transfer is complete, the slave device (ACKEn =1) sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <12>The master device and slave device set a wait status (SCLAn = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICAn: end of transfer).
- <13>The slave device reads the received data and releases the wait status (WRELn = 1).
- <14> By the master device setting a stop condition trigger (SPTn = 1), the bus data line is cleared (SDAAn = 0) and the bus clock line is set (SCLAn = 1). After the stop condition setup time has elapsed, by setting the bus data line (SDAAn = 1), the stop condition is then generated (i.e. SCLAn = 1 changes SDAAn from 0 to 1).
- <15> When a stop condition is generated, the slave device detects the stop condition and issues an interrupt (INTIICAn: stop condition).
- Remark 1. <1> to <15> in Figures 12 42 to 12 44 represent the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12 42 (1) Start condition ~ address ~ data shows the processing from <1> to <6>, Figure 12 43 (3) Address ~ data ~ data shows the processing from <3> to <10>, and Figure 12 44 (3) Data ~ data ~ stop condition shows the processing from <7> to <15>.



## Figure 12 - 45 Example of Master to Slave Communication (When 9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (4/4)

(3) Data ~ restart condition ~ address



- Note 1. Make sure that the time between the rise of the SCLAn pin signal and the generation of the start condition after a restart condition has been issued is at least 4.7 μs when specifying standard mode and at least 0.6 μs when specifying fast mode.
- Note 2.For releasing wait state during reception of a slave device, write "FFH" to IICAn or set the WRELn bit.Remarkn = 0 to 2

The following describes the operations in Figure 12 - 45 (3) Data ~ restart condition ~ address. After the operations in steps <7> and <8>, the operations in steps <i> to <iii> are performed. These steps return the processing to step <iii>, the data transmission step.

- <7> After data transfer is completed, because of ACKEn = 1, the slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <8> The master device and slave device set a wait status (SCLAn = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICAn: end of transfer).
- <i> The slave device reads the received data and releases the wait status (WRELn = 1).
- <ii> The start condition trigger is set again by the master device (STTn = 1) and a start condition (i.e. SCLAn =1 changes SDAAn from 1 to 0) is generated once the bus clock line goes high (SCLAn = 1) and the bus data line goes low (SDAAn = 0) after the restart condition setup time has elapsed. When the start condition is subsequently detected, the master device is ready to communicate once the bus clock line goes low (SCLAn = 0) after the hold time has elapsed.
- <iii> The master device writing the address + R/W (transmission) to the IICA shift register (IICAn) enables the slave address to be transmitted.



## Figure 12 - 46 Example of Slave to Master Communication (When 8-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (1/3)

(1) Start condition ~ address ~ data



**Note 1.** For releasing wait state during reception of a master device, write "FFH" to IICAn or set the WRELn bit.

- **Note 2.** Make sure that the time between the fall of the SDAAn pin signal and the fall of the SCLAn pin signal is at least 4.0 μs when specifying standard mode and at least 0.6 μs when specifying fast mode.
- Note 3. Write data to IICAn, not setting the WRELn bit, in order to cancel a wait state during transmission by a slave device.
- Remark n = 0 to 2



The meanings of <1> to <7> in (1) Start condition ~ address ~ data in Figure 12 - 46 are explained below.

- <1> The start condition trigger is set by the master device (STTn = 1) and a start condition (i.e. SCLAn =1 changes SDAAn from 1 to 0) is generated once the bus data line goes low (SDAAn). When the start condition is subsequently detected, the master device enters the master device communication status (MSTSn = 1). The master device is ready to communicate once the bus clock line goes low (SCLAn = 0) after the hold time has elapsed.
- <2> The master device writes the address + R (reception) to the IICA shift register n (IICAn) and transmits the slave address.
- <3> In the slave device if the address received matches the address (SVAn value) of a slave device <sup>Note</sup>, that slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <4> The master device issues an interrupt (INTIICAn: end of address transmission) at the falling edge of the 9th clock. The slave device whose address matched the transmitted slave address sets a wait status (SCLAn = 0) and issues an interrupt (INTIICAn: address match) <sup>Note</sup>.
- <5> The timing at which the master device sets the wait status changes to the 8th clock (WTIMn = 0).
- <6> The slave device writes the data to transmit to the IICAn register and releases the wait status that it set by the slave device.
- <7> The master device releases the wait status (WRELn = 1) and starts transferring data from the slave device to the master device.
- Note If the transmitted address does not match the address of the slave device, the slave device does not return an ACK to the master device (NACK: SDAAn = 1). The slave device also does not issue the INTIICAn interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICAn interrupt (end of address transmission) regardless of whether it receives an ACK or NACK.
- Remark 1. <1> to <19> in Figures 12 46 to 12 48 represent the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12 46 (1) Start condition ~ address ~ data shows the processing from <1> to <7>, Figure 12 47 (3) Address ~ data ~ data shows the processing from <3> to <12>, and Figure 12 48 (3) Data ~ data ~ stop condition shows the processing from <8> to <19>.



## Figure 12 - 47 Example of Slave to Master Communication (When 8-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (2/3)

(3) Address ~ data ~ data



Note 1. For releasing wait state during reception of a master device, write "FFH" to IICAn or set the WRELn bit.

Note 2. Write data to IICAn, not setting the WRELn bit, in order to cancel a wait state during transmission by a slave device. Remark n = 0 to 2

The meanings of <3> to <12> in (3) Address ~ data ~ data in Figure 12 - 47 are explained below.

- <3> In the slave device if the address received matches the address (SVAn value) of a slave device <sup>Note</sup>, that slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKDn = 1) at the rising edge of the 9th clock.
- <4> The master device issues an interrupt (INTIICAn: end of address transmission) at the falling edge of the 9th clock. The slave device whose address matched the transmitted slave address sets a wait status (SCLAn = 0) and issues an interrupt (INTIICAn: address match) <sup>Note</sup>.
- <5> The master device changes the timing of the wait status to the 8th clock (WTIMn = 0).
- <6> The slave device writes the data to transmit to the IICA shift register n (IICAn) and releases the wait status that it set by the slave device.
- <7> The master device releases the wait status (WRELn = 1) and starts transferring data from the slave device to the master device.
- <8> The master device sets a wait status (SCLAn = 0) at the falling edge of the 8th clock, and issues an interrupt (INTIICAn: end of transfer). Because of ACKEn = 1 in the master device, the master device then sends an ACK by hardware to the slave device.
- <9> The master device reads the received data and releases the wait status (WRELn = 1).
- <10>The ACK is detected by the slave device (ACKDn = 1) at the rising edge of the 9th clock.
- <11>The slave device set a wait status (SCLAn = 0) at the falling edge of the 9th clock, and the slave device issue an interrupt (INTIICAn: end of transfer).
- <12>By the slave device writing the data to transmit to the IICAn register, the wait status set by the slave device is released. The slave device then starts transferring data to the master device.
- **Note** If the transmitted address does not match the address of the slave device, the slave device does not return an ACK to the master device (NACK: SDAAn = 1). The slave device also does not issue the INTIICAn interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICAn interrupt (end of address transmission) regardless of whether it receives an ACK or NACK.
- Remark 1. <1> to <19> in Figures 12 46 to 12 48 represent the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12 46 (1) Start condition ~ address ~ data shows the processing from <1> to <7>, Figure 12 47 (3) Address ~ data ~ data shows the processing from <3> to <12>, and Figure 12 48 (3) Data ~ data ~ stop condition shows the processing from <8> to <19>.

Remark 2. n = 0 to 2



## Figure 12 - 48 Example of Slave to Master Communication (When 8-Clock and 9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (3/3)

(3) Data  $\sim$  data  $\sim$  stop condition



Note 1. To cancel a wait state, write "FFH" to IICAn or set the WRELn bit.

Note 2. Make sure that the time between the rise of the SCLAn pin signal and the generation of the stop condition after a stop condition has been issued is at least 4.0 μs when specifying standard mode and at least 0.6 μs when specifying fast mode.

Note 3. Write data to IICAn, not setting the WRELn bit, in order to cancel a wait state during transmission by a slave device.

Note 4. If a wait state during transmission by a slave device is canceled by setting the WRELn bit, the TRCn bit will be cleared.

Remark n = 0 to 2

The meanings of <8> to <19> in (3) Data ~ data ~ stop condition in Figure 12 - 48 are explained below.

- <8> The master device sets a wait status (SCLAn = 0) at the falling edge of the 8th clock, and issues an interrupt (INTIICAn: end of transfer). Because of ACKEn = 0 in the master device, the master device then sends an ACK by hardware to the slave device.
- <9> The master device reads the received data and releases the wait status (WRELn = 1).
- <10>The ACK is detected by the slave device (ACKDn = 1) at the rising edge of the 9th clock.
- <11>The slave device set a wait status (SCLAn = 0) at the falling edge of the 9th clock, and the slave device issue an interrupt (INTIICAn: end of transfer).
- <12>By the slave device writing the data to transmit to the IICA register, the wait status set by the slave device is released. The slave device then starts transferring data to the master device.
- <13>The master device issues an interrupt (INTIICAn: end of transfer) at the falling edge of the 8th clock, and sets a wait status (SCLAn = 0). Because ACK control (ACKEn = 1) is performed, the bus data line is at the low level (SDAAn = 0) at this stage.
- <14>The master device sets NACK as the response (ACKEn = 0) and changes the timing at which it sets the wait status to the 9th clock (WTIMn = 1).
- <15>If the master device releases the wait status (WRELn = 1), the slave device detects the NACK (ACKDn = 0) at the rising edge of the 9th clock.
- <16>The master device and slave device set a wait status (SCLAn = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICAn: end of transfer).
- <17> When the master device issues a stop condition (SPTn = 1), the bus data line is cleared (SDAAn = 0) and the master device releases the wait status. The master device then waits until the bus clock line is set (SCLAn = 1).
- <18> The slave device acknowledges the NACK, halts transmission, and releases the wait status (WRELn = 1) to end communication. Once the slave device releases the wait status, the bus clock line is set (SCLAn = 1).
- <19> Once the master device recognizes that the bus clock line is set (SCLAn = 1) and after the stop condition setup time has elapsed, the master device sets the bus data line (SDAAn = 1) and issues a stop condition (i.e. SCLAn = 1 changes SDAAn from 0 to 1). The slave device detects the generated stop condition and slave device issue an interrupt (INTIICAn: stop condition).
- Remark 1. <1> to <19> in Figures 12 46 to 12 48 represent the entire procedure for communicating data using the l<sup>2</sup>C bus. Figure 12 46 (1) Start condition ~ address ~ data shows the processing from <1> to <7>, Figure 12 47 (3) Address ~ data ~ data shows the processing from <3> to <12>, and Figure 12 48 (3) Data ~ data ~ stop condition shows the processing from <8> to <19>.

Remark 2. n = 0 to 2



## CHAPTER 13 USB 2.0 HOST/FUNCTION MODULE (USB)

The availability of each pin of USB port, VBUS supply enable output, and overcurrent detection input differs, depending on the product.

|              | R9A02G0150   | R9A02G0151 |
|--------------|--------------|------------|
| UDP0 pin     | $\checkmark$ | —          |
| UDM0 pin     | ✓            |            |
| UVBUS pin    | ✓            | —          |
| UDP1 pin     | ✓            | —          |
| UDM1 pin     | ✓            | —          |
| UVBUSEN0 pin | ✓            | —          |
| UVBUSEN1 pin | ✓            | —          |
| UOVRCUR0 pin | ✓            | —          |
| UOVRCUR1 pin | ✓            | —          |
| UVDD pin     | ✓ <i>✓</i>   | √Note      |

**Note** Connect directory to VDD, or draw power from an external 3.3 V supply.

## 13.1 Functions of USB 2.0 Host/Function Module

The R9A02G0150 incorporates a USB 2.0 host/function module (USB module) compliant to USB (Universal Serial Bus) Specification 2.0. The USB module provides capabilities as a host/function controller which supports full-speed (12 Mbps) and low-speed (1.5 Mbps) transfer.

The USB module can also detect battery charging (hereafter BC) connection during host/function controller operation compliant to USB Battery Charging Specification Revision 1.2.

The USB host/function module can detect connection of USB host/function devices compliant with the 2.1A/1.0A charging mode prescribed in USB power supply component specification.

Table 13 - 1 lists the USB Specifications.



| Item                             | Specifications                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Features                         | <ul> <li>USB Device Controller (UDC) and transceiver for USB 2.0 are incorporated.</li> <li>The USB host controller and USB function controller are incorporated<br/>(can be switched by software).</li> <li>Operable with self-power mode and bus-power mode.</li> </ul>                                                                                                       |
|                                  | Features of the USB host controller<br>- Two ports are provided.                                                                                                                                                                                                                                                                                                                |
|                                  | <ul> <li>Full-speed transfer (12 Mbps) and low-speed transfer (1.5 Mbps) are supported</li> <li>Automatic scheduling for SOF and packet transmissions</li> <li>Programmable intervals for interrupt transfers</li> <li>On-chip D+/D- pin pull-down resistor</li> </ul>                                                                                                          |
|                                  | Features of the USB function controller                                                                                                                                                                                                                                                                                                                                         |
|                                  | <ul> <li>One port is provided.</li> <li>Full-speed transfer (12 Mbps) and low-speed transfer (1.5 Mbps) are supported</li> <li>Control transfer stage control function</li> </ul>                                                                                                                                                                                               |
|                                  | Device state control function     Auto response function for SET_ADDRESS request     SOF interpolation function     On abin D+/D, pin pull up register.                                                                                                                                                                                                                         |
| Communication data transfer type | On-chip D+/D- pin pull-up resistor     Ontrol transfer                                                                                                                                                                                                                                                                                                                          |
|                                  | Bulk transfer     Interrupt transfer                                                                                                                                                                                                                                                                                                                                            |
| Pipe configuration               | <ul> <li>Buffer memory for USB communications is provided for 448 byte.</li> <li>Up to five pipes can be selected (including the default control pipe).</li> <li>Usable pipe numbers are 0, 4 to 7.</li> <li>Endpoint numbers can be assigned flexibly to PIPE4 to PIPE7.</li> </ul>                                                                                            |
|                                  | Transfer conditions that can be set for each pipe:       • PIPE0: Control transfer only                                                                                                                                                                                                                                                                                         |
|                                  | (default control pipe: DCP)<br>Buffer size: 64 byte (single buffer)<br>• PIPE4, PIPE5: Bulk transfer only                                                                                                                                                                                                                                                                       |
|                                  | Buffer size: 64 byte (double buffer can be specified)<br>• PIPE6, PIPE7: Interrupt transfer only<br>Buffer size: 64 byte (single buffer)                                                                                                                                                                                                                                        |
| Others                           | <ul> <li>Reception ending function using transaction count</li> <li>Function that changes the BRDY interrupt event notification timing (BFRE)</li> <li>NAK setting function for response PID generated by end of transfer (SHTNAK)</li> <li>Automatic buffer memory clearing function after reading data in the pipe specified by the DnFIFO (n = 0, 1) port (DCLRM)</li> </ul> |
|                                  | <ul> <li>USB Battery Charging is supported (USB Battery Charging Specification Revision 1.2)</li> <li>Host (charging downstream port, dedicated charging port) BC connection detection function (two ports) is supported</li> <li>Function (portable device) BC connection detection function (two ports) is supported</li> </ul>                                               |
|                                  | <ul> <li>Battery charging connection detection optional functions supported</li> <li>USB host controller supports 2.1A/1.0A charging mode prescribed in USB power supply component specification (2 ports)</li> <li>USB function controller supports 2.1A/1.0A charging mode prescribed in USB power</li> </ul>                                                                 |
|                                  | <ul> <li>supply component specification (2 ports)</li> <li>Optional functions for battery charging connection detection are provided</li> <li>USB port voltage output function (four patterns)</li> <li>USB port voltage detection function (16 stages)</li> </ul>                                                                                                              |



## 13.2 Configuration of USB 2.0 Host/Function Module

The USB module consists of the following hardware.

• USB 2.0 Host/Function Controller

This controls the host/function supporting full-speed (12 Mbps) and low-speed (1.5 Mbps) transfer.

USB transceiver

This is a USB transceiver of one alternate port (USB port 0) for the host/function, and of one dedicated port (USB port 1) for the host.

This transceiver contains an on-chip pull-down resistor (for the host)/pull-up resistor (for the function) for transfer rate detection.

An external power supply (via the UVDD pin) or the internal power supply for the USB can be selected as the power supply for the USB transceiver (hereafter USB power supply).

• Buffer memory for USB communications and FIFO/memory controller

Up to five pipes can be used. End point numbers can be assigned flexibly to PIPE4 to PIPE7 according to peripheral devices and a user system for communication.

• Battery charging detection/controller

This processes BC connection detection during host /function controller operation compliant to Battery Charging Specification Revision 1.2.

Various registers

There are various registers for control, monitoring, and transmitting/receiving data. See Table 13 - 3.

Various pins

USB port I/O pins (UDP0, UDM0, UDP1, UDM1) VBUS input pin (UVBUS) USB transceiver power supply pin (UVDD) VBUS supply control output pins (UVBUSEN0, UVBUSEN1) Overcurrent detection input pins (UOVRCUR0, UOVRCUR1) See Table 13 - 2 for details.

Others

The clock controller operates or stops various clocks to be used by the USB module and divides their frequencies. The bus interface controller controls access between the CPU and each register of the USB module.

Table 13 - 2 lists the USB Module I/O Pins and Figure 13 - 1 the USB Module Block Diagram.



| Pin Name | I/O    | Function                                                                                                                                                                                                                                         |
|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UDP0     | I/O    | D+ I/O pin of USB port 0<br>This pin should be connected to the D+ pin of the USB bus.                                                                                                                                                           |
| UDM0     | I/O    | D- I/O pin of USB port 0<br>This pin should be connected to the D- pin of the USB bus.                                                                                                                                                           |
| UVBUS    | Input  | USB cable connection monitor pin<br>This pin should be connected to VBUS of the USB bus.<br>Whether VBUS is connected or disconnected can be detected during operation as a<br>function controller.                                              |
| UDP1     | I/O    | D+ I/O pin of USB port 1<br>This pin should be connected to the D+ pin of the USB bus.                                                                                                                                                           |
| UDM1     | I/O    | D- I/O pin of USB port 1<br>This pin should be connected to the D- pin of the USB bus.                                                                                                                                                           |
| UVBUSEN0 | Output | VBUS (5 V) supply enable signal to the external power supply IC for USB port 0                                                                                                                                                                   |
| UVBUSEN1 | Output | VBUS (5 V) supply enable signal to the external power supply IC for USB port 1                                                                                                                                                                   |
| UOVRCUR0 | Input  | An external overcurrent detection signal for USB port 0 should be connected to this pin.                                                                                                                                                         |
| UOVRCUR1 | Input  | An external overcurrent detection signal for USB port 1 should be connected to this pin.                                                                                                                                                         |
| UVDD     | I/O    | Power supply (USB power supply) pin for the USB transceiver.<br>This pin should be connected to an external power supply. When using the internal power supply for the USB, a capacitor of 0.33 μF should be connected between this pin and VSs. |

Table 13 - 2 USB module I/O Pins





Figure 13 - 1 Block diagram of USB module



## 13.3 Registers Used in USB 2.0 Host/Function Module

Table 13 - 3 lists the USB Registers.

| Register                                | Name Symbol | After Reset                 | Address        | Access Size |
|-----------------------------------------|-------------|-----------------------------|----------------|-------------|
| System Configuration Control Register   | SYSCFG      | 0000H                       | F0400H, F0401H | 16          |
| System Configuration Control Register 1 | SYSCFG1     | 0000H                       | F0402H, F0403H | 16          |
| System Configuration Status Register 0  | SYSSTS0     | X00X0000<br>00X00000B       | F0404H, F0405H | 16          |
| System Configuration Status Register 1  | SYSSTS1     | X00X0000<br>00X00000B       | F0406H, F0407H | 16          |
| Device State Control Register 0         | DVSTCTR0    | 0000H                       | F0408H, F0409H | 16          |
| Device State Control Register 1         | DVSTCTR1    | 0000H                       | F040AH, F040BH | 16          |
| CFIFO Port Register                     | CFIFOM      | 0000H                       | F0414H, F0415H | 8, 16       |
| D0FIFO Port Register                    | D0FIFOM     | 0000H                       | F0418H, F0419H | 8, 16       |
| D1FIFO Port Register                    | D1FIFOM     | 0000H                       | F041CH, F041DH | 8, 16       |
| CFIFO Port Select Register              | CFIFOSEL    | 0000H                       | F0420H, F0421H | 16          |
| CFIFO Port Control Register             | CFIFOCTR    | 0000H                       | F0422H, F0423H | 16          |
| D0FIFO Port Select Register             | D0FIFOSEL   | 0000H                       | F0428H, F0429H | 16          |
| D0FIFO Port Control Register            | D0FIFOCTR   | 0000H                       | F042AH, F042BH | 16          |
| D1FIFO Port Select Register             | D1FIFOSEL   | 0000H                       | F042CH, F042DH | 16          |
| D1FIFO Port Control Register            | D1FIFOCTR   | 0000H                       | F042EH, F042FH | 16          |
| Interrupt Enable Register 0             | INTENB0     | 0000H                       | F0430H, F0431H | 16          |
| Interrupt Enable Register 1             | INTENB1     | 0000H                       | F0432H, F0433H | 16          |
| Interrupt Enable Register 2             | INTENB2     | 0000H                       | F0434H, F0435H | 16          |
| BRDY Interrupt Enable Register          | BRDYENB     | 0000H                       | F0436H, F0437H | 16          |
| NRDY Interrupt Enable Register          | NRDYENB     | 0000H                       | F0438H, F0439H | 16          |
| BEMP Interrupt Enable Register          | BEMPENB     | 0000H                       | F043AH, F043BH | 16          |
| SOF Output Configuration Register       | SOFCFG      | 0000H                       | F043CH, F043DH | 16          |
| Interrupt Status Register 0             | INTSTS0     | 00000000<br>X000000B        | F0440H, F0441H | 16          |
| Interrupt Status Register 1             | INTSTS1     | XX0X0000<br>0000000B        | F0442H, F0443H | 16          |
| Interrupt Status Register 2             | INTSTS2     | X00X0000<br>00000000B       | F0444H, F0445H | 16          |
| BRDY Interrupt Status Register          | BRDYSTS     | 0000H                       | F0446H, F0447H | 16          |
| NRDY Interrupt Status Register          | NRDYSTS     | 0000H                       | F0448H, F0449H | 16          |
| BEMP Interrupt Status Register          | BEMPSTS     | 0000H                       | F044AH, F044BH | 16          |
| Frame Number Register                   | FRMNUM      | 0000H                       | F044CH, F044DH | 16          |
| USB Address Register                    | USBADDR     | 0000H                       | F0450H, F0451H | 16          |
| USB Request Type Register               | USBREQ      | 0000H                       | F0454H, F0455H | 16          |
| USB Request Value Register              | USBVAL      | 0000H                       | F0456H, F0457H | 16          |
| USB Request Index Register              | USBINDX     | 0000H                       | F0458H, F0459H | 16          |
| USB Request Length Register             | USBLENG     | 0000H                       | F045AH, F045BH | 16          |
| DCP Configuration Register              | DCPCFG      | 0000H                       | F045CH, F045DH | 16          |
| DCP Maximum Packet Size Register        | DCPMAXP     | 0040H                       | F045EH, F045FH | 16          |
| DCP Control Register                    | DCPCTR      | 0040H                       | F0460H, F0461H | 16          |
| Pipe Window Select Register             | PIPESEL     | 0000H                       | F0464H, F0465H | 16          |
| Pipe Configuration Register             | PIPECFG     | 0000H                       | F0468H, F0469H | 16          |
| Pipe Maximum Packet Size Register       | PIPEMAXP    | 0000H/0040H <sup>Note</sup> | F046CH, F046DH | 16          |
| Pipe Cycle Control Register             | PIPEPERI    | 0000H                       | F046EH, F046FH | 16          |

#### Table 13 - 3 List of USB Registers (1/2)



| Register                                   | Name Symbol | After Reset | Address        | Access Size |
|--------------------------------------------|-------------|-------------|----------------|-------------|
| Pipe 4 Control Register                    | PIPE4CTR    | 0000H       | F0476H, F0477H | 16          |
| Pipe 5 Control Register                    | PIPE5CTR    | 0000H       | F0478H, F0479H | 16          |
| Pipe 6 Control Register                    | PIPE6CTR    | 0000H       | F047AH, F047BH | 16          |
| Pipe 7 Control Register                    | PIPE7CTR    | 0000H       | F047CH, F047DH | 16          |
| Pipe 4 Transaction Counter Enable Register | PIPE4TRE    | 0000H       | F049CH, F049DH | 16          |
| Pipe 4 Transaction Counter Register        | PIPE4TRN    | 0000H       | F049EH, F049FH | 16          |
| Pipe 5 Transaction Counter Enable Register | PIPE5TRE    | 0000H       | F04A0H, F04A1H | 16          |
| Pipe 5 Transaction Counter Register        | PIPE5TRN    | 0000H       | F04A2H, F04A3H | 16          |
| BC Control Register 0                      | USBBCCTRL0  | 0000H       | F04B0H, F04B1H | 16          |
| BC Control Register 1                      | USBBCCTRL1  | 0000H       | F04B4H, F04B5H | 16          |
| BC Option Control Register 0               | USBBCOPT0   | 0000H       | F04B8H, F04B9H | 16          |
| BC Option Control Register 1               | USBBCOPT1   | 0000H       | F04BCH, F04BDH | 16          |
| USB Clock Selection Register               | UCKSEL      | 0000H       | F04C4H, F04C5H | 16          |
| USB Module Control Register                | USBMC       | 0002H       | F04CCH, F04CDH | 16          |
| Device Address 0 Configuration Register    | DEVADD0     | 0000H       | F04D0H, F04D1H | 16          |
| Device Address 1 Configuration Register    | DEVADD1     | 0000H       | F04D2H, F04D3H | 16          |
| Device Address 2 Configuration Register    | DEVADD2     | 0000H       | F04D4H, F04D5H | 16          |
| Device Address 3 Configuration Register    | DEVADD3     | 0000H       | F04D6H, F04D7H | 16          |
| Device Address 4 Configuration Register    | DEVADD4     | 0000H       | F04D8H, F04D9H | 16          |
| Device Address 5 Configuration Register    | DEVADD5     | 0000H       | F04DAH, F04DBH | 16          |

### Table 13 - 3 List of USB Registers (2/2)

Note

The initial value of this register differs according to the setting of the PIPESEL3 to PIPESEL0 bits. The initial value is 0000H when the pipe is not selected and 0040H when selected.

#### Table 13 - 4 Registers Initialized by Writing USBE = 0 (When Function Controller Function is Selected)

| Register | Symbol                  | Remarks                                                              |
|----------|-------------------------|----------------------------------------------------------------------|
| SYSSTS0  | LNST1, LNST0            | The value is retained when the host controller function is selected. |
| SYSSTS1  | LNST1, LNST0            | The value is retained when the host controller function is selected. |
| DVSTCTR0 | RHST2 to RHST0          |                                                                      |
| DVSTCTR1 | RHST2 to RHST0          |                                                                      |
| INTSTS0  | DVSQ2 to DVSQ0          | The value is retained when the host controller function is selected. |
| USBADDR  | USBADDR                 | The value is retained when the host controller function is selected. |
| USBREQ   | BREQUEST, BMREQUESTTYPE | The value is retained when the host controller function is selected. |
| USBVAL   | WVALUE                  | The value is retained when the host controller function is selected. |
| USBINDX  | WINDEX                  | The value is retained when the host controller function is selected. |
| USBLENG  | WLENGTH                 | The value is retained when the host controller function is selected. |

#### Table 13 - 5 Registers Initialized by Writing USBE = 0 (When Host Controller Function is Selected)

| Register | Symbol         | Remarks                                                                  |
|----------|----------------|--------------------------------------------------------------------------|
| DVSTCTR0 | RHST2 to RHST0 |                                                                          |
| DVSTCTR1 | RHST2 to RHST0 |                                                                          |
| FRMNUM   | FRNM           | The value is retained when the function controller function is selected. |



## 13.3.1 System configuration control register (SYSCFG), system configuration control register 1 (SYSCFG1)

#### Figure 13 - 2 Format of System Configuration Control Register (SYSCFG) Address: F0400H, F0401H After reset: 0000H Symbol 15 14 13 12 11 10 7 5 4 3 2 0 9 8 6 1 DPRP DMRF SYSCFG DCFM DRPD SCKE CNEN USBE U U Bits 15 to 11 Nothing is assigned R/W The write value must be 0. The read value is 0. \_ SCKE USB module clock enable R/W 0 Stops supplying the clock signal to the USB module. R/W 1 Enables supplying the clock signal to the USB module. Stops or enables supplying 48-MHz clock signals to the USB module. After setting the SCKE bit to 1, be sure to read this bit to confirm that it is actually set to 1. When the SCKE bit is 0, the USB module registers that can be read and written are SYSCFG, SYSCFG1, USBBCCTRL0, USBBCCTRL1, USBBCOPT0, USBBCOPT1, and USBMC. Bit 9 Nothing is assigned R/W \_ The write value must be 0. The read value is 0. CNEN USB port 0 single end receiver enable R/W 0 Single end receiver operation is disabled. R/W 1 Single end receiver operation is enabled. Enables or disables the single end receiver. Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 0 and set the LNST bit to monitor the status of the D+/D- lines. The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging. Nothing is assigned R/W Bit 7 The write value must be 0. The read value is 0. DCFM Controller function select R/W 0 R/W Function controller function is selected. 1 Host controller function is selected. Selects the function of the USB module. The DCFM bit should be modified while DPRPU is 0 and DRPD is 0. DRPD USB port 0 D+/D- line resistor control R/W R/W 0 Pulling down the lines is disabled. 1 Pulling down the lines is enabled. Enables or disables pulling down the D+/D- lines of USB port 0 when the host controller function is selected. The DRPD bit should be set to 1 if the host controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is selected.

RENESAS

| DPRPU         | USB port 0 D+ line resistor control Note | R/V |
|---------------|------------------------------------------|-----|
| 0             | Pulling up the line is disabled.         | R/V |
| 1             | Pulling up the line is enabled.          |     |
| Exclusion and |                                          |     |

Enables or disables pulling up the D+ line when the function controller function is selected. Setting the DPRPU bit to 1 when the function controller function is selected allows the USB module to enable pulling up the D+ line of USB port 0, thus notifying the USB host of connection as a full-speed device. Modifying the DPRPU bit from 1 to 0 allows the USB module to disable pulling up the D+ line of USB port 0, thus notifying the USB host of disconnection.

The DPRPU bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is selected.

| DMRPU | USB port 0 D- line resistor control Note | R/W |
|-------|------------------------------------------|-----|
| 0     | Pulling up the line is disabled.         | R/W |
| 1     | Pulling up the line is enabled.          |     |

Enables or disables pulling up the D- line when the function controller function is selected. Setting the DMRPU bit to 1 when the function controller function is selected allows the USB module to enable pulling up the D- line of USB port 0, thus notifying the USB host of connection as a low-speed device. Modifying the DMRPU bit from 1 to 0 allows the USB module to disable pulling up the D- line of USB port 0, thus notifying the USB host of disconnection.

The DMRPU bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is selected.

| Bits 2, 1 | Nothing is assigned                             | R/W |
|-----------|-------------------------------------------------|-----|
| _         | The write value must be 0. The read value is 0. | —   |

| USBE          | USB module clock enable                                                                          | R/W |
|---------------|--------------------------------------------------------------------------------------------------|-----|
| 0             | USB module operation is disabled.                                                                | R/W |
| 1             | USB module operation is enabled.                                                                 |     |
| Enables or d  | isables operation of the USB module.                                                             |     |
| Modifying the | e USBE bit from 1 to 0 initializes some register bits as listed in Table 13 - 4 and 13 - 5.      |     |
| This bit shou | is bit should be modified while SCKE is 1.                                                       |     |
| When the ho   | st controller function is selected, USBE should be set to 1 after setting DRPD to 1, eliminating |     |
| LNST bit cha  | ttering, and checking that the USB bus state has been settled.                                   |     |

Note Setting the DMRPU and DPRPU bits simultaneously to 1 (to enable pulling up the line) is prohibited.



| —       The write value must be 0. The read value is 0.         Bits 14 to 9       Nothing is assigned         —       The write value must be 0. The read value is 0.         F       —         The write value must be 0. The read value is 0.         CNEN       USB port 1 single end receiver enable         0       Single end receiver operation is disabled.         1       Single end receiver operation is enabled.         Enables or disables the single end receiver.         Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.         The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.         Bits 7, 6       Nothing is assigned         F       —         DRPD       F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | lress: | F0402             | :H, F04              | 03H      | After     | reset: ( | 0000H    |         |             |          |         |           |        |            |          |      |   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------|----------------------|----------|-----------|----------|----------|---------|-------------|----------|---------|-----------|--------|------------|----------|------|---|
| Bit 15       Reserved       F         —       The write value must be 0. The read value is 0.       F         Bits 14 to 9       Nothing is assigned       F         —       The write value must be 0. The read value is 0.       F         —       The write value must be 0. The read value is 0.       F         —       The write value must be 0. The read value is 0.       F         O       Single end receiver operation is disabled.       F         1       Single end receiver operation is enabled.       F         Enables or disables the single end receiver.       Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.       The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.         Bits 7, 6       Nothing is assigned       F         —       The write value must be 0. The read value is 0.       F         0       Pulling down the lines is disabled.       F         1       Pulling down the lines is enabled.       F         1       Pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         1       Pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         1       Pulling down the D+/D- lines of USB port 1 whe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | nbol   | 15                | 14                   | 13       | 12        | 11       | 10       | 9       | 8           | 7        | 6       | 5         | 4      | 3          | 2        | 1    |   |
| —       The write value must be 0. The read value is 0.         Bits 14 to 9       Nothing is assigned       F         —       The write value must be 0. The read value is 0.       F         —       The write value must be 0. The read value is 0.       F         O       Single end receiver operation is disabled.       F         1       Single end receiver operation is enabled.       F         1       Single end receiver operation is enabled.       F         1       Single end receiver operation is enabled.       F         1       Single end receiver.       Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.       F         The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.       F         Bits 7, 6       Nothing is assigned       F         —       The write value must be 0. The read value is 0.       F         0       Pulling down the lines is disabled.       F         1       Pulling down the lines is enabled.       F         1       Pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connecti                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | FG1    |                   | _                    | —        | _         | —        | —        | —       | CNEN        |          | —       | DRPD      |        | _          | _        | —    | - |
| Bits 14 to 9       Nothing is assigned       F         —       The write value must be 0. The read value is 0.       F         O       Single end receiver operation is disabled.       F         1       Single end receiver operation is disabled.       F         1       Single end receiver operation is disabled.       F         1       Single end receiver operation is enabled.       F         1       Single end receiver operation is enabled.       F         1       Single end receiver.       Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor LNST when the USB module operates as a Portable Device for Battery Charging.         Bits 7, 6       Nothing is assigned       F         —       The write value must be 0. The read value is 0.       F         0       Pulling down the lines is disabled.       F         1       Pulling down the lines is enabled.       F         1       Pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | [      | Bit               | 15                   |          |           |          |          |         | R           | eserve   | d       |           |        |            |          |      | R |
| Image: Construction of the status of | ľ      | _                 | -                    | The wr   | ite value | e must l | be 0. Th | ie read | value is    | Э.       |         |           |        |            |          |      | - |
| CNEN         USB port 1 single end receiver enable         F           0         Single end receiver operation is disabled.         F           1         Single end receiver operation is enabled.         F           Enables or disables the single end receiver.         Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.         The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.           Bits 7, 6         Nothing is assigned         F           —         The write value must be 0. The read value is 0.         F           0         Pulling down the lines is disabled.         F           1         Pulling down the lines is enabled.         F           1         Pulling down the lines is enabled.         F           1         Pulling down the D+/D- lines of USB port 1 when the host controller function is selected.           This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | [      | Bits 1            | 4 to 9               |          |           |          |          |         | Nothin      | g is ass | signed  |           |        |            |          |      | R |
| 0       Single end receiver operation is disabled.       F         1       Single end receiver operation is enabled.       F         1       Single end receiver operation is enabled.       F         Enables or disables the single end receiver.       Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.       The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.         Bits 7, 6       Nothing is assigned       F         —       The write value must be 0. The read value is 0.       F         0       Pulling down the lines is disabled.       F         1       Pulling down the lines is enabled.       F         1       Pulling down the lines is enabled.       F         1       Pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        | _                 | _                    | The wr   | ite value | e must l | be 0. Th | ie read | value is    | ).       |         |           |        |            |          |      | - |
| 1       Single end receiver operation is enabled.         Enables or disables the single end receiver.         Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.         The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.         Bits 7, 6       Nothing is assigned         F       —         The write value must be 0. The read value is 0.         F       0         Pulling down the lines is disabled.         I       Pulling down the lines is enabled.         Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         This bit should be set to 1 if the function controller function, or function BC connection detection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | [      | CN                | EN                   |          |           |          |          | USB po  | ort 1 sing  | e end    | receive | r enable  |        |            |          |      | R |
| Enables or disables the single end receiver.         Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.         The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.         Bits 7, 6       Nothing is assigned         —       The write value must be 0. The read value is 0.         DRPD       F         0       Pulling down the lines is disabled.         1       Pulling down the lines is enabled.         Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, or function BC connection detection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        | C                 | )                    | Single   | end rec   | eiver op | peration | is disa | bled.       |          |         |           |        |            |          |      | R |
| Setting the CNEN bit is set to 1 allows the USB module to enable the single end receiver of USB port 1 and set the LINST bit to monitor the status of the D+/D- lines.         The CNEN bit is used to monitor LNST when the USB module operates as a Portable Device for Battery Charging.         Bits 7, 6       Nothing is assigned         F       —         The write value must be 0. The read value is 0.         DRPD       F         0       Pulling down the lines is disabled.         1       Pulling down the lines is enabled.         Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | 1                 | I                    | Single   | end rec   | eiver op | peration | is ena  | bled.       |          |         |           |        |            |          |      |   |
| —       The write value must be 0. The read value is 0.         DRPD       F         0       Pulling down the lines is disabled.         1       Pulling down the lines is enabled.         Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | The Cl            | NEN bi               |          |           |          |          |         |             | le ope   | rates a | s a Porta | ble De | vice for   | Battery  |      |   |
| DRPD       F         0       Pulling down the lines is disabled.       F         1       Pulling down the lines is enabled.       F         Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.       F         This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | [      | Bits              | 7, 6                 |          |           |          |          |         | Nothin      | g is ass | signed  |           |        |            |          |      | R |
| 0         Pulling down the lines is disabled.         F           1         Pulling down the lines is enabled.         F           Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.         F           This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection function is         F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ĺ      | _                 | _                    | The wr   | ite value | e must l | be 0. Th | ie read | value is    | Э.       |         |           |        |            |          |      | - |
| Image: Constraint of the section of the section function is selected.           1         Pulling down the lines is enabled.           Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.           This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ſ      | DR                | PD                   |          |           |          |          |         |             |          |         |           |        |            |          |      | R |
| Enables or disables pulling down the D+/D- lines of USB port 1 when the host controller function is selected.<br>This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection detection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Ī      | C                 | )                    | Pulling  | down tl   | ne lines | is disat | oled.   |             |          |         |           |        |            |          |      | R |
| This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the function controller function, host BC connection detection function, or function BC connection function is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        | 1                 | l                    | Pulling  | down tl   | ne lines | is enab  | led.    |             |          |         |           |        |            |          |      |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        | This bi<br>contro | it shoul<br>ller fun | d be set | to 1 if t | he func  | tion con | troller | function is | s selec  | ted, an | d should  | be set | to 0 if th | ne funct | tion |   |
| District to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | L      |                   |                      |          |           |          |          |         |             |          |         |           |        |            |          |      |   |

## Figure 13 - 3 Format of System Configuration Control Register 1 (SYSCFG1)

| Bits 4 to 0 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| _           | The write value must be 0. The read value is 0. | _   |



## 13.3.2 System configuration status register n (SYSSTSn) (n = 0, 1)

## Figure 13 - 4 Format of System Configuration Status Register n (SYSSTSn) (n = 0, 1)

Address: F0404H, F0405H (SYSSTS0), F0406H, F0407H (SYSSTS1) After reset: X00X0000 00X00000B

| Symbol | 15          | 14   | 13                              | 12       | 11        | 10        | 9        | 8         | 7         | 6         | 5                   | 4        | 3   | 2 | 1         | 0         |
|--------|-------------|------|---------------------------------|----------|-----------|-----------|----------|-----------|-----------|-----------|---------------------|----------|-----|---|-----------|-----------|
| YSSTSn | OVCM<br>ON1 |      | _                               | _        | _         | —         | _        | _         | _         | HTAC<br>T | _                   | _        | _   |   | LNST<br>1 | LNST<br>0 |
|        | OVCM        | ON1  | İ                               |          |           | Ext       | ternal U | IOVRCI    | JRn inp   | ut pin m  | onitor <sup>N</sup> | lote     |     |   |           | R/W       |
|        |             |      | dicate th<br>N1 bit in          |          |           |           |          |           | •         | er-supply | / IC.               |          |     |   |           | R         |
|        | Bit 2       | 13   |                                 |          |           |           |          | Nothir    | ng is as  | signed    |                     |          |     |   |           | R/W       |
|        |             |      | The wr                          | ite valu | e must t  | oe 0. Th  | e read   | value is  | 0.        |           |                     |          |     |   |           | —         |
|        | Bit 1       | 12   |                                 |          |           |           |          | F         | Reserve   | d         |                     |          |     |   |           | R/W       |
|        |             |      | The wr                          | ite valu | e must k  | be 0. Th  | e read   | value is  | undefir   | ned.      |                     |          |     |   |           | —         |
|        | Bits 11     | to 7 |                                 |          |           |           |          | Nothir    | ng is as  | signed    |                     |          |     |   |           | R/W       |
|        |             | -    | The wr                          | ite valu | e must k  | be 0. Th  | e read   | value is  | 0.        |           |                     |          |     |   |           | _         |
|        | HTA         | СТ   |                                 |          |           | USB       | port n l | USB ho    | st seque  | encer sta | atus mo             | onitor   |     |   |           | R/W       |
|        | 0           |      | Host se                         | equence  | er of the | USB m     | odule is | s compl   | etely sto | opped.    |                     |          |     |   |           | R         |
|        | 1           |      | Host se                         | equence  | er of the | USB m     | odule i  | s not co  | mpletel   | y stoppe  | ed.                 |          |     |   |           |           |
|        |             |      | /hen the<br>e HTAC <sup>−</sup> |          | •         |           |          |           | •         |           | ••                  |          |     |   |           |           |
|        | Bit         | 5    |                                 |          |           |           |          | F         | Reserve   | d         |                     |          |     |   |           | R/W       |
|        |             |      | The wr                          | ite valu | e must k  | oe 0. Th  | e read   | value is  | undefir   | ned.      |                     |          |     |   |           | —         |
|        | Bits 4      | to 2 |                                 |          |           |           |          | Nothir    | ng is as: | signed    |                     |          |     |   |           | R/W       |
|        |             |      | The wr                          | ite valu | e must k  | oe 0. Th  | e read   | value is  | 0.        |           |                     |          |     |   |           | —         |
| ĺ      | LNS         | T1   | LNS                             | T0       |           |           | U        | SB por    | t n USB   | data lin  | e status            | s monito | r   |   |           | R/W       |
|        | 0           |      | 0                               |          | SE0       |           |          |           |           |           |                     |          |     |   |           | R         |
|        | 0           |      | 1                               |          | J-State   | (full spe | ed)/K-S  | State (lo | w speed   | d)        |                     |          |     |   |           |           |
|        | 1           |      | 0                               |          | K-State   | (full spe | ed)/J-8  | State (lo | w speed   | d)        |                     |          |     |   |           | 1         |
|        | 1           |      | 1                               |          | SE1       |           |          |           |           |           |                     |          |     |   |           | 1         |
|        |             |      | dicate th<br>nd LNS             |          |           |           |          | •         |           | ,         | line (D             | RPD = '  | 1). |   |           |           |

**Note** The read value depends on the status of the UOVRCURn pin.



## 13.3.3 Device state control register n (DVSTCTRn) (n = 0, 1)

#### Figure 13 - 5 Format of Device State Control Register 0 (DVSTCTR0)

| dress | F0408                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 8H, F04 | 09H        | After    | reset: ( | 0000H     |            |           |           |            |            |          |                      |           |           |                       |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------|----------|----------|-----------|------------|-----------|-----------|------------|------------|----------|----------------------|-----------|-----------|-----------------------|
| nbol  | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 14      | 13         | 12       | 11       | 10        | 9          | 8         | 7         | 6          | 5          | 4        | 3                    | 2         | 1         | 0                     |
| CTR0  | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | _       | _          | _        | _        | _         | VBUS<br>EN | WKUP      | RWUP<br>E | USBR<br>ST | RESU<br>ME | UACT     | _                    | RHST<br>2 | RHST<br>1 | RHS <sup>-</sup><br>0 |
|       | Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 15      |            |          |          |           |            | F         | eserve    | d          |            |          |                      |           |           | R/W                   |
|       | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | _       | The wri    | te value | e must l | be 0. Th  | ne read    | value is  | 0.        |            |            |          |                      |           |           | _                     |
|       | Bits 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 4 to 12 |            |          |          |           |            | Nothin    | g is ass  | signed     |            |          |                      |           |           | R/W                   |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _       | The wri    | te value | e must l | be 0. Th  | ne read    | value is  | 0.        |            |            |          |                      |           |           | -                     |
|       | Bits 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1, 10   |            |          |          |           |            | F         | eserve    | d          |            |          |                      |           |           | R/V                   |
|       | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | _       | The wri    | te value | e must l | be 0. Th  | ne read    | value is  | 0.        |            |            |          |                      |           |           | —                     |
|       | VBU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | SEN     |            |          |          | U         | SB port    | 0 UVBL    | ISEN0     | output p   | oin cont   | ol       |                      |           |           | R/V                   |
|       | The VI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | BUSEN   | l bit valu | e is out | put as t | he stati  | us of the  | e externa | I UVBL    | JSEN0      | pin with   | out chai | nge.                 |           |           | R/W                   |
|       | WK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | UP      |            |          |          |           | U          | SB port   | 0 wake    | up outp    | ut         |          |                      |           |           | R/V                   |
|       | C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | )       | Remote     | e wakeı  | ıp signa | ıl is not | output.    |           |           |            |            |          |                      |           |           | R/V                   |
|       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1       | Remote     | e wakeı  | ıp signa | ıl is out | put.       |           |           |            |            |          |                      |           |           | Note                  |
|       | <ul> <li>controller function is selected.</li> <li>The USB module controls the output time of a remote wakeup signal. When this bit is set to 1, the USB module clears this bit to 0 after outputting the 10-ms K-state.</li> <li>According to the USB Specifications, the USB bus idle state must be kept for 5 ms or longer before a remote wakeup signal is sent. Even if the USB module writes 1 to this bit right after detection of the suspended state, the K-state will be output after 2 ms.</li> <li>Do not write 1 to this bit, unless the device state is in the suspended state (DVSQ2 to DVSQ0 in the INTSTS0 register = 1xxB) and the USB host enables the remote wakeup signal. When this bit is set to 1, the internal clock must not be stopped even in the suspended state (write 1 to WKUP while SCKE in the SYSCFG register = 1). This bit should be set to 0 if the host controller function is selected.</li> </ul> |         |            |          |          |           |            |           |           |            |            |          |                      |           |           |                       |
|       | RWI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | JPE     |            |          |          |           | USB p      | ort 0 wa  | keup de   | tection    | enable     |          |                      |           |           | R/V                   |
|       | C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | )       | Downst     | tream p  | ort wak  | eup is o  | disabled   |           |           |            |            |          |                      |           |           | R/V                   |
|       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1       | Downst     | tream p  | ort wak  | eup is e  | enabled    | •         |           |            |            |          |                      |           |           |                       |
|       | Enables or disables the downstream port peripheral device to use the remote wakeup function (resume signal output) when the host controller function is selected.<br>With this bit set to 1, on detecting the remote wakeup signal, the USB module detects the resume signal (K-state for 2.5 µs) from the downstream port device and performs the resume processing (drives the port to the K-state) With this bit set to 0, the USB module ignores the detected remote wakeup signal (K-state) from the peripheral device connected to the USB port.                                                                                                                                                                                                                                                                                                                                                                                     |         |            |          |          |           |            |           |           |            |            |          | K-state<br>(-state). |           |           |                       |

While the PWUPE bit is 1, the internal clock should not be stopped even in the suspended state (SCKE should be set to 1).

This bit should be set to 0 if the function controller function is selected.

| USBRST          | USB port 0 USB bus reset output                                                                        | R/W |
|-----------------|--------------------------------------------------------------------------------------------------------|-----|
| 0               | USB bus reset signal is not output.                                                                    | R/W |
| 1               | USB bus reset signal is output.                                                                        |     |
| Controls the L  | JSB bus reset signal output when the host controller function is selected.                             |     |
| When the hos    | t controller function is selected, setting this bit to 1 allows the USB module to drive SE0 of the USB |     |
| port to reset t | he USB bus.                                                                                            |     |
| The USB mod     | lule continues outputting SE0 while USBRST is 1 (until software sets USBRST to 0). The USBRST          |     |
| bit should be   | 1 (= USB bus reset period) for the time defined by the USB Specifications 2.0.                         |     |
| Writing 1 to th | is bit during communication (UACT = 1) or during the resume processing (RESUME = 1) prevents           |     |
| the USB mod     | ule from starting the USB bus reset processing until UACT and RESUME become 0.                         |     |
| Write 1 to the  | UACT bit simultaneously with the end of the USB bus reset processing (writing 0 to USBRST).            |     |
| This bit shoul  | d be set to 0 if the function controller function is selected.                                         |     |

 RESUME
 USB port 0 resume output
 R/W

 0
 Resume signal is not output.
 R/W

 1
 Resume signal is output.
 R/W

 Controls the resume signal output when the host controller function is selected.
 Setting the RESUME bit to 1 allows the USB module to drive the port to the K-state and output the resume

signal.

The USB module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). The RESUME bit should be 1 (= resume period) for the time defined by the USB Specifications 2.0.

This bit should be set to 1 in the suspended state.

Write 1 to the UACT bit simultaneously with the end of the resume processing (writing 0 to RESUME). This bit should be set to 0 if the function controller function is selected.

| 0               | Downstream port is disabled (SOF transmission is disabled).                                       | R/W |
|-----------------|---------------------------------------------------------------------------------------------------|-----|
| 1               | Downstream port is enabled (SOF transmission is enabled).                                         |     |
| Enables ope     | ration of the USB bus (controls the SOF packet transmission to the USB bus) when the host         |     |
| controller fur  | nction is selected.                                                                               |     |
| With this bit s | set to 1, the USB module puts the USB port to the USB-bus enabled state and performs SOF output   |     |
| and data trar   | nsmission and reception.                                                                          |     |
| This module     | starts outputting SOF packets within one frame after software has written 1 to UACT.              |     |
| With this bit   | set to 0, the USB module enters the idle state after outputting SOF packets.                      |     |
| The USB mo      | odule sets the UACT bit to 0 on any of the following conditions.                                  |     |
| • A DTCH in     | terrupt is detected during communication (while UACT = 1).                                        |     |
| • An EOFER      | R interrupt is detected during communication (while UACT = 1).                                    |     |
| Writing 1 to t  | his bit should be done at the end of the USB reset processing (writing 0 to USBRST) or at the end |     |
| of the resum    | e processing from the suspended state (writing 0 to RESUME).                                      |     |
| This bit shou   | Id be set to 0 if the function controller function is selected.                                   |     |

| Bit 3 | Reserved                                                             | R/W |  |
|-------|----------------------------------------------------------------------|-----|--|
| _     | Nothing is assigned. The write value must be 0. The read value is 0. | —   |  |



| RHST2                             | RHST1            | RHST0            | USB port 0 USB bus reset status                                       | R/W |
|-----------------------------------|------------------|------------------|-----------------------------------------------------------------------|-----|
| <ul> <li>When the h</li> </ul>    | ost controller f | unction is sele  | cted                                                                  | R   |
| 0                                 | 0                | 0                | Communication speed not determined (powered state or no connection)   |     |
| 1                                 | Х                | Х                | USB bus reset in progress                                             |     |
| 0                                 | 0                | 1                | Low-speed connection                                                  |     |
| 0                                 | 1                | 0                | Full-speed connection                                                 |     |
| <ul> <li>When the full</li> </ul> | unction control  | ler function is  | selected                                                              |     |
| 0                                 | 0                | 0                | Communication speed not determined                                    |     |
| 1                                 | Х                | Х                | USB bus reset in progress                                             |     |
| 0                                 | 0                | 1                | Low-speed connection                                                  |     |
| 0                                 | 1                | 0                | Full-speed connection                                                 |     |
| The RHST[2:                       | 0] bits indicate | the status of t  | the USB bus reset.                                                    |     |
| When the hose                     | st controller fu | nction is select | ted, these bits indicate 100B after software has written 1 to USBRST. |     |
| The USB mo                        | dule fixes the v | alue of these    | bits when software writes 0 to USBRST and the USB module              |     |

The USB module fixes the value of these bits when software writes 0 to USBRST and the USB module completes SE0 driving.

When the function controller function is selected, a DVST interrupt is generated as soon as the USB module detects the USB bus reset and then these bits are fixed to 010B.

Note Only 1 can be written.

**Remark** x = Don't care



| Address  | F040A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | AH, F04 | 0BH                                     | After                                           | reset: (  | 0000H    |            |          |            |            |            |          |      |           |           |           |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------------------------|-------------------------------------------------|-----------|----------|------------|----------|------------|------------|------------|----------|------|-----------|-----------|-----------|
| Symbol   | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 14      | 13                                      | 12                                              | 11        | 10       | 9          | 8        | 7          | 6          | 5          | 4        | 3    | 2         | 1         | 0         |
| DVSTCTR1 | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _       | _                                       | _                                               | _         | —        | VBUS<br>EN | _        | RWUP<br>E  | USBR<br>ST | RESU<br>ME | UACT     | _    | RHST<br>2 | RHST<br>1 | RHST<br>0 |
|          | Bits 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5, 14   |                                         |                                                 |           |          |            | Nothir   | ng is ass  | signed     |            |          |      |           |           | R/W       |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _       | The wri                                 | ite value                                       | e must b  | oe 0. Th | ne read v  | /alue is | 0.         |            |            |          |      |           |           | —         |
|          | Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 13      | Reserved                                |                                                 |           |          |            |          |            |            |            |          |      |           | R/W       |           |
|          | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | -       | The wri                                 | The write value must be 0. The read value is 0. |           |          |            |          |            |            |            |          |      |           |           | —         |
|          | Bits 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2 to 10 |                                         |                                                 |           |          |            | Nothir   | ng is ass  | signed     |            |          |      |           |           | R/W       |
|          | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _       | The wri                                 | ite value                                       | e must k  | be 0. Th | ne read v  | /alue is | 0.         |            |            |          |      |           |           | —         |
|          | VBU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SEN     |                                         |                                                 |           | U        | SB port    | 1 UVBI   | JSEN1      | output p   | oin contr  | ol       |      |           |           | R/W       |
|          | The VI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | BUSEN   | l bit valu                              | e is out                                        | put as tl | he stati | us of the  | extern   | al UVBL    | JSEN1      | pin with   | out chai | nge. |           |           | R/W       |
|          | Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | t 8     |                                         |                                                 |           |          |            | Nothir   | ng is ass  | sianed     |            |          |      |           |           | R/W       |
|          | <ul> <li>The write value must be 0. The read value is 0.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |                                         |                                                 |           |          |            |          |            |            |            |          |      | —         |           |           |
|          | R//I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | IDE     | PE USB port 1 wakeup detection enable R |                                                 |           |          |            |          |            |            |            |          |      |           | R/W       |           |
|          | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | -       | Downst                                  | tream p                                         | ort wake  | eup out  | put is di  |          |            | lection    | enable     |          |      |           |           | R/W       |
|          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1       | Downst                                  | tream p                                         | ort wak   | eup is e | enabled.   |          |            |            |            |          |      |           |           |           |
|          | 1       Downstream port wakeup is enabled.         Enables or disables the downstream port peripheral device to use the remote wakeup function (resume signal output) when the host controller function is selected.         With this bit set to 1, on detecting the remote wakeup signal, the USB module detects the resume signal (K-state for 2.5 µs) from the downstream port device and performs the resume processing (drives the port to the K-state).         With this bit set to 0, the USB module ignores the detected remote wakeup signal (K-state) from the peripheral device connected to the USB port.         While the PWUPE bit is 1, the internal clock should not be stopped even in the suspended state (SCKE should be set to 1).         This bit should be set to 0 if the function controller function is selected.               |         |                                         |                                                 |           |          |            |          |            |            |            |          |      |           |           |           |
|          | USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RST     |                                         |                                                 |           |          | USB        | port 1 L | JSB bus    | reset c    | output     |          |      |           |           | R/W       |
|          | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |                                         |                                                 | signal i  |          | •          |          |            |            |            |          |      |           |           | R/W       |
|          | Contro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |                                         |                                                 | signal i  |          |            | ant on   | atrollar f | unction    | io color   | tod      |      |           |           |           |
|          | Controls the USB bus reset signal output when the host controller function is selected.<br>When the host controller function is selected, setting this bit to 1 allows the USB module to drive SE0 of the USB port to reset the USB bus.<br>The USB module continues outputting SE0 while USBRST is 1 (until software sets USBRST to 0). The USBRST bit should be 1 (= USB bus reset period) for the time defined by the USB Specifications 2.0.<br>Writing 1 to this bit during communication (UACT = 1) or during the resume processing (RESUME = 1) prevents the USB module from starting the USB bus reset processing until both UACT and RESUME become 0.<br>Write 1 to the UACT bit simultaneously with the end of the USB bus reset processing (writing 0 to USBRST).<br>This bit should be set to 0 if the function controller function is selected. |         |                                         |                                                 |           |          |            |          |            |            |            |          |      |           |           |           |

## Figure 13 - 6 Format of Device State Control Register 1 (DVSTCTR1)



| RESUME                | USB port 1 resume output                                                                    | R/W |
|-----------------------|---------------------------------------------------------------------------------------------|-----|
| 0                     | Resume signal is not output.                                                                | R/W |
| 1                     | Resume signal is output.                                                                    |     |
| Controls the          | resume signal output when the host controller function is selected.                         |     |
| Setting the R signal. | ESUME bit to 1 allows the USB module to drive the port to the K-state and output the resume |     |
| The USB mo            | dule continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). The  |     |
| RESUME bit            | should be 1 (= resume period) for the time defined by the USB Specifications 2.0.           |     |
| This bit shoul        | d be set to 1 in the suspended state.                                                       |     |

Write 1 to the UACT bit simultaneously with the end of the resume processing (writing 0 to RESUME). This bit should be set to 0 if the function controller function is selected.

| UACT           | USB port 1 USB bus enable                                                                         | R/W |
|----------------|---------------------------------------------------------------------------------------------------|-----|
| 0              | Downstream port is disabled (SOF transmission is disabled).                                       | R/W |
| 1              | Downstream port is enabled (SOF transmission is enabled).                                         |     |
| Enables ope    | ration of the USB bus (controls the SOF packet transmission to the USB bus) when the host         |     |
| controller fur | nction is selected.                                                                               |     |
| With this bit  | set to 1, the USB module puts the USB port to the USB-bus enabled state and performs SOF output   |     |
| and data tra   | nsmission and reception.                                                                          |     |
| This module    | starts outputting SOF packets within one frame after software has written 1 to the UACT bit.      |     |
| With this bit  | set to 0, the USB module enters the idle state after outputting SOF packets.                      |     |
| The USB mo     | dule sets the UACT bit to 0 on any of the following conditions.                                   |     |
| A DTCH inte    | rrupt is detected during communication (while UACT = 1).                                          |     |
| An EOFERF      | interrupt is detected during communication (while UACT = 1).                                      |     |
| Writing 1 to t | his bit should be done at the end of the USB reset processing (writing 0 to USBRST) or at the end |     |
| of the resum   | e processing from the suspended state (writing 0 to RESUME).                                      |     |
| This bit shou  | ld be set to 0 if the function controller function is selected.                                   |     |

| ſ | Bit 3 | Nothing is assigned                             | R/W |
|---|-------|-------------------------------------------------|-----|
|   | —     | The write value must be 0. The read value is 0. | _   |

| RHST2          | RHST1             | RHST0              | USB port 1 USB bus reset status                                      | R/W |
|----------------|-------------------|--------------------|----------------------------------------------------------------------|-----|
| When the h     | ost controller fu | unction is seled   | cted                                                                 | R   |
| 0              | 0                 | 0                  | Communication speed not determined (powered state or no connection)  |     |
| 1              | Х                 | Х                  | USB bus reset in progress                                            |     |
| 0              | 0                 | 1                  | Low-speed connection                                                 |     |
| 0              | 1                 | 0                  | Full-speed connection                                                |     |
| The RHST[2:    | 0] bits indicate  | 000B when th       | e function controller function is selected.                          |     |
| These bits inc | dicate the statu  | is of the USB b    | ous reset when the host controller function is selected.             |     |
| When the hos   | st controller fur | nction is selected | ed, these bits indicate 100B after software has written 1 to USBRST. |     |
| The USB mo     | dule fixes the v  | alue of these b    | pits when software writes 0 to USBRST and the USB module             |     |

completes SE0 driving.

**Remark** x = Don't care



## 13.3.4 CFIFO port register (CFIFOM), DnFIFO port register (DnFIFOM) (n = 0, 1)

| Iress: | F0414                                                                                                                | H, F041 | 15H                 | After    | reset: ( | 0000H    |           |           |          |          |          |           |          |       |         |     |
|--------|----------------------------------------------------------------------------------------------------------------------|---------|---------------------|----------|----------|----------|-----------|-----------|----------|----------|----------|-----------|----------|-------|---------|-----|
| nbol   | 15                                                                                                                   | 14      | 13                  | 12       | 11       | 10       | 9         | 8         | 7        | 6        | 5        | 4         | 3        | 2     | 1       | 0   |
| FOM    |                                                                                                                      |         |                     |          |          |          |           | CFIFC     | [15:0]   |          |          |           |          |       |         |     |
| Г      | CFIFO                                                                                                                | [15:0]  |                     |          |          |          |           | CI        | FIFO po  | ort      |          |           |          |       |         | R/W |
|        | Accessing the CFIFO bits allow reading the received data from the FIFO buffer or writing the transmit data to the R/ |         |                     |          |          |          |           |           |          |          |          |           |          | R/W   |         |     |
|        | The CF                                                                                                               |         | Ũ                   | er can l | be acce  | ssed or  | nly while | e the FR  | DY bit i | n the C  | FIFO po  | ort contr | ol regis | ter   |         |     |
|        |                                                                                                                      |         | n the C<br>e 13 - 6 | •        | 0        | ter depe | end on t  | the setti | ngs of t | he corre | espondii | ng MBV    | V and B  | IGEND | bits as |     |

Caution 3. There are two FIFO buffer states: the access right is on the CPU side and it is on the SIE side. When the FIFO buffer access right is on the SIE side, the FIFO buffer cannot be accessed from the CPU.

| BIGEND Bit in CFIFO Port Register,<br>DnFIFO Port Register | Bits 15 to 8 | Bits 7 to 0 |
|------------------------------------------------------------|--------------|-------------|
| 0                                                          | N + 1 data   | N + 0 data  |
| 1                                                          | N + 0 data   | N + 1 data  |

### Table 13 - 7 Endian Operation in 8-Bit Access

| BIGEND Bit in CFIFO Port Register,<br>DnFIFO Port Register | Bits 15 to 8      | Bits 7 to 0 |
|------------------------------------------------------------|-------------------|-------------|
| 0                                                          | Access prohibited | N + 0 data  |
| 1                                                          | Access prohibited | N + 0 data  |



#### Figure 13 - 8 Format of DnFIFO Port Register (DnFIFOM) (n = 0, 1)

Address: F0418H, F0419H (D0FIFOM), F041CH, F041DH (D1FIFOM) After reset: 0000H

|        |                                                                                                                | 13      | 12       | 11       | 10                                   | 9        | 8        | 7         | 6      | 5      | 4       | 3         | 2      | 1      | 0   |  |  |  |
|--------|----------------------------------------------------------------------------------------------------------------|---------|----------|----------|--------------------------------------|----------|----------|-----------|--------|--------|---------|-----------|--------|--------|-----|--|--|--|
| FIFOM  |                                                                                                                |         |          |          |                                      |          | DnFIF    | O[15:0]   |        |        |         |           |        |        |     |  |  |  |
| DnFIF  | O[15:0]                                                                                                        |         |          |          |                                      |          |          | FIFO po   | ort    |        |         |           |        |        | R/W |  |  |  |
| Addre  | sses for                                                                                                       | CPU tra | ansfers  | using th | ne DnFl                              | FO port  | t.       |           |        |        |         |           |        |        | R/W |  |  |  |
|        | Accessing the DnFIFO bits allow reading the received data from the FIFO buffer or writing the transmit data to |         |          |          |                                      |          |          |           |        |        |         |           |        |        |     |  |  |  |
| the FI | FO buffe                                                                                                       | r.      |          |          |                                      |          |          |           |        |        |         |           |        |        |     |  |  |  |
|        | nFIFO p                                                                                                        | 0       | ster can | be acc   | essed c                              | only whi | le the F | RDY bit   | in the | DnFIFO | port co | ntrol reg | gister |        |     |  |  |  |
| (DnFIF | FOCTR)                                                                                                         | is 1.   |          |          |                                      |          |          |           |        |        |         |           |        |        |     |  |  |  |
| The va | alid bits i                                                                                                    | n the D | nFIFO p  | oort reg | ister de                             | pend or  | n the se | ttings of | the co | respon | ding ME | SW and    | BIGEN  | D bits |     |  |  |  |
| as sho | wn in Ta                                                                                                       | able 13 | - 6 and  | 13 - 7.  | as shown in Table 13 - 6 and 13 - 7. |          |          |           |        |        |         |           |        |        |     |  |  |  |

- Caution 2. When using functions specific to the FIFO port, the pipe number (selected pipe) specified by the CURPIPE bits cannot be changed.
- Caution 3. The same pipe should not be assigned to different FIFO ports.
- Caution 4. There are two FIFO buffer states: the access right is on the CPU side and it is on the SIE side. When the FIFO buffer access right is on the SIE side, the FIFO buffer cannot be accessed from the CPU.



## 13.3.5 CFIFO port select register (CFIFOSEL), DnFIFO port select register (DnFIFOSEL) (n = 0, 1)

Figure 13 - 9 Format of CFIFO Port Select Register (CFIFOSEL)

| Symbol         15         14         13         12         11         10         9         8         7         6         5         4         3         2         1         0           CFIFOSEL         RCNT         REW         -         -         -         ISEL         -         CURP         CURP <th>Address</th> <th>: F0420</th> <th>H, F04</th> <th>21H</th> <th>After</th> <th>reset: (</th> <th>H0000</th> <th></th>                                                                                                                                                                                                                                                                                                                                                                                  | Address  | : F0420                                                                                                     | H, F04  | 21H       | After      | reset: (   | H0000                 |          |             |           |           |            |          |            |           |          |        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------|---------|-----------|------------|------------|-----------------------|----------|-------------|-----------|-----------|------------|----------|------------|-----------|----------|--------|
| CHPOSEL       RCN1       REW       -       -       ND       -       ND       -       PE3       IPE2       IPE1       IPE0         RCNT       RCNT       Read count mode       R/W       R/W       0       When all of the receive data has been read from the CFIF0. 0 is written to the DTLN bit. (In double buffer mode, the DTLN bit value is cleared when all the data has been read from only a single plane.)       R/W         1       The DTLN bit is decremented each time the receive data is read from the CFIF0.       Specifies the read mode for the value in the DTLN(8:0) bits in the CFIF0CTR register.       R/W         0       Disable (the buffer pointer is rewound.)       R/W       R/W       R/W         1       The buffer pointer is rewound.       R/W       Note 1       Note 1         Specifies whether or not to rewind the buffer pointer.       Note 1       Note 1       Note 1         Specifies whether or not to rewind the first data is allowed).       Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits.       R/W         —       The write value must be 0. The read value is 0.       -       -       -         MBW       CFIF0 port access bit width       R/W       R/W       N/W       N/W       -       -       -                                                                                                                                                                                                                                                                                                                                                                                                              | Symbol   | 15                                                                                                          | 14      | 13        | 12         | 11         | 10                    | 9        | 8           | 7         | 6         | 5          | 4        | 3          | 2         | 1        | 0      |
| 0         When all of the receive data has been read from the CFIFO, 0 is written to the DTLN bit.<br>(In double buffer mode, the DTLN bit value is cleared when all the data has been read from only a<br>single plane.)         R/W           1         The DTLN bit is decremented each time the receive data is read from the CFIFO.         Specifies the read mode for the value in the DTLN[8:0] bits in the CFIFOCTR register.           REW         Buffer pointer rewind         R/W           0         Disable (the buffer pointer is not rewound.)         R/W           1         The buffer pointer is rewound.         Note 1           Specifies whether or not to rewind the buffer pointer.         Note 1         Note 1           When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO buffer plane from the first data is allowed).         Do not set the REW bit to 1 simulaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit is 1.         —           To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.         MW           9         8-bit width         R/W         —           1         16-bit width         R/W         1           1         16-bit width         R/W         1           1         16-bit width<                                                                                                                                                                                                                                     | CFIFOSEL | RCNT                                                                                                        | REW     |           | _          | —          | MBW                   | —        |             | _         | _         | ISEL       | _        |            |           |          |        |
| In double buffer mode, the DTLN bit value is cleared when all the data has been read from only a single plane.).         In the DTLN bit is decremented each time the receive data is read from the CFIFO.           Specifies the read mode for the value in the DTLN[8:0] bits in the CFIFOCTR register.         RW           0         Disable (the buffer pointer is not rewound.)         RW           1         The buffer pointer is rewound.         RW           Specifies whether or not to rewind the buffer pointer.         Note 1           When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data is allowed).         RW           Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FROY bit 1 f.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.           Bits 13 to 11         Nothing is assigned         RW           -         The write value must be 0. The read value is 0.            MBW         CFIFO port.         RW           1         16-bit width         RW                                                                                                                                                                                                                                                                                                                       |          | RCI                                                                                                         | NT      |           |            |            |                       |          | Read        | count r   | node      |            |          |            |           |          | R/W    |
| single plane.)         1         The DTLN bit is decremented each time the receive data is read from the CFIFO.           Specifies the read mode for the value in the DTLN[8:0] bits in the CFIFOCTR register.         R/W           0         Disable (the buffer pointer is not rewound.)         R/W           1         The buffer pointer is rewound.         R/W           Specifies whether or not to rewind the buffer pointer.         Note 1           When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO buffer plane from the first data is allowed).         Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FROY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.           Bits 13 to 11         Nothing is assigned         R/W           -         The write value must be 0. The read value is 0.         -           MBW         CFIFO port access bit width         R/W           1         16-bit width         R/W           1         16-bit width         R/W           2         MBW         CFIFO port.           When the selected pipe is in the receiving direction, nee reading data is started after setting this bit, this bit should not be modified uniii                                                                                                                                                                                                                                          |          | 0                                                                                                           |         | When a    | all of the | e receiv   | e data h              | as bee   | n read fr   | om the    | CFIFO     | , 0 is wri | itten to | the DTL    | N bit.    |          | R/W    |
| Specifies the read mode for the value in the DTLN(8:0) bits in the CFIFOCTR register.         RW           REW         Buffer pointer rewind         R/W           0         Disable (the buffer pointer is not rewound.)         R/W           1         The buffer pointer is rewound.         R/W           Specifies whether or not to rewind the buffer pointer.         When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO buffer again from the first data is allowed).         Net 1           Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.           Bits 13 to 11         Nothing is assigned         R/W           -         The write value must be 0. The read value is 0.         -           MBW         CFIFO port access bit width         R/W           1         16-bit width         R/W           1         16-bit width         R/W           0         8-bit width         R/W           1         16-bit width         R/W           0         8-bit width         R/W           1         16-bit width <td></td> <td></td> <td></td> <td>•</td> <td></td> <td>er mode</td> <td>e, the D<sup>-</sup></td> <td>ΓLN bit</td> <td>value is</td> <td>cleared</td> <td>when</td> <td>all the da</td> <td>ata has</td> <td>been re</td> <td>ad from</td> <td>only a</td> <td></td>                                                                         |          |                                                                                                             |         | •         |            | er mode    | e, the D <sup>-</sup> | ΓLN bit  | value is    | cleared   | when      | all the da | ata has  | been re    | ad from   | only a   |        |
| REW         Buffer pointer rewind         RW           0         Disable (the buffer pointer is not rewound.)         RW           1         The buffer pointer is rewound.         RW           2         Specifies whether or not to rewind the buffer pointer.         Note 1           Specifies whether or not to rewind the buffer pointer.         When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO buffer plane from the first data is allowed).         Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.           Bits 13 to 11         Nothing is assigned         RW           —         The write value must be 0. The read value is 0.         -           MBW         CFIFO port access bit width         RW           1         16-bit width         RW           1         16-bit width         RW           1         16-bit width or accessing the CFIFO port.         RW           1         16-bit width         RW           1         16-bit width or accessing the CFIFO port.         When the selected pipe is in the receiving direction, once reading data i                                                                                                                                                                                                                                                                                       |          | 1                                                                                                           |         | The DT    | 'LN bit i  | s decre    | mented                | each t   | ime the I   | eceive    | data is   | read fro   | m the (  | CFIFO.     |           |          |        |
| 0         Disable (the buffer pointer is not rewound.)         R/W           1         The buffer pointer is rewound.         Note 1           Specifies whether or not to rewind the buffer pointer.         When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO buffer plane from the first data is allowed).         Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.           Bits 13 to 11         Nothing is assigned         R/W           -         The write value must be 0. The read value is 0.         -           MBW         CFIFO port access bit width         R/W           1         16-bit width         R/W           0         8-bit width         R/W           1         16-bit width         R/W           1         16-bit width         R/W           2         Specifies the bit width for accessing the CFIFO port.         R/W           1         16-bit width         R/W           2         Specifies us in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-b                                                                                                                                                                                                                                                                              |          | Specifi                                                                                                     | es the  | read mo   | de for t   | he valu    | e in the              | DTLN[    | 8:0] bits   | in the C  | FIFOC     | TR regis   | ster.    |            |           |          |        |
| Image: Note 1         The buffer pointer is rewound.         Note 1           Specifies whether or not to rewind the buffer pointer.         When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data is allowed).         Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.           Bits 13 to 11         Nothing is assigned         RW           —         The write value must be 0. The read value is 0.         -           MBW         CFIFO port access bit width         RW           1         16-bit width         RW           1         16-bit width         RW           1         16-bit width         RW           Specifies the bit width for accessing the CFIFO port.         When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.         Withen the selected pipe is in the transmitting direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected.           When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written through byte-access control even when 16-bit                                                                                                                                  |          | RE                                                                                                          | W       |           |            |            |                       |          | Buffer      | pointer   | rewind    |            |          |            |           |          | R/W    |
| If the builter pointer is reworded.         Specifies whether or not to rewind the buffer pointer.         When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data is allowed).         Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit s 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.         Bits 13 to 11       Nothing is assigned       RW         —       The write value must be 0. The read value is 0.       -         MBW       CFIFO port access bit width       RW         1       16-bit width is selected, pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected. <td></td> <td>0</td> <td></td> <td>Disable</td> <td>(the bu</td> <td>uffer poi</td> <td>inter is r</td> <td>not rew</td> <td>ound.)</td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td>R/W</td>                                                                                                                                                                                                |          | 0                                                                                                           |         | Disable   | (the bu    | uffer poi  | inter is r            | not rew  | ound.)      |           |           |            |          |            |           |          | R/W    |
| When the selected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read         allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO         buffer plane from the first data is allowed).         Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the         REW bit to 1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.         Bits 13 to 11       Nothing is assigned       RW         —       The write value must be 0. The read value is 0.       -         MBW       CFIFO port access bit width       RW         1       16-bit width       RW         Specifies the bit width for accessing the CFIFO port.       RW       RW         1       16-bit width       RW         Specifies the bit width for accessing direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width to 16-bit width while data is being written to the buffer memory. <t< td=""><td></td><td>1</td><td></td><td>The but</td><td>ffer poir</td><td>nter is re</td><td>ewound</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>Note 1</td></t<> |          | 1                                                                                                           |         | The but   | ffer poir  | nter is re | ewound                |          |             |           |           |            |          |            |           |          | Note 1 |
| allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO         buffer plane from the first data is allowed).         Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the         REW bit 0.1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.         Bits 13 to 11       Nothing is assigned       RW         —       The write value must be 0. The read value is 0.       —         MBW       CFIFO port access bit width       R/W         0       8-bit width       R/W         1       16-bit width       R/W         Specifies the bit width for accessing the CFIFO port.       R/W         When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —                                                                                                                                                                                                                                                                         |          | Specifi                                                                                                     | es whe  | ther or r | not to re  | wind th    | e buffer              | pointe   | r.          |           |           |            |          |            |           |          |        |
| buffer plane from the first data is allowed).       Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.         Bits 13 to 11       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.          MBW       CFIFO port access bit width       R/W         0       8-bit width       R/W         1       16-bit width       R/W         When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width to 16-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       -         Bit 9       Nothing is assigned       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                  |          |                                                                                                             |         |           |            |            | -                     |          | -           |           |           |            |          |            |           | -        |        |
| Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the REW bit to 1, be sure to check that the FRDY bit is 1.         To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.         Bits 13 to 11       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.          MBW       CFIFO port access bit width       R/W         0       8-bit width       R/W         1       16-bit width       R/W         1       16-bit width for accessing the CFIFO port.       R/W         When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       R/W         When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width wile data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.                                                                                                                                                                                                                                                                            |          |                                                                                                             |         | -         |            |            |                       | rst data | i (in doul  | ble buffe | er mode   | e, re-rea  | ding th  | e curren   | itly-read | IFIFO    |        |
| REW bit to 1, be sure to check that the FRDY bit is 1.       To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.         Bits 13 to 11       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         MBW       CFIFO port access bit width       R/W         0       8-bit width       R/W         1       16-bit width       R/W         1       16-bit width for accessing the CFIFO port.       R/W         When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected.       Event width withe data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.       M/W         —       The write value must be 0. The read value is 0.       —         Mit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         B                                                                                                                                                                                                                                                                                                                                          |          | Do not set the REW bit to 1 simultaneously with modifying the CURPIPE3 to CURPIPE0 bits. Before setting the |         |           |            |            |                       |          |             |           |           |            |          |            |           |          |        |
| Bits 13 to 11       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         MBW       CFIFO port access bit width       R/W         0       8-bit width       R/W         1       16-bit width       R/W         Specifies the bit width for accessing the CFIFO port.       R/W       R/W         When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory. An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         BIGEND       CFIFO port endian control       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |                                                                                                             |         |           |            |            |                       |          |             |           |           |            |          |            |           |          |        |
| —       The write value must be 0. The read value is 0.       —         MBW       CFIFO port access bit width       R/W         0       8-bit width       R/W         1       16-bit width       R/W         Specifies the bit width for accessing the CFIFO port.       When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         BIGEND       CFIFO port endian control       R/W         0       Little endian       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          | To re-w                                                                                                     | rite to | the FIFC  | ) buffer   | again f    | rom the               | first da | ita for the | e pipe ir | n the tra | ansmittin  | g direc  | tion, use  | e the BC  | CLR bit. |        |
| —       The write value must be 0. The read value is 0.       —         MBW       CFIFO port access bit width       R/W         0       8-bit width       R/W         1       16-bit width       R/W         Specifies the bit width for accessing the CFIFO port.       When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.       When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         BIGEND       CFIFO port endian control       R/W         0       Little endian       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          | Bits 13                                                                                                     | to 11   |           |            |            |                       |          | Nothin      | a is ass  | sianed    |            |          |            |           |          | R/W    |
| 08-bit widthR/W116-bit widthSpecifies the bit width for accessing the CFIFO port.When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit<br>should not be modified until all the data has been read.When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits<br>simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete<br>unnecessary bytes after reading the data in words.When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit<br>width while data is being written to the buffer memory.<br>An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.Bit 9Nothing is assignedR/W—The write value must be 0. The read value is 0.—BIGENDCFIFO port endian controlR/W1Big endianR/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          | _                                                                                                           | -       | The wri   | te value   | e must l   | be 0. Th              | e read   |             | -         |           |            |          |            |           |          | _      |
| 08-bit widthR/W116-bit widthSpecifies the bit width for accessing the CFIFO port.When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit<br>should not be modified until all the data has been read.When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits<br>simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete<br>unnecessary bytes after reading the data in words.When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit<br>width while data is being written to the buffer memory.<br>An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.Bit 9Nothing is assignedR/W—The write value must be 0. The read value is 0.—BIGENDCFIFO port endian controlR/W1Big endianR/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |                                                                                                             | 14/     |           |            |            |                       | 0        |             | 4         | - h:+;    | مافاه      |          |            |           |          |        |
| 116-bit widthSpecifies the bit width for accessing the CFIFO port.When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit<br>should not be modified until all the data has been read.When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits<br>simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete<br>unnecessary bytes after reading the data in words.When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit<br>width while data is being written to the buffer memory.<br>An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.Bit 9Nothing is assignedR/W—The write value must be 0. The read value is 0.—BIGENDCFIFO port endian controlR/W0Little endianR/W1Big endianR/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |                                                                                                             |         | 0 hituri  | dth        |            |                       | C        |             | t acces   | S DIT WI  | aın        |          |            |           |          |        |
| Specifies the bit width for accessing the CFIFO port.         When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.         When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         BIGEND       CFIFO port endian control       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |                                                                                                             |         |           |            |            |                       |          |             |           |           |            |          |            |           |          | rt/vv  |
| When the selected pipe is in the receiving direction, once reading data is started after setting this bit, this bit should not be modified until all the data has been read.         When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         BIGEND       CFIFO port endian control       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                                                                                                             |         | -         |            | occina     | the CEI               | EO nor   | +           |           |           |            |          |            |           |          |        |
| should not be modified until all the data has been read.         When the selected pipe is in the receiving direction, set the CURPIPE3 to CURPIPE0 and MBW bits         simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete         unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit         width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned         —       The write value must be 0. The read value is 0.         —       BIGEND         CFIFO port endian control       R/W         0       Little endian         R/W       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          | -                                                                                                           |         |           |            | -          |                       |          |             | adina c   | lata is s | started a  | fter set | tina this  | bit. this | bit      |        |
| simultaneously. If the size of data to be read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         BIGEND       CFIFO port endian control       R/W         0       Little endian       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |                                                                                                             |         |           |            |            | -                     |          |             | 5         |           |            |          | 5          | ,         |          |        |
| unnecessary bytes after reading the data in words.         When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned       R/W         —       The write value must be 0. The read value is 0.       —         BIGEND       CFIFO port endian control       R/W         1       Big endian       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |                                                                                                             |         |           |            |            | -                     |          |             |           |           |            |          |            |           |          |        |
| When the selected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned         —       The write value must be 0. The read value is 0.         —       BIGEND         CFIFO port endian control       R/W         0       Little endian         1       Big endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |                                                                                                             |         | -         |            |            |                       |          | odd numl    | per of b  | ytes wh   | nen 16-b   | it width | is selec   | ted, del  | lete     |        |
| width while data is being written to the buffer memory.         An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.         Bit 9       Nothing is assigned         —       The write value must be 0. The read value is 0.         —       BIGEND         CFIFO port endian control       R/W         0       Little endian         1       Big endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |                                                                                                             |         |           |            | -          |                       |          | on. the b   | it width  | cannot    | be char    | naed fro | om 8-bit   | width to  | o 16-bit |        |
| Bit 9     Nothing is assigned     R/W       —     The write value must be 0. The read value is 0.     —       BIGEND     CFIFO port endian control     R/W       0     Little endian     R/W       1     Big endian     R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |                                                                                                             |         |           |            |            | -                     |          |             |           |           |            | 5        |            |           |          |        |
| BIGEND     CFIFO port endian control     R/W       0     Little endian     R/W       1     Big endian     R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          | An odd                                                                                                      | numb    | er of byt | es can     | also be    | written               | throug   | n byte-ao   | cess co   | ontrol e  | ven whe    | en 16-b  | it width i | s select  | ted.     |        |
| BIGEND     CFIFO port endian control     R/W       0     Little endian     R/W       1     Big endian     R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          | Bit                                                                                                         | 9       |           |            |            |                       |          | Nothin      | g is ass  | signed    |            |          |            |           |          | R/W    |
| 0     Little endian     R/W       1     Big endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |                                                                                                             | -       | The wri   | te value   | e must l   | be 0. Th              | e read   | value is    | 0.        |           |            |          |            |           |          | —      |
| 0     Little endian     R/W       1     Big endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          | BIGE                                                                                                        |         |           |            |            |                       | 0        |             | ort ondic | n cont    | rol        |          |            |           |          | D/M    |
| 1 Big endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          | -                                                                                                           |         | Little er | ndian      |            |                       |          | n n o po    |           |           |            |          |            |           |          |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |                                                                                                             |         |           |            |            |                       |          |             |           |           |            |          |            |           |          |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |                                                                                                             |         | -         |            | the CFI    | FO port               |          |             |           |           |            |          |            |           |          |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |                                                                                                             |         | ,         |            |            |                       |          |             |           |           |            |          |            |           |          | I      |



| Bits 7, 6 | Nothing is assigned                              | R/W |
|-----------|--------------------------------------------------|-----|
| _         | The write value must be 0. The read value is 0.  | _   |
|           |                                                  |     |
| ISEI      | CEIEO port access direction when DCP is selected | R/W |

| IJLL            | Criti o portaccess direction when Dor is selected                                                               | 1.0/0.0 |  |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------|---------|--|--|--|--|--|--|
| 0               | Reading from the buffer memory is selected                                                                      |         |  |  |  |  |  |  |
| 1               | 1 Writing to the buffer memory is selected                                                                      |         |  |  |  |  |  |  |
| After writing t | After writing to the ISEL bit with the DCP being a selected pipe, read this bit to check that the written value |         |  |  |  |  |  |  |
| agrees with th  | he read value before proceeding to the next process.                                                            |         |  |  |  |  |  |  |
|                 |                                                                                                                 | 1       |  |  |  |  |  |  |

Set this bit and the CURPIPE3 to CURPIPE0 bits simultaneously.

| Bit 4 | Nothing is assigned                             | R/W |
|-------|-------------------------------------------------|-----|
| _     | The write value must be 0. The read value is 0. | _   |

| i        |           |          |          |                                             |     |
|----------|-----------|----------|----------|---------------------------------------------|-----|
| CURPIPE3 | CURPIPE2  | CURPIPE1 | CURPIPE0 | CFIFO port access pipe specification Note 2 | R/W |
| 0        | 0         | 0        | 0        | DCP (Default control pipe)                  | R/W |
| 0        | 1         | 0        | 0        | Pipe 4                                      |     |
| 0        | 1         | 0        | 1        | Pipe 5                                      |     |
| 0        | 1         | 1        | 0        | Pipe 6                                      |     |
| 0        | 1         | 1        | 1        | Pipe 7                                      |     |
|          | Other the | an above |          | Do not set.                                 |     |

The CURPIPE3 to CURPIPE0 bits specify the pipe number using which data is read or written through the CFIFO port.

After writing to the CURPIPE3 to CURPIPE0 bits, read these bits to check that the written value agrees with the read value before proceeding to the next process.

Even if an attempt is made to modify the setting of these bits during access to the FIFO buffer, the current access setting is retained until the access is completed. Then, the modification becomes effective, thus enabling continuous access.

Note 1. Only 0 can be read.

**Note 2.** The same pipe number should not be set by the CURPIPE3 to CURPIPE0 bits in the CFIFOSEL, D0FIFOSEL, and D1FIFOSEL registers.



#### Figure 13 - 10 Format of DnFIFO port select register (DnFIFOSEL) (n = 0, 1)

Address: F0428H, F0429H (D0FIFOSEL), F042CH, F042DH (D1FIFOSEL) After reset: 0000H

| Symbol    | 15                                                                                                                      | 14     | 13                                                                                                                                                                                                             | 12       | 11         | 10        | 9       | 8          | 7        | 6         | 5         | 4        | 3            | 2            | 1            | 0            |
|-----------|-------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|-----------|---------|------------|----------|-----------|-----------|----------|--------------|--------------|--------------|--------------|
| DnFIFOSEL | RCNT                                                                                                                    | REW    | DCLR<br>M                                                                                                                                                                                                      | —        | _          | MBW       |         | BIGE<br>ND | —        |           | _         |          | CURPI<br>PE3 | CURP<br>IPE2 | CURP<br>IPE1 | CURP<br>IPE0 |
|           | RC                                                                                                                      | NT     |                                                                                                                                                                                                                |          |            |           |         | Read       | count r  | node      |           |          |              |              |              | R/W          |
|           | 0 (In double buffer mode, the DTLN[8:0] bit value is cleared when all the data has been read from only a single plane.) |        |                                                                                                                                                                                                                |          |            |           |         |            |          |           |           |          |              |              | R/W          |              |
|           | 1                                                                                                                       |        | The DTLN[8:0] bits are decremented each time the receive data is read from the DnFIFO.                                                                                                                         |          |            |           |         |            |          |           |           |          |              |              |              |              |
|           | •                                                                                                                       |        | read mod<br>ing DnFIF                                                                                                                                                                                          |          |            |           | -       | -          |          |           | 0         | ister.   |              |              |              |              |
|           | RE                                                                                                                      | W      |                                                                                                                                                                                                                |          |            |           |         | Buffer p   | ointer   | rewind    |           |          |              |              |              | R/W          |
|           | C                                                                                                                       | )      | Disable                                                                                                                                                                                                        | (the bu  | iffer poi  | nter is n | ot rewo | ound.)     |          |           |           |          |              |              |              | R/W          |
|           | 1                                                                                                                       |        | The buff                                                                                                                                                                                                       | er poin  | iter is re | wound.    |         |            |          |           |           |          |              |              |              | Note 1       |
|           | Specifi                                                                                                                 | es whe | ther or no                                                                                                                                                                                                     | ot to re | wind the   | e buffer  | pointer |            |          |           |           |          |              |              |              |              |
|           |                                                                                                                         |        | ected pipe is in the receiving direction, setting the REW bit to 1 while the FIFO buffer is being read<br>ading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO |          |            |           |         |            |          |           |           |          |              |              |              |              |
|           |                                                                                                                         |        | •                                                                                                                                                                                                              |          |            |           | st data | (in doub   | le buffe | er mode   | e, re-rea | ding the | e curren     | tly-read     | I FIFO       |              |
|           |                                                                                                                         |        | om the fi                                                                                                                                                                                                      |          |            | ,         |         |            |          |           |           |          |              |              |              |              |
|           | Do not                                                                                                                  | set RE | W to 1 si                                                                                                                                                                                                      | multar   | eously     | with mo   | difying | the CUF    | RPIPE b  | oits. Bef | ore sett  | ing RE   | W to 1, I    | be sure      | to           |              |

check that FRDY is 1. When accessing the DnFIFO with the BFRE bit set to 1, do not set the REW bit to 1 while reading of the short packet data is completed. To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit.

| DCLRM                                                     | Auto buffer memory clear mode accessed after specified pipe data is read                                                                                                                                                                                                                                                                                                                                                                               | R/W |
|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 0                                                         | Auto buffer clear mode is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W |
| 1                                                         | Auto buffer clear mode is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| selected pip<br>With the DC<br>receiving a<br>short packe | disables the buffer memory to be cleared automatically after data has been read out using the e.<br>LRM bit set to 1, the USB module sets BCLR to 1 for the FIFO buffer of the selected pipe on zero-length packet while the FIFO buffer assigned to the selected pipe is empty, or on receiving a and reading the data while BFRE in the PIPECFG register is 1.<br>the USB module with BRDYM in the SOFCFG register set to 1, set the DCLRM bit to 0. |     |
| Bit 12                                                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |
|                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
| —                                                         | The write value must be 0. The read value is 0.                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |

| Bit 11 | Nothing is assigned                             | R/W |
|--------|-------------------------------------------------|-----|
|        | The write value must be 0. The read value is 0. | —   |



| MBW          | DnFIFO port access bit width                                                                              | R/W |
|--------------|-----------------------------------------------------------------------------------------------------------|-----|
| 0            | 8-bit width                                                                                               | R/W |
| 1            | 16-bit width                                                                                              |     |
| Specifies th | e bit width for accessing the DnFIFO port.                                                                |     |
| When the s   | elected pipe is in the receiving direction, once reading data is started after setting the MBW bit, this  |     |
| bit should n | ot be modified until all the data has been read.                                                          |     |
| When the s   | elected pipe is in the receiving direction, set the CURPIPE and MBW bits simultaneously. If the size      |     |
| of data to b | e read is an odd number of bytes when 16-bit width is selected, delete unnecessary bytes after            |     |
| reading the  | data in words.                                                                                            |     |
| When the s   | elected pipe is in the transmitting direction, the bit width cannot be changed from 8-bit width to 16-bit |     |
| width while  | data is being written to the buffer memory.                                                               |     |
|              |                                                                                                           |     |

An odd number of bytes can also be written through byte-access control even when 16-bit width is selected.

| Bit 9 | Nothing is assigned                             | R/W |
|-------|-------------------------------------------------|-----|
| _     | The write value must be 0. The read value is 0. | —   |

| BIGEND        | DnFIFO port endian control       | R/W |
|---------------|----------------------------------|-----|
| 0             | Little endian                    | R/W |
| 1             | Big endian                       |     |
| Specifies the | byte endian for the DnFIFO port. |     |

| Bit 7 | Reserved                                        | R/W |
|-------|-------------------------------------------------|-----|
| _     | The write value must be 0. The read value is 0. | —   |

| Bits 6 to 4 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| —           | The write value must be 0. The read value is 0. | _   |

| CURPIPE3 | CURPIPE2  | CURPIPE1 CURPIPE0 |   | DnFIFO port access pipe specification Note 2 |     |  |
|----------|-----------|-------------------|---|----------------------------------------------|-----|--|
| 0        | 0         | 0                 | 0 | No pipe specified                            | R/W |  |
| 0        | 1         | 0                 | 0 | Pipe 4                                       |     |  |
| 0        | 1         | 0                 | 1 | Pipe 5                                       |     |  |
| 0        | 1         | 1                 | 0 | Pipe 6                                       |     |  |
| 0        | 1         | 1                 | 1 | Pipe 7                                       |     |  |
|          | Other the | an above          |   | Do not set.                                  |     |  |

The CURPIPE3 to CURPIPE0 bits specify the pipe number using which data is read or written through the DnFIFO port.

After writing to CURPIPE3 to CURPIPE0 bits, then read these bits to check that the written value agrees with the read value before proceeding to the next process.

Even if an attempt is made to modify the setting of these bits during access to the FIFO buffer, the current access setting is retained until the access is completed. Then, the modification becomes effective, thus enabling continuous access.

Note 1. Only 0 can be read.

**Note 2.** The same pipe number should not be set by the CURPIPE3 to CURPIPE0 bits in the CFIFOSEL, D0FIFOSEL, and D1FIFOSEL registers.



# 13.3.6 CFIFO port control register (CFIFOCTR), DnFIFO port control register (DnFIFOCTR) (n = 0, 1)

|          | Figure 13 - 11 Format of CFIFO Port Control Register (CFIFOCTR) |          |      |       |          |       |   |          |         |           |   |         |    |   |   |     |
|----------|-----------------------------------------------------------------|----------|------|-------|----------|-------|---|----------|---------|-----------|---|---------|----|---|---|-----|
| Address  | : F0422                                                         | :H, F042 | 23H  | After | reset: ( | 0000H |   |          |         |           |   |         |    |   |   |     |
| Symbol   | 15                                                              | 14       | 13   | 12    | 11       | 10    | 9 | 8        | 7       | 6         | 5 | 4       | 3  | 2 | 1 | 0   |
| CFIFOCTR | BVAL                                                            | BCLR     | FRDY |       | —        | —     | — |          |         |           | D | TLN[8:0 | )] |   |   |     |
|          | BV                                                              | AL       |      |       |          |       | E | Buffer m | emorv v | alid flad | 1 |         |    |   |   | R/W |
|          | BVAL Buffer memory valid flag R/W                               |          |      |       |          |       |   |          |         |           |   |         |    |   |   |     |

| BVAL            | Builer memory valid liag                                                                             | R/W    |
|-----------------|------------------------------------------------------------------------------------------------------|--------|
| 0               | Invalid                                                                                              | R/W    |
| 1               | Writing ended                                                                                        | Note 1 |
| This bit shoul  | d be set to 1 when data has been completely written to the FIFO buffer on the CPU side for the       |        |
| pipe selected   | using the CURPIPE3 to CURPIPE0 bits (selected pipe).                                                 |        |
| When the sele   | ected pipe is in the transmitting direction, set the BVAL bit to 1 in the following cases. Then, the |        |
| USB module      | switches the FIFO buffer from the CPU side to the SIE side, thus enabling transmission.              |        |
| To transmit     | a short packet, set the BVAL bit to 1 after data has been written.                                   |        |
| To transmit     | a zero-length packet, set the BVAL bit to 1 while the FIFO buffer is empty.                          |        |
| When data of    | the maximum packet size has been written for the pipe in continuous transfer mode, the USB           |        |
| module sets t   | he BVAL bit to 1 and switches the FIFO buffer from the CPU side to the SIE side, thus enabling       |        |
| transmission.   |                                                                                                      |        |
| Writing 1 to th | e BVAL bit should be done while FRDY is 1 (set by the USB module).                                   |        |
| When the sel    | ected pipe is in the receiving direction, do not set the BVAL bit to 1.                              |        |

| 1Clears the buffer memory on the CPU side.Note1Clears the buffer memory on the CPU side.NoteThis bit should be set to 1 to clear the FIFO buffer on the CPU side for the selected pipe.When double buffer mode is set for the FIFO buffer assigned to the selected pipe, the USB module clears only<br>one plane of the FIFO buffer even when both planes are read-enabled.When the selected pipe is the DCP, setting BCLR to 1 allows the USB module to clear the FIFO buffer<br>regardless of whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the<br>PID bits for the DCP control register to NAK before setting BCLR to 1.When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously,<br>the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port | BCLR           | CPU buffer clear                                                                                        | R/W    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------|--------|
| This bit should be set to 1 to clear the FIFO buffer on the CPU side for the selected pipe.<br>When double buffer mode is set for the FIFO buffer assigned to the selected pipe, the USB module clears only one plane of the FIFO buffer even when both planes are read-enabled.<br>When the selected pipe is the DCP, setting BCLR to 1 allows the USB module to clear the FIFO buffer regardless of whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the PID bits for the DCP control register to NAK before setting BCLR to 1.<br>When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously, the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.<br>When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                         | 0              | Invalid                                                                                                 | R/W    |
| When double buffer mode is set for the FIFO buffer assigned to the selected pipe, the USB module clears only<br>one plane of the FIFO buffer even when both planes are read-enabled.<br>When the selected pipe is the DCP, setting BCLR to 1 allows the USB module to clear the FIFO buffer<br>regardless of whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the<br>PID bits for the DCP control register to NAK before setting BCLR to 1.<br>When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously,<br>the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.<br>When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                            | 1              | Clears the buffer memory on the CPU side.                                                               | Note 2 |
| one plane of the FIFO buffer even when both planes are read-enabled.<br>When the selected pipe is the DCP, setting BCLR to 1 allows the USB module to clear the FIFO buffer<br>regardless of whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the<br>PID bits for the DCP control register to NAK before setting BCLR to 1.<br>When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously,<br>the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.<br>When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                                                                                                                                            | This bit shou  | ld be set to 1 to clear the FIFO buffer on the CPU side for the selected pipe.                          |        |
| When the selected pipe is the DCP, setting BCLR to 1 allows the USB module to clear the FIFO buffer regardless of whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the PID bits for the DCP control register to NAK before setting BCLR to 1.<br>When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously, the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.<br>When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                                                                                                                                                                                                                             | When double    | e buffer mode is set for the FIFO buffer assigned to the selected pipe, the USB module clears only      |        |
| regardless of whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the PID bits for the DCP control register to NAK before setting BCLR to 1.<br>When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously, the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.<br>When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | one plane of   | the FIFO buffer even when both planes are read-enabled.                                                 |        |
| PID bits for the DCP control register to NAK before setting BCLR to 1.<br>When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously,<br>the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.<br>When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | When the se    | lected pipe is the DCP, setting BCLR to 1 allows the USB module to clear the FIFO buffer                |        |
| When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously, the USB module clears the data that has been written before it, enabling transmission of a zero-length packet. When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | regardless of  | whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the    |        |
| the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.<br>When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PID bits for t | he DCP control register to NAK before setting BCLR to 1.                                                |        |
| When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | When the se    | lected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously, |        |
| When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port control register is 1 (set by the USB module).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | the USB mod    | dule clears the data that has been written before it, enabling transmission of a zero-length packet.    |        |
| control register is 1 (set by the USB module).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | When the se    | lected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY in the FIFO port        |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | control regist | er is 1 (set by the USB module).                                                                        |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                |                                                                                                         |        |

| FRDY           | FIFO port ready R                                                                                          |       |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------|-------|--|--|--|
| 0              | FIFO port access is disabled.                                                                              | R     |  |  |  |
| 1              | FIFO port access is enabled.                                                                               |       |  |  |  |
| Indicates wh   | ether the FIFO port can be accessed by the CPU.                                                            |       |  |  |  |
| In the followi | ng cases, the USB module sets FRDY to 1 but data cannot be read via the FIFO port because there            |       |  |  |  |
|                | be read. In these cases, set BCLR to 1 to clear the FIFO buffer, and enable transmission and he next data. |       |  |  |  |
| • A zero-leng  | th packet is received when the FIFO buffer assigned to the selected pipe is empty.                         |       |  |  |  |
| A short pace   | ket is received and the data is completely read while BFRE in the PIPECFG register is 1.                   |       |  |  |  |
| -              | 1                                                                                                          |       |  |  |  |
| Rite 12 to 9   | Nothing is assigned                                                                                        | R/\// |  |  |  |

| Bits 12 to 9 | Nothing is assigned                             | R/W |  |
|--------------|-------------------------------------------------|-----|--|
| _            | The write value must be 0. The read value is 0. | —   |  |



| DTLN[8:0]      | Receive data length                                                                                    | R/W |
|----------------|--------------------------------------------------------------------------------------------------------|-----|
| The DTLN[8:0   | )] bits indicate the length of the receive data.                                                       | R   |
| While the FIF  | O buffer is being read, the DTLN[8:0] bits indicate different values depending on the RCNT bit         |     |
| value as desc  | ribed below.                                                                                           |     |
| • RCNT = 0     |                                                                                                        |     |
| The USB mod    | dule sets the DTLN[8:0] bits to indicate the length of the receive data until the CPU has read all the |     |
| received data  | from a single FIFO buffer plane.                                                                       |     |
| While BFRE i   | n the PIPECFG register is 1, these bits retain the length of the receive data until BCLR is set to 1   |     |
| even after all | the data has been read.                                                                                |     |
| • RCNT = 1     |                                                                                                        |     |
| The USB mod    | dule decrements the value indicated by these bits each time data is read from the FIFO buffer. (The    |     |
| value is decre | emented by one when MBW is 0, and by two when MBW is 1.)                                               |     |
| The USB mod    | dule sets these bits to 0 when all the data has been read from one FIFO buffer plane. However, in      |     |
| double buffer  | mode, if data has been received in one FIFO buffer plane before all the data has been read from        |     |
| the other plan | e, the USB module sets the DTLN[8:0] bits to indicate the length of the receive data in the former     |     |
| plane when a   | Il the data has been read from the latter plane.                                                       |     |

Note 1. Only 1 can be written.

Note 2. Only 0 can be read and 1 can be written.



DnFIFOCTR BVAL BCLR FRDY

### Figure 13 - 12 Format of DnFIFO Port Control Register (DnFIFOCTR) (n = 0, 1)

Address: F042AH, F042BH (D0FIFOCTR), F042EH, F042FH (D1FIFOCTR) After reset: 0000H

—

—

—

| Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

—

DTLN[8:0]

| BVAL          | Buffer memory valid flag                                                                              |      |  |  |  |  |  |  |  |  |
|---------------|-------------------------------------------------------------------------------------------------------|------|--|--|--|--|--|--|--|--|
| 0             | Invalid                                                                                               | R/\  |  |  |  |  |  |  |  |  |
| 1             | Writing ended                                                                                         | Note |  |  |  |  |  |  |  |  |
| This bit shou | Id be set to 1 when data has been completely written to the FIFO buffer on the CPU side for the       |      |  |  |  |  |  |  |  |  |
| pipe selecte  | d using the CURPIPE3 to CURPIPE0 bits (selected pipe).                                                |      |  |  |  |  |  |  |  |  |
| When the se   | lected pipe is in the transmitting direction, set the BVAL bit to 1 in the following cases. Then, the |      |  |  |  |  |  |  |  |  |
| USB module    | switches the FIFO buffer from the CPU side to the SIE side, thus enabling transmission.               |      |  |  |  |  |  |  |  |  |
| To transmit   | a short packet, set the BVAL bit to 1 after data has been written.                                    |      |  |  |  |  |  |  |  |  |
| To transmit   | a zero-length packet, set the BVAL bit to 1 while the FIFO buffer is empty.                           |      |  |  |  |  |  |  |  |  |
| When data o   | f the maximum packet size has been written for the pipe in continuous transfer mode, the USB          |      |  |  |  |  |  |  |  |  |
| module sets   | the BVAL bit to 1 and switches the FIFO buffer from the CPU side to the SIE side, thus enabling       |      |  |  |  |  |  |  |  |  |
| transmissior  | l.                                                                                                    |      |  |  |  |  |  |  |  |  |
| Writing 1 to  | he BVAL bit should be done while FRDY is 1 (set by the USB module).                                   |      |  |  |  |  |  |  |  |  |
| When the se   | lected pipe is in the receiving direction, do not set the BVAL bit to 1.                              |      |  |  |  |  |  |  |  |  |

| BCLR                                                                                                               | CPU buffer clear                                                                                 |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0                                                                                                                  | Invalid                                                                                          |  |  |  |  |  |  |  |  |  |
| 1                                                                                                                  | Clears the buffer memory on the CPU side.                                                        |  |  |  |  |  |  |  |  |  |
| This bit should be set to 1 to clear the FIFO buffer on the CPU side for the selected pipe.                        |                                                                                                  |  |  |  |  |  |  |  |  |  |
| When double                                                                                                        | buffer mode is set for the FIFO buffer assigned to the selected pipe, the USB module clears only |  |  |  |  |  |  |  |  |  |
| one plane of                                                                                                       | the FIFO buffer even when both planes are read-enabled.                                          |  |  |  |  |  |  |  |  |  |
| When the selected pipe is in the transmitting direction, if 1 is written to the BVAL and BCLR bits simultaneously, |                                                                                                  |  |  |  |  |  |  |  |  |  |
| the USB module clears the data that has been written before it, enabling transmission of a zero-length packet.     |                                                                                                  |  |  |  |  |  |  |  |  |  |
| When the selected pipe is not the DCP, writing 1 to the BCLR bit should be done while FRDY is 1 (set by the        |                                                                                                  |  |  |  |  |  |  |  |  |  |

| USB | module | ). |
|-----|--------|----|
|     |        |    |

| FRDY                                                                                                          | FIFO port ready                                                                              |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 0                                                                                                             | IFO port access is disabled.                                                                 |  |  |  |  |  |  |  |  |  |  |
| 1                                                                                                             | FIFO port access is enabled.                                                                 |  |  |  |  |  |  |  |  |  |  |
| ndicates whe                                                                                                  | ether the FIFO port can be accessed by the CPU.                                              |  |  |  |  |  |  |  |  |  |  |
| In the following cases, the USB module sets FRDY to 1 but data cannot be read via the FIFO port because there |                                                                                              |  |  |  |  |  |  |  |  |  |  |
| s no data to                                                                                                  | be read. In these cases, set BCLR to 1 to clear the FIFO buffer, and enable transmission and |  |  |  |  |  |  |  |  |  |  |
| eception of t                                                                                                 | he next data.                                                                                |  |  |  |  |  |  |  |  |  |  |
| A zero-leng                                                                                                   | th packet is received when the FIFO buffer assigned to the selected pipe is empty.           |  |  |  |  |  |  |  |  |  |  |
| • A short packet is received and the data is completely read when BFRE is set to 1.                           |                                                                                              |  |  |  |  |  |  |  |  |  |  |

| Bits 12 to 9 | Nothing is assigned                             | R/W |
|--------------|-------------------------------------------------|-----|
| —            | The write value must be 0. The read value is 0. | —   |



| DTLN[8:0]        | N[8:0] Receive data length F                                                                            |     |  |  |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|
| The DTLN[8:0     | )] bits indicate the length of the receive data.                                                        | R/W |  |  |  |  |  |  |  |
| While the FIF    | O buffer is being read, the DTLN[8:0] bits indicate different values depending on the RCNT bit          |     |  |  |  |  |  |  |  |
| value as desc    | ribed below.                                                                                            |     |  |  |  |  |  |  |  |
| • RCNT = 0       |                                                                                                         |     |  |  |  |  |  |  |  |
| The USB mod      | dule sets the DTLN[8:0] bits to indicate the length of the receive data until the CPU has read all the  |     |  |  |  |  |  |  |  |
| received data    | from a single FIFO buffer plane.                                                                        |     |  |  |  |  |  |  |  |
| While the BFF    | RE bit in the PIPECFG register is 1, these bits retain the length of the receive data until BCLR is set |     |  |  |  |  |  |  |  |
| to 1 even afte   | r all the data has been read.                                                                           |     |  |  |  |  |  |  |  |
| • RCNT = 1       |                                                                                                         |     |  |  |  |  |  |  |  |
| The USB mod      | ule decrements the value indicated by these bits each time data is read from the FIFO buffer. (The      |     |  |  |  |  |  |  |  |
| value is decre   | emented by one when MBW is 0, and by two when MBW is 1.) The USB module sets DTLN to 0                  |     |  |  |  |  |  |  |  |
| when all the c   | lata has been read from one FIFO buffer plane. However, in double buffer mode, if data has been         |     |  |  |  |  |  |  |  |
| received in or   | ne FIFO buffer plane before all the data has been read from the other plane, the USB module sets        |     |  |  |  |  |  |  |  |
| these bits to in | ndicate the length of the receive data in the former plane when all the data has been read from the     |     |  |  |  |  |  |  |  |
| latter plane.    | ·                                                                                                       |     |  |  |  |  |  |  |  |

Note 1. Only 1 can be written.

Note 2. Only 0 can be read and 1 can be written.



## 13.3.7 Interrupt enable register 0 (INTENB0)

Figure 13 - 13 Format of Interrupt Enable Register 0 (INTENB0)

| Address | : F0430                                                                                                                        | H, F043   | 31H                                                     | After                                                                                       | reset: (  | 0000H     |           |           |           |           |          |      |   |     |   |     |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------|-----------|---------------------------------------------------------|---------------------------------------------------------------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|----------|------|---|-----|---|-----|--|--|
| Symbol  | 15                                                                                                                             | 14        | 13                                                      | 12                                                                                          | 11        | 10        | 9         | 8         | 7         | 6         | 5        | 4    | 3 | 2   | 1 | 0   |  |  |
| NTENB0  | VBSE                                                                                                                           | RSME      | SOFE                                                    | DVSE                                                                                        | CTRE      | BEMP<br>E | NRDY<br>E | BRDY<br>E | _         | _         | _        |      | _ | _   | _ | —   |  |  |
|         | VB                                                                                                                             | SE        |                                                         |                                                                                             |           |           |           | VBUS i    | nterrupt  | enable    | •        |      |   |     |   | R/W |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | ot outpu                                                                                    | t disable | ed        |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | 1                                                                                                                              | I         | Interrup                                                | ot outpu                                                                                    | t enable  | ed        |           |           |           |           |          |      |   |     |   |     |  |  |
|         | Enable                                                                                                                         | es or dis | ables th                                                | ne USB                                                                                      | interrup  | ot outpu  | t when    | the VBI   | NT inter  | rupt is ( | detectec | l.   |   |     |   |     |  |  |
|         | RS                                                                                                                             | ME        |                                                         |                                                                                             |           |           | Re        | sume in   | terrupt e | enable    | Note     |      |   |     |   | R/W |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | ot outpu                                                                                    | t disable | ed        |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | 1                                                                                                                              | I         | Interrup                                                | terrupt output enabled<br>les the USB interrupt output when the RESM interrupt is detected. |           |           |           |           |           |           |          |      |   |     |   |     |  |  |
|         | Enable                                                                                                                         | es or dis | ables th                                                | ne USB                                                                                      | interrup  | ot outpu  | t when    | the RES   | M inter   | rupt is o | detected | l.   |   |     |   |     |  |  |
|         | SO                                                                                                                             | FE        |                                                         | Frame number update interrupt enable                                                        |           |           |           |           |           |           |          |      |   |     |   |     |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | ot outpu                                                                                    | t disable | ed        |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | 1                                                                                                                              | l         | Interrup                                                | ot outpu                                                                                    | t enable  | ed        |           |           |           |           |          |      |   |     |   |     |  |  |
|         | Enables or disables the USB interrupt output when the SOFR interrupt is detected.                                              |           |                                                         |                                                                                             |           |           |           |           |           |           |          |      |   |     |   |     |  |  |
|         | DV                                                                                                                             | SE        |                                                         | Device state transition interrupt enable Note                                               |           |           |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | Interrupt output disabled                                                                   |           |           |           |           |           |           |          |      |   | R/W |   |     |  |  |
|         | 1                                                                                                                              |           |                                                         |                                                                                             |           |           |           |           |           |           |          |      |   |     |   |     |  |  |
|         | Enables or disables the USB interrupt output when the DVST interrupt is detected.                                              |           |                                                         |                                                                                             |           |           |           |           |           |           |          |      |   |     |   |     |  |  |
|         | СТ                                                                                                                             | RE        | Control transfer stage transition interrupt enable Note |                                                                                             |           |           |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | ot outpu                                                                                    | t disable | ed        |           |           |           |           |          |      |   |     |   |     |  |  |
|         | 1                                                                                                                              | l         | Interrup                                                | ot outpu                                                                                    | t enable  | ed        |           |           |           |           |          |      |   |     |   |     |  |  |
|         | Enables or disables the USB interrupt output when the CTRT interrupt is detected.                                              |           |                                                         |                                                                                             |           |           |           |           |           |           |          |      |   |     |   |     |  |  |
|         | BEN                                                                                                                            | /IPE      |                                                         |                                                                                             |           |           | But       | ffer emp  | ty interr | upt ena   | able     |      |   |     |   | R/W |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | ot outpu                                                                                    | t disable | ed        |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | 1                                                                                                                              | l         | Interrup                                                | ot outpu                                                                                    | t enable  | ed        |           |           |           |           |          |      |   |     |   |     |  |  |
|         | Enable                                                                                                                         | es or dis | ables th                                                | ne USB                                                                                      | interrup  | ot outpu  | t when    | the BEN   | 1P interi | rupt is o | detected |      |   |     |   |     |  |  |
|         | NRE                                                                                                                            | DYE       |                                                         |                                                                                             |           | Buf       | fer Not   | Ready F   | Respons   | se Inter  | rupt Ena | able |   |     |   | R/W |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | ot outpu                                                                                    | t disable | ed        |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | 1                                                                                                                              | l         | Interrup                                                | ot outpu                                                                                    | t enable  | ed        |           |           |           |           |          |      |   |     |   |     |  |  |
|         | Enable                                                                                                                         | es or dis | ables th                                                | ne USB                                                                                      | interrup  | ot outpu  | twhen     | the NR    | OY interi | rupt is o | detected |      |   |     |   |     |  |  |
|         | BRD                                                                                                                            | DYE       |                                                         |                                                                                             |           |           | Buf       | fer Read  | dy Interr | upt En    | able     |      |   |     |   | R/W |  |  |
|         | C                                                                                                                              | )         | Interrup                                                | ot outpu                                                                                    | t disable | ed        |           |           |           |           |          |      |   |     |   | R/W |  |  |
|         | 1                                                                                                                              |           | Interrup                                                | ot outpu                                                                                    | t enable  | ed        |           |           |           |           |          |      |   |     |   |     |  |  |
|         | 1         Interrupt output enabled           Enables or disables the USB interrupt output when the BRDY interrupt is detected. |           |                                                         |                                                                                             |           |           |           |           |           |           |          |      |   |     |   |     |  |  |



| Bits 7 to 0 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| —           | The write value must be 0. The read value is 0. | —   |

**Note** The RSME, DVSE, and CTRE bits can be set to 1 only when the function controller function is selected; do not set these bits to 1 (interrupt output enabled) when the host controller function is selected.



#### R9A02G015

## 13.3.8 Interrupt enable register n (INTENBn) (n = 1, 2)

Figure 13 - 14 Format of Interrupt Enable Register 1 (INTENB1)

| Address | : F0432                                                                           | H, F04                                                                             | 33H       | After                                                                                        | reset: 0   | 000H    |           |          |           |             |           |        |   |   |   |               |  |  |
|---------|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------|----------------------------------------------------------------------------------------------|------------|---------|-----------|----------|-----------|-------------|-----------|--------|---|---|---|---------------|--|--|
| Symbol  | 15                                                                                | 14                                                                                 | 13        | 12                                                                                           | 11         | 10      | 9         | 8        | 7         | 6           | 5         | 4      | 3 | 2 | 1 | 0             |  |  |
| INTENB1 | OVRC<br>RE                                                                        | BCHG<br>E                                                                          | i _       | DTCH<br>E                                                                                    | ATTCH<br>E | _       | _         | _        | _         | EOFE<br>RRE | SIGNE     | SACKE  | — | — | _ | PDDET<br>INTE |  |  |
|         | OVR                                                                               | CRE                                                                                |           |                                                                                              | ι          | JSB po  | ort 0 ove | ercurren | t input d | hange       | interrupt | enable |   |   |   | R/W           |  |  |
|         | C                                                                                 |                                                                                    | Interrup  | ot outpu                                                                                     | t disable  | -       | -         |          | •         | 5           |           |        |   |   |   | R/W           |  |  |
|         | 1                                                                                 |                                                                                    | Interrup  | ot outpu                                                                                     | t enable   | d       |           |          |           |             |           |        |   |   |   | _             |  |  |
|         | Enable                                                                            | es or di                                                                           | sables th | ne USB                                                                                       | interrup   | t outpu | t when    | the OVF  | RCR int   | errupt is   | detecte   | ed.    |   |   |   |               |  |  |
|         | BCH                                                                               | IGE                                                                                |           |                                                                                              |            | USI     | B port 0  | USB b    | us chan   | ge inter    | rupt ena  | able   |   |   |   | R/W           |  |  |
|         | C                                                                                 | )                                                                                  | Interrup  | errupt output disabled                                                                       |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | 1                                                                                 |                                                                                    | Interrup  | terrupt output enabled<br>bles the USB interrupt output when the BCHG interrupt is detected. |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | Enable                                                                            | es or di                                                                           | sables tł | ne USB                                                                                       | interrup   | t outpu | t when    | the BCI  | IG inter  | rupt is o   | detected  | l.     |   |   |   |               |  |  |
|         | Bit                                                                               | Bit 13 Nothing is assigned                                                         |           |                                                                                              |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         |                                                                                   | -                                                                                  | The wr    | he write value must be 0. The read value is 0.                                               |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | DTC                                                                               | HE                                                                                 |           | USB port 0 disconnection detection interrupt enable                                          |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | C                                                                                 |                                                                                    | Interrup  | Interrupt output disabled                                                                    |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | 1                                                                                 |                                                                                    | Interrup  | nterrupt output enabled                                                                      |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | Enables or disables the USB interrupt output when the DTCH interrupt is detected. |                                                                                    |           |                                                                                              |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | ATTO                                                                              | ATTCHE USB port 0 connection detection interrupt enable                            |           |                                                                                              |            |         |           |          |           |             |           |        |   |   |   | R/W           |  |  |
|         | C                                                                                 | )                                                                                  | Interrup  | Interrupt output disabled                                                                    |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | 1                                                                                 | 1 Interrupt output enabled                                                         |           |                                                                                              |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | Enable                                                                            | Enables or disables the USB interrupt output when the ATTCH interrupt is detected. |           |                                                                                              |            |         |           |          |           |             |           |        |   |   |   |               |  |  |
|         | Bits 1                                                                            | 0 to 7                                                                             |           |                                                                                              |            |         |           | Nothir   | ng is as  | signed      |           |        |   |   |   | R/W           |  |  |
|         |                                                                                   | _                                                                                  | The wr    | ite value                                                                                    | e must b   | e 0. Th | e read    | value is | 0.        |             |           |        |   |   |   | —             |  |  |
|         | EOFE                                                                              | RRE                                                                                |           |                                                                                              |            | USB     | port 0 I  | EOF erro | or deteo  | tion inte   | errupt er | nable  |   |   |   | R/W           |  |  |
|         | C                                                                                 | )                                                                                  | Interrup  | ot outpu                                                                                     | t disable  | ed      |           |          |           |             |           |        |   |   |   | R/W           |  |  |
|         | 1                                                                                 |                                                                                    | Interrup  | ot outpu                                                                                     | t enable   | d       |           |          |           |             |           |        |   |   |   |               |  |  |
|         | Enable                                                                            | es or di                                                                           | sables tl | ne USB                                                                                       | interrup   | t outpu | t when    | the EOF  | ERR ir    | nterrupt    | is detec  | ted.   |   |   |   |               |  |  |
|         | SIG                                                                               | NE                                                                                 |           |                                                                                              |            | ę       | Setup tr  | ansactio | on error  | interrup    | ot enable | Э      |   |   |   | R/W           |  |  |
|         | C                                                                                 | )                                                                                  | Interrup  | ot outpu                                                                                     | t disable  | ed      |           |          |           |             |           |        |   |   |   | R/W           |  |  |
|         | 1                                                                                 |                                                                                    | Interrup  | ot outpu                                                                                     | t enable   | d       |           |          |           |             |           |        |   |   |   |               |  |  |
|         | Enable                                                                            | es or di                                                                           | sables tl | ne USB                                                                                       | interrup   | t outpu | t when    | the SIG  | N interr  | upt is d    | etected.  |        |   |   |   |               |  |  |
|         | SAC                                                                               | KE                                                                                 |           |                                                                                              |            | Setup 1 | transac   | tion nor | mal res   | ponse ir    | nterrupt  | enable |   |   |   | R/W           |  |  |
|         | C                                                                                 | )                                                                                  | Interrup  | ot outpu                                                                                     | t disable  | ed      |           |          |           |             |           |        |   |   |   | R/W           |  |  |
|         | 1                                                                                 |                                                                                    | Interrup  | ot outpu                                                                                     | t enable   | d       |           |          |           |             |           |        |   |   |   |               |  |  |
|         | Enable                                                                            | es or di                                                                           | sables tl | ne USB                                                                                       | interrup   | t outpu | t when    | the SAC  | CK inter  | rupt is c   | letected  | -      |   |   |   |               |  |  |



| Bits 3 to 1                                                                           | Nothing is assigned                                   |     |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------|-------------------------------------------------------|-----|--|--|--|--|--|--|--|
| _                                                                                     | The write value must be 0. The read value is 0.       |     |  |  |  |  |  |  |  |
|                                                                                       |                                                       |     |  |  |  |  |  |  |  |
| PDDETINTE                                                                             | USB port 0 Portable Device detection interrupt enable | R/W |  |  |  |  |  |  |  |
| 0                                                                                     | Interrupt output disabled                             | R/W |  |  |  |  |  |  |  |
| 1                                                                                     | Interrupt output enabled                              |     |  |  |  |  |  |  |  |
| Enables or disables the USB interrupt output when the PDDETINT interrupt is detected. |                                                       |     |  |  |  |  |  |  |  |

Caution The bits in INTENB1 can be set to 1 only when the host controller function is selected; do not set these bits to 1 (interrupt output enabled) when the function controller function is selected.



| ess: | F0434H, F04                                                                         | 35H                                                   | After                                                                             | reset: 0                  | 000H    |         |          |          |             |          |          |   |     |     |            |  |
|------|-------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------|---------|---------|----------|----------|-------------|----------|----------|---|-----|-----|------------|--|
| ool  | 15 14                                                                               | 13                                                    | 12                                                                                | 11                        | 10      | 9       | 8        | 7        | 6           | 5        | 4        | 3 | 2   | 1   | 0          |  |
| 32   | DVRC BCHG<br>RE E                                                                   | 9 –                                                   | DTCH<br>E                                                                         | ATTCH<br>E                | _       | _       | _        | _        | EOFE<br>RRE | -        | _        | _ | -   | -   | PDD<br>INT |  |
| Г    | OVRCRE                                                                              |                                                       |                                                                                   | ι                         | JSB po  | rt 1 Ov | ercurren | t input  | change      | interrup | t enable | ; |     |     | R/V        |  |
| F    | 0                                                                                   | Interrup                                              | USB port 1 Overcurrent input change interrupt enable<br>Interrupt output disabled |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| F    | 1                                                                                   | Interrup                                              | pt outpu                                                                          | it enable                 | d       |         |          |          |             |          |          |   |     |     |            |  |
|      | Enables or di                                                                       | sables tl                                             | he USB                                                                            | interrup                  | t outpu | t when  | the OVI  | RCR in   | terrupt is  | s detect | ed.      |   |     |     |            |  |
| Г    | BCHGE                                                                               | HGE USB port 1 USB bus change interrupt enable        |                                                                                   |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| F    | 0                                                                                   | Interrup                                              | pt outpu                                                                          | ıt disable                | ed      | -       |          |          | -           | -        |          |   |     |     | R/V        |  |
| F    | 1                                                                                   | 1 Interrupt output enabled                            |                                                                                   |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| I    | Enables or disables the USB interrupt output when the BCHG interrupt is detected.   |                                                       |                                                                                   |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| Г    | Bit 13                                                                              |                                                       |                                                                                   |                           |         |         | Nothir   | ng is as | signed      |          |          |   |     |     | R/V        |  |
| Ľ    |                                                                                     | The wr                                                | The write value must be 0. The read value is 0.                                   |                           |         |         |          |          |             |          |          |   |     |     | —          |  |
| Г    | DTCHE                                                                               | USB port 1 disconnection detection interrupt enable   |                                                                                   |                           |         |         |          |          |             |          |          |   |     | R/V |            |  |
| F    | 0                                                                                   | Interrup                                              | pt outpu                                                                          | it disable                | ed      |         |          |          |             |          |          |   |     |     | R/V        |  |
| F    | 1                                                                                   | Interrupt output enabled                              |                                                                                   |                           |         |         |          |          |             |          |          |   |     |     |            |  |
|      | Enables or disables the USB interrupt output when the DTCH interrupt is detected.   |                                                       |                                                                                   |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| Г    | ATTCHE                                                                              | USB port 1 connection detection interrupt enable      |                                                                                   |                           |         |         |          |          |             |          |          |   |     | R/W |            |  |
| Γ    | 0                                                                                   | Interrup                                              | pt outpu                                                                          | ıt disable                | ed      |         |          |          |             |          |          |   |     |     | R/V        |  |
| Γ    | 1                                                                                   | Interrup                                              | Interrupt output enabled                                                          |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| I    | Enables or disables the USB interrupt output when the ATTCH interrupt is detected.  |                                                       |                                                                                   |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| Г    | Bits 10 to 7                                                                        | Nothing is assigned                                   |                                                                                   |                           |         |         |          |          |             |          |          |   | R/W |     |            |  |
|      |                                                                                     | The write value must be 0. The read value is 0.       |                                                                                   |                           |         |         |          |          |             |          |          |   |     | —   |            |  |
| Г    | EOFERRE                                                                             | USB port 1 EOF error detection interrupt enable       |                                                                                   |                           |         |         |          |          |             |          |          |   |     | R/V |            |  |
| F    | 0                                                                                   | Interrupt output disabled                             |                                                                                   |                           |         |         |          |          |             |          |          |   | R/V |     |            |  |
| F    | 1                                                                                   | Interrup                                              | pt outpu                                                                          | it enable                 | d       |         |          |          |             |          |          |   |     |     |            |  |
|      | Enables or disables the USB interrupt output when the EOFERR interrupt is detected. |                                                       |                                                                                   |                           |         |         |          |          |             |          |          |   |     |     |            |  |
| Г    | Bits 5 to 1                                                                         |                                                       |                                                                                   |                           |         |         | Nothir   | ng is as | signed      |          |          |   |     |     | R/V        |  |
|      |                                                                                     | The write value must be 0. The read value is 0.       |                                                                                   |                           |         |         |          |          |             |          |          |   | _   |     |            |  |
|      | PDDETINT                                                                            | USB port 1 Portable Device detection interrupt enable |                                                                                   |                           |         |         |          |          |             |          |          |   |     | R/V |            |  |
|      | Е                                                                                   |                                                       |                                                                                   | Interrupt output disabled |         |         |          |          |             |          |          |   |     |     | R/V        |  |
|      |                                                                                     | Interrup                                              | pt outpu                                                                          | ıt disable                | ed      |         |          |          |             |          |          |   |     |     | 1.0.4      |  |
|      | Е                                                                                   | -                                                     |                                                                                   | it disable<br>it enable   |         |         |          |          |             |          |          |   |     |     |            |  |

Figure 13 - 15 Format of Interrupt Enable Register 2 (INTENB2)

Caution The bits in INTENB2 can be set to 1 only when the host controller function is selected; do not set these bits to 1 (interrupt output enabled) when the function controller function is selected.

#### R9A02G015

## 13.3.9 BRDY interrupt enable register (BRDYENB)

Figure 13 - 16 Format of BRDY Interrupt Enable Register (BRDYENB)

| Address: F0436H, F0437H |                                                   |    | After | reset: ( | H000C  |    |   |   |                    |                    |   |                    |     |       |   |                    |
|-------------------------|---------------------------------------------------|----|-------|----------|--------|----|---|---|--------------------|--------------------|---|--------------------|-----|-------|---|--------------------|
| Symbol                  | 15                                                | 14 | 13    | 12       | 11     | 10 | 9 | 8 | 7                  | 6                  | 5 | 4                  | 3   | 2     | 1 | 0                  |
| BRDYENB                 |                                                   |    | _     |          | _      | _  | _ | _ | PIPE7<br>BRDY<br>E | PIPE6<br>BRDY<br>E | - | PIPE4<br>BRDY<br>E | _   | _     | _ | PIPE0<br>BRDY<br>E |
|                         | Bits 15 to 8.                                     |    |       |          |        |    |   |   |                    |                    |   |                    |     |       |   |                    |
|                         | 3 to 1 Nothing is assigned                        |    |       |          |        |    |   |   |                    |                    |   |                    | R/W |       |   |                    |
|                         | — The write value must be 0. The read value is 0. |    |       |          |        |    |   |   |                    |                    |   |                    | —   |       |   |                    |
|                         | PIPEnBRDYE BRDY interrupt enable for PIPEn        |    |       |          |        |    |   |   |                    |                    |   |                    |     | R/W   |   |                    |
|                         | PIPEnBRDYE BRDY interrupt enable for PIPEn        |    |       |          |        |    |   |   |                    |                    |   |                    |     | 17/17 |   |                    |
|                         | 0 Interrupt output disabled                       |    |       |          |        |    |   |   |                    |                    |   |                    |     | R/W   |   |                    |
|                         | 1 Interrupt output enabled                        |    |       |          |        |    |   |   |                    |                    |   |                    |     |       |   |                    |
|                         | 1                                                 |    | monup | r outpu  | Chabit | 54 |   |   |                    |                    |   |                    |     |       |   |                    |

**Remark** n = 7 to 4, 0

## 13.3.10 NRDY interrupt enable register (NRDYENB)





**Remark** n = 7 to 4, 0



### R9A02G015

## 13.3.11 BEMP interrupt enable register (BEMPENB)

Figure 13 - 18 Format of BEMP Interrupt Enable Register (BEMPENB)

| Address: F043AH, F043BH                           |                                           |                                                              |                                                                                                                                            | reset: (                                                                                                                                                                                  | H0000                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------------------------|-------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15                                                | 14                                        | 13                                                           | 12                                                                                                                                         | 11                                                                                                                                                                                        | 10                                                                                                                                                                                                                                                                                                                           | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| _                                                 | _                                         | _                                                            | _                                                                                                                                          | _                                                                                                                                                                                         | _                                                                                                                                                                                                                                                                                                                            | _                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | PIPE7<br>BEMP<br>E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PIPE0<br>BEMP<br>E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                   |                                           |                                                              |                                                                                                                                            |                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bits 15 to 8,<br>3 to 1 Nothing is assigned       |                                           |                                                              |                                                                                                                                            |                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| — The write value must be 0. The read value is 0. |                                           |                                                              |                                                                                                                                            |                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                   |                                           |                                                              |                                                                                                                                            |                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PIPEnBEMPE BEMP interrupt enable for PIPEn        |                                           |                                                              |                                                                                                                                            |                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0 Interrupt output disabled                       |                                           |                                                              |                                                                                                                                            |                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1 Interrupt output enabled                        |                                           |                                                              |                                                                                                                                            |                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                   | 15<br>—<br>Bits 15<br>3 to<br>—<br>PIPEnB | 15 14<br>— — —<br>Bits 15 to 8,<br>3 to 1<br>—<br>PIPEnBEMPE | 15     14     13       -     -     -       Bits 15 to 8,<br>3 to 1     -       -     The write       PIPEnBEMPE     -       0     Interrup | 15     14     13     12       -     -     -     -       Bits 15 to 8,<br>3 to 1     -     -       Bits 15 to 8,<br>3 to 1     -     -       PIPEnBEMPE     -       0     Interrupt output | 15       14       13       12       11         -       -       -       -       -         Bits 15 to 8,<br>3 to 1       -       -       -       -         Bits 15 to 8,<br>3 to 1       -       -       -       -         PIPEnBEMPE       -       -       -       -         0       Interrupt output disable       -       - | 15       14       13       12       11       10         —       —       —       —       —       —       —         Bits 15 to 8,<br>3 to 1       —       —       —       —       —       —         Bits 15 to 8,<br>3 to 1       —       The write value must be 0. The       —       —       —         PIPEnBEMPE       —       —       —       —       —       —       —         0       Interrupt output disabled       —       —       —       —       — | 15       14       13       12       11       10       9         -       -       -       -       -       -       -         Bits 15 to 8,<br>3 to 1       -       -       -       -       -       -         Bits 15 to 8,<br>3 to 1       -       -       -       -       -       -       -         PIPEnBEMPE       The write value must be 0. The read       -       -       BEM       -       -         0       Interrupt output disabled       -       -       -       -       -       - | 15       14       13       12       11       10       9       8         -       -       -       -       -       -       -       -         Bits 15 to 8, 3 to 1       -       -       -       -       -       -       -         PIPEnBEMPE       The write value must be 0. The read value is       -       -       BEMP international states of the | 15       14       13       12       11       10       9       8       7         -       -       -       -       Image: Constraint of the state of the s | 15       14       13       12       11       10       9       8       7       6         -       -       -       -       -       -       PIPE7       PIPE6       BEMP       BEMP       BEMP       BEMP       BEMP       BEMP       BEMP       BEMP       B       10       9       8       7       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6       6< | 15       14       13       12       11       10       9       8       7       6       5         -       -       -       -       -       9       8       7       6       5         -       -       -       -       -       -       PIPE7       PIPE6       PIPE5       BEMP       Interrupt output disabled       Interrupt | 15       14       13       12       11       10       9       8       7       6       5       4         -       -       -       -       9       8       7       6       5       4         -       -       -       -       PIPE7       PIPE6       PIPE6       PIPE5       PIPE4         Bits       15 to 8,       -       -       -       -       PIPE7       PIPE6       PIPE6       PIPE4         Bits       15 to 8,       -       -       -       -       PIPE7       PIPE6       PIPE6       PIPE4         -       -       -       -       -       -       PIPE7       PIPE6       PIPE6       PIPE4         Bits       15 to 8,       -       -       -       -       -       PIPE7       PIPE6       PIPE4         -       -       -       -       -       -       -       -       PIPE4       PIPE4         PIPE1       -       -       -       -       BEMP       Interrupt       -       -       -       -       -       -       -       -       -       -       -       -       -       - | 15       14       13       12       11       10       9       8       7       6       5       4       3         -       -       -       -       -       -       PIPE7       PIPE6       PIPE5       PIPE4       6       5       4       3         -       -       -       -       -       -       PIPE7       PIPE6       PIPE5       PIPE4       6       5       4       3         -       -       -       -       -       -       PIPE7       PIPE6       PIPE5       PIPE4       6       6       5       4       3         -       -       -       -       -       -       PIPE7       PIPE6       PIPE5       PIPE4       6       6       5       4       3         -       -       -       -       -       -       -       PIPE7       PIPE6       PIPE4       BEMP       6       5       4       3         -       -       -       -       -       -       -       PIPE6       PIPE6       PIPE4       -       -       -       -       -       PIPE7       PIPE6       PIPE7       PIPE7       PIP | 15       14       13       12       11       10       9       8       7       6       5       4       3       2         -       -       -       -       -       PIPE7       PIPE6       PIPE5       PIPE4       -       -       -         Bits 15 to 8, 3 to 1       -       -       -       -       -       BEMP       BEMP       BEMP       BEMP       BEMP       -       -       -         PIPE6 Note:       -       -       -       -       -       BEMP       BEMP       BEMP       BEMP       BEMP       -       -       -         Bits 15 to 8, 3 to 1       -       -       -       -       Nothing is assigned       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -< | 15       14       13       12       11       10       9       8       7       6       5       4       3       2       1         -       -       -       -       -       -       PIPE7       PIPE6       PIPE5       PIPE4       -       -       -       -         Bits 15 to 8, 3 to 1       -       -       -       -       -       BEMP       BEMP       BEMP       BEMP       BEMP       -       -       -       -         -       -       The write value must be 0. The read value is 0.       Nothing is assigned       -       -       -       -         PIPEnBEMPE       BEMP Interrupt enable for PIPEn       -       -       -       -         0       Interrupt output disabled       Interrupt enable for PIPEn |

**Remark** n = 7 to 4, 0



## 13.3.12 SOF output configuration register (SOFCFG)

#### Figure 13 - 19 Format of SOF Output Configuration Register (SOFCFG)

| dress | : F043C                                                                    | CH, F04   | 3DH                                                                                                                                         | After                                                                        | reset: (  | 0000H    |          |              |         |           |                     |             |         |          |    |     |
|-------|----------------------------------------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-----------|----------|----------|--------------|---------|-----------|---------------------|-------------|---------|----------|----|-----|
| nbol  | 15                                                                         | 14        | 13                                                                                                                                          | 12                                                                           | 11        | 10       | 9        | 8            | 7       | 6         | 5                   | 4           | 3       | 2        | 1  | 0   |
| CFG   | _                                                                          | —         | _                                                                                                                                           | _                                                                            | _         | _        | _        | TRNE<br>NSEL | _       | BRDY<br>M | _                   | EDGE<br>STS | _       | —        | _  | _   |
|       | Bits 15 to 9 Nothing is assigned                                           |           |                                                                                                                                             |                                                                              |           |          |          |              |         |           | R/W                 |             |         |          |    |     |
|       | <ul> <li>The write value must be 0. The read value is 0.</li> </ul>        |           |                                                                                                                                             |                                                                              |           |          |          |              |         | —         |                     |             |         |          |    |     |
|       | TRNENSEL                                                                   |           |                                                                                                                                             |                                                                              |           |          | Trar     | saction-     | enable  | d time s  | elect               |             |         |          |    | R/W |
|       | C                                                                          | )         | For nor                                                                                                                                     | n-low-sp                                                                     | eed co    | mmunic   | ation    |              |         |           |                     |             |         |          |    | R/W |
|       | 1                                                                          | l         | For low                                                                                                                                     | -speed                                                                       | commu     | nicatior | ו        |              |         |           |                     |             |         |          |    |     |
|       | This bi                                                                    | it select | s, for ful                                                                                                                                  | l-speed                                                                      | or low-   | speed o  | commu    | nication,    | the tra | nsactior  | -enable             | ed time i   | n whicł | n the US | SB |     |
|       | module issues tokens in a frame via the port.                              |           |                                                                                                                                             |                                                                              |           |          |          |              |         |           |                     |             |         |          |    |     |
|       |                                                                            |           | ISEL bit is valid only when the host controller function is selected. This bit should be set to 0 if the<br>Introller function is selected. |                                                                              |           |          |          |              |         |           |                     |             |         |          |    |     |
| L     | Tunctio                                                                    | in contr  |                                                                                                                                             |                                                                              | Selecte   | u.       |          |              |         |           |                     |             |         |          |    |     |
|       | Bit                                                                        | t 7       |                                                                                                                                             | Nothing is assigned                                                          |           |          |          |              |         |           |                     |             | R/W     |          |    |     |
| Ľ     | _                                                                          | _         | The write value must be 0. The read value is 0.                                                                                             |                                                                              |           |          |          |              |         | —         |                     |             |         |          |    |     |
|       | BRD                                                                        | DYM       |                                                                                                                                             |                                                                              |           | BRD      | Y interr | upt statu    | s clear | timing f  | or each             | ı pipe      |         |          |    | R/W |
|       | C                                                                          | )         | Softwar                                                                                                                                     | re clear                                                                     | s the sta | atus.    |          |              |         |           |                     |             |         |          |    | R/W |
|       | 1                                                                          | I         | The USB module clears the status when data has been read from the FIFO buffer or data has been written to the FIFO buffer.                  |                                                                              |           |          |          |              |         |           |                     |             |         |          |    |     |
|       | Specifies the timing for clearing the BRDY interrupt status for each pipe. |           |                                                                                                                                             |                                                                              |           |          |          |              |         |           |                     |             |         |          |    |     |
|       | Bit                                                                        | t 5       | 5 Nothing is assigned                                                                                                                       |                                                                              |           |          |          |              |         |           |                     | R/W         |         |          |    |     |
|       | _                                                                          | -         | The wri                                                                                                                                     | te value                                                                     | e must b  | be 0. Th | e read   | value is     | 0.      |           |                     |             |         |          |    | —   |
|       | EDGE                                                                       | ESTS      |                                                                                                                                             |                                                                              |           | E        | dge int  | errupt ou    | tput st | atus mo   | nitor <sup>No</sup> | te          |         |          |    | R/W |
|       | C                                                                          | )         | The ed                                                                                                                                      | ne edge interrupt output signal is not in the middle of the edge processing. |           |          |          |              |         |           |                     |             | R       |          |    |     |
|       | 1                                                                          |           | The edge interrupt output signal is in the middle of the edge processing.                                                                   |                                                                              |           |          |          |              |         | 1         |                     |             |         |          |    |     |
|       | Indicat                                                                    | tes 1 wł  | nen the e                                                                                                                                   | edge in                                                                      | terrupt o | output s | ignal is | in the m     | iddle o | f the ed  | ge proc             | essing.     |         |          |    |     |
|       |                                                                            | 3 to 0    |                                                                                                                                             |                                                                              |           |          |          | Nothin       | g is as | signed    |                     |             |         |          |    | R/W |
|       | BIIS 3                                                                     | 5100      |                                                                                                                                             |                                                                              |           |          |          |              |         |           |                     |             |         |          |    |     |



### 13.3.13 Interrupt status register 0 (INTSTS0)

#### Figure 13 - 20 Format of Interrupt Status Register 0 (INTSTS0)

Address: F0440H, F0441H After reset: 00000000 X0000000B

| Symbol 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|----------------------------------------------|
|----------------------------------------------|

INTSTS0 VBINT RESM SOFR DVST CTRT BEMP NRDY BRDY VBSTS DVSQ2 DVSQ1 DVSQ0 VALID CTSQ2 CTSQ1 CTSQ0

| VBINT          | VBUS interrupt status Note 1                                                                        | R/W    |
|----------------|-----------------------------------------------------------------------------------------------------|--------|
| 0              | VBUS interrupts are not generated.                                                                  | R/W    |
| 1              | VBUS interrupts are generated.                                                                      | Note 2 |
| The USB mo     | odule sets the VBINT bit to 1 on detecting a level change (high to low or low to high) in the UVBUS |        |
| pin input val  | ue. The USB module sets the VBSTS bit to indicate the VBUS pin input value. When the UVBUS          |        |
| interrupt is g | enerated, use software to repeat reading the VBSTS bit until the same value is read three or more   |        |
| times, and e   | liminate chattering.                                                                                |        |

| RESM         | Resume interrupt status Note 1, 3                                                                     | R/W    |
|--------------|-------------------------------------------------------------------------------------------------------|--------|
| 0            | Resume interrupts are not generated.                                                                  | R/W    |
| 1            | Resume interrupts are generated.                                                                      | Note 2 |
| When the fun | ction controller function is selected, the USB module sets the RESM bit to 1 on detecting the falling |        |

edge of the signal on the USB\_DP pin in the suspended state (DVSQ2 to DVSQ2 = 1xxB). When the host controller function is selected, the read value is invalid.

| SOFR         | Frame number refresh interrupt status                                                          | R/W |  |  |  |  |  |
|--------------|------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|
| 0            | SOF interrupts are not generated.                                                              |     |  |  |  |  |  |
| 1            | SOF interrupts are generated.                                                                  |     |  |  |  |  |  |
| (1) When the | host controller function is selected                                                           |     |  |  |  |  |  |
| The USB mo   | dule sets the SOFR bit to 1 on updating the frame number when software has set the UACT bit in |     |  |  |  |  |  |
| DVSTCTR0 t   | o 1. (A frame number refresh interrupt is detected every 1 ms.)                                |     |  |  |  |  |  |
| (2) When the | function controller function is selected                                                       |     |  |  |  |  |  |
| The USB mo   | dule sets the SOFR bit to 1 on updating the frame number. (A frame number refresh interrupt is |     |  |  |  |  |  |
| detected eve | ry 1 ms.)                                                                                      |     |  |  |  |  |  |
| The USB mo   | dule can detect an SOFR interrupt through the internal interpolation function even when a      |     |  |  |  |  |  |
| damaged SO   | F packet is received from the USB host.                                                        |     |  |  |  |  |  |

| DVST                                                                                                           | Device state transition interrupt status Note 3                                            | R/W |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----|--|--|--|--|
| 0                                                                                                              | Device state transition interrupts are not generated.                                      |     |  |  |  |  |
| 1                                                                                                              | Device state transition interrupts are generated.                                          |     |  |  |  |  |
| When the fur                                                                                                   | ction controller function is selected, the USB module updates the DVSQ2 to DVSQ2 value and |     |  |  |  |  |
| sets the DVS                                                                                                   | T bit to 1 on detecting a change in the device state.                                      |     |  |  |  |  |
| When a device state transition interrupt is generated, clear the status before the USB module detects the next |                                                                                            |     |  |  |  |  |
| device state                                                                                                   | ransition.                                                                                 |     |  |  |  |  |
| When the ho                                                                                                    | st controller function is selected, the read value is invalid.                             |     |  |  |  |  |



| 1            |                                                                                                             |        |  |  |
|--------------|-------------------------------------------------------------------------------------------------------------|--------|--|--|
| CTRT         | Control transfer stage transition interrupt status Note 3                                                   | R/W    |  |  |
| 0            | Control transfer stage transition interrupts are not generated                                              | R/W    |  |  |
| 1            | Control transfer stage transition interrupts are generated.                                                 | Note 2 |  |  |
| When the fun | When the function controller function is selected, the USB module updates the CTSQ2 to CTSQ0 value and sets |        |  |  |
| the CTRT bit | to 1 on detecting a change in the control transfer stage.                                                   |        |  |  |

When a control transfer stage transition interrupt is generated, clear the status before the USB module detects the next control transfer stage transition.

When the host controller function is selected, the read value is invalid.

| BEMP | Buffer empty interrupt status      | R/W |
|------|------------------------------------|-----|
| 0    | BEMP interrupts are not generated. | R   |
| 1    | BEMP interrupts are generated.     |     |

Indicates the BEMP interrupt status.

The USB module sets the BEMP bit to 1 when at least one PIPEnBEMP bit in the BEMPSTS register is set to 1 among the PIPEnBEMP bits corresponding to the PIPEnBEMPE bits in the BEMPENB register to which 1 has been set (when the USB module detects the BEMP interrupt status in at least one pipe among the pipes for which software enables the BEMP interrupt output).

For the conditions for PIPEnBEMP status assertion, refer to 13.4.3.3 BEMP interrupt.

The USB module clears the BEMP bit to 0 when software writes 0 to all the PIPEnBEMP bits corresponding to the PIPEnBEMPE bits to which 1 has been set.

The BEMP bit cannot be cleared to 0 even if software writes 0 to this bit.

| NRDY                                                                                                   | Buffer not ready interrupt status                                                          | R/W |  |  |  |  |
|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----|--|--|--|--|
| 0                                                                                                      | IRDY interrupts are not generated.                                                         |     |  |  |  |  |
| 1                                                                                                      | NRDY interrupts are generated.                                                             |     |  |  |  |  |
| Indicates the                                                                                          | NRDY interrupt status.                                                                     |     |  |  |  |  |
| The USB module sets the NRDY bit to 1 when at least one PIPEnNRDY bit in NRDYSTS is set to 1 among the |                                                                                            |     |  |  |  |  |
| PIPEnNRDY                                                                                              | bits corresponding to the PIPEnNRDYE bits in NRDYENB to which 1 has been set (when the USB |     |  |  |  |  |

module detects the NRDY interrupt status in at least one pipe among the pipes for which software enables the NRDY interrupt output).

For the conditions for PIPEnNRDY status assertion, refer to 13.4.3.2 NRDY interrupt.

The USB module clears the NRDY bit to 0 when software writes 0 to all the PIPEnNRDY bits corresponding to the PIPEnNRDYE bits to which 1 has been set.

The NRDY bit cannot be cleared to 0 even if software writes 0 to this bit.

| BRDY                                               | Buffer ready interrupt status                                                                   | R/W |  |  |  |  |  |  |
|----------------------------------------------------|-------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| 0                                                  | BRDY interrupts are not generated.                                                              |     |  |  |  |  |  |  |
| 1                                                  | RDY interrupts are generated.                                                                   |     |  |  |  |  |  |  |
| Indicates the                                      | BRDY interrupt status.                                                                          |     |  |  |  |  |  |  |
| The USB mo                                         | dule sets the BRDY bit to 1 when at least one PIPEnBRDY bit in the BRDYSTS register is set to 1 |     |  |  |  |  |  |  |
| among the P                                        | IPEnBRDY bits corresponding to the PIPEnBRDYE bits in the BRDYENB register to which 1 has       |     |  |  |  |  |  |  |
| been set (wh                                       | en the USB module detects the BRDY interrupt status in at least one pipe among the pipes for    |     |  |  |  |  |  |  |
| which software enables the BRDY interrupt output). |                                                                                                 |     |  |  |  |  |  |  |
| For the cond                                       | itions for PIPEnBRDY status assertion, refer to 13.4.3.1 BRDY interrupt.                        |     |  |  |  |  |  |  |
| The USB mo                                         | dule clears the BRDY bit to 0 when software writes 0 to all the PIPEnBRDY bits corresponding to |     |  |  |  |  |  |  |
| the PIPEnBF                                        | RDYE bits to which 1 has been set.                                                              |     |  |  |  |  |  |  |
| The BRDY b                                         | it cannot be cleared to 0 even if software writes 0 to this bit.                                |     |  |  |  |  |  |  |

| VBSTS | VBUS interrupt status Note 4 | R/W |
|-------|------------------------------|-----|
| 0     | UVBUS pin is low.            | R   |
| 1     | UVBUS pin is high.           |     |



| DVSQ2 | DVSQ1 | DVSQ1 | Device state     | F | R/W |
|-------|-------|-------|------------------|---|-----|
| 0     | 0     | 0     | Powered state    |   | R   |
| 0     | 0     | 1     | Default state    |   |     |
| 0     | 1     | 0     | Address state    |   |     |
| 0     | 1     | 1     | Configured state |   |     |
| 1     | Х     | Х     | Suspended state  |   |     |

When the host controller function is selected, the read value is invalid.

| VALID         | USB request reception         | R/W    |
|---------------|-------------------------------|--------|
| 0             | Not detected                  | R/W    |
| 1             | Setup packet reception        | Note 2 |
| Indicates the | USB request reception status. | 1      |

When the host controller function is selected, the read value is invalid.

| CTSQ2 | CTSQ1 | CTSQ0 | Control transfer stage               | R/W |
|-------|-------|-------|--------------------------------------|-----|
| 0     | 0     | 0     | Idle or setup stage                  | R   |
| 0     | 0     | 1     | Control read data stage              |     |
| 0     | 1     | 0     | Control read status stage            |     |
| 0     | 1     | 1     | Control write data stage             |     |
| 1     | 0     | 0     | Control write status stage           |     |
| 1     | 0     | 1     | Control write (no data) status stage |     |
| 1     | 1     | 0     | Control transfer sequence error      |     |
| 1     | 1     | 1     | Do not set.                          |     |

When the host controller function is selected, the read value is invalid.

- **Note 1.** A change in the status indicated by the VBINT and RESM bits can be detected even while the clock supply is stopped (SCKE = 0), and the interrupts are output when the corresponding interrupt enable bits are enabled. Clearing the status through software should be done after enabling the clock supply.
- **Note 2.** To clear the VBINT, RESM, SOFR, DVST, CTRT, or VALID bit, write 0 only to the bits to be cleared; write 1 to the other bits. Do not write 0 to the status bits indicating 0.
- **Note 3.** A change in the status of the RESM, DVST, and CTRT bits occur only when the function controller function is selected; set the corresponding interrupt enable bits to 0 (disabled) when the host controller function is selected.
- **Note 4.** The value after reset depends on the value of the UVBUS pin. This bit is 1 when the UVBUS pin input is high level and 0 when the input is low level.



### 13.3.14 Interrupt status register n (INTSTSn) (n = 1, 2)

#### Figure 13 - 21 Format of Interrupt Status Register 1 (INTSTS1)

Address: F0442H, F0443H After reset: XX0X0000 0000000B Symbol 12 0 15 14 13 11 10 9 8 7 6 5 3 2 1 4 PDDET OVRC EOFE INTSTS1 BCHG DTCH ATTCH SIGN SACK RR INT OVRCR USB port 0 overcurrent input change interrupt status Note 1 R/W 0 OVRCR interrupts are not generated. R/W Note 2 OVRCR interrupts are generated. 1 Indicates the status of the UOVRCUR0 input pin change interrupt. The USB module detects the OVRCR interrupt when a change (high to low or low to high) occurs in at least one of the input values to the UOVRCUR0 pin, and sets the OVRCR bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, the USB module generates the interrupt. BCHG USB port 0 USB bus change interrupt status Note 1 R/W 0 BCHG interrupts are not generated. R/W Note 2 BCHG interrupts are generated. 1 Indicates the status of the USB bus change interrupt. The USB module detects the BCHG interrupt when a change in the full-speed/low-speed signal level occurs on the USB port (a change from J-state, K-state, or SE0 to J-state, K-state, or SE0), and sets the BCHG bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, the USB module generates the interrupt. The USB module sets the LNST bits in the SYSSTS0 register to indicate the current input state of the USB port. When the BCHG interrupt is generated, use software to repeat reading the LNST bits until the same value is read three or more times, and eliminate chattering. A change in the USB bus state can be detected even while the internal clock supply is stopped. When the function controller function is selected, the read value is invalid. Bit 13 Nothing is assigned R/W The write value must be 0. The read value is 0. DTCH USB port 0 USB disconnection detection interrupt status R/W 0 DTCH interrupts are not generated. R/W Note 2 1 DTCH interrupts are generated. Indicates the status of the USB disconnection detection interrupt when the host controller function is selected. The USB module detects the disconnection detection interrupt on detecting USB bus disconnection, and sets the DTCH bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, the USB module generates the interrupt. The USB module detects bus disconnection based on the USB Specification 2.0. After detecting the disconnection detection interrupt, the USB module controls hardware as described below (irrespective of the setting of the corresponding interrupt enable bit). Software should terminate all the pipes in which communications are currently carried out for the USB port and make a transition to the wait state for bus connection to the USB port (wait state for connection detection interrupt generation). Modifies the UACT bit for the port in which a disconnection detection interrupt has been detected to 0. • Puts the port in which a disconnection detection interrupt has been generated into the idle state. When the function controller function is selected, the read value is invalid.



| ATTCH          | USB port 0 connection detection interrupt status                                                        | R/W    |
|----------------|---------------------------------------------------------------------------------------------------------|--------|
| 0              | Connection detection interrupts are not generated.                                                      | R/W    |
| 1              | Connection detection interrupts are generated.                                                          | Note 2 |
| Indicates the  | status of the ATTCH interrupt when the host controller function is selected.                            |        |
| The USB mod    | dule detects the ATTCH interrupt on detecting J-state or K-state of the full-speed signal level for 2.5 |        |
| μs, and sets t | he ATTCH bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, the USB       |        |
| module gene    | rates the interrupt.                                                                                    |        |

Specifically, the USB module detects the connection detection interrupt on any of the following conditions.

• K-state, SE0, or SE1 changes to J-state, and J-state continues for 2.5 µs.

 $\bullet$  J-state, SE0, or SE1 changes to K-state, and K-state continues for 2.5  $\mu s.$ 

When the function controller function is selected, the read value is invalid.

| Bits 10 to 7 | Nothing is assigned                             | R/W |
|--------------|-------------------------------------------------|-----|
| _            | The write value must be 0. The read value is 0. | _   |

| EOFERR                           | USB port 0 EOF error detection interrupt status                                                | R/W    |
|----------------------------------|------------------------------------------------------------------------------------------------|--------|
| 0                                | EOFERR interrupts are not generated.                                                           | R/W    |
| 1                                | EOFERR interrupts are generated.                                                               | Note 2 |
| Indicates the                    | status of the EOFERR interrupt when the host controller function is selected.                  |        |
| The USB mod                      | dule detects the EOFERR interrupt on detecting that communication is not completed at the EOF2 |        |
| timing prescri                   | bed by the USB Specifications 2.0, and sets the EOFERR bit to 1. Here, if software has set the |        |
| corresponding                    | g interrupt enable bit to 1, the USB module generates the EOFERR interrupt.                    |        |
| After detectin                   | g the EOFERR interrupt, the USB module controls hardware as described below (irrespective of   |        |
| the setting of                   | the corresponding interrupt enable bit). Software should terminate all the pipes in which      |        |
| communicatio                     | ons are currently carried for the USB port and perform re-enumeration of the USB port.         |        |
| <ul> <li>Modifies the</li> </ul> | UACT bit for the port in which an EOFERR interrupt has been detected to 0.                     |        |

• Puts the port in which an EOFERR interrupt has been generated into the idle state.

When the function controller function is selected, the read value is invalid.

| SIGN          | Setup transaction error interrupt status                                                               | R/W    |
|---------------|--------------------------------------------------------------------------------------------------------|--------|
| 0             | SIGN interrupts are not generated.                                                                     | R/W    |
| 1             | SIGN interrupts are generated.                                                                         | Note 2 |
| Indicates the | e status of the setup transaction error interrupt when the host controller function is selected.       |        |
| The USB me    | odule detects the SIGN interrupt when ACK response is not returned from the peripheral device          |        |
| three conse   | cutive times during the setup transactions issued by this module, and sets the SIGN bit to 1. Here, if |        |
| software has  | set the corresponding interrupt enable bit to 1, the USB module generates the SIGN interrupt.          |        |
| Specifically, | the USB module detects the SIGN interrupt when any of the following response conditions occur for      |        |
| three conse   | cutive setup transactions.                                                                             |        |
| Timeout is    | detected by the USB module when the peripheral device has returned no response.                        |        |
| • A damage    | ACK packet is received.                                                                                |        |

• A handshake other than ACK (NAK, NYET, or STALL) is received.

When the function controller function is selected, the read value is invalid.

| SACK         | Setup transaction normal response interrupt status                                               | R/W    |
|--------------|--------------------------------------------------------------------------------------------------|--------|
| 0            | SACK interrupts are not generated.                                                               | R/W    |
| 1            | SACK interrupts are generated.                                                                   | Note 2 |
| ndicates th  | e status of the setup transaction normal response interrupt when the host controller function is |        |
| selected.    |                                                                                                  |        |
| The USB m    | odule detects the SACK interrupt when ACK response is returned from the peripheral device during |        |
| he setup tra | ansactions issued by the USB module, and sets the SACK bit to 1. Here, if software has set the   |        |
| correspondi  | ng interrupt enable bit to 1, the USB module generates the SACK interrupt.                       |        |
| Mhon the f   | notion controller function is colored, the read value is involid                                 |        |

When the function controller function is selected, the read value is invalid.



| Bits 3 to 1   | Nothing is assigned                                                                                | R/W    |
|---------------|----------------------------------------------------------------------------------------------------|--------|
| —             | The write value must be 0. The read value is 0.                                                    | _      |
|               |                                                                                                    |        |
| PDDETINT      | USB port 0 Portable Device detection interrupt status                                              | R/W    |
| 0             | PDDETINT interrupts are not generated.                                                             | R/W    |
| 1             | PDDETINT interrupts are generated.                                                                 | Note 2 |
| Indicates the | status of the Portable Device detection interrupt when the host controller function is selected.   |        |
| The USB mo    | dule detects when a change (high to low or low to high) occurs in the input value to the USB       |        |
| transceiver V | DPDET pin, and sets this bit to 1. The USB module indicates the input value to the USB transceiver |        |
| VDPDET pin    | to the PDDETSTS bit.                                                                               |        |
| When the PD   | DETINT interrupt is generated, use software to repeat reading the PDDETSTS bit until the same      |        |
| value is read | three or more times, and eliminate chattering.                                                     |        |

- Note 1. A change in the status indicated by the OVRCR or BCHG bit can be detected even while the clock supply is stopped (SCKE = 0), and the interrupt is output when the corresponding interrupt enable bit is enabled. Clearing the status through software should be done after enabling the clock supply. No interrupts other than those indicated by the BCHG and OVRCR bits can be detected while the clock supply is stopped (SCKE = 0).
- **Note 2.** To clear the status indicated by the bits in the INTSTS1 register, write 0 only to the bits to be cleared; write 1 to the other bits. Do not write 0 to the status bits indicating 0.



| uuress | : F0444                                                                                                                                                                                                                                                                                                                                                                           | H, F04                                    | 45H                                          | After                                      | reset: X                                                                    | 00X00                      | 00 000                         | 00000B                           |                                 |                                    |                      |                    |                   |         |   |             |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------|----------------------------|--------------------------------|----------------------------------|---------------------------------|------------------------------------|----------------------|--------------------|-------------------|---------|---|-------------|
| Symbol | 15                                                                                                                                                                                                                                                                                                                                                                                | 14                                        | 13                                           | 12                                         | 11                                                                          | 10                         | 9                              | 8                                | 7                               | 6                                  | 5                    | 4                  | 3                 | 2       | 1 | 0           |
| ISTS2  | OVRC<br>R                                                                                                                                                                                                                                                                                                                                                                         | BCHG                                      | _                                            | DTCH                                       | ATTCH                                                                       | _                          | _                              | _                                | _                               | EOFE<br>RR                         | _                    | _                  | _                 | _       | _ | PDDE<br>INT |
|        | OVRCR USB port 1 overcurrent input change interrupt status Note 1                                                                                                                                                                                                                                                                                                                 |                                           |                                              |                                            |                                                                             |                            |                                |                                  |                                 |                                    | R/W                  |                    |                   |         |   |             |
|        | (                                                                                                                                                                                                                                                                                                                                                                                 | )                                         | OVRC                                         | R interr                                   | upts are                                                                    | not gei                    | nerated.                       |                                  |                                 |                                    |                      |                    |                   |         |   | R/W         |
|        | 1                                                                                                                                                                                                                                                                                                                                                                                 |                                           | OVRC                                         | R interr                                   | upts are                                                                    | genera                     | ited.                          |                                  |                                 |                                    |                      |                    |                   |         |   | Note        |
| ]      | Indicates the status of the UOVRCUR1 input pin change interrupt.<br>The USB module detects the overcurrent interrupt when a change (high to low or low to high) occurs in at least<br>one of the input values to the UOVRCUR1 pin, and sets the OVRCR bit to 1. Here, if software has set the<br>corresponding interrupt enable bit to 1, the USB module generates the interrupt. |                                           |                                              |                                            |                                                                             |                            |                                |                                  |                                 |                                    |                      |                    |                   |         |   |             |
|        | BCHG USB port 1 USB bus change interrupt status Note 1                                                                                                                                                                                                                                                                                                                            |                                           |                                              |                                            |                                                                             |                            |                                |                                  |                                 |                                    |                      | R/W                |                   |         |   |             |
|        | (                                                                                                                                                                                                                                                                                                                                                                                 | )                                         | BCHG                                         | interrup                                   | ots are no                                                                  |                            |                                |                                  |                                 |                                    |                      |                    |                   |         |   | R/W         |
|        | 1                                                                                                                                                                                                                                                                                                                                                                                 |                                           |                                              |                                            | ots are ge                                                                  | -                          |                                |                                  |                                 |                                    |                      |                    |                   |         |   | Note        |
|        | The U<br>BCHG<br>more t<br>A char                                                                                                                                                                                                                                                                                                                                                 | SB moo<br>interru<br>imes, a<br>nge in tl | lule sets<br>pt is ger<br>nd elimi<br>ne USB | s the LN<br>nerated<br>inate ch<br>bus sta | onding in<br>IST bits i<br>, use soft<br>attering.<br>te can be<br>function | n SYS<br>ware t<br>e detec | STS1 to<br>o repea<br>cted eve | o indicat<br>t readin<br>n while | e the c<br>g the Ll<br>the inte | urrent in<br>NST bits<br>ernal clo | put stat<br>until th | e of the<br>e same | USB p<br>value is | ort. Wh |   |             |
| 1      | Bit                                                                                                                                                                                                                                                                                                                                                                               | 13                                        | Nothing is assigned                          |                                            |                                                                             |                            |                                |                                  |                                 |                                    |                      | R/W                |                   |         |   |             |
|        | _                                                                                                                                                                                                                                                                                                                                                                                 | _                                         | The wr                                       | ite valu                                   | e must b                                                                    | e 0. Th                    | e read                         | value is                         | 0.                              | -                                  |                      |                    |                   |         |   |             |
|        | DT                                                                                                                                                                                                                                                                                                                                                                                | СН                                        |                                              |                                            |                                                                             | USB p                      | ort 1 dis                      | sconnec                          | tion de                         | tection i                          | nterrupt             | status             |                   |         |   | R/W         |
|        | (                                                                                                                                                                                                                                                                                                                                                                                 | )                                         | DTCH                                         | interrup                                   | ts are no                                                                   | ot gene                    | rated.                         |                                  |                                 |                                    |                      |                    |                   |         |   | R/W         |
|        | 1                                                                                                                                                                                                                                                                                                                                                                                 | 1 DTCH interrupts are generated.          |                                              |                                            |                                                                             |                            |                                |                                  |                                 |                                    |                      |                    |                   |         |   |             |
|        |                                                                                                                                                                                                                                                                                                                                                                                   |                                           |                                              |                                            | ts are ge<br>B disco                                                        |                            |                                |                                  |                                 |                                    |                      |                    |                   |         |   | Note :      |

### Figure 13 - 22 Format of Interrupt Status Register 2 (INTSTS2)



| ATTCH           | USB port 1 connection detection interrupt status                                                        | R/W    |
|-----------------|---------------------------------------------------------------------------------------------------------|--------|
| 0               | Connection detection interrupts are not generated.                                                      | R/W    |
| 1               | Connection detection interrupts are generated.                                                          | Note 2 |
| Indicates the   | status of the ATTCH interrupt when the host controller function is selected.                            |        |
| The USB mod     | dule detects the ATTCH interrupt on detecting J-state or K-state of the full-speed signal level for 2.5 |        |
| µs, and sets t  | the ATTCH bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, the USB      |        |
| module gene     | rates the interrupt.                                                                                    |        |
| Specifically, t | he USB module detects the connection detection interrupt on any of the following conditions.            |        |
| K state SEO     | or SE1 changes to Listate, and Listate continues for 2.5 us                                             |        |

K-state, SE0, or SE1 changes to J-state, and J-state continues for 2.5 µs.

J-state, SE0, or SE1 changes to K-state, and K-state continues for 2.5  $\mu s.$ 

When the function controller function is selected, the read value is invalid.

| Bits 10 to 7 | Nothing is assigned                             | R/W |
|--------------|-------------------------------------------------|-----|
| _            | The write value must be 0. The read value is 0. | —   |

| EOFERR         | USB port 1 EOF error detection interrupt status                                                | R/W    |
|----------------|------------------------------------------------------------------------------------------------|--------|
| 0              | EOFERR interrupts are not generated.                                                           | R/W    |
| 1              | EOFERR interrupts are generated.                                                               | Note 2 |
| Indicates the  | status of the EOFERR interrupt when the host controller function is selected.                  |        |
| The USB mod    | dule detects the EOFERR interrupt on detecting that communication is not completed at the EOF2 |        |
| timing prescri | bed by the USB Specifications 2.0, and sets the EOFERR bit to 1. Here, if software has set the |        |
| corresponding  | g interrupt enable bit to 1, the USB module generates the EOFERR interrupt.                    |        |
| After detectin | g the EOFERR interrupt, the USB module controls hardware as described below (irrespective of   |        |
| the setting of | the corresponding interrupt enable bit). Software should terminate all the pipes in which      |        |
| communicatio   | ons are currently carried for the USB port and perform re-enumeration of the USB port.         |        |
| Modifies the   | e UACT bit for the port in which an EOFERR interrupt has been detected to 0.                   |        |
| Puts the port  | rt in which an EOFERR interrupt has been generated into the idle state.                        |        |
| When the fun   | ction controller function is selected, the read value is invalid.                              |        |

| Bits 5 to 1 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| _           | The write value must be 0. The read value is 0. | —   |

| PDDETINT      | USB port 1 portable Device detection interrupt status                                              | R/W    |
|---------------|----------------------------------------------------------------------------------------------------|--------|
| 0             | PDDETINT interrupts are not generated.                                                             | R/W    |
| 1             | PDDETINT interrupts are generated.                                                                 | Note 2 |
| Indicates the | status of the Portable Device detection interrupt when the host controller function is selected.   |        |
| The USB mo    | dule detects when a change (high to low or low to high) occurs in the input value to the USB       |        |
| transceiver V | DPDET pin, and sets this bit to 1. The USB module indicates the input value to the USB transceiver |        |
| VDPDET pin    | to the PDDETSTS bit.                                                                               |        |
| When the PD   | DETINT interrupt is generated, use software to repeat reading the PDDETSTS bit until the same      |        |
| value is read | three or more times, and eliminate chattering.                                                     |        |

- Note 1.
   A change in the status indicated by the OVRCR or BCHG bit can be detected even while the clock supply is stopped (SCKE = 0), and the interrupt is output when the corresponding interrupt enable bit is enabled.

   Clearing the status through software should be done after enabling the clock supply. No interrupts other than those indicated by the BCHG and OVRCR bits can be detected while the clock supply is stopped (SCKE = 0).
- **Note 2.** To clear the status indicated by the bits in the INTSTS2 register, write 0 only to the bits to be cleared; write 1 to the other bits.



### 13.3.15 BRDY interrupt status register (BRDYSTS)

#### Figure 13 - 23 Format of BRDY Interrupt Status Register (BRDYSTS)

| Address | : F0446         | H, F04 | 47H      | After     | reset: ( | 0000H    |        |          |               |               |          |               |   |   |   |               |
|---------|-----------------|--------|----------|-----------|----------|----------|--------|----------|---------------|---------------|----------|---------------|---|---|---|---------------|
| Symbol  | 15              | 14     | 13       | 12        | 11       | 10       | 9      | 8        | 7             | 6             | 5        | 4             | 3 | 2 | 1 | 0             |
| BRDYSTS | _               | _      | _        | _         | _        | _        | _      | _        | PIPE7<br>BRDY | PIPE6<br>BRDY |          | PIPE4<br>BRDY | _ | _ | _ | PIPE0<br>BRDY |
|         |                 |        |          |           |          |          |        |          |               |               |          |               |   |   |   |               |
|         | Bits 15<br>3 to |        |          |           |          |          |        | Nothi    | ng is ass     | signed        |          |               |   |   |   | R/W           |
|         |                 | _      | The wr   | ite value | e must l | be 0. Th | e read | value is | 0.            |               |          |               |   |   |   | —             |
|         |                 |        |          |           |          |          |        |          |               |               |          |               |   |   |   |               |
|         | PIPEn           | BRDY   |          |           |          |          | BRDY i | nterrup  | t status f    | or PIPE       | n Note 1 |               |   |   |   | R/W           |
|         | 0               | )      | Interrup | ots are i | not gene | erated.  |        |          |               |               |          |               |   |   |   | R/W           |
|         | 1               |        | Interrup | ots are o | generat  | ed.      |        |          |               |               |          |               |   |   |   | Note 2        |
|         |                 |        |          |           |          |          |        |          |               |               |          |               |   |   |   |               |

**Note 1.** When BRDYM in SOFCGFG is 0, clearing BRDY interrupts should be done before accessing the FIFO.

**Note 2.** When BRDYM in SOFCGFG is 0, to clear the status indicated by the bits in BRDYSTS, write 0 only to the bits to be cleared; write 1 to the other bits. Do not write 0 to the status bits indicating 0.

**Remark** n = 7 to 4, 0

### 13.3.16 NRDY interrupt status register (NRDYSTS)

#### Address: F0448H, F0449H After reset: 0000H Symbol 15 14 13 12 11 10 9 8 7 6 5 4 3 2 0 1 PIPE7 PIPE6 PIPE5 PIPE4 PIPE0 NRDYSTS \_\_\_\_ \_ \_\_\_\_ \_\_\_\_ \_\_\_\_ NRDY NRDY NRDY NRDY NRDY Bits 15 to 8. Nothing is assigned R/W 3 to 1 The write value must be 0. The read value is 0. PIPEnNRDY NRDY interrupt status for PIPEn R/W 0 R/W Interrupts are not generated. Note 1 Interrupts are generated.

#### Figure 13 - 24 Format of NRDY Interrupt Status Register (NRDYSTS)

**Note** To clear the status indicated by the bits in the NRDYSTS register, write 0 only to the bits to be cleared; write 1 to the other bits. Do not write 0 to the status bits indicating 0.

Remark n = 7 to 4, 0



### 13.3.17 BEMP interrupt status register (BEMPSTS)

#### Figure 13 - 25 Format of BEMP Interrupt Status Register (BEMPSTS)

| Address | F044A   | H, F04 | 4BH      | After     | reset: ( | H000C    |        |          |               |               |      |               |   |   |   |               |
|---------|---------|--------|----------|-----------|----------|----------|--------|----------|---------------|---------------|------|---------------|---|---|---|---------------|
| Symbol  | 15      | 14     | 13       | 12        | 11       | 10       | 9      | 8        | 7             | 6             | 5    | 4             | 3 | 2 | 1 | 0             |
| BEMPSTS | _       | _      | _        | _         | _        | _        | _      |          | PIPE7<br>BEMP | PIPE6<br>BEMP | -    | PIPE4<br>BEMP | _ | _ | _ | PIPE0<br>BEMP |
|         |         |        | 1        |           |          |          |        |          |               |               |      |               |   |   |   |               |
|         | Bits 15 |        |          |           |          |          |        | Nothir   | ng is ass     | sianed        |      |               |   |   |   | R/W           |
|         | 3 to    | o 1    |          |           |          |          |        |          |               |               |      |               |   |   |   |               |
|         | _       | -      | The wri  | te value  | e must l | be 0. Th | e read | value is | 0.            |               |      |               |   |   |   | —             |
|         |         |        |          |           |          |          |        |          |               |               |      |               |   |   |   |               |
|         | PIPEn   | nBEM   |          |           |          |          | REM    | P interr | upt stati     | is for P      | IPEn |               |   |   |   | R/W           |
|         | P       | )      |          |           |          |          |        | i inten  | upt stati     |               |      |               |   |   |   | 10,00         |
|         | 0       | )      | Interrup | ots are r | not gene | erated.  |        |          |               |               |      |               |   |   |   | R/W           |
|         | 1       |        | Interrup | ots are g | generat  | ed.      |        |          |               |               |      |               |   |   |   | Note          |
|         |         |        | 1        |           |          |          |        |          |               |               |      |               |   |   |   |               |

**Note** To clear the status indicated by the bits in the BEMPSTS register, write 0 only to the bits to be cleared; write 1 to the other bits. Do not write 0 to the status bits indicating 0.

**Remark** n = 7 to 4, 0

### 13.3.18 Frame number register (FRMNUM)

#### Figure 13 - 26 Format of Frame Number Register (FRMNUM)

| Address                                                                                                                                                                                                                                                                                                                                                                                       | F044C | CH, F04    | 4DH        | After   | reset: ( | H0000    |      |   |          |      |   |   |     |   |   |   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------|------------|---------|----------|----------|------|---|----------|------|---|---|-----|---|---|---|
| Symbol                                                                                                                                                                                                                                                                                                                                                                                        | 15    | 14         | 13         | 12      | 11       | 10       | 9    | 8 | 7        | 6    | 5 | 4 | 3   | 2 | 1 | 0 |
| FRMNUM       -       -       -       FRNM[10:0]         Bits 15 to 11       Reserved       F         -       The write value must be 0. The read value is 0.       F         FRNM[10:0]       Frame number       F         The USB module sets the FRNM[10:0] bits to indicate the latest frame number, which is updated every time an SOF packet is issued or received (every 1 ms).       F |       |            |            |         |          |          |      |   |          |      |   |   |     |   |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                               |       |            |            |         |          |          |      |   |          |      |   |   |     |   |   |   |
| Symbol       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1         FRMNUM                                                                                                                                                                                                                                           |       |            |            |         |          |          |      |   |          | R/W  |   |   |     |   |   |   |
| FRMNUM       -       -       -       FRNM[10:0]         Bits 15 to 11       Reserved       F         -       The write value must be 0. The read value is 0.       F         FRNM[10:0]       Frame number       F         The USB module sets the FRNM[10:0] bits to indicate the latest frame number, which is updated every time an SOF packet is issued or received (every 1 ms).       F |       |            |            |         |          |          |      |   |          |      | — |   |     |   |   |   |
| Bits 15 to 11       Reserved       R/V         —       The write value must be 0. The read value is 0.       —         FRNM[10:0]       Frame number       R/V         The USB module sets the FRNM[10:0] bits to indicate the latest frame number, which is updated every time an       R                                                                                                    |       |            |            |         |          |          |      |   |          |      |   |   |     |   |   |   |
| —     The write value must be 0. The read value is 0.       FRNM[10:0]     Frame number                                                                                                                                                                                                                                                                                                       |       |            |            |         |          |          |      |   |          |      |   |   | R/W |   |   |   |
| Bits 15 to 11       Reserved       F         —       The write value must be 0. The read value is 0.       F         FRNM[10:0]       Frame number       F         The USB module sets the FRNM[10:0] bits to indicate the latest frame number, which is updated every time an SOF packet is issued or received (every 1 ms).       F                                                         |       |            |            |         |          |          |      |   |          |      |   | R |     |   |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                               | SOF p | acket is   | s issued   | or rece | ived (ev | /erv 1 m | s).  |   |          |      |   |   |     | - |   |   |
| FRMNUM       -       -       -       FRNM[10:0]         Bits 15 to 11       Reserved       F         -       The write value must be 0. The read value is 0.       F         FRNM[10:0]       Frame number       F         The USB module sets the FRNM[10:0] bits to indicate the latest frame number, which is updated every time an       F                                                |       |            |            |         |          |          |      |   |          |      |   |   |     |   |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                               | переа | it i cauli | ig ale i i |         | .0] 013  |          | Jame |   | i cau th | 100. |   |   |     |   |   |   |



### 13.3.19 USB address register (USBADDR)

| Address: | : F0450 | H, F04    | 51H    | After    | reset:    | 0000H    |           |          |            |             |          |         |       |          |   |     |
|----------|---------|-----------|--------|----------|-----------|----------|-----------|----------|------------|-------------|----------|---------|-------|----------|---|-----|
| Symbol   | 15      | 14        | 13     | 12       | 11        | 10       | 9         | 8        | 7          | 6           | 5        | 4       | 3     | 2        | 1 | 0   |
| USBADDR  |         |           |        |          |           | <u> </u> |           | <u> </u> | —          |             |          | US      | BADDR | [6:0]    |   |     |
|          | Bit     | ts 15 to  | 12     |          |           |          |           | N        | lothing is | s assigr    | ned      |         |       |          |   | R/W |
|          |         |           |        | The wr   | rite valu | le must  | be 0. T   | he read  | l value is | <b>;</b> 0. |          |         |       |          |   | —   |
| -        |         |           |        |          |           |          |           |          |            |             |          |         |       |          |   |     |
|          | Bi      | its 11 to | 8      |          |           |          |           |          | Rese       | erved       |          |         |       |          |   | R/W |
|          |         | _         |        | The wr   | rite valı | le must  | be 0. T   | he read  | l value is | <b>;</b> 0. |          |         |       |          |   | —   |
| -        | ·       |           | ·      | <u> </u> |           | <u> </u> | <u></u>   | ·        |            |             |          | <u></u> |       | <u> </u> | · |     |
|          |         | Bit 7     |        |          |           |          |           | N        | lothing is | s assigr    | ned      |         |       |          |   | R/W |
|          |         |           |        | The wr   | rite valı | le must  | be 0. T   | he read  | l value is | <b>;</b> 0. |          |         |       |          |   | —   |
|          |         |           |        |          |           |          |           |          |            |             |          |         |       |          |   |     |
|          | USB     | BADDR     | [6:0]  |          |           |          |           |          | USB a      | address     |          |         |       |          |   | R/W |
|          | The cu  | Irrent U  | SB add | ress val | ue can    | be read  | I. This r | egister  | is not us  | ed whil     | e in the | host m  | ode.  |          |   | R   |

#### Figure 13 - 27 Format of USB Address Register (USBADDR)



### 13.3.20 USB request type register (USBREQ)

|         |             | F        | Figure 1   | 3 - 28   | Form      | at of U   | ISB Re        | equest   | t Type I  | Regist    | er (US   | BREQ)     |          |          |       |      |
|---------|-------------|----------|------------|----------|-----------|-----------|---------------|----------|-----------|-----------|----------|-----------|----------|----------|-------|------|
| Address | : F0454     | H, F045  | 55H        | After    | reset: (  | 0000H     |               |          |           |           |          |           |          |          |       |      |
| Symbol  | 15          | 14       | 13         | 12       | 11        | 10        | 9             | 8        | 7         | 6         | 5        | 4         | 3        | 2        | 1     | 0    |
| USBREQ  |             |          | E          | BREQU    | EST[7:0]  |           |               |          |           |           | BM       | REQUE     | STTYPE   | [7:0]    |       |      |
|         | BF          | REQUE    | ST[7:0]    |          |           |           |               |          | R         | equest    |          |           |          |          |       | R/W  |
|         | These       | bits sto | re the U   | SB req   | uest bR   | lequest   | value.        |          |           |           |          |           |          |          |       | R/W  |
|         |             |          | st control | •        |           | •         |               |          |           |           |          |           |          |          |       | Note |
|         | -<br>The US | SB requ  | iest data  | value    | for the s | setup tra | -<br>ansactio | on to be | e transm  | itted sh  | ould be  | set in th | nese bit | s. Do no | ot    |      |
|         | modify      | these t  | bits while | SURE     | Q is 1.   | •         |               |          |           |           |          |           |          |          |       |      |
|         | [When       | the fun  | ction cor  | ntroller | functio   | n is sele | ected]        |          |           |           |          |           |          |          |       |      |
|         | -<br>These  | bits ind | licate the | USB r    | equest    | data va   | lue rece      | eived d  | uring the | e setup i | transact | tion. Wr  | iting to | these bi | ts is |      |
|         | invalid     |          |            |          | •         |           |               |          | Ũ         | ·         |          |           | Ũ        |          |       |      |
|         |             |          |            |          |           |           |               |          |           |           |          |           |          |          |       |      |
|         | BMRE        | QUEST    | TTYPE[7    | :0]      |           |           |               |          | Req       | uest typ  | be       |           |          |          |       | R/W  |
|         | These       | bits sto | re the U   | SB req   | uest br   | Reque     | stType        | value.   |           |           |          |           |          |          |       | R/W  |
|         | [When       | the hos  | st control | ler fun  | ction is  | selecte   | d]            |          |           |           |          |           |          |          |       | Note |
|         | The US      | SB requ  | iest data  | value    | for the s | setup tra | ansactio      | on to be | e transm  | itted sh  | ould be  | set in th | nese bit | s. Do no | ot    |      |
|         | modify      | these b  | bits while | SURE     | Q is 1.   |           |               |          |           |           |          |           |          |          |       |      |
|         | -           |          | ction cor  |          |           | n is sele | ected]        |          |           |           |          |           |          |          |       |      |
|         | -<br>These  | bits ind | licate the | USB r    | equest    | data va   | lue rece      | eived d  | uring the | esetup    | transact | tion. Wr  | iting to | these bi | ts is |      |
|         | invalid     |          |            |          | •         |           |               |          | 0         | •         |          |           | Ũ        |          |       |      |
|         | <u> </u>    |          |            |          |           |           |               |          |           |           |          |           |          |          |       |      |

**Note** When the function controller function is selected, these bits can only be read from, and writing to these bits is invalid. When the host controller function is selected, these bits can be read from and written to.

### 13.3.21 USB request value register (USBVAL)

| Address | : F0456 | H, F045  | 57H       | After     | reset: (  | 0000H     |         |          |          |          |          |          |         |          |           |      |
|---------|---------|----------|-----------|-----------|-----------|-----------|---------|----------|----------|----------|----------|----------|---------|----------|-----------|------|
| Symbol  | 15      | 14       | 13        | 12        | 11        | 10        | 9       | 8        | 7        | 6        | 5        | 4        | 3       | 2        | 1         | 0    |
| USBVAL  |         |          |           |           |           |           |         | WVALU    | JE[15:0] |          |          |          |         |          |           |      |
|         | ٧       | /VALUE   | [15:0]    |           |           |           |         |          | ,        | Value    |          |          |         |          |           | R/W  |
|         | These   | bits sto | re the L  | JSB req   | uest w\   | alue va   | ue.     |          |          |          |          |          |         |          |           | R/W  |
|         | [When   | the hos  | st contro | oller fun | ction is  | selected  | 4]      |          |          |          |          |          |         |          |           | Note |
|         | The U   | SB requ  | iest wVa  | alue val  | ue for th | ie setup  | transa  | ction to | be trans | smitted  | should   | be set i | n these | bits. Do | o not     |      |
|         | modify  | these b  | oits whil | e SURE    | EQ is 1.  |           |         |          |          |          |          |          |         |          |           |      |
|         | [When   | the fun  | ction co  | ontroller | functior  | n is sele | cted]   |          |          |          |          |          |         |          |           |      |
|         | These   | bits ind | icate the | e USB r   | equest    | wValue    | value r | eceived  | during   | the setu | up trans | action.  | Writing | to these | e bits is |      |
|         | invalid |          |           |           |           |           |         |          |          |          |          |          |         |          |           |      |
|         |         |          |           |           |           |           |         |          |          |          |          |          |         |          |           |      |

Figure 13 - 29 Format of USB Request Value Register (USBVAL)

**Note** When the function controller function is selected, these bits can only be read from, and writing to these bits is invalid. When the host controller function is selected, these bits can be read from and written to.

### 13.3.22 USB request index register (USBINDX)

|          |         | F        | igure 1    | 3 - 30    | Forma     | at of US  | SB Re   | quest    | Index F  | Regist   | er (US   | BINDX    | <b>(</b> ) |          |         |      |
|----------|---------|----------|------------|-----------|-----------|-----------|---------|----------|----------|----------|----------|----------|------------|----------|---------|------|
| Address: | F0458   | 8H, F048 | 59H        | After     | reset: (  | 0000H     |         |          |          |          |          |          |            |          |         |      |
| Symbol   | 15      | 14       | 13         | 12        | 11        | 10        | 9       | 8        | 7        | 6        | 5        | 4        | 3          | 2        | 1       | 0    |
| USBINDX  |         |          |            |           |           |           |         | WINDE    | X[15:0]  |          |          |          |            |          |         |      |
| [        | ۷       | VINDEX   | ([15:0]    |           |           |           |         |          |          | Index    |          |          |            |          |         | R/W  |
|          | These   | bits sto | re the L   | ISB req   | uest wli  | ndex va   | lue.    |          |          |          |          |          |            |          |         | R/W  |
|          | [When   | the hos  | st contro  | oller fun | ction is  | selected  | d]      |          |          |          |          |          |            |          |         | Note |
|          | The U   | SB requ  | iest wln   | dex valı  | ue for th | ne setup  | transa  | ction to | be trans | smitted  | should   | be set i | n these    | bits. Do | not     |      |
|          | modify  | these I  | oits while | e SURE    | Q in the  | e DCPC    | TR reg  | ister is | 1.       |          |          |          |            |          |         |      |
|          | [When   | the fun  | ction co   | ntroller  | function  | n is sele | cted]   |          |          |          |          |          |            |          |         |      |
|          | These   | bits ind | icate the  | e USB r   | equest    | wIndex    | value r | eceived  | during t | the setu | ıp trans | action.  | Writing 1  | to these | bits is |      |
|          | invalid |          |            |           |           |           |         |          |          |          |          |          |            |          |         |      |
| L        |         |          |            |           |           |           |         |          |          |          |          |          |            |          |         |      |

**Note** When the function controller function is selected, these bits can only be read from, and writing to these bits is invalid. When the host controller function is selected, these bits can be read from and written to.

### 13.3.23 USB request length register (USBLENG)

#### Figure 13 - 31 Format of USB Request Length Register (USBLENG)

| Address: | F045A   | H, F04   | 5BH        | After    | reset: ( | 0000H     |         |           |           |         |          |          |         |           |           |      |
|----------|---------|----------|------------|----------|----------|-----------|---------|-----------|-----------|---------|----------|----------|---------|-----------|-----------|------|
| Symbol   | 15      | 14       | 13         | 12       | 11       | 10        | 9       | 8         | 7         | 6       | 5        | 4        | 3       | 2         | 1         | 0    |
| USBLENG  |         |          |            |          |          |           |         | WLENG     | TH[15:0]  |         |          |          |         |           |           |      |
|          | W       | LENGT    | H[15:0]    |          |          |           |         |           | L         | ength   |          |          |         |           |           | R/W  |
|          | These   | bits sto | re the U   | SB req   | uest wL  | ength v   | alue.   |           |           |         |          |          |         |           |           | R/W  |
|          | [When   | the hos  | st contro  | ller fun | ction is | selected  | 4]      |           |           |         |          |          |         |           |           | Note |
|          | The US  | SB requ  | iest wLe   | ngth va  | alue for | the setu  | p trans | action to | o be trai | nsmitte | d should | d be set | in thes | e bits. D | )o not    |      |
|          | modify  | these b  | oits while | e SURE   | EQ in th | e DCPC    | TR reg  | ister is  | 1.        |         |          |          |         |           |           |      |
|          | [When   | the fun  | ction co   | ntroller | functio  | n is sele | cted]   |           |           |         |          |          |         |           |           |      |
|          | These   | bits ind | icate the  | USB r    | equest   | wLength   | value   | received  | d during  | the set | up trans | action.  | Writing | to these  | e bits is |      |
|          | invalid | -        |            |          |          |           |         |           |           |         |          |          |         |           |           |      |

**Note** When the function controller function is selected, these bits can only be read from, and writing to these bits is invalid. When the host controller function is selected, these bits can be read from and written to.



### 13.3.24 DCP configuration register (DCPCFG)

|                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                           | I       | Figure   | 13 - 32  | ? Form   | at of D  | CP Co    | onfigu   | ration F                  | Regist             | er (DC | PCFG)    | 1        |         |          |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|----------|----------|----------|----------|----------|---------------------------|--------------------|--------|----------|----------|---------|----------|-----|
| Address                                                                                                                                                                                                                                                                                                                                                                                                 | : F045C                                                                                                                                                                                                                                                                                                                                                                                                                   | CH, F04 | 5DH      | After    | reset: ( | 0000H    |          |          |                           |                    |        |          |          |         |          |     |
| Symbol                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                                                                                                                                                                                                                                                                                                                                                                        | 14      | 13       | 12       | 11       | 10       | 9        | 8        | 7                         | 6                  | 5      | 4        | 3        | 2       | 1        | 0   |
| DCPCFG                                                                                                                                                                                                                                                                                                                                                                                                  | _                                                                                                                                                                                                                                                                                                                                                                                                                         | _       | _        | _        | _        |          | _        | _        | SHTNA<br>K                |                    | _      | DIR      |          | _       | _        | _   |
| Bits 15 to 8       Nothing is assigned       R         —       The write value must be 0. The read value is 0.       -                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                           |         |          |          |          |          |          |          |                           |                    |        |          |          | R/W     |          |     |
|                                                                                                                                                                                                                                                                                                                                                                                                         | —     The write value must be 0. The read value is 0.     -       SHTNAK     Pipe disabled at end of transfer Note     R/                                                                                                                                                                                                                                                                                                 |         |          |          |          |          |          |          |                           |                    |        |          |          |         | —        |     |
| DCPCFG                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                           |         |          |          |          |          |          |          |                           |                    |        |          | R/W      |         |          |     |
| SHTNAK       Pipe disabled at end of transfer Note       R/         0       Pipe continued at the end of transfer       R/         1       Pipe disabled at the end of transfer       R/         Specifies whether to modify PID to NAK upon the end of transfer when the selected pipe is in the receiving direction.       The SHTNAK bit is valid when the selected pipe in the receiving direction. |                                                                                                                                                                                                                                                                                                                                                                                                                           |         |          |          |          |          |          |          |                           |                    |        |          |          | R/W     |          |     |
|                                                                                                                                                                                                                                                                                                                                                                                                         | 1       Pipe disabled at the end of transfer         Specifies whether to modify PID to NAK upon the end of transfer when the selected pipe is in the receiving                                                                                                                                                                                                                                                           |         |          |          |          |          |          |          |                           |                    |        |          |          |         |          |     |
|                                                                                                                                                                                                                                                                                                                                                                                                         | Specifies whether to modify PID to NAK upon the end of transfer when the selected pipe is in the receiving direction.<br>The SHTNAK bit is valid when the selected pipe in the receiving direction.                                                                                                                                                                                                                       |         |          |          |          |          |          |          |                           |                    |        |          |          |         |          |     |
|                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                           |         |          |          |          |          |          |          |                           |                    |        |          |          |         | ing the  |     |
|                                                                                                                                                                                                                                                                                                                                                                                                         | Specifies whether to modify PID to NAK upon the end of transfer when the selected pipe is in the receiving direction.<br>The SHTNAK bit is valid when the selected pipe in the receiving direction.<br>When the SHTNAK bit is set to 1, the USB module modifies the PID bits for the DCP to NAK on determining the end of the transfer. The USB module determines that the transfer has ended on the following condition. |         |          |          |          |          |          |          |                           |                    |        |          |          |         |          |     |
|                                                                                                                                                                                                                                                                                                                                                                                                         | Bits                                                                                                                                                                                                                                                                                                                                                                                                                      | 6, 5    |          |          |          |          |          | Nothi    | ng is ass                 | igned              |        |          |          |         |          | R/W |
|                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                           | -       | The wri  | te value | e must k | be 0. Th | e read v | value is | ; 0.                      |                    |        |          |          |         |          | —   |
|                                                                                                                                                                                                                                                                                                                                                                                                         | DI                                                                                                                                                                                                                                                                                                                                                                                                                        | R       |          |          |          |          |          | Transfe  | er directi                | on <sup>Note</sup> |        |          |          |         |          | R/W |
|                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                                                                                                                                                         | )       | Data re  | ceiving  | directio | n        |          |          |                           |                    |        |          |          |         |          | R/W |
|                                                                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                         |         | Data tra | ansmitti | ng direo | ction    |          |          |                           |                    |        |          |          |         |          |     |
|                                                                                                                                                                                                                                                                                                                                                                                                         | stage.                                                                                                                                                                                                                                                                                                                                                                                                                    |         |          |          |          |          |          |          | ets the tra<br>oit should |                    |        | n of the | data sta | age and | l status |     |

| Bits 3 to 0 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| —           | The write value must be 0. The read value is 0. |     |

**Note** Modify these bits while PID is NAK. Before modifying these bits after modifying the PID bits for the DCP from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.



### **13.3.25 DCP maximum packet size register (DCPMAXP)**

#### Figure 13 - 33 Format of DCP Maximum Packet Size Register (DCPMAXP)

| ddress: | : F045E                                 | H, F04                                  | 5FH                                         | Afte                                     | er reset: (                             | 0040H                              |                                                                  |                                |                                |                                |                                   |                                |                                 |                                   |                                 |               |
|---------|-----------------------------------------|-----------------------------------------|---------------------------------------------|------------------------------------------|-----------------------------------------|------------------------------------|------------------------------------------------------------------|--------------------------------|--------------------------------|--------------------------------|-----------------------------------|--------------------------------|---------------------------------|-----------------------------------|---------------------------------|---------------|
| Symbol  | 15                                      | 14                                      | 13                                          | 12                                       | 11                                      | 10                                 | 9                                                                | 8                              | 7                              | 6                              | 5                                 | 4                              | 3                               | 2                                 | 1                               | 0             |
| PMAXP   | —                                       | DEVSE<br>L2                             | DEVSE<br>L1                                 | DEVSI<br>L0                              | Ē _                                     | _                                  | _                                                                | _                              | _                              |                                |                                   | Ν                              | /XPS[6:0                        | )]                                |                                 |               |
|         | Bit                                     | 15                                      |                                             |                                          |                                         |                                    |                                                                  | Nothin                         | g is as                        | signed                         |                                   |                                |                                 |                                   |                                 | R/W           |
|         |                                         | -                                       | The wr                                      | ite valu                                 | lue must be 0. The read value is 0.     |                                    |                                                                  |                                |                                |                                |                                   |                                |                                 |                                   |                                 |               |
|         | DEVS                                    | EL2                                     | DEVS                                        | EL1                                      | DEVS                                    | EL0                                |                                                                  |                                |                                | Device                         | e select <sup>I</sup>             | Note 1                         |                                 |                                   |                                 | R/W           |
|         | 0                                       |                                         | 0                                           |                                          | 0                                       |                                    | USB ad                                                           | dress 00                       | 00                             |                                |                                   |                                |                                 |                                   |                                 | R/W           |
|         | 0                                       |                                         | 0                                           |                                          | 1                                       |                                    | USB ad                                                           | dress 00                       | )1                             |                                |                                   |                                |                                 |                                   |                                 | -             |
|         | 0                                       |                                         | 1                                           |                                          | 0                                       |                                    | USB ad                                                           | dress 01                       | 0                              |                                |                                   |                                |                                 |                                   |                                 |               |
|         | 0                                       |                                         | 1                                           |                                          | 1                                       |                                    | USB ad                                                           | dress 01                       | 1                              |                                |                                   |                                |                                 |                                   |                                 | -             |
|         | 1                                       |                                         | 0                                           |                                          | 0                                       |                                    | USB ad                                                           | dress 10                       | 00                             |                                |                                   |                                |                                 |                                   |                                 |               |
|         | 1                                       |                                         | 0                                           |                                          | 1                                       |                                    | USB ad                                                           | dress 10                       | )1                             |                                |                                   |                                |                                 |                                   |                                 |               |
|         |                                         | С                                       | ther tha                                    | n abov                                   | /e                                      |                                    | Do not s                                                         | et.                            |                                |                                |                                   |                                |                                 |                                   |                                 |               |
|         | periphe<br>The DE<br>corresp<br>the ado | eral dev<br>EVSEL<br>ponding<br>dress s | vice whi<br>2 to DE<br>g to the<br>hould be | ch is th<br>/SEL0<br>value t<br>e set to | bits sho<br>bits sho<br>be set<br>DEVAD | unicat<br>uld be<br>in thes<br>D2. | ed, the Di<br>ion targe<br>set after<br>se bits. F<br>ected, the | t during<br>setting<br>or exam | control<br>the add<br>ple, bef | transfe<br>ress to<br>fore set | r.<br>the DE\<br>ting DE\         | /ADDn<br>/SEL21                | (n = 0 to                       | o 5) regi                         |                                 |               |
| i<br>I  | Bits 11                                 | to 7                                    |                                             |                                          |                                         |                                    |                                                                  | Nothin                         | g is as                        | signod                         |                                   |                                |                                 |                                   |                                 | R/W           |
|         |                                         | -                                       | The wr                                      | ite valu                                 | ie must t                               | be 0. T                            | he read                                                          |                                | -                              | signed                         |                                   |                                |                                 |                                   |                                 |               |
|         | MXPS                                    | 5[6:0]                                  |                                             |                                          |                                         |                                    | Ма                                                               | aximum                         | packet                         | size <sup>Not</sup>            | te 2                              |                                |                                 |                                   |                                 | R/W           |
|         | (64 byt<br>These                        | es).<br>bits sh                         | ould be                                     | set to t                                 | the value                               | base                               | oad (max<br>d on the<br>the FIFO                                 | imum pa<br>USB Sp              | acket si<br>ecificati          | ze) for t<br>ons.              | he DCP                            |                                | itial valu                      | ie is 40I                         | 4                               | R/W           |
|         | Note 1.<br>Note 2.                      | mo<br>be<br>Mo                          | odifying<br>en modi<br>odify the            | the PII<br>ified to<br>MXPS              | D bits for<br>NAK by<br>S[6:0] bits     | the D<br>the U<br>s while          | PID is NA<br>CP from<br>SB modu<br>PID is N<br>hat PBUS          | BUF to<br>le, chec<br>IAK. Bet | NAK, cł<br>king the<br>fore mo | neck tha<br>PBUS<br>difying f  | at PBUS<br>Y bit thr<br>these bit | Y is 0.<br>ough so<br>ts after | Howeve<br>oftware i<br>modifyir | r, if the<br>s not ne<br>ng the P | PID bits<br>ecessar<br>PID bits | y.<br>for the |



and the DCP has been set to the CURPIPE bits, clear the buffer by setting BCLR to 1.

USB module, checking the PBUSY bit through software is not necessary. After modifying the MXPS[6:0] bits

### 13.3.26 DCP control register (DCPCTR)

#### Figure 13 - 34 Format of DCP Control Register (DCPCTR)

| Address | : F0460                                                | H, F04                                                                                               | 61H                                                               | After     | reset: 0   | 040H    |          |          |           |          |                         |         |         |          |            |        |
|---------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------|------------|---------|----------|----------|-----------|----------|-------------------------|---------|---------|----------|------------|--------|
| Symbol  | 15                                                     | 14                                                                                                   | 13                                                                | 12        | 11         | 10      | 9        | 8        | 7         | 6        | 5                       | 4       | 3       | 2        | 1          | 0      |
| DCPCTR  | R BSTS SURE SURE SURE R SQCL R SQSET N PBUSY CCPL PID1 |                                                                                                      |                                                                   |           |            |         |          |          |           |          |                         |         | PID1    | PID0     |            |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          |          |           |          |                         |         | R/W     |          |            |        |
|         | 0                                                      | )                                                                                                    | Buffer a                                                          | access    | is enable  | əd.     |          |          |           |          |                         |         |         |          |            | R      |
|         | 1                                                      | 1 Buffer access is disabled.                                                                         |                                                                   |           |            |         |          |          |           |          |                         |         |         |          |            |        |
|         | Indicat                                                | licates whether DCP FIFO buffer access is enabled or disabled.                                       |                                                                   |           |            |         |          |          |           |          |                         |         |         |          |            |        |
|         | The me                                                 | eaning                                                                                               | aning of the BSTS bit depends on the ISEL bit setting as follows. |           |            |         |          |          |           |          |                         |         |         |          |            |        |
|         | <ul> <li>Wher</li> </ul>                               | n ISEL                                                                                               | is 0, the                                                         | BSTS      | bit indica | ates wh | ether th | ne recei | ved data  | a can be | e read fro              | om the  | buffer. |          |            |        |
|         | <ul> <li>Wher</li> </ul>                               | n ISEL is 1, the BSTS bit indicates whether the data to be transmitted can be written to the buffer. |                                                                   |           |            |         |          |          |           |          |                         |         |         |          |            |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          |          |           |          |                         |         |         |          |            |        |
|         | SUR                                                    | REQ                                                                                                  |                                                                   |           |            |         | S        | Setup to | ken tran  | ismissio | on                      |         |         |          |            | R/W    |
|         | 0                                                      | )                                                                                                    | Invalid                                                           |           |            |         |          |          |           |          |                         |         |         |          |            | R/W    |
|         | 1                                                      |                                                                                                      | Transm                                                            | its the   | setup pa   | icket.  |          |          |           |          |                         |         |         |          |            | Note 1 |
|         | The US                                                 | SB mod                                                                                               | lule tran                                                         | smits tl  | ne setup   | packet  | by sett  | ing the  | SUREC     | bit to 1 | l when th               | e host  | control | ler func | tion is    |        |
|         | selecte                                                | ed.                                                                                                  |                                                                   |           |            |         | -        | -        |           |          |                         |         |         |          |            |        |
|         | After co                                               | ompleti                                                                                              | ng the s                                                          | etup tra  | ansactio   | n proce | ess, the | USB m    | odule ge  | enerate  | s either t              | he SA(  | CK or S | IGN inte | errupt     |        |
|         | and cle                                                | ears the                                                                                             | SURE                                                              | ຊ bit to  | 0.         |         |          |          |           |          |                         |         |         |          |            |        |
|         | _                                                      |                                                                                                      |                                                                   |           |            |         |          |          |           |          | SUREQC                  |         |         |          |            |        |
|         |                                                        | -                                                                                                    |                                                                   |           |            |         |          |          |           |          | AL, USB                 |         |         |          |            |        |
|         |                                                        | -                                                                                                    |                                                                   |           |            |         |          |          |           |          | . Before s<br>o 1, do n | -       |         |          |            |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          | -        |           |          | ansactio                |         | -       |          |            |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          | -        |           |          | purpose                 |         |         |          | · ~ · · ). |        |
|         |                                                        |                                                                                                      |                                                                   |           | -          |         | -        |          |           |          | SUREQ                   |         |         |          |            |        |
|         | Bits 1                                                 | 3, 12                                                                                                |                                                                   |           |            |         |          | Nothir   | ng is as  | signed   |                         |         |         |          |            | R/W    |
|         |                                                        | -                                                                                                    | The wri                                                           | te valu   | e must b   | e0Th    | e read   |          | 0         | 0        |                         |         |         |          |            | _      |
|         |                                                        |                                                                                                      |                                                                   |           |            | 0 0. 11 | o rouu   | value le | 0.        |          |                         |         |         |          |            |        |
|         | SURE                                                   | QCLR                                                                                                 |                                                                   |           |            |         |          | SUF      | EQ bit    | clear    |                         |         |         |          |            | R/W    |
|         | 0                                                      | )                                                                                                    | Invalid                                                           |           |            |         |          |          |           |          |                         |         |         |          |            | R/W    |
|         | 1                                                      |                                                                                                      | 0 is wri                                                          | tten to t | the SUR    | EQ bit. |          |          |           |          |                         |         |         |          |            | Note 2 |
|         | SURE                                                   | QCLR I                                                                                               | oit alway                                                         | s indic   | ates 0.    |         |          | -        |           |          | o 1 clears              |         |         |          |            |        |
|         |                                                        |                                                                                                      |                                                                   |           | -          |         |          |          |           |          | opped wit<br>e automa   |         |         | -        | -          |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          |          |           |          | through                 | •       |         |          |            |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          | -        |           |          | e UACT i                |         |         |          | -          |        |
|         |                                                        | -                                                                                                    |                                                                   |           | is being   |         |          |          |           |          |                         |         |         |          |            |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          |          |           |          | SUREQO                  | CLR bit | -       |          |            |        |
|         |                                                        |                                                                                                      |                                                                   |           |            |         |          |          |           |          |                         |         |         |          |            |        |
|         | Bits 1                                                 | 10, 9                                                                                                |                                                                   |           |            |         |          | Nothir   | ng is ass | signed   |                         |         |         |          |            | R/W    |

\_\_\_\_



The write value must be 0. The read value is 0.

\_\_\_\_

| SQCLR                                                                                                                                                | Toggle bit clear Note 2 | R/W    |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------|--|--|--|--|--|--|
| 0                                                                                                                                                    | Invalid                 | R/W    |  |  |  |  |  |  |
| 1                                                                                                                                                    | Specifies DATA0.        | Note 3 |  |  |  |  |  |  |
| Specifies DATA0 as the expected value of the sequence toggle bit for the next transaction during the DCP transfer. The SQCLR bit always indicates 0. |                         |        |  |  |  |  |  |  |

Do not set the SQCLR and SQSET bits to 1 simultaneously.

| Toggle bit set Note 2                                                                       | R/W                         |
|---------------------------------------------------------------------------------------------|-----------------------------|
| Invalid                                                                                     | R/W                         |
| Specifies DATA1.                                                                            | Note 3                      |
| A1 as the expected value of the sequence toggle bit for the next transaction during the DCP |                             |
|                                                                                             |                             |
|                                                                                             | Invalid<br>Specifies DATA1. |

Do not set the SQCLR and SQSET bits to 1 simultaneously.

| SQMON         | Sequence toggle bit monitor                                                                 | R/W |
|---------------|---------------------------------------------------------------------------------------------|-----|
| 0             | DATAO                                                                                       | R   |
| 1             | DATA1                                                                                       |     |
| Indicates the | expected value of the sequence toggle bit for the next transaction during the DCP transfer. |     |

The USB module allows the SQMON bit to toggle upon normal completion of the transaction. However, the SQMON bit is not allowed to toggle when a DATA-PID disagreement occurs during the transfer in the receiving direction.

When the function controller function is selected, the USB module sets the SQMON bit to 1 (specifies DATA1 as the expected value) upon successful reception of the setup packet.

When the function controller function is selected, the USB module does not reference the SQMON bit during the IN/OUT transaction of the status stage, and does not allow the SQMON bit to toggle upon normal completion.

| PBUSY          | Pipe busy                                                                                             | R/W |
|----------------|-------------------------------------------------------------------------------------------------------|-----|
| 0              | DCP is not used for the transaction.                                                                  | R   |
| 1              | DCP is used for the transaction.                                                                      |     |
| Indicates wh   | ether DCP is used or not for the transaction when USB changes the PID bits from BUF to NAK.           |     |
| The USB mo     | odule modifies the PBUSY bit from 0 to 1 upon start of the USB transaction for the relevant pipe, and |     |
| modifies the   | PBUSY bit from 1 to 0 upon completion of one transaction.                                             |     |
| Reading the    | PBUSY bit after software has set PID to NAK allows checking whether modification of the pipe          |     |
| settings is p  | ossible.                                                                                              |     |
| For details, i | refer to 13.4.4.1 Pipe control register switching procedures.                                         |     |
|                |                                                                                                       | 1   |
| D:4- 4 0       | No de la construcción de la construcción                                                              | DAA |

| Bits 4, 3 | Nothing is assigned                             | R/W |
|-----------|-------------------------------------------------|-----|
| _         | The write value must be 0. The read value is 0. | —   |



| CCPL        | Control transfer end enable                                                                                                                                                                          | R/W |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 0           | Completion of control transfer is disabled.                                                                                                                                                          | R/W |
| 1           | Completion of control transfer is enabled.                                                                                                                                                           |     |
|             | nction controller function is selected, setting the CCPL bit to 1 enables the status stage of the<br>fer to be completed.                                                                            |     |
|             | are sets the CCPL bit to 1 while the corresponding PID bits are set to BUF, the USB module ne control transfer stage.                                                                                |     |
| •           | during control read transfer, the USB module transmits the ACK handshake in response to the OUT                                                                                                      |     |
|             | rom the USB host, and transmits the zero-length packet in response to the IN transaction from the<br>uring control write or no-data control transfer. However, on detecting the SET ADDRESS request, |     |
| the USB mo  | dule operates in auto response mode from the setup stage up to the status stage completion                                                                                                           |     |
| •           | of the setting of the CCPL bit.<br>odule modifies the CCPL bit from 1 to 0 on receiving a new setup packet.                                                                                          |     |
| Software ca | nnot write 1 to the CCPL bit while VALID is 1.                                                                                                                                                       |     |
| When the he | ost controller function is selected, be sure to write 0 to the CCPL bit.                                                                                                                             |     |

|                                                                                                                                                                                                                                                                                            | PID0                                                                                                                                                                                                                       | Response PID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 0                                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                          | NAK response                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W |
| 0                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                          | BUF response (depending on the buffer state)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
| 1                                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                          | STALL response                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 1                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                          | STALL response                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| The PID1 and                                                                                                                                                                                                                                                                               | d PID0 bits co                                                                                                                                                                                                             | ntrol the response type of the USB module during control transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| [When the ho                                                                                                                                                                                                                                                                               | ost controller f                                                                                                                                                                                                           | unction is selected]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
|                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            | D1 and PID0 bits from NAK to BUF using the following procedure.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|                                                                                                                                                                                                                                                                                            | ransmitting dir                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            | to the FIFO buffer while UACT is 1 and PID is NAK, and then set PID to BUF. After                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |
|                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            | the USB module executes the OUT transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|                                                                                                                                                                                                                                                                                            | eceiving direc                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            | er is empty (or empty the buffer) while UACT is 1 and PID is NAK, and then set PID to set to BUF, the USB module executes the IN transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |
| DUF. Allel I                                                                                                                                                                                                                                                                               | FID has been                                                                                                                                                                                                               | set to DOF, the OSD module executes the in transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
|                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|                                                                                                                                                                                                                                                                                            | dule modifies                                                                                                                                                                                                              | the setting of the PID1 and PID0 bits as follows                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| The USB mo                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                            | the setting of the PID1 and PID0 bits as follows.<br>) to STALL (11B) on receiving the data of a size exceeding the maximum packet size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| The USB mo<br>• The USB m                                                                                                                                                                                                                                                                  | odule sets PI                                                                                                                                                                                                              | the setting of the PID1 and PID0 bits as follows.<br>D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| The USB mo<br>• The USB m<br>when softw                                                                                                                                                                                                                                                    | odule sets PII<br>are has set th                                                                                                                                                                                           | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size e PID1 and PID0 bits to BUF.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m                                                                                                                                                                                                                                     | odule sets PII<br>are has set th<br>odule sets PII                                                                                                                                                                         | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m                                                                                                                                                                                                                      | odule sets PII<br>are has set th<br>odule sets PII<br>odule also se                                                                                                                                                        | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu                                                                                                                                                                                                      | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll                                                                                                                                  | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]                                                                                                                                                                                                                                                                                                                                                                                                                      |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu<br>The USB mo                                                                                                                                                                                        | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll<br>dule modifies                                                                                                                 | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.                                                                                                                                                                                                                                                                                                                                                                 |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu<br>The USB mo<br>• The USB m                                                                                                                                                                         | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll<br>dule modifies<br>nodule modifie                                                                                               | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.<br>s the PID1 and PID0 bits to NAK on receiving the setup packet. Here, the USB                                                                                                                                                                                                                                                                                 |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu<br>The USB mo<br>• The USB m                                                                                                                                                                         | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll<br>dule modifies<br>nodule modifies<br>s VALID to 1.3                                                                            | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.                                                                                                                                                                                                                                                                                                                                                                 |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu<br>The USB mo<br>• The USB m<br>module sets<br>VALID to 0.                                                                                                                                           | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>notion controll<br>dule modifies<br>nodule modifie<br>s VALID to 1.3                                                                             | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.<br>s the PID1 and PID0 bits to NAK on receiving the setup packet. Here, the USB<br>Software cannot modify the setting of the PID1 and PID0 bits until software sets                                                                                                                                                                                             |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu<br>The USB mo<br>• The USB m<br>module sets<br>VALID to 0.<br>• The USB m                                                                                                                            | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll<br>dule modifies<br>nodule modifie<br>s VALID to 1.                                                                              | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.<br>s the PID1 and PID0 bits to NAK on receiving the setup packet. Here, the USB                                                                                                                                                                                                                                                                                 |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu<br>The USB mo<br>• The USB m<br>module sets<br>VALID to 0.<br>• The USB m<br>when softw                                                                                                              | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll<br>dule modifies<br>nodule modifies<br>s VALID to 1.<br>nodule sets PII<br>are has set th                                        | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.<br>s the PID1 and PID0 bits to NAK on receiving the setup packet. Here, the USB<br>Software cannot modify the setting of the PID1 and PID0 bits until software sets<br>D to STALL (11B) on receiving the data of a size exceeding the maximum packet size                                                                                                       |     |
| The USB mo<br>• The USB m<br>when softw<br>• The USB m<br>• The USB m<br>[When the fu<br>The USB mo<br>• The USB m<br>module sets<br>VALID to 0.<br>• The USB m<br>when softw<br>• The USB m                                                                                               | nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll<br>dule modifies<br>nodule modifies<br>s VALID to 1.<br>nodule sets PII<br>are has set th<br>nodule sets PII                     | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.<br>s the PID1 and PID0 bits to NAK on receiving the setup packet. Here, the USB<br>Software cannot modify the setting of the PID1 and PID0 bits until software sets<br>D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.                                                                       |     |
| <ul> <li>The USB mo</li> <li>The USB m<br/>when softw</li> <li>The USB m</li> <li>The USB m</li> <li>[When the fu</li> <li>The USB mo</li> <li>The USB m</li> <li>Module sets</li> <li>VALID to 0.</li> <li>The USB m</li> <li>when softw</li> <li>The USB m</li> <li>The USB m</li> </ul> | are has sets PII<br>are has set th<br>nodule sets PII<br>nodule also se<br>nction controll<br>dule modifies<br>nodule modifies<br>s VALID to 1.<br>nodule sets PII<br>are has set th<br>nodule sets PII<br>nodule sets PII | D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to NAK on detecting a receive error, such as a CRC error, three consecutive times.<br>ts PID to STALL (11B) on receiving the STALL handshake.<br>er function is selected]<br>the setting of the PID1 and PID0 bits as follows.<br>s the PID1 and PID0 bits to NAK on receiving the setup packet. Here, the USB<br>Software cannot modify the setting of the PID1 and PID0 bits until software sets<br>D to STALL (11B) on receiving the data of a size exceeding the maximum packet size<br>e PID1 and PID0 bits to BUF.<br>D to STALL (1xB) on detecting the control transfer sequence error. |     |

- Note 2.Write 1 to the SQSET and SQCLR bits while PID is NAK. Before modifying these bits after modifying the PID<br/>bits for the DCP from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to<br/>NAK by the USB module, checking the PBUSY bit through software is not necessary.
- **Note 3.** This bit is always read as 0. Only 1 can be written.

### 13.3.27 Pipe window select register (PIPESEL)

Figure 13 - 35 Format of Pipe Window Select Register (PIPESEL)

| dress: | F0464                                                                                  | H, F04                           | 65H       | After  | reset: ( | H0000      |           |         |            |         |          |            |              |                  |              |              |                  |  |  |  |  |
|--------|----------------------------------------------------------------------------------------|----------------------------------|-----------|--------|----------|------------|-----------|---------|------------|---------|----------|------------|--------------|------------------|--------------|--------------|------------------|--|--|--|--|
| nbol   | 15                                                                                     | 14                               | 13        | 12     | 11       | 10         | 9         | 8       | 7          | 6       | 5        | 4          | 3            | 2                | 1            | 0            |                  |  |  |  |  |
| SEL    | —                                                                                      | _                                | -         | _      | _        | _          | _         | _       | —          | —       | —        | _          | PIPES<br>EL3 | PIPES<br>EL2     | PIPES<br>EL1 | PIPES<br>EL0 |                  |  |  |  |  |
| [      | Bits 1                                                                                 | Bits 15 to 4 Nothing is assigned |           |        |          |            |           |         |            |         |          |            |              |                  |              | R/W          |                  |  |  |  |  |
| ľ      | <ul> <li>The write value must be 0. The read value is 0.</li> </ul>                    |                                  |           |        |          |            |           |         |            |         |          |            |              | —                |              |              |                  |  |  |  |  |
| ĺ      | PIPESEL3         PIPESEL2         PIPESEL1         PIPESEL0         Pipe window select |                                  |           |        |          |            |           |         |            |         |          |            | R/W          |                  |              |              |                  |  |  |  |  |
|        | 0                                                                                      | 0 0 0 0 No pipe selected F       |           |        |          |            |           |         |            |         |          |            |              | lo pipe selected |              |              | No pipe selected |  |  |  |  |
| Ì      | 0                                                                                      |                                  | 1         |        | 0        |            | 0         |         | PIPE4      |         |          |            |              |                  |              |              |                  |  |  |  |  |
| ĺ      | 0                                                                                      |                                  | 1         |        | 0        |            | 1         |         | PIPE5      |         |          |            |              |                  |              |              |                  |  |  |  |  |
|        | 0                                                                                      | )                                | 1         |        | 1        |            | 0         |         | PIPE6      |         |          |            |              |                  |              |              |                  |  |  |  |  |
|        | 0                                                                                      | )                                | 1         |        | 1        |            | 1         |         | PIPE7      |         |          |            |              |                  |              |              |                  |  |  |  |  |
|        |                                                                                        | 0                                | ther that | n abov | e        |            |           |         | Do not se  | et.     |          |            |              |                  |              |              |                  |  |  |  |  |
|        | The PI                                                                                 | PESEL                            | .3 to PIP | ESEL0  | bits sel | ect the    | pipe nur  | nber c  | orrespon   | ding to | the PIPI | ECFG, I    | PIPEBU       | F, PIPE          | Maxp,        |              |                  |  |  |  |  |
|        |                                                                                        |                                  | •         |        |          |            | tten to o |         |            |         |          |            |              |                  |              |              |                  |  |  |  |  |
|        |                                                                                        |                                  |           |        | -        |            |           | -       | to and re  | -       | om the   | PIPEC      | FG, PIP      | EMAXP,           | and          |              |                  |  |  |  |  |
|        |                                                                                        |                                  |           |        | •        |            |           | • •     | e number   |         |          |            |              |                  |              |              |                  |  |  |  |  |
|        |                                                                                        |                                  |           |        |          |            |           | ,       | 0 is read  |         | of the b | oits in th | ne PIPE      | CFG,             |              |              |                  |  |  |  |  |
|        | PIPEM                                                                                  | іахР, а                          | ina PIPE  | PERI   | egisters | s. vvritii | ng to the | se dits | is invalio | Ι.      |          |            |              |                  |              |              |                  |  |  |  |  |

Caution After selecting the pipe using the PIPESEL register, functions of the pipe should be set using the PIPECFG, PIPEMAXP, and PIPEPERI registers. The PIPEnCTR, PIPEnTRE, and PIPEnTRN registers can be set regardless of the pipe selection in the PIPESEL register.



## 13.3.28 Pipe configuration register (PIPECFG)

|        |                                                              | F                                                     | igure                                                                     | 13 - 3                                                        | 6 Form                                       | at of P                                                       | Pipe Co                                                   | onfigu                                | ration F                                                                      | Regist                                    | er (PIP                                     | ECFG                                          | )                                                |                                   |                      |            |
|--------|--------------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------|---------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------|---------------------------------------------|-----------------------------------------------|--------------------------------------------------|-----------------------------------|----------------------|------------|
| ddress | : F0468                                                      | 8H, F04                                               | 69H                                                                       | Afte                                                          | er reset:                                    | 0000H                                                         |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
| ymbol  | 15                                                           | 14                                                    | 13                                                                        | 12                                                            | 11                                           | 10                                                            | 9                                                         | 8                                     | 7                                                                             | 6                                         | 5                                           | 4                                             | 3                                                | 2                                 | 1                    | 0          |
| ECFG   | TYPE1                                                        | TYPE0                                                 | _                                                                         | —                                                             | _                                            | BFRE                                                          | DBLB                                                      | _                                     | SHTNA<br>K                                                                    | _                                         | _                                           | _                                             | DIR                                              | E                                 | PNUM[3               | :0]        |
|        | TYF                                                          | PE1                                                   | TYP                                                                       | E0                                                            |                                              |                                                               |                                                           |                                       | Transf                                                                        | er tvpe                                   | Note 1                                      |                                               |                                                  |                                   |                      | R/W        |
|        | PIPE4                                                        | , PIPE5                                               | 5                                                                         |                                                               |                                              |                                                               |                                                           |                                       |                                                                               | ,,                                        |                                             |                                               |                                                  |                                   |                      | R/W        |
|        | C                                                            | )                                                     | 0                                                                         |                                                               | Pipe no                                      | t used                                                        |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | C                                                            | )                                                     | 1                                                                         |                                                               | Bulk tra                                     | Insfer                                                        |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | 1                                                            | 1                                                     | 0                                                                         |                                                               | Do not                                       | set.                                                          |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      | _          |
|        | 1                                                            | 1                                                     | 1                                                                         |                                                               | Do not                                       | set.                                                          |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | PIPE6                                                        | , PIPE7                                               | 1                                                                         |                                                               |                                              |                                                               |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | C                                                            | )                                                     | 0                                                                         |                                                               | Pipe no                                      | t used                                                        |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | C                                                            | )                                                     | 1                                                                         |                                                               | Do not                                       | set.                                                          |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | 1                                                            | 1                                                     | 0                                                                         |                                                               | Interrup                                     | ot transf                                                     | er                                                        |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | 1                                                            | 1                                                     | 1                                                                         |                                                               | Do not                                       | set.                                                          |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      |            |
|        | sure to                                                      | o set the                                             |                                                                           |                                                               | r the sel<br>TYPE0 b                         |                                                               |                                                           | her tha                               |                                                                               |                                           | iunicatio                                   | on using                                      | the sele                                         | ected pip                         | be), be              |            |
|        | Bits 13                                                      | 3 to 11                                               | <b>-</b>                                                                  |                                                               |                                              | 0 <b>T</b>                                                    |                                                           |                                       | ng is ass                                                                     | igned                                     |                                             |                                               |                                                  |                                   |                      | R/W        |
|        |                                                              | -                                                     | The wr                                                                    | ite valu                                                      | ie must l                                    | be U. In                                                      | he read                                                   | value i                               | s 0.                                                                          |                                           |                                             |                                               |                                                  |                                   |                      | —          |
|        | BF                                                           | RE                                                    |                                                                           |                                                               |                                              | BRD                                                           | DY interr                                                 | upt op                                | eration s                                                                     | oecifica                                  | ation <sup>Not</sup>                        | e 2 <sub>,</sub> 3                            |                                                  |                                   |                      | R/W        |
|        | C                                                            | )                                                     | BRDY                                                                      | interru                                                       | pt upon f                                    | transmit                                                      | tting or r                                                | eceivir                               | ng data                                                                       |                                           |                                             |                                               |                                                  |                                   |                      | R/W        |
|        | 1                                                            | 1                                                     | BRDY                                                                      | interru                                                       | pt upon (                                    | complet                                                       | ion of re                                                 | ading                                 | data                                                                          |                                           |                                             |                                               |                                                  |                                   |                      | -          |
|        | pipe.<br>When<br>detects<br>When<br>The FI<br>When<br>does n | softwar<br>s the tra<br>the BRI<br>FO buff<br>softwar | re has so<br>ansfer co<br>DY inter<br>fer assig<br>re has so<br>erate the | et the E<br>omplet<br>rupt is<br>gned to<br>et the E<br>e BRD | BFRE bit<br>ion and g<br>generat<br>the sele | to 1 an<br>generate<br>ed with<br>ected pij<br>to 1 an<br>pt. | id the se<br>es the B<br>the abo<br>pe is no<br>id the se | elected<br>RDY i<br>ve con<br>t enabl | SB modu<br>pipe is ir<br>nterrupt c<br>ditions, s<br>ed for rec<br>pipe is ir | n the re<br>on havi<br>oftware<br>ception | eceiving<br>ng read<br>e needs<br>n until 1 | directio<br>the rele<br>to write<br>is writte | on, the U<br>evant pa<br>e 1 to the<br>en to the | SB moo<br>cket.<br>BCLR<br>BCLR t | dule<br>bit.<br>bit. |            |
|        |                                                              |                                                       |                                                                           |                                                               |                                              |                                                               | D                                                         |                                       | former                                                                        | le Note                                   | 2 3                                         |                                               |                                                  |                                   |                      |            |
|        | DB                                                           |                                                       | Single                                                                    | buffor                                                        |                                              |                                                               | Do                                                        | udie d                                | uffer moo                                                                     | IE NOLE                                   | 2, 0                                        |                                               |                                                  |                                   |                      | R/W<br>R/W |
|        | 1                                                            |                                                       | Single<br>Double                                                          |                                                               |                                              |                                                               |                                                           |                                       |                                                                               |                                           |                                             |                                               |                                                  |                                   |                      | R/W        |
|        | Select                                                       | s either                                              | single                                                                    | or doub                                                       |                                              |                                                               |                                                           |                                       | uffer used<br>I.                                                              | d by the                                  | e selecte                                   | ed pipe.                                      |                                                  |                                   |                      | -          |

| Bit 8 | Nothing is assigned                             | R/W |
|-------|-------------------------------------------------|-----|
| —     | The write value must be 0. The read value is 0. | —   |



| SHTNAK | Pipe disabled at end of transfer Note 1 |  |  |  |  |  |  |
|--------|-----------------------------------------|--|--|--|--|--|--|
| 0      | Pipe continued at the end of transfer R |  |  |  |  |  |  |
| 1      | Pipe disabled at the end of transfer    |  |  |  |  |  |  |

Specifies whether to modify PID to NAK upon the end of transfer when the selected pipe is in the receiving direction.

The SHTNAK bit is valid when the selected pipe is PIPE4 and PIPE5 in the receiving direction.

When software has set the SHTNAK bit to 1 for the selected pipe in the receiving direction, the USB module modifies the PID bits corresponding to the selected pipe to NAK on determining the end of the transfer. The USB module determines that the transfer has ended on any of the following conditions.

• A short packet (including a zero-length packet) is successfully received.

• The transaction counter is used and the number of packets specified by the counter are successfully received.

| Bits 6, 5 | Nothing is assigned                             | R/W |
|-----------|-------------------------------------------------|-----|
| _         | The write value must be 0. The read value is 0. |     |

| DIR           | Transfer direction Note 2, 3                            | R/W |  |  |  |  |
|---------------|---------------------------------------------------------|-----|--|--|--|--|
| 0             | Receiving direction                                     | R/W |  |  |  |  |
| 1             | Fransmitting direction                                  |     |  |  |  |  |
| Specifies the | Specifies the transfer direction for the selected pipe. |     |  |  |  |  |

When software has set the DIR bit to 0, the USB module uses the selected pipe in the receiving direction, and when software has set the DIR bit to 1, the USB module uses the selected pipe in the transmitting direction.

| EPNUM[3:0]                                                                                                      | Endpoint number Note 1                                                | R/W |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----|--|--|--|--|--|--|--|
| These bits specify the endpoint number for the selected pipe.                                                   |                                                                       |     |  |  |  |  |  |  |  |
| Setting 0000B means unused pipe.                                                                                |                                                                       |     |  |  |  |  |  |  |  |
| During function controller operation, do not allow the combination of the settings of the DIR and EPNUM bits to |                                                                       |     |  |  |  |  |  |  |  |
| be the same f                                                                                                   | or two or more pipes (EPNUM = 0000B can be set for all of the pipes). |     |  |  |  |  |  |  |  |

- Note 1. Modify the TYPE1 and TYPE0, SHTNAK, and EPNUM bits while PID is NAK. Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.
- Note 2. Modify the BFRE, DBLB, and DIR bits while PID is NAK and before the pipe is selected by the CURPIPE3 to CURPIPE0 bits. Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.
- **Note 3.** To modify the BFRE, DBLB, and DIR bits after completing USB communication using the selected pipe, write 1 and then 0 to ACLRM continuously through software to clear the FIFO buffer assigned to the selected pipe while the PID and CURPIPE bits are in the state described in the above note 2.



### **13.3.29** Pipe maximum packet size register (PIPEMAXP)

#### Figure 13 - 37 Format of Pipe Maximum Packet Size Register (PIPEMAXP)

| Address  | : F0460                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CH, F04     | 6DH                   | After                      | r reset: 0              | 000H     |                     |             |          |          |         |            |         |          |         |     |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------|----------------------------|-------------------------|----------|---------------------|-------------|----------|----------|---------|------------|---------|----------|---------|-----|
| Symbol   | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 14          | 13                    | 12                         | 11                      | 10       | 9                   | 8           | 7        | 6        | 5       | 4          | 3       | 2        | 1       | 0   |
| PIPEMAXP | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DEVSE<br>L2 | DEVSE<br>L1           | DEVSE<br>L0                | _                       | —        | —                   |             |          |          | Ν       | /IXPS[8:0  | )]      |          |         |     |
|          | Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 15          |                       |                            |                         |          |                     | Nothing     | n is as  | signed   |         |            |         |          |         | R/W |
|          | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | _           | The wri               | te valu                    | e must b                | e 0 T    | he read             |             |          | Jighida  |         |            |         |          |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                       |                            | o maor b                | 0 0. 1   | no road             |             |          |          |         |            |         |          |         |     |
|          | DEV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SEL2        | DEVS                  | EL1                        | DEVSEL0                 |          |                     |             |          | Device   | select  | Note 1     |         |          |         | R/W |
|          | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C           | 0                     |                            | 0                       |          | USB ad              | dress 00    | 0        |          |         |            |         |          |         | R/W |
|          | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C           | 0                     |                            | 1                       |          | USB ad              | dress 00    | 1        |          |         |            |         |          |         |     |
|          | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C           | 1                     |                            | 0                       |          | USB ad              | dress 01    | D        |          |         |            |         |          |         |     |
|          | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C           | 1                     |                            | 1                       |          | USB ad              | dress 01    | 1        |          |         |            |         |          |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1           | 0                     |                            | 0                       |          | USB ad              | dress 10    | 0        |          |         |            |         |          |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1           | 0                     |                            | 1                       |          | USB ad              | dress 10    | 1        |          |         |            |         |          |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0           | ther tha              | n above                    | е                       |          | Do not s            | et.         |          |          |         |            |         |          |         |     |
|          | When                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | the hos     | t control             | ler fund                   | ction is se             | electe   | d, the DE           | EVSEL2 t    | o DEV    | SEL0 bi  | ts spec | ify the U  | SB dev  | ice add  | ress of |     |
|          | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |                       |                            | s the cor               |          |                     | -           |          |          |         |            |         | _, ,     |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                       |                            | bits shou<br>be set i   |          |                     | -           |          |          |         |            | •       | , -      |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             | ld be set             |                            |                         | 11 1108  |                     |             | JIE, DE  | iore seu | ing the | DEVSE      |         | лотов,   |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                       |                            | function                | is sele  | ected, th           | ese bits :  | should   | be set t | o 000B  | -          |         |          |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                       |                            |                         |          |                     |             |          |          |         |            |         |          |         |     |
|          | Bits 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1 to 9      |                       |                            |                         |          | Nothing is assigned |             |          |          |         |            |         |          |         | R/W |
|          | — The write value must be 0. The read value is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |                       |                            |                         |          |                     |             |          |          |         |            | _       |          |         |     |
|          | MXP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | S[8:0]      |                       | Maximum packet size Note 2 |                         |          |                     |             |          |          |         |            | R/W     |          |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                       |                            | num data                |          |                     |             |          | ze).     |         |            |         |          |         | R/W |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -           |                       |                            | set for ea<br>H), 16 by |          |                     |             |          | 31 hytos | (0404)  | ) (Rite 19 | .71 and | [2:0] or | o not   |     |
|          | provid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |             | . o byte:             | 5 (0001                    | 1), 10 Dy               | 165 (0   | 1011), 52           | Dytes (U    | 2011), ( | 54 Dytes | (04011  | ) (Dits [C | o.rjanu | [2.0] ai | enot    |     |
|          | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             | ': 1 byte             | (001H)                     | ) to 64 by              | /tes (0  | 40H) (B             | its [8:7] a | re not   | provide  | d.)     |            |         |          |         |     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                       |                            | t to the a              |          |                     |             |          |          |         | d on the   | USB S   | pecifica | tions.  |     |
|          | While                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | the MX      | PS bits a             | are 0, d                   | lo not wr               | ite to t | he FIFO             | buffer or   | r set Pl | ID to BU | F.      |            |         |          |         |     |
|          | While the MXPS bits are 0, do not write to the FIFO buffer or set PID to BUF.         Note 1.       Modify the DEVSEL bits while PID is NAK and the SUREQ bit is 0. Before modifying these bits after modifying the PID bits for the DCP from BUF to NAK, check that PBUSY is 0. However, if the PID bits has been been been been been been been bee                                                                                                                                            |             |                       |                            |                         |          |                     |             |          |          |         |            |         |          |         |     |
|          | <ul> <li>been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.</li> <li>Note 2. Modify the MXPS bits while PID is NAK and before the pipe is selected by the CURPIPE bits.</li> <li>Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBU bit through software is not necessary.</li> </ul> |             |                       |                            |                         |          |                     |             |          |          | k that  |            |         |          |         |     |
|          | Cautio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |             | ie value<br>nen a pij |                            | PIPEMA                  |          | -                   | fter rese   | t diffe  | rs depe  | nding   | on whe     | n no pi | pe is se | elected | and |



### 13.3.30 Pipe cycle control register (PIPEPERI)

|          |                                                                                                                                                                                                         | F      | igure '    | 13 - 38   | Form     | at of P   | ipe Cy   | cle Co   | ontrol R  | legiste  | er (PIP            | EPERI    | )       |         |           |     |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|-----------|----------|-----------|----------|----------|-----------|----------|--------------------|----------|---------|---------|-----------|-----|
| Address  | F046E                                                                                                                                                                                                   | H, F04 | 6FH        | After     | reset: ( | 0000H     |          |          |           |          |                    |          |         |         |           |     |
| Symbol   | 15                                                                                                                                                                                                      | 14     | 13         | 12        | 11       | 10        | 9        | 8        | 7         | 6        | 5                  | 4        | 3       | 2       | 1         | 0   |
| PIPEPERI | —                                                                                                                                                                                                       | —      | —          | —         | —        | —         | —        | —        | —         | —        | —                  | —        | —       |         | IITV[2:0] |     |
|          | Bits 15                                                                                                                                                                                                 | to 13  |            |           |          |           |          | Nothir   | ng is ass | signed   |                    |          |         |         |           | R/W |
|          |                                                                                                                                                                                                         | -      | The wri    | te value  | e must l | be 0. Th  | e read   | value is | 0.        |          |                    |          |         |         |           | —   |
|          | Bit 12 Reserved                                                                                                                                                                                         |        |            |           |          |           |          | R/W      |           |          |                    |          |         |         |           |     |
|          |                                                                                                                                                                                                         | -      | The wri    | te value  | e must l | be 0. Th  | e read   | value is | 0.        |          |                    |          |         |         |           | —   |
|          | Bits 11                                                                                                                                                                                                 | 1 to 3 |            |           |          |           |          | Nothir   | ng is ass | signed   |                    |          |         |         |           | R/W |
|          |                                                                                                                                                                                                         | -      | The wri    | te value  | e must l | be 0. Th  | e read   | value is | 0.        |          |                    |          |         |         |           | —   |
|          | IITV[                                                                                                                                                                                                   | 2:0]   |            |           |          |           | Interva  | al error | detectio  | n interv | al <sup>Note</sup> |          |         |         |           | R/W |
|          | Specifi<br>power                                                                                                                                                                                        |        | interval e | error de  | tection  | timing f  | or the s | elected  | pipe in t | terms o  | f frame:           | s, which | is expr | essed a | as n-th   | R/W |
|          |                                                                                                                                                                                                         |        | the fund   | ctions, r | efer to  | 13.4.8 lı | nterrup  | t trans  | fers (PIF | PE6, PI  | <b>PE7)</b> .      |          |         |         |           |     |
|          | Before modifying the IITV[2:0] bits after USB communication has been completed with the IITV[2:0] bits set to a certain value, set PID to NAK and then set ACLRM to 1 to initialize the interval timer. |        |            |           |          |           |          |          |           |          |                    |          |         |         |           |     |
|          |                                                                                                                                                                                                         | ,      | bits are   |           |          |           |          |          | muanze    |          | arvar um           | сі.      |         |         |           |     |
|          |                                                                                                                                                                                                         |        | to 000B    |           |          |           |          |          |           |          |                    |          |         |         |           |     |
|          |                                                                                                                                                                                                         |        |            |           |          |           |          |          |           |          |                    |          |         |         |           | ·   |

**Note** Modify the IITV bits while PID is NAK. Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.



### 13.3.31 PIPEn control registers (PIPEnCTR) (n = 4 to 7)

#### Figure 13 - 39 Format of PIPEn Control Registers (PIPEnCTR) (n = 4, 5)

Address: F0476H, F0477H (PIPE4CTR), F0478H, F0479H (PIPE5CTR) After reset: 0000H

| Symbol | 15      | 14         | 13        | 12        | 11       | 10                   | 9         | 8         | 7          | 6                   | 5                      | 4         | 3         | 2        | 1          | 0    |  |
|--------|---------|------------|-----------|-----------|----------|----------------------|-----------|-----------|------------|---------------------|------------------------|-----------|-----------|----------|------------|------|--|
| PEnCTR | BSTS    | INBUF<br>M |           | —         | _        | ATREP<br>M           | ACLR<br>M | SQCL<br>R | SQSET      | SQMO<br>N           | PBUSY                  |           | _         | _        | PID1       | PID0 |  |
|        | BS      | TS         |           |           |          |                      |           | В         | uffer stat | us                  |                        |           |           |          |            | R/W  |  |
|        | 0       | )          | Buffer a  | access    | by the   | CPU is d             | isabled   |           |            |                     |                        |           |           |          |            | R    |  |
|        | 1       |            | Buffer a  | access    | by the   | CPU is e             | nabled.   |           |            |                     |                        |           |           |          |            |      |  |
|        |         |            |           |           |          | the relevands on the |           |           | e DIR, B   | FRE, ai             | nd DCLR                | M bits    | as sho    | wn in Ta | able 13    |      |  |
|        | INBL    | JFM        |           |           |          |                      |           | Transm    | it buffer  | monitor             |                        |           |           |          |            | R/W  |  |
|        | 0       | )          | There is  | s no da   | ta to be | e transmi            | tted in 1 | the buff  | er mem     | ory.                |                        |           |           |          |            | R    |  |
|        | 1       |            |           |           |          | ansmitteo            |           |           |            | -                   |                        |           |           |          |            |      |  |
|        | Indicat | es the     |           |           |          |                      |           |           |            |                     | ansmittir              | a dire    | ction.    |          |            |      |  |
|        |         |            |           |           |          |                      |           |           | • •        |                     | odule se               | •         |           | A bit to | 1 when     |      |  |
|        |         |            |           |           |          | t least or           |           | -         | -          |                     |                        |           |           |          |            |      |  |
|        | The US  | SB mod     | lule sets | the INE   | BUFM     | oit to 0 wl          | nen the   | USB m     | nodule co  | omplete             | s transm               | itting t  | he data   | from th  | e FIFO     |      |  |
|        |         |            |           |           |          | s been w             |           |           |            |                     |                        |           |           |          |            |      |  |
|        |         |            |           |           |          |                      |           |           |            |                     | 0 when                 |           |           |          |            |      |  |
|        |         | itting th  | ne data f | rom the   | e two Fl | FO buffe             | er plane  | s befor   | e softwa   | re comp             | oletes wr              | iting da  | ata to oi | ne FIFC  | ) buffer   |      |  |
|        | plane.  |            | hit india | otoo the  |          | voluo or             | the DC    | TO hit    | when th    | o rolova            | nt nina i              | o in the  | o rocoiv  | ina dira | otion      |      |  |
|        | (DIR =  |            |           |           | same     | value as             |           |           |            |                     | ant pipe i             | 5 111 110 | e leceiv  | ing une  | CUON       |      |  |
|        | ,       | ,          |           |           |          |                      |           |           |            |                     |                        |           |           |          |            |      |  |
|        | Bits 13 | 3 to 11    |           |           |          |                      |           | Nothi     | ng is ass  | signed              |                        |           |           |          |            | R/W  |  |
|        |         | -          | The wri   | ite value | e must   | be 0. Th             | e read v  | value is  | s 0.       |                     |                        |           |           |          |            | —    |  |
|        | ATRE    | EPM        |           |           |          |                      | Au        | uto resp  | oonse m    | ode <sup>Note</sup> | e 1                    |           |           |          |            | R/W  |  |
|        | 0       | )          | Auto re   | sponse    | is disa  | bled.                |           |           |            |                     |                        |           |           |          |            | R/W  |  |
|        | 1       |            | Auto re   | sponse    | is ena   | bled.                |           |           |            |                     |                        |           |           |          |            |      |  |
|        | Enable  | es or dis  | sables a  | uto resp  | ponse i  | node for             | the rele  | evant p   | ipe.       |                     |                        |           |           |          |            |      |  |
|        | When    | the fun    | ction cor | ntroller  | functio  | n is seled           | cted and  | d the re  | levant p   | ipe is fo           | or bulk tra            | ansfer,   | the AT    | REPM     | oit can    |      |  |
|        | be set  |            |           |           |          |                      |           |           |            |                     |                        |           |           |          |            |      |  |
|        |         |            |           |           |          |                      |           | •         |            |                     | om the L               | ISB ho    | st as de  | escribed | below.     |      |  |
|        | -       |            |           |           |          | N transfe            |           |           |            |                     |                        |           |           |          |            |      |  |
|        |         | AIREP      | 'M is 1 a | IND PID   | IS BUF   | , the US             | B modu    | le trans  | smits a z  | ero-len             | gth pack               | et in re  | esponse   | to the   | IN         |      |  |
|        | token.  | SB mor     | میں ماینا | atos (al  | lows to  | aalina of            | f) the se | auona     | e togale   | hit (DA             | ra-Pid) (              | aach ti   | ma tha    |          | odulo      |      |  |
|        |         |            |           |           |          |                      |           |           |            | -                   | ed, zero-              |           |           |          |            |      |  |
|        |         |            | is recei  |           |          | a anigio             |           |           | . tenerrit |                     |                        | .s.igui   | Paonol    |          |            |      |  |
|        |         |            |           | ,         | does     | not gene             | rate the  | BRDY      | or BEM     | P interr            | upt.                   |           |           |          |            |      |  |
|        |         |            |           |           |          | OUT trans            |           |           |            |                     |                        |           |           |          |            |      |  |
|        | -       |            |           |           |          |                      | •         |           |            |                     | onse to th             | e OUT     | r token   | and ger  | nerates    |      |  |
|        | the NR  | RDY inte   | errupt.   |           |          |                      |           |           |            |                     |                        |           |           |          |            |      |  |
|        |         |            |           |           |          | ponse m<br>selected  |           |           |            |                     | while the<br>bit to 0. | FIFO      | buffer i  | s empty  | <i>I</i> . |      |  |
|        |         |            |           |           |          |                      |           |           |            |                     |                        |           |           |          |            |      |  |



| ACLRM                                                                                                            | Auto buffer clear mode Note 2                                                                               | R/W |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| 0                                                                                                                | abled R/                                                                                                    |     |  |  |  |  |  |  |
| 1                                                                                                                | Enabled (all buffers are initialized)                                                                       |     |  |  |  |  |  |  |
| Enables or disables auto buffer clear mode for the relevant pipe.                                                |                                                                                                             |     |  |  |  |  |  |  |
| To delete the information in the FIFO buffer assigned to the relevant pipe completely, write 1 and then 0 to the |                                                                                                             |     |  |  |  |  |  |  |
| ACLRM bit continuously.                                                                                          |                                                                                                             |     |  |  |  |  |  |  |
| Table 13 - 9 s                                                                                                   | able 13 - 9 shows the information cleared by writing 1 and 0 to the ACLRM bit continuously and the cases in |     |  |  |  |  |  |  |

which clearing the information is necessary.

| S | SQCLR | Toggle bit clear Note 1 | R/W    |
|---|-------|-------------------------|--------|
|   | 0     | Invalid                 | R/W    |
|   | 1     | Specifies DATA0.        | Note 3 |
|   |       |                         |        |

The SQCLR bit should be set to 1 to clear the expected value (to set DATA0 as the expected value) of the sequence toggle bit for the next transaction of the relevant pipe.

Setting the SQCLR bit to 1 through software allows the USB module to set DATA0 as the expected value of the sequence toggle bit of the relevant pipe. The USB module always sets the SQCLR bit to 0.

| SQSET     | Toggle bit set <sup>Note 1</sup>                                                                  | R/W |  |  |  |  |
|-----------|---------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| 0         | Invalid                                                                                           | R/W |  |  |  |  |
| 1         | 1 Specifies DATA1.                                                                                |     |  |  |  |  |
| The SQSET | bit should be set to 1 to set DATA1 as the expected value of the sequence toggle bit for the next |     |  |  |  |  |

transaction of the relevant pipe.

Setting the SQSET bit to 1 through software allows the USB module to set DATA1 as the expected value of the sequence toggle bit of the relevant pipe. The USB module always sets the SQSET bit to 0.

| SQMON         | Toggle bit monitor                                                                      | R/W |
|---------------|-----------------------------------------------------------------------------------------|-----|
| 0             | DATAO                                                                                   | R   |
| 1             | DATA1                                                                                   |     |
| Indicates the | expected value of the sequence toggle bit for the next transaction of the relevant nine |     |

Indicates the expected value of the sequence toggle bit for the next transaction of the relevant pipe. The USB module allows the SQMON bit to toggle upon normal completion of the transaction of the relevant pipe. However, the SQMON bit is not allowed to toggle when a DATA-PID disagreement occurs during the transfer in the receiving direction.

| PBUSY | Pipe busy                                          | R/W |
|-------|----------------------------------------------------|-----|
| 0     | The relevant pipe is not used for the transaction. | R   |
| 1     | The relevant pipe is used for the transaction.     |     |

Indicates whether the relevant pipe is being currently used or not for the transaction.

The USB module modifies the PBUSY bit from 0 to 1 upon start of the USB transaction for the relevant pipe, and modifies the PBUSY bit from 1 to 0 upon completion of one transaction.

Reading the PBUSY bit after software has set PID to NAK allows checking whether modification of the pipe settings is possible.

For details, refer to 13.4.4.1 Pipe control register switching procedures.

| Bits 4 to 2 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| —           | The write value must be 0. The read value is 0. | _   |



| PID1 | PID0 | Response PID                                 | R/W |
|------|------|----------------------------------------------|-----|
| 0    | 0    | NAK response                                 | R/W |
| 0    | 1    | BUF response (depending on the buffer state) |     |
| 1    | 0    | STALL response                               |     |
| 1    | 1    | STALL response                               |     |

The PID1 and PID0 bits specify the response type for the next transaction of the relevant pipe. The default setting of the PID1 and PID0 bits is NAK. Modify the setting of these bits to BUF to use the relevant pipe for USB transfer. Tables 13 - 10 and 13 - 11 show the basic operation (operation when there are no errors in the transmitted and received packets) of the USB module depending on the PID bit setting.

After modifying the setting of the PID1 and PID0 bits through software from BUF to NAK during USB communication using the relevant pipe, check that PBUSY is 1 to see if USB transfer using the relevant pipe has actually entered the NAK state.

The USB module modifies the setting of the PID1 and PID0 bits in the following cases.

- The USB module sets PID to NAK on recognizing the completion of the transfer when the relevant pipe is in the receiving direction and software has set the SHTNAK bit for the selected pipe to 1.
- The USB module sets PID to STALL (11B) on receiving a data packet with a payload exceeding the maximum packet size of the relevant pipe.
- The USB module sets PID to NAK on detecting a USB bus reset when the function controller function is selected.
- The USB module sets PID to NAK on detecting a receive error, such as a CRC error, three consecutive times when the host controller function is selected.
- The USB module sets PID to STALL (11B) on receiving the STALL handshake when the host controller function is selected.

To specify each response type, set the PID1 and PID0 bits as follows.

- To make a transition from NAK (00B) to STALL, write 10B.
- To make a transition from BUF (01B) to STALL, write 11B.
- To make a transition from STALL (11B) to NAK, write 10B and then 00B.
- To make a transition from STALL to BUF, write 00B (NAK) and then 01B (BUF).
- Note 1. Modify the ATREPM bit or write 1 to the SQCLR or SQSET bit while PID is NAK. Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.
- Note 2. Modify the ATREPM bit while PID is NAK and before the pipe is selected by the CURPIPE bits. Before modifying this bit after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.
- Note 3. Only 0 can be read and 1 can be written.



| DIR Bit | BFRE Bit | DCLRM Bit | BSTS Bit Function                                                                                                                                                      |
|---------|----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | 0        | 0         | 1 when the received data can be read from the FIFO buffer; 0 when the received data has been completely read from the FIFO buffer.                                     |
|         |          | 1         | Setting prohibited                                                                                                                                                     |
|         | 1        | 0         | 1 when the received data can be read from the FIFO buffer; 0 when software has set<br>BCLR to 1 after the received data has been completely read from the FIFO buffer. |
|         |          | 1         | 1 when the received data can be read from the FIFO buffer; 0 when the received data has been completely read from the FIFO buffer.                                     |
| 1       | 0        | 0         | 1 when the transmit data can be written to the FIFO buffer; 0 when the transmit data has been completely written to the FIFO buffer.                                   |
|         |          | 1         | Setting prohibited                                                                                                                                                     |
|         | 1        | 0         | Setting prohibited                                                                                                                                                     |
|         |          | 1         | Setting prohibited                                                                                                                                                     |

Table 13 - 8 Operation of BSTS Bit

| No. | Information Cleared by ACLRM Bit Manipulation                                                                                                  | Cases in which Clearing Information is Necessary           |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| 1   | All the information in the FIFO buffer assigned to the relevant pipe (both FIFO buffer planes are cleared when double buffer mode is selected) |                                                            |
| 2   | Internal flags concerning the BFRE bit                                                                                                         | When the BFRE setting is modified                          |
| 3   | FIFO buffer toggle control                                                                                                                     | When the DBLB setting is modified                          |
| 4   | Internal flags concerning the transaction count                                                                                                | When the transaction count function is forcibly terminated |

#### Table 13 - 10 Operation of USB Module depending on PID Bit Setting (When Host Controller Function is Selected)

| PID Bits<br>(PID1 and PID0) | Transfer Type                             | Transfer Direction<br>(DIR Bit)              | Operation of USB Module                                                                                                                                                                                                                                                              |
|-----------------------------|-------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00 (NAK)                    | Operation does not depend on the setting. | Operation does not depend on the setting.    | Does not issue tokens.                                                                                                                                                                                                                                                               |
| 01 (BUF)                    | Bulk or interrupt                         | Operation does not<br>depend on the setting. | Issues tokens while UACT is 1 and the FIFO buffer<br>corresponding to the relevant pipe is ready for<br>transmission and reception.<br>Does not issue tokens while UACT is 0 or the FIFO<br>buffer corresponding to the relevant pipe is not ready<br>for transmission or reception. |
| 10 (STALL) or 11<br>(STALL) | Operation does not depend on the setting. | Operation does not depend on the setting.    | Does not issue tokens.                                                                                                                                                                                                                                                               |



|                             | (When Function Controller Function is Deletered) |                                           |                                                                                                                                                                     |  |  |  |  |
|-----------------------------|--------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| PID Bits<br>(PID1 and PID0) | Transfer Type                                    | Transfer Direction<br>(DIR Bit)           | Operation of USB Module                                                                                                                                             |  |  |  |  |
| 00 (NAK)                    | Bulk or interrupt                                | Operation does not depend on the setting. | Returns NAK in response to the token from the USB<br>host<br>For the operation when ATREPM is 1, refer to the<br>description of the ATREPM bit.                     |  |  |  |  |
| 01 (BUF)                    | Bulk                                             | Receiving direction<br>(DIR = 0)          | Receives data and returns ACK in response to the OUT token from the USB host if the FIFO buffer corresponding to the relevant pipe is ready for reception.          |  |  |  |  |
|                             | Interrupt                                        | Receiving direction<br>(DIR = 0)          | Receives data and returns ACK in response to the<br>OUT token from the USB host if the FIFO buffer<br>corresponding to the relevant pipe is ready for<br>reception. |  |  |  |  |
|                             | Bulk or interrupt                                | Transmitting direction<br>(DIR = 1)       | Transmits data in response to the token from the USB host if the corresponding FIFO buffer is ready for transmission. Returns NAK if not ready.                     |  |  |  |  |
| 10 (STALL) or<br>11 (STALL) | Bulk or interrupt                                | Operation does not depend on the setting. | Returns STALL in response to the token from the USB host.                                                                                                           |  |  |  |  |

# Table 13 - 11 Operation of USB Module depending on PID Bit Setting (When Function Controller Function is Selected)

#### Figure 13 - 40 Format of PIPEn Control Registers (PIPEnCTR) (n = 6, 7)

Address: F047AH, F047BH (PIPE6CTR), F047CH, F047DH (PIPE7CTR) After reset: 0000H

| Symbol   | 15   | 14 | 13 | 12 | 11 | 10 | 9         | 8         | 7     | 6         | 5     | 4 | 3 | 2 | 1    | 0    |
|----------|------|----|----|----|----|----|-----------|-----------|-------|-----------|-------|---|---|---|------|------|
| PIPEnCTR | BSTS | _  | _  | _  | _  |    | ACLR<br>M | SQCL<br>R | SQSET | SQMO<br>N | PBUSY | _ | _ | _ | PID1 | PID0 |
|          |      |    |    |    |    |    |           |           |       |           |       |   |   |   |      |      |

| BSTS          | Buffer status                                                                                  | R/W |
|---------------|------------------------------------------------------------------------------------------------|-----|
| 0             | Buffer access by the CPU is disabled.                                                          | R   |
| 1             | Buffer access by the CPU is enabled.                                                           |     |
| Indicates the | FIFO buffer status for the relevant pipe.                                                      |     |
| The meaning   | of the BSTS bit depends on the settings of the DIR, BFRE, and DCLR bits as shown in Table 13 - |     |
| 8.            |                                                                                                |     |

| Bits 14 to 10 | Nothing is assigned                             | R/W |
|---------------|-------------------------------------------------|-----|
| _             | The write value must be 0. The read value is 0. | —   |

| ACLRM          | Auto buffer clear mode <sup>Note 1</sup>                                                                         |     |  |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| 0              | Auto buffer clear mode is disabled.                                                                              | R/W |  |  |  |  |
| 1              | Auto buffer clear mode is enabled (all buffers are initialized)                                                  |     |  |  |  |  |
| Enables or di  | Enables or disables auto buffer clear mode for the relevant pipe.                                                |     |  |  |  |  |
| To delete the  | To delete the information in the FIFO buffer assigned to the relevant pipe completely, write 1 and then 0 to the |     |  |  |  |  |
| ACLRM bit co   | ontinuously.                                                                                                     |     |  |  |  |  |
| Table 13 - 12  | shows the information cleared by writing 1 and 0 to the ACLRM bit continuously and the cases in                  |     |  |  |  |  |
| which clearing | which clearing the information is necessary.                                                                     |     |  |  |  |  |



| SQCLR     | Toggle bit clear Note 2                                                                        | R/W    |
|-----------|------------------------------------------------------------------------------------------------|--------|
| 0         | Invalid                                                                                        | R/W    |
| 1         | Specifies DATA0.                                                                               | Note 3 |
| The SQCLR | bit should be set to 1 to clear the expected value (to set DATA0 as the expected value) of the |        |

sequence toggle bit for the next transaction of the relevant pipe. Setting the SQCLR bit to 1 through software allows the USB module to set DATA0 as the expected value of the

sequence toggle bit of the relevant pipe. The USB module always sets the SQCLR bit to 0.

| SQSET | Toggle bit set Note 2 | R/W    |
|-------|-----------------------|--------|
| 0     | Invalid               | R/W    |
| 1     | Specifies DATA1.      | Note 3 |

The SQSET bit should be set to 1 to set DATA1 as the expected value of the sequence toggle bit for the next transaction of the relevant pipe.

Setting the SQSET bit to 1 through software allows the USB module to set DATA1 as the expected value of the sequence toggle bit of the relevant pipe. The USB module always sets the SQSET bit to 0.

|   | SQMON | Toggle bit monitor | R/W |
|---|-------|--------------------|-----|
| ſ | 0     | DATA0              | R   |
|   | 1     | DATA1              |     |

Indicates the value of the sequence toggle bit for the next transaction of the relevant pipe.

When the relevant pipe is not for the isochronous transfer, the USB module allows the SQMON bit to toggle upon normal completion of the transaction of the relevant pipe. However, the SQMON bit is not allowed to toggle when a DATA-PID disagreement occurs during the transfer in the receiving direction.

| PBUSY                                                                                                          | Pipe busy                                            |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|--|--|--|--|
| 0                                                                                                              | 0 The relevant pipe is not used for the transaction. |  |  |  |  |  |  |  |
| 1                                                                                                              | 1 The relevant pipe is used for the transaction.     |  |  |  |  |  |  |  |
| Indicates whether the relevant pipe is being currently used or not for the transaction.                        |                                                      |  |  |  |  |  |  |  |
| The USB module modifies the PBUSY bit from 0 to 1 upon start of the USB transaction for the relevant pipe, and |                                                      |  |  |  |  |  |  |  |
| modifies the PBUSY bit from 1 to 0 upon completion of one transaction.                                         |                                                      |  |  |  |  |  |  |  |

Reading the PBUSY bit after software has set PID to NAK allows checking whether modification of the pipe settings is possible. For details, refer to **13.4.4.1 Pipe control register switching procedures**.

| Bits 4 to 2 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| —           | The write value must be 0. The read value is 0. | _   |



| PID1                          | PID0            | Response PID                                                                           | R/V |
|-------------------------------|-----------------|----------------------------------------------------------------------------------------|-----|
| 0                             | 0               | NAK response                                                                           | R/V |
| 0                             | 1               | BUF response (depending on the buffer state)                                           |     |
| 1                             | 0               | STALL response                                                                         |     |
| 1                             | 1               | STALL response                                                                         |     |
| The PID1 an                   | d PID0 bits sp  | ecify the response type for the next transaction of the relevant pipe.                 |     |
| The default s                 | etting of the F | PID1 and PID0 bits is NAK. Modify the setting of these bits to BUF to use the relevant |     |
| pipe for USB                  | transfer. Tabl  | es 13 - 10 and 13 - 11 show the basic operation (operation when there are no errors    |     |
| in the transm                 | itted and rece  | ived packets) of the USB module depending on the PID bit setting.                      |     |
| After modifyi                 | ng the setting  | of the PID1 and PID0 bits through software from BUF to NAK during USB                  |     |
| communicati                   | on using the re | elevant pipe, check that PBUSY is 1 to see if USB transfer using the relevant pipe has |     |
| actually ente                 | red the NAK s   | tate.                                                                                  |     |
| The USB mo                    | dule modifies   | the setting of the PID1 and PID0 bits in the following cases.                          |     |
| The USB m                     | odule sets Pl   | D to NAK on recognizing the completion of the transfer when the relevant pipe is in    |     |
| the receivir                  | g direction an  | d software has set the SHTNAK bit for the selected pipe to 1.                          |     |
| The USB m                     | odule sets Pl   | D to STALL (11B) on receiving a data packet with a payload exceeding the maximum       |     |
| packet size                   | of the relevar  | nt pipe.                                                                               |     |
|                               | odule sets Pl   | D to NAK on detecting a USB bus reset when the function controller function is         |     |
| selected.                     |                 |                                                                                        |     |
|                               |                 | D to NAK on detecting a receive error, such as a CRC error, three consecutive times    |     |
|                               |                 | function is selected.                                                                  |     |
|                               |                 | D to STALL (11B) on receiving the STALL handshake when the host controller             |     |
| function is                   | selected.       |                                                                                        |     |
| To specify ea                 | ch response t   | ype, set the PID1 and PID0 bits as follows.                                            |     |
| <ul> <li>To make a</li> </ul> | transition from | NAK (00B) to STALL, write 10B.                                                         |     |
| To make a                     | transition from | BUF (01B) to STALL, write 11B.                                                         |     |
| • To make a                   | transition from | STALL (11B) to NAK, write 10B and then 00B.                                            |     |
|                               |                 | STALL to BUF, write 00B (NAK) and then 01B (BUF).                                      | 1   |

- Note 1. Modify the ACLRM bit while PID is NAK and before the pipe is selected by the CURPIPE bits. Before modifying this bit after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.
- **Note 2.** Write 1 to the SQCLR or SQSET bit while PID is NAK. Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.
- Note 3. Only 0 can be read and 1 can be written.

| No. | Information Cleared by ACLRM Bit Manipulation                                                                          | Cases in which Clearing Information is Necessary           |
|-----|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| 1   | All the information in the FIFO buffer assigned to the selected pipe                                                   |                                                            |
| 2   | The interval count value when the selected pipe is for interrupt transfer and the host controller function is selected | When the interval count value is to be reset               |
| 3   | Internal flags concerning the BFRE bit                                                                                 | When the BFRE setting is modified                          |
| 4   | Internal flags concerning the transaction count                                                                        | When the transaction count function is forcibly terminated |

#### Table 13 - 12 Information Cleared by USB Module by Setting ACLRM = 1

### 13.3.32 PIPEn transaction counter enable registers (PIPEnTRE) (n = 4, 5)

#### Figure 13 - 41 Format of PIPEn Transaction Counter Enable Registers (PIPEnTRE) (n = 4, 5)

Address: F049CH, F049DH (PIPE4TRE), F04A0H, F04A1H (PIPE5TRE) After reset: 0000H

| bol                               | 15                 | 14                                                                                                                                                                                              | 13        | 12                                              | 11        | 10         | 9        | 8         | 7         | 6        | 5        | 4        | 3         | 2           | 1       | 0   |
|-----------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------------------|-----------|------------|----------|-----------|-----------|----------|----------|----------|-----------|-------------|---------|-----|
| RE                                | _                  | —                                                                                                                                                                                               | —         | —                                               | —         | —          | TRENE    | TRCLR     | _         | _        | —        | —        | —         | —           | —       | —   |
| Bits 15 to 10 Nothing is assigned |                    |                                                                                                                                                                                                 |           |                                                 |           |            |          |           |           |          |          | R/W      |           |             |         |     |
| ľ                                 | _                  | _                                                                                                                                                                                               | The wr    | The write value must be 0. The read value is 0. |           |            |          |           |           |          |          |          |           |             |         | —   |
| [                                 | TRE                | TRENB Transaction counter enable F                                                                                                                                                              |           |                                                 |           |            |          |           |           |          |          |          |           | R/W         |         |     |
| ľ                                 | (                  | )                                                                                                                                                                                               | Transa    | ction co                                        | unter is  | disable    | ed.      |           |           |          |          |          |           |             |         | R/W |
| ľ                                 | 1                  |                                                                                                                                                                                                 | Transa    | ction co                                        | ounter is | enable     | ed.      |           |           |          |          |          |           |             |         |     |
| ľ                                 | Enable             | es or di                                                                                                                                                                                        | sables th | ne trans                                        | action    | counter.   |          |           |           |          |          |          |           |             |         |     |
|                                   | For the            | e pipe ii                                                                                                                                                                                       | n the red | ceiving o                                       | direction | n, settin  | g the TI | RENB bi   | t to 1 af | ter sett | ing the  | total nu | mber of   | the pac     | kets to |     |
|                                   | be rec             | eived ir                                                                                                                                                                                        | the TR    |                                                 | oits thro | ugh sof    | tware a  | llows the | USB r     | nodule   | to contr | ol hard  | ware as   | describ     | bed     |     |
|                                   | below              | on hav                                                                                                                                                                                          | ing rece  | ived the                                        | e numbe   | er of page | ckets ec | ual to th | e settin  | g of the | e TRNC   | NT bits  |           |             |         |     |
|                                   |                    |                                                                                                                                                                                                 |           |                                                 |           |            |          | PID bits  |           |          |          | spondin  | g pipe o  | on havin    | ng      |     |
|                                   |                    |                                                                                                                                                                                                 |           | •                                               |           |            |          | DY interr |           |          |          | the nu   | mber of   | -<br>packet | s equal |     |
|                                   |                    |                                                                                                                                                                                                 |           |                                                 |           |            |          | g out the | •         | •        |          |          |           | puonot      | oquu    |     |
|                                   | For the            | e pipe i                                                                                                                                                                                        | n the tra | nsmittin                                        | ng direc  | tion, set  | the TR   | ENB bit   | to 0.     |          |          |          |           |             |         |     |
|                                   |                    | • •                                                                                                                                                                                             |           |                                                 | •         |            |          | RENB b    |           |          |          |          |           |             |         |     |
|                                   |                    |                                                                                                                                                                                                 |           |                                                 |           |            |          |           |           | setting  | the TR   | ENB bit  | to 1. S   | et the T    | RENB    |     |
|                                   |                    | When the transaction counter is used, set the TRNCNT bits before setting the TRENB bit to 1. Set the TRENB bit to 1 before receiving the first packet to be counted by the transaction counter. |           |                                                 |           |            |          |           |           |          |          |          |           |             |         |     |
| ſ                                 | TRO                | CLR                                                                                                                                                                                             |           |                                                 |           |            | Т        | ransacti  | on cour   | nter cle | ar       |          |           |             |         | R/W |
| ľ                                 | (                  | )                                                                                                                                                                                               | Invalid   |                                                 |           |            |          |           |           |          |          |          |           |             |         | R/W |
| ŀ                                 | 1                  |                                                                                                                                                                                                 | The cu    | rrent co                                        | unter v   | alue is o  | leared.  |           |           |          |          |          |           |             |         | 1   |
| ·                                 | Clears<br>bit to 0 |                                                                                                                                                                                                 | rrent val | ue of th                                        | e transa  | action c   | ounter o | correspo  | nding to  | o the re | levant p | pipe and | l then so | ets the 1   | TRCLR   |     |

| Bits 7 to 0 | Nothing is assigned                             | R/W |
|-------------|-------------------------------------------------|-----|
| —           | The write value must be 0. The read value is 0. | _   |

Caution Modify each bit in the PIPEnTRE register while CSST is 1 and PID is NAK.

Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that PBUSY is 0. However, if the PID bits have been modified to NAK by the USB module, checking the PBUSY bit through software is not necessary.



### 13.3.33 PIPEn transaction counter registers (PIPEnTRN) (n = 4, 5)

#### Figure 13 - 42 Format of PIPEn Transaction Counter Registers (PIPEnTRN) (4, 5)

Address: F049EH, F049FH (PIPE4TRN), F04A2H, F04A3H (PIPE5TRN) After reset: 0000H

Symbol 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

PIPEnTRN

TRNCNT[15:0]

| TRNCNT[15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Transaction counter                                                                 | R/W |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----|
| [When written to]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                     | R/W |
| Specifies the number of tra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ansactions.                                                                         |     |
| [When read from]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                     |     |
| Indicates the specified nur                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | nber of transactions if TRENB is 0.                                                 |     |
| Indicates the number of cu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | irrently counted transactions if TRENB is 1.                                        |     |
| The USB module increment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | nts the value of the TRNCNT bits by one when all of the following conditions are    |     |
| satisfied on receiving the p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | packet.                                                                             |     |
| • TRENB = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |     |
| <ul> <li>(TRNCNT set value ≠ cu</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | rrent counter value + 1) on receiving the packet.                                   |     |
| The payload of the received of the receiv | ved packet agrees with the setting of the MXPS bits.                                |     |
| The USB module clears th                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | e value of the TRNCNT bits to 0 when any of the following conditions are satisfied. |     |
| (1) All of the following cond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ditions are satisfied.                                                              |     |
| • TRENB = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |     |
| <ul> <li>(TRNCNT set value = cu</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | rrent counter value + 1) on receiving the packet.                                   |     |
| The payload of the received of the receiv | ved packet agrees with the setting of the MXPS bits.                                |     |
| (2) All of the following cond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ditions are satisfied.                                                              |     |
| • TRENB = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |     |
| The USB module has rec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | •                                                                                   |     |
| (3) All of the following cond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ditions are satisfied.                                                              |     |
| • TRENB = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |     |
| Software has set the TR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | CLR bit to 1.                                                                       |     |
| For the pipe in the transmi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | tting direction, set the TRNCNT bits to 0.                                          |     |
| When the transaction cour                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | nter is not used, set the TRNCNT bits to 0.                                         |     |
| Setting the number of trans                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | sactions to be transferred to the TRNCNT bits is only enabled when the TRENB bit in |     |
| the PIPEnTRE register is (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0. To modify the number of transactions to be transferred, set the TRCLR bit in the |     |
| PIPEnTRE register to 1 (to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | o clear the current counter value) before setting TRENB to 1.                       |     |



## 13.3.34 BC control register n (USBBCCTRLn) (n = 0, 1)

| Figure 13 - 43 Format of BC Control Register 0 (USBBCCTRL0) |                    |  |  |  |  |  |  |
|-------------------------------------------------------------|--------------------|--|--|--|--|--|--|
| Address: F04B0H, F04B1H                                     | After reset: 0000H |  |  |  |  |  |  |

| Symbol    | 15                                                                                                                                                                                                                                                                                                                                                | 14                                                                                                                                                                                                                                                                                                                                   | 13       | 12         | 11      | 10        | 9             | 8                  | 7            | 6            | 5        | 4             | 3            | 2             | 1            | 0          |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|---------|-----------|---------------|--------------------|--------------|--------------|----------|---------------|--------------|---------------|--------------|------------|
| SBBCCTRL0 |                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                      | _        | _          | _       |           | PDDET<br>STS0 | CHGD<br>ETST<br>S0 | BATCH<br>GE0 | DCPM<br>ODE0 |          | IDPSIN<br>KE0 | VDPS<br>RCE0 | IDMSI<br>NKE0 | IDPSR<br>CE0 | RPDM<br>E0 |
|           | Bits 1                                                                                                                                                                                                                                                                                                                                            | 5 to 10                                                                                                                                                                                                                                                                                                                              |          |            |         |           |               | Nothi              | ng is as     | signed       |          |               |              |               |              | R/W        |
|           | -                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                      | The w    | /rite valu | ue mus  | t be 0. 1 | The read      | d value            | is 0.        |              |          |               |              |               |              | —          |
|           | PDDE                                                                                                                                                                                                                                                                                                                                              | TSTS0                                                                                                                                                                                                                                                                                                                                |          |            |         | Vdp_      | SRC (0.6      | 3 V) inp           | ut detec     | tion flag    | g for UD | P0 pin        |              |               |              | R/W        |
|           |                                                                                                                                                                                                                                                                                                                                                   | 0 Not detected                                                                                                                                                                                                                                                                                                                       |          |            |         |           |               |                    |              |              |          |               | R            |               |              |            |
|           |                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                    | Detec    | ted        |         |           |               |                    |              |              |          |               |              |               |              |            |
|           | (Detec<br>To use<br>receive                                                                                                                                                                                                                                                                                                                       | tects VDP_SRC (0.6 V) is applied to the UDP0 pin from the connected device.<br>etects that the voltage applied to UDP0 is in the range of VDAT_REF to VIH (UDP0).)<br>use this bit for detection, set the CNEN bit (bit 8) in the SYSCFG register to 1, and enable the single end<br>eever of USB port 0.<br>Id when IDPSINKE0 is 1. |          |            |         |           |               |                    |              |              |          |               |              |               |              |            |
|           | CHGD                                                                                                                                                                                                                                                                                                                                              | ETSTS0                                                                                                                                                                                                                                                                                                                               |          |            |         | Vdm       | SRC (0.6      | 3 V) inp           | ut detec     | tion flac    | a for UD | M0 pin        |              |               |              | R/W        |
|           |                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                    | Not de   | etected    |         |           |               | , .                |              |              |          |               |              |               |              | R          |
|           |                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                    | Detec    | ted        |         |           |               |                    |              |              |          |               |              |               |              |            |
|           | Detects VDM_SRC (0.6 V) is applied to the UDM0 pin from the connected device.<br>(Detects that the voltage applied to UDM0 is in the range of VDAT_REF to VIH (UDM0).)<br>To use this bit for detection, set the CNEN bit (bit 8) in the SYSCFG register to 1, and enable the single end<br>receiver of USB port 0.<br>Valid when IDMSINKE0 is 1. |                                                                                                                                                                                                                                                                                                                                      |          |            |         |           |               |                    |              |              |          |               |              |               |              |            |
|           | BATC                                                                                                                                                                                                                                                                                                                                              | HGE0                                                                                                                                                                                                                                                                                                                                 |          |            |         | USB po    | ort 0 BC      | connec             | tion det     | tection      | operatio | n enabl       | е            |               |              | R/W        |
|           | -                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                    | Opera    | ation dis  |         | P         |               |                    |              |              |          |               |              |               |              | R/W        |
|           |                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                    |          | ation en   |         |           |               |                    |              |              |          |               |              |               |              |            |
|           |                                                                                                                                                                                                                                                                                                                                                   | this bit is<br>CE0 is v                                                                                                                                                                                                                                                                                                              | s set to | enable     | d, each |           | -             |                    |              |              |          | SINKE0,       | IDMSI        | NKE0, a       | and          |            |

| DCPMODE0                                                                                                                                      | Dedicated charging port resistor connection control for UDP0/UDM0 pins | R/W |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----|--|--|--|--|--|
| 0                                                                                                                                             | Resistor disabled                                                      | R/W |  |  |  |  |  |
| 1                                                                                                                                             | 1 Resistor enabled                                                     |     |  |  |  |  |  |
| Connects the resistor (RDCP_DAT) between the UDP0 and UDM0 pins used for the host (dedicated charging port) BC connection detection function. |                                                                        |     |  |  |  |  |  |

| VDMSRCE0                     | UDM0 pin VDM_SRC (0.6 V) output control |  |  |  |  |  |  |
|------------------------------|-----------------------------------------|--|--|--|--|--|--|
| 0                            | VDM_SRC output disabled                 |  |  |  |  |  |  |
| 1                            | VDM_SRC output enabled (0.6 V output)   |  |  |  |  |  |  |
| Controls the VDM_SRC output. |                                         |  |  |  |  |  |  |



| IDPSINKE0                                                                                                          | UDP0 pin VDP_SRC (0.6 V) input detection (comparator and sink) control | R/W |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| 0                                                                                                                  | UDP0 pin (0.6 V) input detection disabled                              | R/W |  |  |  |  |  |  |
| 1                                                                                                                  | UDP0 pin (0.6 V) input detection enabled                               |     |  |  |  |  |  |  |
| Controls the IDP_SINK (sink current) used for the 0.6 V input detection circuit (comparator) and detection for the |                                                                        |     |  |  |  |  |  |  |
| UDP0 pin.                                                                                                          |                                                                        |     |  |  |  |  |  |  |

| VDPSRCE0                     | UDP0 pin VDP_SRC (0.6 V) output control | R/W |  |  |  |  |
|------------------------------|-----------------------------------------|-----|--|--|--|--|
| 0                            | VDP_SRC output disabled                 | R/W |  |  |  |  |
| 1                            | VDP_SRC output enabled (0.6 V output)   |     |  |  |  |  |
| Controls the VDP_SRC output. |                                         |     |  |  |  |  |

| IDMSINKE0                                                                                                          | UDM0 pin VDM_SRC (0.6 V) input detection (comparator and sink) control | R/W |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| 0                                                                                                                  | DM0 pin (0.6 V) input detection disabled R/                            |     |  |  |  |  |  |  |
| 1                                                                                                                  | UDM0 pin (0.6 V) input detection enabled                               |     |  |  |  |  |  |  |
| Controls the IDM_SINK (sink current) used for the 0.6 V input detection circuit (comparator) and detection for the |                                                                        |     |  |  |  |  |  |  |
| UDM0 pin.                                                                                                          |                                                                        |     |  |  |  |  |  |  |

| Γ | IDPSRCE0                     | UDP0 pin IDP_SRC (10 µA) output control |  |  |  |  |  |
|---|------------------------------|-----------------------------------------|--|--|--|--|--|
|   | 0                            | PP_SRC output disabled R                |  |  |  |  |  |
|   | 1                            | IDP_SRC output enabled (10 µA output)   |  |  |  |  |  |
|   | Controls the IDP_SRC output. |                                         |  |  |  |  |  |

| RPDME0                                                          | UDM0 pull-down control | R/W |  |  |  |  |
|-----------------------------------------------------------------|------------------------|-----|--|--|--|--|
| 0                                                               | Pulling down disabled  | R/W |  |  |  |  |
| 1                                                               | Pulling down enabled   |     |  |  |  |  |
| Only the UDM0 pin can be pulled down (RPD) by setting this bit. |                        |     |  |  |  |  |



| Address:   | F04B4                                                                                                                                                                                                                                                                                                                                              | 4H, F04E               | 85H    | After     | reset: (  | 000H    |               |                                       |              |              |           |               |              |               |              |            |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------|-----------|-----------|---------|---------------|---------------------------------------|--------------|--------------|-----------|---------------|--------------|---------------|--------------|------------|
| Symbol     | 15                                                                                                                                                                                                                                                                                                                                                 | 14                     | 13     | 12        | 11        | 10      | 9             | 8                                     | 7            | 6            | 5         | 4             | 3            | 2             | 1            | 0          |
| JSBBCCTRL1 | _                                                                                                                                                                                                                                                                                                                                                  | _                      | _      | _         | _         | _       | PDDET<br>STS1 | CHGD<br>ETST<br>S1                    | BATCH<br>GE1 | DCPM<br>ODE1 |           | IDPSIN<br>KE1 | VDPS<br>RCE1 | IDMSI<br>NKE1 | IDPSR<br>CE1 | RPDM<br>E1 |
|            | Bits 1                                                                                                                                                                                                                                                                                                                                             | 5 to 10                |        |           |           |         |               | Nothi                                 | ng is as     | signed       |           |               |              |               |              | R/W        |
|            | -                                                                                                                                                                                                                                                                                                                                                  |                        | The w  | /rite val | ue must   | be 0.   | The read      | d value                               | is 0.        |              |           |               |              |               |              | —          |
|            | PDDE                                                                                                                                                                                                                                                                                                                                               | TSTS1                  |        |           |           | VDP     | _SRC (0.      | 6 V) inp                              | ut detec     | tion flag    | g for UD  | P1 pin        |              |               |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 0                      | Not de | etected   |           |         |               |                                       |              |              |           |               |              |               |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 1                      | Detec  | ted       |           |         |               |                                       |              |              |           |               |              |               |              |            |
|            | Detects VDP_SRC (0.6 V) is applied to the UDP1 pin from the connected device.<br>(Detects that the voltage applied to UDP1 is in the range of VDAT_REF to VIH (UDP1).)<br>To use this bit for detection, set the CNEN bit (bit 8) in the SYSCFG1 register to 1, and enable the single end<br>receiver of USB port 1.<br>Valid when IDPSINKE1 is 1. |                        |        |           |           |         |               |                                       |              |              |           |               |              |               |              |            |
|            | CHGDETSTS1 VDM SRC (0.6 V) input detection flag for UDM1 pin                                                                                                                                                                                                                                                                                       |                        |        |           |           |         |               |                                       |              |              |           |               |              | R/W           |              |            |
|            |                                                                                                                                                                                                                                                                                                                                                    | 0                      |        | etected   |           | , Dill  | _0.100 (01.   | , , , , , , , , , , , , , , , , , , , |              |              | ,         | p             |              |               |              | R          |
|            |                                                                                                                                                                                                                                                                                                                                                    | 1                      | Detec  | ted       |           |         |               |                                       |              |              |           |               |              |               |              |            |
|            | (Detects that the voltage applied to UDM1 is in the range of VDAT_REF to VIH (UDM1).)<br>To use this bit for detection, set the CNEN bit (bit 8) in the SYSCFG register to 1, and enable the single end<br>receiver of USB port 1.<br>Valid when IDMSINKE1 is 1.                                                                                   |                        |        |           |           |         |               |                                       |              |              |           |               | end          |               |              |            |
|            |                                                                                                                                                                                                                                                                                                                                                    | CHGE1                  |        |           |           |         |               |                                       |              |              |           |               |              |               | R/W          |            |
|            |                                                                                                                                                                                                                                                                                                                                                    | 0                      |        |           |           |         |               |                                       |              |              |           |               | R/W          |               |              |            |
|            | 1         Operation enabled           When this bit is set to enabled, each bit setting of VDMSRCE1, IDPSINKE1 is valid BC connection detection can be operated via USB port 1.                                                                                                                                                                    |                        |        |           |           |         |               |                                       |              |              |           |               |              |               |              |            |
|            | DCPN                                                                                                                                                                                                                                                                                                                                               | MODE1                  |        | D         | edicated  | d charg | ing port      | resisto                               | conne        | ction co     | ntrol for | UDP1/         | UDM1 p       | oins          |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 0                      | Resis  | tor disa  | bled      |         |               |                                       |              |              |           |               |              |               |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 1                      | Resis  | tor ena   | bled      |         |               |                                       |              |              |           |               |              |               |              |            |
|            |                                                                                                                                                                                                                                                                                                                                                    | ects the r<br>BC conne |        | • –       | . ,       |         | the UDF       | 1 and l                               | JDM1 pi      | ns used      | for the   | host (d       | edicate      | d charg       | ing          |            |
|            | VDM                                                                                                                                                                                                                                                                                                                                                | SRCE1                  |        |           |           | l       | JDM1 p        | n VDM_                                | SRC (0.6     | 6 V) out     | put cont  | rol           |              |               |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 0                      | VDM_   | SRC out   | put disa  | bled    |               |                                       |              |              |           |               |              |               |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 1                      | VDM_   | SRC out   | put ena   | bled (0 | .6 V out      | put)                                  |              |              |           |               |              |               |              |            |
|            | Contro                                                                                                                                                                                                                                                                                                                                             | ols the Vi             | OM_SRC | output    | •         |         |               |                                       |              |              |           |               |              |               |              |            |
|            | IDPS                                                                                                                                                                                                                                                                                                                                               | INKE1                  |        | U         | IDP1 pir  |         | SRC (0.6      | V) inpu                               | t detect     | ion (cor     | nparato   | r and si      | nk) con      | trol          |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 0                      | UDP1   |           |           | _       | ection dis    | , .                                   |              | `            |           |               |              |               |              | R/W        |
|            |                                                                                                                                                                                                                                                                                                                                                    | 1                      | UDP1   | pin (0.   | 6 V) inp  | ut dete | ction en      | abled                                 |              |              |           |               |              |               |              |            |
|            | Contro<br>UDP1                                                                                                                                                                                                                                                                                                                                     | ols the ID<br>pin.     | P_SINK | (sink cı  | urrent) u | sed fo  | the 0.6       | V input                               | detectio     | on circu     | it (comp  | oarator)      | and det      | tection f     | for the      |            |

### Figure 13 - 44 Format of BC Control Register 1 (USBBCCTRL1)



| VDPSRCE1        | UDP1 pin VDP_SRC (0.6 V) output control | R/W |
|-----------------|-----------------------------------------|-----|
| 0               | VDP_SRC output disabled                 | R/W |
| 1               | VDP_SRC output enabled (0.6 V output)   |     |
| Controls the VI | DP_SRC output.                          |     |

| IDMSINKE1       | UDM1 pin VDM_SRC (0.6 V) input detection (comparator and sink) control                              | R/W |
|-----------------|-----------------------------------------------------------------------------------------------------|-----|
| 0               | UDM1 pin (0.6 V) input detection disabled                                                           | R/W |
| 1               | UDM1 pin (0.6 V) input detection enabled                                                            |     |
| Controls the ID | M_SINK (sink current) used for the 0.6 V input detection circuit (comparator) and detection for the |     |
| UDM1 pin.       |                                                                                                     |     |

| IDPSRCE1        | UDP1 pin IDP_SRC (10 µA) output control | R/W |  |  |  |  |  |
|-----------------|-----------------------------------------|-----|--|--|--|--|--|
| 0               | IDP_SRC output disabled                 | R/W |  |  |  |  |  |
| 1               | SRC output enabled (10 μA output)       |     |  |  |  |  |  |
| Controls the ID | P_SRC output.                           |     |  |  |  |  |  |

| RPDME1        | UDM1 pull-down control                            | R/W |
|---------------|---------------------------------------------------|-----|
| 0             | Pulling down disabled                             | R/W |
| 1             | Pulling down enabled                              |     |
| Only the UDM1 | pin can be pulled down (RPD) by setting this bit. |     |



#### R9A02G015

### 13.3.35 BC option control register n (USBBCOPTn) (n = 0, 1)

#### Figure 13 - 45 Format of BC Option Control Register 0 (USBBCOPT0)

Address: F04B8H, F04B9H After reset: 0000H

| Symbol    | 15     | 14                                                                                                                                                                                                                                                          | 13                                                  | 12                                                                                                                                                                                                                    | 11         | 10       | 9             | 8                    | 7        | 6            | 5           | 4        | 3           | 2           | 1           | 0           |
|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|---------------|----------------------|----------|--------------|-------------|----------|-------------|-------------|-------------|-------------|
| USBBCOPT0 |        | _                                                                                                                                                                                                                                                           | _                                                   | _                                                                                                                                                                                                                     | —          | _        | DMCU<br>SDET0 | DPCU<br>SDET<br>0    | _        | CUSD<br>ETE0 | VDOU<br>TE0 |          | VDSEL<br>03 | VDSEL<br>02 | VDSEL<br>01 | VDSEL<br>00 |
|           | Bits   | 15, 14                                                                                                                                                                                                                                                      |                                                     |                                                                                                                                                                                                                       |            |          |               | F                    | Reserv   | əd           |             |          |             |             |             | R/W         |
|           |        |                                                                                                                                                                                                                                                             | The w                                               | rite val                                                                                                                                                                                                              | ue must    | t be 0.  |               |                      |          |              |             |          |             |             |             | _           |
|           | Bits 1 | 3 to 10                                                                                                                                                                                                                                                     |                                                     |                                                                                                                                                                                                                       |            |          |               | Nothi                | ng is as | signed       |             |          |             |             |             | R/W         |
|           | -      |                                                                                                                                                                                                                                                             | The w                                               | rite val                                                                                                                                                                                                              | ue must    | t be 0.  | The read      | d value i            | s 0.     |              |             |          |             |             |             | —           |
|           |        | JSDET0<br>lote                                                                                                                                                                                                                                              | UDM0 voltage detectiion (Option BC: Host/functiion) |                                                                                                                                                                                                                       |            |          |               |                      |          |              |             |          |             |             |             | R/W         |
|           |        | 0                                                                                                                                                                                                                                                           | VDSE<br>• Fund                                      | Host<br>JDM0 pin output voltage is maintained (Within the comparison voltage range selected by the<br>/DSEL0x bit).<br>Function<br>JDM0 pin voltage is lower than the comparison voltage selected by the VDSEL0x bit. |            |          |               |                      |          |              |             |          |             |             |             |             |
|           |        | <ul> <li>Host<br/>UDM0 pin output voltage change is detected (When the comparison voltage range selected by<br/>the VDSEL0x bit is exceeded).</li> <li>Function<br/>UDM0 pin voltage exceeds the comparison voltage selected by the VDSEL0x bit.</li> </ul> |                                                     |                                                                                                                                                                                                                       |            |          |               |                      |          |              |             |          |             |             |             |             |
|           |        | JSDET0<br>lote                                                                                                                                                                                                                                              |                                                     |                                                                                                                                                                                                                       |            | UDPO     | voltage       | detectii             | on (Op   | tion BC      | : Host/fu   | Inctiion | )           |             |             | R/W         |
|           |        | 0                                                                                                                                                                                                                                                           | VDSE<br>• Fund                                      | ) pin ou<br>L0x bit                                                                                                                                                                                                   | ).         | -        |               | ned (With<br>compari |          |              |             | -        | -           | -           | / the       | R           |
|           |        | 1                                                                                                                                                                                                                                                           | the VI<br>• Fund                                    | ) pin ou<br>DSEL0><br>ction                                                                                                                                                                                           | c bit is e | xceede   | ed).          | detected             |          |              |             |          |             |             | ted by      |             |
|           | В      | it 7                                                                                                                                                                                                                                                        |                                                     |                                                                                                                                                                                                                       |            |          |               | Nothi                | ng is as | signed       |             |          |             |             |             | R/W         |
|           |        |                                                                                                                                                                                                                                                             | The w                                               | rite val                                                                                                                                                                                                              | ue must    | be 0.    | The read      | d value i            | s 0.     |              |             |          |             |             |             | —           |
|           | CUSI   | DETE0                                                                                                                                                                                                                                                       |                                                     |                                                                                                                                                                                                                       | Optior     | n voltag | e detec       | tiion circ           | uit con  | trol (Op     | tion BC:    | Host/f   | unctiion    | )           |             | R/W         |
|           |        | 0                                                                                                                                                                                                                                                           | Disab                                               |                                                                                                                                                                                                                       |            |          |               |                      |          |              |             |          |             |             |             | R/W         |
|           |        | 1                                                                                                                                                                                                                                                           | Enabl                                               | ed                                                                                                                                                                                                                    |            |          |               |                      |          |              |             |          |             |             |             |             |
|           | VDC    | OUTE0                                                                                                                                                                                                                                                       |                                                     |                                                                                                                                                                                                                       |            | Opt      | ion volta     | age outp             | ut cont  | rol (Opt     | ion BC:     | Host)    |             |             |             | R/W         |
|           |        | 0                                                                                                                                                                                                                                                           | Disab                                               |                                                                                                                                                                                                                       |            |          |               |                      |          |              |             |          |             |             |             | R/W         |
|           |        | 1                                                                                                                                                                                                                                                           | Enabl                                               | eu                                                                                                                                                                                                                    |            |          |               |                      |          |              |             |          |             |             |             |             |



| Bit 4                 | Nothing is assigned                                                                              | R/W |
|-----------------------|--------------------------------------------------------------------------------------------------|-----|
| —                     | The write value must be 0. The read value is 0.                                                  | —   |
|                       |                                                                                                  |     |
| VDSEL03 to<br>VDSEL00 | UDP0/UDM0 pin option output voltage and comparison voltage select (Option BC:<br>Host/functiion) | R/W |
| Select UDP0/U         | DM0 pin output voltage and comparison voltage value (Refer to Remark)                            | R/W |

**Note** Valid when CUSDETE0 = 1

**Remark** The option output voltage values of the UDP0 and UDM0 pins and the comparison voltage values of the option BC detection circuit when UVBUS = 5.0 V are shown below. The following voltages vary in proportion to the UVBUS input voltage.

| VDOUTE0       | VDSEL03 | VDSEL02 | VDSEL01 | VDSEL00 | Output v | oltage (V) |              | n voltage (V)<br>USDETE0 = 1) |  |  |
|---------------|---------|---------|---------|---------|----------|------------|--------------|-------------------------------|--|--|
|               |         |         |         |         | UDP0     | UDM0       | UDP0         | UDM0                          |  |  |
| 1 (Host)      | 1       | 0       | 0       | 0       | 2.00     | 2.00       | 1.60 to 2.60 | 1.60 to 2.60                  |  |  |
|               | 1       | 0       | 0       | 1       | 2.68     | 2.00       | 2.45 to 2.80 | 1.60 to 2.60                  |  |  |
|               | 1       | 0       | 1       | 0       | 2.00     | 2.68       | 1.60 to 2.60 | 2.45 to 2.80                  |  |  |
|               | 1       | 1       | 0       | 0       | 3.30     | 3.30       | _            | —                             |  |  |
| 0 (Function)  | 0       | 0       | 0       | 0       | -        | _          | 1.           | 60                            |  |  |
|               | 0       | 0       | 0       | 1       | -        | _          | 1.           | 70                            |  |  |
|               | 0       | 0       | 1       | 0       | -        | _          | 1.           | 85                            |  |  |
|               | 0       | 0       | 1       | 1       | -        | _          | 2.00         |                               |  |  |
|               | 0       | 1       | 0       | 0       | -        | _          | 2.           | 15                            |  |  |
|               | 0       | 1       | 0       | 1       | -        | _          | 2.30         |                               |  |  |
|               | 0       | 1       | 1       | 0       | -        | _          | 2.45         |                               |  |  |
|               | 0       | 1       | 1       | 1       | -        | _          | 2.           | 60                            |  |  |
|               | 1       | 0       | 0       | 0       | -        | _          | 2.           | 80                            |  |  |
|               | 1       | 0       | 0       | 1       | -        | _          | 3.           | 00                            |  |  |
|               | 1       | 0       | 1       | 0       | -        | _          | 3.           | 20                            |  |  |
|               | 1       | 0       | 1       | 1       | -        | _          | 3.           | 40                            |  |  |
|               | 1       | 1       | 0       | 0       | -        | _          | 3.           | 60                            |  |  |
|               | 1       | 1       | 0       | 1       | -        | _          | 3.           | 80                            |  |  |
|               | 1       | 1       | 1       | 0       | -        | _          | 4.           | 00                            |  |  |
|               | 1       | 1       | 1       | 1       | -        | _          | 4.20         |                               |  |  |
| Other than ab | ove     |         | •       | •       |          | Settin     | g prohibited |                               |  |  |



| Symbol       15       14       13       12       11       10       9       8       7       6       5       4       3       2         USBBCOPT1       -       -       -       -       DMCU       DPCU       -       CUSD       VDOU       -       VDSEL       VDSEL       VDSEL       VDSEL       13       12 | 1                                                                                                                                                                           | 0           |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|
| USBBCOPTI $         -$                                                                                                                                                                                                                                                                                       |                                                                                                                                                                             |             |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                              | 11                                                                                                                                                                          | VDSEL<br>10 |  |  |  |  |  |  |  |  |  |  |  |
| Bits 15, 14 Reserved                                                                                                                                                                                                                                                                                         |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| — The write value must be 0.                                                                                                                                                                                                                                                                                 |                                                                                                                                                                             | —           |  |  |  |  |  |  |  |  |  |  |  |
| Bits 13 to 10 Nothing is assigned                                                                                                                                                                                                                                                                            |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| — The write value must be 0. The read value is 0.                                                                                                                                                                                                                                                            |                                                                                                                                                                             | —           |  |  |  |  |  |  |  |  |  |  |  |
| DMCUSDET1<br>Note UDM1 voltage detectiion (Option BC: Host/functiion)                                                                                                                                                                                                                                        | LU)M1 voltage detection (Option BC: Host/tunction)                                                                                                                          |             |  |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>Host</li> <li>UDM1 pin output voltage is maintained (Within the comparison voltage range selected by VDSEL1x bit).</li> <li>Function</li> <li>UDM1 pin voltage is lower than the comparison voltage selected by the VDSEL1x bit.</li> </ul>                                                         | 0 • Host<br>UDM1 pin output voltage is maintained (Within the comparison voltage range selected by the<br>VDSEL1x bit).<br>• Function                                       |             |  |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>Host         <ul> <li>UDM1 pin output voltage change is detected (When the comparison voltage range selection</li> <li>VDSEL1x bit is exceeded).</li> <li>Function</li> <li>UDM1 pin voltage exceeds the comparison voltage selected by the VDSEL1x bit.</li> </ul> </li> </ul>                     | <ul> <li>Host</li> <li>UDM1 pin output voltage change is detected (When the comparison voltage range selected by the VDSEL1x bit is exceeded).</li> <li>Function</li> </ul> |             |  |  |  |  |  |  |  |  |  |  |  |
| DPCUSDET1<br>Note UDP1 voltage detectiion (Option BC: Host/functiion)                                                                                                                                                                                                                                        | UDP1 voltage detectiion (Option BC: Host/functiion)                                                                                                                         |             |  |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>Host</li> <li>UDP1 pin output voltage is maintained (Within the comparison voltage range selected b</li> <li>VDSEL1x bit).</li> <li>Function</li> <li>UDP1 pin voltage is lower than the comparison voltage selected by the VDSEL1x bit.</li> </ul>                                                 | UDP1 pin output voltage is maintained (Within the comparison voltage range selected by the VDSEL1x bit).<br>• Function                                                      |             |  |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>Host</li> <li>UDP1 pin output voltage change is detected (When the comparison voltage range selection</li> <li>Function</li> <li>UDP1 pin voltage exceeds the comparison voltage selected by the VDSEL1x bit.</li> </ul>                                                                            | <ul> <li>Host</li> <li>UDP1 pin output voltage change is detected (When the comparison voltage range selected by the VDSEL1x bit is exceeded).</li> <li>Function</li> </ul> |             |  |  |  |  |  |  |  |  |  |  |  |
| Bit 7 Nothing is assigned                                                                                                                                                                                                                                                                                    |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>The write value must be 0. The read value is 0.</li> </ul>                                                                                                                                                                                                                                          |                                                                                                                                                                             |             |  |  |  |  |  |  |  |  |  |  |  |
| CUSDETE1 Option voltage detectiion circuit control (Option BC: Host)                                                                                                                                                                                                                                         |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| 0 Disabled                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| 1 Enabled                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                             |             |  |  |  |  |  |  |  |  |  |  |  |
| VDOUTE1 Option voltage output control (Option BC: Host)                                                                                                                                                                                                                                                      |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| 0 Disabled                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| 1 Enabled                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                             |             |  |  |  |  |  |  |  |  |  |  |  |
| Bit 4 Nothing is assigned                                                                                                                                                                                                                                                                                    |                                                                                                                                                                             | R/W         |  |  |  |  |  |  |  |  |  |  |  |
| — The write value must be 0. The read value is 0.                                                                                                                                                                                                                                                            |                                                                                                                                                                             | -           |  |  |  |  |  |  |  |  |  |  |  |

### Figure 13 - 46 Format of BC Option Control Register 1 (USBBCOPT1)



| VDSEL13 to<br>VDSEL10 | UDP1/UDM1 pin option output voltage and comparison voltage select (Option BC: Host) | R/W |
|-----------------------|-------------------------------------------------------------------------------------|-----|
| Select UDP1/U         | DM1 pin output voltage and comparison voltage value (Refer to Remark)               | R/W |
| Note Vali             | d when CUSDETE1 = 1                                                                 |     |

**Remark** The option output voltage values of the UDP1 and UDM1 pins and the comparison voltage values of the option BC detection circuit when UVBUS = 5.0 V are shown below. The following voltages vary in proportion to the UVBUS input voltage.

| VDOUTE1       | VDSEL13 | VDSEL12   | VDSEL11 | VDSEL10 | Output v  | oltage (V) |               | n voltage (V)<br>USDETE1 = 1) |  |  |
|---------------|---------|-----------|---------|---------|-----------|------------|---------------|-------------------------------|--|--|
|               |         |           |         |         | UDP1      | UDM1       | UDP1          | UDM1                          |  |  |
| 1 (Host)      | 1       | 0         | 0       | 0       | 2.00      | 2.00       | 1.60 to 2.60  | 1.60 to 2.60                  |  |  |
|               | 1       | 0         | 0       | 1       | 2.68      | 2.00       | 2.45 to 2.80  | 1.60 to 2.60                  |  |  |
|               | 1       | 0         | 1       | 0       | 2.00 2.68 |            | 1.60 to 2.60  | 2.45 to 2.80                  |  |  |
|               | 1       | 1         | 0       | 0       | 3.30 3.30 |            | —             | _                             |  |  |
| 0 (Function)  | 0       | 0         | 0       | 0       | —         |            | 1.            | 60                            |  |  |
|               | 0       | 0         | 0       | 1       | -         | _          | 1.            | 70                            |  |  |
|               | 0       | 0 0 1 0 — |         | 1.      | 85        |            |               |                               |  |  |
|               | 0       | 0         | 1       | 1       | -         | _          | 2.00          |                               |  |  |
|               | 0       | 1         | 0       | 0       | -         | _          | 2.15          |                               |  |  |
|               | 0       | 1         | 0       | 1       | -         | _          | 2.30          |                               |  |  |
|               | 0       | 1         | 1       | 0       | -         | _          | 2.45          |                               |  |  |
|               | 0       | 1         | 1       | 1       | -         | _          | 2.60          |                               |  |  |
|               | 1       | 0         | 0       | 0       | -         | _          | 2.            | 80                            |  |  |
|               | 1       | 0         | 0       | 1       | -         | _          | 3.00          |                               |  |  |
|               | 1       | 0         | 1       | 0       | -         | _          | 3.            | 20                            |  |  |
|               | 1       | 0         | 1       | 1       | -         | _          | 3.            | 40                            |  |  |
|               | 1       | 1         | 0       | 0       | -         | _          | 3.            | 60                            |  |  |
|               | 1       | 1         | 0       | 1       | -         | _          | 3.            | 80                            |  |  |
|               | 1       | 1         | 1       | 0       | -         | _          | 4.            | 00                            |  |  |
|               | 1       | 1         | 1       | 1       | -         | _          | 4.            | 20                            |  |  |
| Other than ab | ove     |           |         |         |           | Settir     | ng prohibited |                               |  |  |



### 13.3.36 USB clock selection register (UCKSEL)

| Address: F04C4H, F04C5H       After reset: 0000H         Symbol       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1         UCKSEL       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 |             | Figure 13 - 47 Format of USB clock selection register (UCKSEL)             |                                            |  |  |  |  |  |  |  |       |          |        |                         |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------|--------------------------------------------|--|--|--|--|--|--|--|-------|----------|--------|-------------------------|--|--|--|--|--|
| UCKSEL 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |                                                                            |                                            |  |  |  |  |  |  |  | 0000H | reset: ( | After  | Address: F04C4H, F04C5H |  |  |  |  |  |
| UCKSEL 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0           | 1                                                                          | Symbol 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |  |  |  |  |  |  |  |       | Symbol   |        |                         |  |  |  |  |  |
| UCKSELC USB clock selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | UCKS<br>ELC | L 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                    |                                            |  |  |  |  |  |  |  |       |          | UCKSEL |                         |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W         | UCKSELC USB clock selection                                                |                                            |  |  |  |  |  |  |  |       |          |        |                         |  |  |  |  |  |
| 0 High-speed on-chip oscillator clock (fHOCO) is not selected as USB clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W         | 0 High-speed on-chip oscillator clock (fHOCO) is not selected as USB clock |                                            |  |  |  |  |  |  |  |       |          | Ī      |                         |  |  |  |  |  |
| 1 High-speed on-chip oscillator clock (fHOCO) is selected as USB clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | -           |                                                                            |                                            |  |  |  |  |  |  |  |       |          |        |                         |  |  |  |  |  |

Figure 13 - 47 Format of USB clock selection register (UCKSEL)

Caution 1. When selecting the high-speed on-chip oscillator clock (fHOCO) as the USB clock, set UCKSELC = and the CKSELR bit in the MCKC register to 0 at the same time.

 $\label{eq:caution 2} \mbox{Caution 2. The USB clock select register can be rewritten only when the USB is disconnected.}$ 

Caution 3. The high-speed on-chip oscillator clock can be selected only when TA = -20 to +85°C.

- Caution 4. If the high-speed on-chip oscillator clock is selected as the USB clock, when the USB is suspended, perform USB suspended processing while the high-speed on-chip oscillator clock is selected (UCKSELC = 1).
- Caution 5. If the high-speed on-chip oscillator clock is selected as the USB clock, when the USB is disconnected, perform USB stopped processing (including setting DPRPU = 0) before setting UCKSELC = 0.



#### R9A02G015

### 13.3.37 USB module control register (USBMC)

#### Figure 13 - 48 Format of USB Module Control Register (USBMC)

Address: F04CCH, F04CDH After reset: 0002H

| Symbol | 15                                                                                                                                                                                                                                                                                                                                                                                                           | 14           | 13     | 12        | 11        | 10        | 9        | 8        | 7                     | 6        | 5         | 4                   | 3                   | 2 | 1          | 0           |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|-----------|-----------|-----------|----------|----------|-----------------------|----------|-----------|---------------------|---------------------|---|------------|-------------|
| USBMC  | _                                                                                                                                                                                                                                                                                                                                                                                                            | —            | _      | _         | _         | —         | _        | _        | VBRP<br>DCUT          | _        | —         | —                   | _                   | _ | PXXC<br>ON | VDDU<br>SBE |
| [      | Bits 1                                                                                                                                                                                                                                                                                                                                                                                                       | 5 to 8       |        |           |           |           |          | Noth     | ing is as             | signed   |           |                     |                     |   |            | R/W         |
|        | -                                                                                                                                                                                                                                                                                                                                                                                                            | _            | The w  | /rite val | ue must   | : be 0. 1 | he read  | d value  | is 0.                 |          |           |                     |                     |   |            | —           |
|        |                                                                                                                                                                                                                                                                                                                                                                                                              | DCUT<br>te 1 |        |           |           |           | UVBU     | S pin pu | ıll-down              | resistor | - control |                     |                     |   |            | R/W         |
|        |                                                                                                                                                                                                                                                                                                                                                                                                              | 0            | Pull-d | own res   | sistor is | valid.    |          |          |                       |          |           |                     |                     |   |            | R/W         |
|        |                                                                                                                                                                                                                                                                                                                                                                                                              | 1            | Pull-d | own res   | sistor is | invalid.  |          |          |                       |          |           |                     |                     |   |            |             |
| ſ      | Bits 6 to 2 Nothing is assigned                                                                                                                                                                                                                                                                                                                                                                              |              |        |           |           |           |          |          |                       |          |           | R/W                 |                     |   |            |             |
|        | — The write value must be 0. The read value is 0.                                                                                                                                                                                                                                                                                                                                                            |              |        |           |           |           |          |          |                       |          |           | —                   |                     |   |            |             |
| ſ      | PXX                                                                                                                                                                                                                                                                                                                                                                                                          | CON          | VDE    | DUSBE     |           |           |          | USE      | 3 interna             | l power  | supply    | control             |                     |   |            | R/W         |
|        |                                                                                                                                                                                                                                                                                                                                                                                                              | 0            |        | 0         |           |           | •        |          | for USB<br>n setting  |          | bed       |                     |                     |   |            | R/W         |
|        | UVDD pin input is pull-down setting Note 2           0         1           The internal power supply for USB is stopped Note 3           Setting for when power (3.3 V) is applied externally via the UVDD pin Note 3           Be sure to specify this setting when using the BC connection detection function (except the optional BC connection detection functions) as well as the above settings Note 4 |              |        |           |           |           |          |          |                       |          |           |                     |                     |   |            |             |
|        | 1     0     The internal power supply for USB is stopped       Setting for when power (3.3 V) is applied externally via the UVDD pin Note 3                                                                                                                                                                                                                                                                  |              |        |           |           |           |          |          |                       |          |           |                     |                     |   |            |             |
|        |                                                                                                                                                                                                                                                                                                                                                                                                              | 1            |        | 1         |           |           | •        |          | for USB<br>l internal |          |           | ipply <sup>No</sup> | te 3 <sub>,</sub> 4 |   |            |             |
|        | Contro                                                                                                                                                                                                                                                                                                                                                                                                       | lling to t   | he USE | 3 interna | al powe   | r supply  | <i>.</i> |          |                       |          |           |                     |                     |   |            | I           |

**Note 1.** Be sure to set VBRPDCUT = 1 (pull-down resistor is invalid) when this pin is used as VBUS power supply in the BC option (host), etc. Set VBRPDCUT = 0 (pull-down resistor is valid) when the VBUS input is used, or this pin is not used.

**Note 2.** To prevent malfunction caused by a floating USB power supply, be sure to specify this setting when power is not being applied externally from the UVDD pin or when the internal USB power supply might stop.

Note 3. When PXXCON = 0 and VDDUSBE = 1 or PXXCON = 1 and VDDUSBE = 0, the high level of the UDP and UDM pins is based on the level of the external power supply input from the UVDD pin. When PXXCON = 1 and VDDUSBE = 1, the high level of the UDP and UDM pins is based on the voltage

generated by the internal USB power supply (3.3 V), and 3.3 V is output from the UVDD pin.

Note 4. Specify PXXCON = 0 and VDDUSBE = 1 when using the BC connection detection function (except the optional BC connection detection functions) with external power being applied to the UVDD pin. Specify PXXCON = 1 and VDDUSBE = 1 when using the BC connection detection function (except the optional BC connection detection functions) with the internal USB power supply. Note that the temperature sensor cannot be used and A/D conversion that uses the internal reference voltage cannot be performed when using the internal USB power supply or using the BC connection function (except the optional BC connection detection functions) (VDDUSBE = 1).

### 13.3.38 Device address n configuration registers (DEVADDn) (n = 0 to 5)

Figure 13 - 49 Format of Device Address n Configuration Registers (DEVADDn) (n = 0 to 5)

Address: F04D0H, F04D1H (DEVADD0), F04D2H, F04D3H (DEVADD1), After reset: 0000H F04D4H, F04D5H (DEVADD2), F04D6H, F04D7H (DEVADD3), F04D8H, F04D9H (DEVADD4), F04DAH, F04DBH (DEVADD5)

| Symbol  | 15             | 14             | 13      | 12        | 11        | 10        | 9        | 8          | 7                                   | 6           | 5        | 4        | 3      | 2         | 1         | 0          |
|---------|----------------|----------------|---------|-----------|-----------|-----------|----------|------------|-------------------------------------|-------------|----------|----------|--------|-----------|-----------|------------|
| DEVADDn | —              | —              | —       | —         | —         | —         | —        | _          | USBSP<br>D1                         | USBSP<br>D0 | —        | —        | —      | _         | _         | RTPO<br>RT |
|         | Bits ´         | 15 to 8        |         |           |           |           |          | Noth       | ing is as                           | signed      |          |          |        |           |           | R/W        |
|         | -              |                | The w   | rite valu | ue mus    | t be 0. 1 | he rea   | d value    | is 0.                               |             |          |          |        |           |           | —          |
| [       | USB            | SPD1           | USE     | BSPD0     |           |           | Tra      | nsfer s    | peed of o                           | commur      | nication | target o | device |           |           | R/W        |
|         |                | 0              |         | 0         | The       | DEVAD     | Dn regi  | ister is I | not used                            |             |          |          |        |           |           | R/W        |
|         |                | 0              |         | 1         |           | speed     |          |            |                                     |             |          |          |        |           |           |            |
|         |                | 1              |         | 0         | Full      | speed     |          |            |                                     |             |          |          |        |           |           |            |
|         |                | 1              |         | 1         | Do n      | ot set.   |          |            |                                     |             |          |          |        |           |           |            |
|         | When<br>packet | the host<br>s. | control | ler func  | tion is s | elected   | , the US | SB mod     | cation ta<br>ule refer<br>bits to 0 | rs to the   | •        |          |        | D[1:0] bi | its to ge | enerate    |
|         | Bits           | 5 to 1         |         |           |           |           |          | Noth       | ing is as                           | signed      |          |          |        |           |           | R/W        |
|         | -              |                | The w   | rite valu | ue musi   | t be 0. 1 | he rea   | d value    | is 0.                               |             |          |          |        |           |           | —          |
|         | RTF            | PORT           |         |           |           |           |          | Route      | hub port                            | t numbe     | r        |          |        |           |           | R/W        |
|         |                | 0              | USB p   | oort 0    |           |           |          |            |                                     |             |          |          |        |           |           | R/W        |
|         |                | 1              | USB p   | oort 1    |           |           |          |            |                                     |             |          |          |        |           |           |            |

Specifies the corresponding device is connected to which port.

When the host controller function is selected, the USB module references to the setting of the RTPORT bit and generates a packet.

When the function controller function is selected, this setting is ignored.



(3) When using the on-chip USB internal

#### 13.4 Operation

#### 13.4.1 System control

This section describes the register settings that are necessary for initialization of this module and power consumption control.

#### 13.4.1.1 Starting operation

The source for the USB power supply (UVDD) can be applied either externally from the UVDD pin or from the on-chip USB internal power supply.

When no external power is applied to the UVDD pin, the initial state after releasing the USB power supply reset is a floating state. To prevent erroneous operation caused by the floating state, pull down the USB power supply (UVDD) by setting the register (VDDUSBE bit = 0, PXXCON bit = 0) until applying external power to the UVDD pin or using the USB internal power supply.

When using the on-chip USB internal power supply, it is necessary to connect an external 0.33 µF stabilization capacitance (for Vss) to the UVDD pin. While the USB internal power supply is used, A/D conversion cannot be performed using the temperature sensor or internal reference voltage at the same time.

Figure 13 - 50 shows the flow for turning on the USB power when using the USB host/function controller. For details about the flow for turning on the USB power when using the USB host/function controller and the BC connection detection function (except the optional BC connection detection functions), see the application note.

#### Figure 13 - 50 Flow for Turning on USB Power

(1) When applying external power to the UVDD pin before reset release

(2) When applying external power to the UVDD pin at an arbitrary timing after reset release

power supply Note 5 No external power applied to Initial state Apply external power to UVDD pin UVDD pin after reset release (USB power supply is left floating) VDDUSBE = 0Initial state PXXCON = 1 Initial state after reset release after reset release (USB power supply is left floating) VDDUSBE = 0 VDDUSBE = 0 PXXCON = 1 Pull down USB power supply (UVDD) PXXCON = 1 VDDUSBE = 0 Note 3 PXXCON = 0 Wait time until UV\_DD pin voltage stabilizes at 3.3 V  $\pm$  0.3 V  $^{Notes \ 1, \ 2}$ Pull down USB power supply (UVDD) VDDUSBE = 0 Not Use USB internal power supply VDDUSBE = 1 Note 4 PXXCON = 0PXXCON = 1 Enable USB operation SCKE = 1 After setting VDDUSBE = 0, Confirm SCKE = 1 (read) PXXCON = 1. USBE = 1 Wait for 1 ms until output from USB apply external power to UVDD pin internal power supply stabilizes Wait time until the UVDD pin voltage stabilizes at 3.3 V ± 0.3 V Note Enable USB operation SCKF = 1Confirm SCKE = 1 (read) USBE = 1 Enable USB operation SCKF = 1

- Note 1. The wait time depends on the characteristics of an external power supply to be used.
- Note 2. No wait time is required if the UVDD pin voltage stabilizes during the reset release sequence.
- Note 3 To prevent malfunction caused by a floating USB power supply, be sure not to change this setting when power is not being applied externally from the UVDD pin or when the internal USB power supply might be stop.

Confirm SCKE = 1 (read) USBF = 1



- **Note 4.** When the USB internal power supply is used, A/D conversion cannot be performed using the temperature sensor or internal reference voltage.
- **Note 5.** When using the USB internal power supply, connect an external 0.33 µF stabilization capacitance (for VSS) to the UVDD pin.

#### 13.4.1.2 Controller function selection

For the USB module, the host controller function or function controller function can be selected using the DCFM bit in the SYSCFG register. The DCFM bit should be modified in the initial settings immediately after a power-on reset or in the D+ pull-up-disabled (DPRPU = 0) and D+ and D- pull-down-disabled (DRPD = 0) state.

Table 13 - 13 shows USB Port Function Selection.

| When the host controller function is selected |                            |                                                                                                                         |  |  |  |  |
|-----------------------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| USB port 0                                    | USB port 1                 | USB port 1 Remark                                                                                                       |  |  |  |  |
| Full or low Full or low                       |                            | The transfer scheduling is common to USB port 0 and USB port 1. The output is driven to both USB port 0 and USB port 1. |  |  |  |  |
| When the function contro                      | oller function is selected |                                                                                                                         |  |  |  |  |
| USB port 0                                    | USB port 1                 | Remark                                                                                                                  |  |  |  |  |
| Full or low                                   | Not used                   | USB port 1 is invalid.                                                                                                  |  |  |  |  |

### 13.4.1.3 Controlling USB data bus resistors

The USB module contains pull-up and pull-down resistors of the D+ and D- lines. Pull up or pull down these lines by setting the DPRPU and DRPD bits in the SYSCFG register.

When the function controller function is selected, confirm that connection to the USB host is made, then set the DPRPU bit in the SYSCFG register to 1 and pull up the D+ (full speed)/D- (low speed) line.

When the DPRPU bit in the SYSCFG register is set to 1 during communication with the PC, the USB module disables the pull-up resistor of the USB data line, thus notifying the USB host of connection.

When the host controller function is selected, set the DRPD bit (SYSCFG or SYSCFG1 register) for the used port to 1 and pull down the D+/D- lines.

Table 13 - 14 lists the settings for Controlling USB Data Bus Resistors of USB port 0 and Table 13 - 15 lists the settings for Controlling USB Data Bus Resistors of USB port 1.

| Settings         |       |       |                     |                        | USB Data Bus Resistor Control                                             |  |  |
|------------------|-------|-------|---------------------|------------------------|---------------------------------------------------------------------------|--|--|
| DRPD             | DPRPU | DMRPU | D- Line             | - Line D+ Line Remarks |                                                                           |  |  |
| 0                | 0     | 0     | Open                | Open                   | When USB port 0 is not used                                               |  |  |
| 0                | 1     | 0     | Open                | Pull-up                | Set to this state when operating as the function controller (full speed). |  |  |
| 0                | 0     | 1     | 1 Pull-up Open      |                        | Set to this state when operating as the function controller (low speed).  |  |  |
| 1                | 0     | 0     | Pull-down Pull-down |                        | Set to this state when operating as the host controller.                  |  |  |
| Other than above |       | —     | —                   | Setting prohibited     |                                                                           |  |  |

Table 13 - 14 Controlling USB Data Bus Resistors of USB port 0



| Settings |           | USB Data Bus Resistor Control |                                                              |  |  |  |  |
|----------|-----------|-------------------------------|--------------------------------------------------------------|--|--|--|--|
| DRPD     | D- Line   | D- Line D+ Line Remarks       |                                                              |  |  |  |  |
| 0        | Open      | Open                          | When USB port 1 is not used                                  |  |  |  |  |
| 1        | Pull-Down | Pull-Down                     | Set to this state when operating as the function controller. |  |  |  |  |

#### Table 13 - 15 Controlling USB Data Bus Resistors of USB port 1

Figures 13 - 51 to 13 - 55 show the examples of USB external connection circuit.





#### Note Th

The UVBUS input pin is not used when the host controller function is selected.

The UVBUS pin is connected to an on-chip pulled-down resistor while the VBRPDCUT bit (bit 7 in the USBMC register) is in the default state (0), in order to prevent the pin level from becoming unstable when the pin is left open.

To fix the voltage of the UVBUS pin by applying an external voltage, set the VBRPDCUT bit to 1 and disconnect this onchip resistor to prevent unnecessary current consumption.

When using the battery charging connection detection optional functions, the VBUS voltage to be connected to the USB connector must be applied to the UVBUS pin. In this case, set the VBRPDCUT bit to 1 and cut off the internal pull-down resistor of the UVBUS pin.

RENESAS



Figure 13 - 52 USB Connector Function Connection Example in Self-powered Mode (5 V)





Note 1. 5 V torelant

Note 2. Set the VBRPDCUT bit (bit 7 in the USBMC register) to 0 and connect the on-chip pull-down resistor of the UVBUS pin.











Note 1. 5 V torelant

Note 2. Set the VBRPDCUT bit (bit 7 in the USBMC register) to 0 and connect the on-chip pull-down resistor of the UVBUS pin.



#### 13.4.2 Interrupt sources

Table 13 - 16 lists the Interrupt Sources in the USB module.

When an interrupt generation condition is satisfied and the interrupt output is enabled using the corresponding interrupt enable register, the USB issues a USB interrupt request to the interrupt controller and an USB interrupt will be generated.

| Bit to be Set | Name                                                  | Interrupt Source                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Function That<br>Generates<br>Interrupt | Status Flag                         |
|---------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------|
| VBINT         | VBUS interrupt                                        | When a change in the state of the VBUS input pin has been detected (low to high or high to low)                                                                                                                                                                                                                                                                                                                                                                                          | Host/function                           | VBSTS                               |
| RESM          | Resume interrupt                                      | When a change in the state of the USB bus has been detected in the suspended state (J-state to K-state or J-state to SE0)                                                                                                                                                                                                                                                                                                                                                                | Function                                | —                                   |
| SOFR          | Frame number update<br>interrupt                      | <ul> <li>[Host controller function is selected]</li> <li>When an SOF packet with a different frame number has been transmitted</li> <li>[Function controller function is selected]</li> <li>When an SOF packet with a different frame number has been received</li> </ul>                                                                                                                                                                                                                | Host/function                           | _                                   |
| DVST          | Device state transition<br>interrupt                  | When a device state transition has been detected     A USB bus reset detected     Suspend state detected     SET_ADDRESS request received     SET_CONFIGURATION request received                                                                                                                                                                                                                                                                                                         | Function                                | DVSQ2 to<br>DVSQ0                   |
| CTRT          | Control transfer stage<br>transition interrupt        | When a stage transition has been detected in control transfer<br>Setup stage completed<br>Control write transfer status stage transition<br>Control read transfer status stage transition<br>Control transfer completed<br>A control transfer sequence error occurred                                                                                                                                                                                                                    | Function                                | CTSQ2 to<br>CTSQ0                   |
| BEMP          | Buffer empty interrupt                                | <ul> <li>When transmission of all data in the buffer memory has been<br/>completed and the buffer has become empty</li> <li>When a packet larger than the maximum packet size has been<br/>received</li> </ul>                                                                                                                                                                                                                                                                           | Host/function                           | PIPEnBEMP<br>in BEMPSTS<br>register |
| NRDY          | Buffer not ready interrupt                            | <ul> <li>[Host controller function is selected]</li> <li>When STALL has been received from the peripheral device for the issued token</li> <li>When a response has not been received correctly from the peripheral device for the issued token (no response was returned three consecutive times or a packet reception error occurred three consecutive times)</li> <li>[Function controller function is selected]</li> <li>When NAK has been returned for an IN or OUT token</li> </ul> | Host/function                           | PIPEnNRDY<br>in NRDYSTS<br>register |
| BRDY          | Buffer ready interrupt                                | When the buffer has become ready for read access or write access.                                                                                                                                                                                                                                                                                                                                                                                                                        | Host/function                           | PIPEBRDY in<br>BRDYSTS<br>register  |
| OVRCR         | Overcurrent input change interrupt                    | <ul> <li>When a change in the state of the UOVRCUR0 (USB port 0) or<br/>UOVRCUR1 (USB port 1) input pin has been detected (low to high or<br/>high to low)</li> </ul>                                                                                                                                                                                                                                                                                                                    | Host                                    | OVCMON                              |
| BCHG          | Bus change interrupt                                  | When a change of USB bus state has been detected                                                                                                                                                                                                                                                                                                                                                                                                                                         | Host/function                           | LNST                                |
| DTCH          | USB disconnection detection interrupt                 | When disconnection of the USB device has been detected                                                                                                                                                                                                                                                                                                                                                                                                                                   | Host                                    | RHST                                |
| ATTCH         | Connection interrupt                                  | <ul> <li>When J-state or K-state is detected on the USB port for 2.5 μs. Used<br/>for checking whether a peripheral device is connected.</li> </ul>                                                                                                                                                                                                                                                                                                                                      | Host                                    | —                                   |
| EOFERR        | EOF error detection<br>interrupt                      | When an EOF error of a peripheral device has been detected                                                                                                                                                                                                                                                                                                                                                                                                                               | Host                                    | -                                   |
| SACK          | Normal response<br>interrupt for setup<br>transaction | When the normal response (ACK) for the setup transaction has been received                                                                                                                                                                                                                                                                                                                                                                                                               | Host                                    | -                                   |

| Table 13 · | 16 Interrupt Sources | (1/2) |
|------------|----------------------|-------|
|------------|----------------------|-------|



#### Table 13 - 16 Interrupt Sources (2/2)

| Bit to be Set | Name                                   | Interrupt Source                                                                                                                   | Function That<br>Generates<br>Interrupt | Status Flag   |
|---------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------|
| SIGN          | Error interrupt for setup transaction  | <ul> <li>When a setup transaction error (no response or ACK packet<br/>corruption) was detected three consecutive times</li> </ul> | Host                                    | —             |
| PDDETINT      | Portable Device<br>detection interrupt | When connection of the Portable Device has been detected                                                                           | Host                                    | PDDETSTS      |
| Note T        | hough this interrupt can l             | be generated while the host function is selected, it is not usually u                                                              | used with the he                        | ost function. |



Figure 13 - 56 shows the USB interrupt relationship, Table 13 - 17 lists the USB interrupts.





| Interrupt Name | Interrupt Flag                                  | Priority |
|----------------|-------------------------------------------------|----------|
| USB_INT        | VBUS interrupt                                  | High     |
|                | Resume interrupt                                |          |
|                | Frame number update interrupt                   |          |
|                | Device state transition interrupt               |          |
|                | Control transfer stage transition interrupt     |          |
|                | Buffer empty interrupt                          |          |
|                | Buffer not ready interrupt                      |          |
|                | Buffer ready interrupt                          |          |
|                | Overcurrent input change interrupt              |          |
|                | Bus change interrupt                            |          |
|                | USB disconnection detection interrupt           |          |
|                | Connection interrupt                            |          |
|                | EOF error detection interrupt                   |          |
|                | Normal response interrupt for setup transaction |          |
|                | Error interrupt for setup transaction           |          |
|                | Portable Device detection interrupt             |          |
| USB_RESUME     | VBUS interrupt                                  | Low      |
|                | Resume interrupt                                |          |
|                | Overcurrent input change interrupt              |          |
|                | Bus change interrupt                            |          |
|                | Portable Device detection interrupt             |          |

#### Table 13 - 17 USB Interrupt List



### 13.4.3 Interrupts

### 13.4.3.1 BRDY interrupt

The BRDY interrupt is generated when either of the host controller function or function controller function is selected. The following shows the conditions under which the USB module sets 1 to a corresponding bit in the BRDYSTS register. Under this condition, the USB module generates a BRDY interrupt if software has set 1 to the PIPEBRDYE bit in the BRDYENB register that corresponds to the pipe and 1 to the BRDYE bit in the INTENB0 register.

The conditions for generating and clearing the BRDY interrupt depend on the settings of the BRDYM bit and BFRE bit for each pipe as described below.

#### (1) When BRDYM = 0 and BFRE = 0

With these settings, the BRDY interrupt indicates that the FIFO port is accessible.

On any of the following conditions, the USB module generates an internal BRDY interrupt request trigger and sets 1 to the PIPEBRDY bit corresponding to the pertinent pipe.

[For the pipe set to the transmitting direction]

- When software changes the DIR bit from 0 to 1.
- When packet transmission is completed using the pertinent pipe while write-access from the CPU to the FIFO buffer for the pertinent pipe is disabled (when the BSTS bit is read as 0).
- When one FIFO buffer is empty on completion of writing data to the other FIFO buffer in double buffer mode.
- No request trigger is generated until completion of writing data to the currently-written FIFO buffer even if transmission to the other FIFO buffer is completed.
- When 1 is written to the ACLRM bit, which causes the FIFO buffer to make transition from the write-disabled to write-enabled state.

No request trigger is generated for the DCP (that is, during data transmission for control transfers).

[For the pipe set to the receiving direction]

- When packet reception is completed successfully thus enabling the FIFO buffer to be read while read-access from the CPU to the FIFO buffer for the pertinent pipe is disabled (when the BSTS bit is read as 0). No request trigger is generated for the transaction in which DATA-PID disagreement has occurred.
- When one FIFO buffer is read-enabled on completion of reading data from the other FIFO buffer in double
- when one FIFO buller is read-enabled on completion of reading data from the other FIFO buller in double buffer mode.

No request trigger is generated until completion of reading data from the currently-read FIFO buffer even if reception by the other FIFO buffer is completed.

When the function controller function is selected, the BRDY interrupt is not generated in the status stage of control transfers.

The PIPEBRDY interrupt status of the pertinent pipe can be cleared to 0 by writing 0 to the corresponding PIPEBRDY bit in BRDYSTS through software. In this case, 1s should be written to the PIPEBRDY bits for the other pipes.

Be sure to clear the BRDY status before accessing the FIFO buffer.

#### (2) When BRDYM bit = 0 and the BFRE bit = 1

With these settings, the USB module generates a BRDY interrupt on completion of reading all data for a single transfer using the pipe in the receiving direction, and sets 1 to the bit in BRDYSTS corresponding to the pertinent pipe.



On any of the following conditions, the USB module determines that the last data for a single transfer has been received.

- When a short packet including a zero-length packet is received.
- When the transaction counter register (TRNCNT bits) is used and the number of packets specified by the TRNCNT bits are completely received.

When the pertinent data is completely read out after any of the above conditions has been satisfied, the USB module determines that all data for a single transfer has been completely read out.

When a zero-length packet is received while the FIFO buffer is empty, the USB module determines that all data for a single transfer has been completely read out upon passing the zero-length packet data to the CPU. In this case, to start the next transfer, write 1 to the BCLR bit in the corresponding FIFOCTR register through software. With these settings, the USB module does not detect a BRDY interrupt for the pipe in the transmitting direction. The PIPEBRDY interrupt status of the pertinent pipe can be cleared to 0 by writing 0 to the corresponding PIPEBRDY bit through software. In this case, 1s should be written to the PIPEBRDY bits for the other pipes. In this mode, the BFRE bit setting should not be modified until all data for a single transfer has been processed. When it is necessary to modify the BFRE bit before completion of processing, all FIFO buffers for the pertinent pipe should be cleared using the ACLRM bit.

(3) When BRDYM = 1 and BFRE = 0

With these settings, the PIPEBRDY values are linked to the BSTS bit setting for each pipe. In other words, the BRDY interrupt status bits (PIPEBRDY) are set to 1 or 0 by the USB module depending on the FIFO buffer status.

[For the pipe set to the transmitting direction]

The BRDY interrupt status bits are set to 1 when the FIFO buffer is ready for write access, and are set to 0 when it is not ready.

However, the BRDY interrupt is not generated even if the DCP in the transmitting direction is ready for write access.

[For the pipe set to the receiving direction]

The BRDY interrupt status bits are set to 1 when the FIFO buffer is ready for read access, and are set to 0 when all data have been read (not ready for read access).

When a zero-length packet is received while the FIFO buffer is empty, the pertinent bit is set to 1 and the BRDY interrupt is continuously generated until BCLR = 1 is written through software.

With this setting, the PIPEBRDY bit cannot be cleared to 0 through software.

When the BRDYM bit is set to 1, all BFRE bits (for all pipes) should be cleared to 0.

Figure 13 - 57 shows the Timing of BRDY Interrupt Generation.



#### Figure 13 - 57 Timing of BRDY Interrupt Generation

| (1) Example of zero-l                                             | ength packet receptior   | or data packet receptio       | n when BFRE = 0 (single-b                                  | ouffer mode)                                                                    |
|-------------------------------------------------------------------|--------------------------|-------------------------------|------------------------------------------------------------|---------------------------------------------------------------------------------|
| USB bus                                                           | — Token Packet –         | Data Packet                   | ACK Handshake                                              |                                                                                 |
| FIFO buffer status                                                | Ready for rec            | eption                        |                                                            |                                                                                 |
| BRDY interrupt<br>(change in<br>corresponding bit in<br>PIPEBRDY) |                          |                               |                                                            | Ready for read access  ready for read access  ready for read access. Note 1     |
| (2) Example of data                                               | backet reception when    | BFRE = 1 (single-buffer i     | mode)                                                      |                                                                                 |
| USB bus                                                           | Token Packet             | <last> Data Packet</last>     | ACK Handshake                                              |                                                                                 |
| FIFO buffer status                                                | Ready for rec            | eption                        |                                                            | Ready for read access                                                           |
| BRDY interrupt<br>(change in<br>corresponding bit in<br>PIPEBRDY) |                          |                               | The buffer becomes ready for read access                   | A BRDY interrupt is generated<br>s. Note 1 because the transfer has ended. Note |
| (3) Example of packe                                              | et transmission (single- | buffer mode)                  |                                                            |                                                                                 |
| USB bus                                                           | — Token Packet –         | Data Packet                   | ACK Handshake                                              |                                                                                 |
| FIFO buffer status                                                | Ready for tra            | ansmission                    |                                                            | Ready for write access                                                          |
| BRDY interrupt<br>(change in<br>corresponding bit<br>in PIPEBRDY) |                          |                               |                                                            | ↑ pt is generated because the ready for write access.                           |
| Packet transmitted                                                | by host device Pac       | ket transmitted by peripheral | device                                                     |                                                                                 |
|                                                                   |                          |                               | ler the following conditior<br>read in the buffer in the C |                                                                                 |

 Note 2.
 A transfer ends under either of the following conditions:

 (1) When a short packet including a zero-length packet is received

 (2) When the number of packets specified in the transaction counter are received

The condition that USB module clears the BRDY bit in INTSTS0 depends on the setting of the BRDYM bit in the SOFCFG register. Table 13 - 18 shows the Condition for Clearing BRDY Bit.

#### Table 13 - 18 Condition for Clearing BRDY Bit

| BRDYM | Condition for Clearing BRDY Bit                                                                                        |
|-------|------------------------------------------------------------------------------------------------------------------------|
| 0     | The USB module clears the BRDY bit in the INTSTS0 register when software has cleared all bits in the BRDYSTS register. |
| 1     | The USB module clears the BRDY bit in the INTSTS0 register when the BSTS bits for all piles have become 0.             |

### 13.4.3.2 NRDY interrupt

On generating an internal NRDY interrupt request for the pipe whose PID bits are set to BUF by software, the USB module sets the corresponding PIPEnNRDY bit in the NRDYSTS register to 1. If the corresponding bit in the NRDYENB register has been set to 1 by software, the USB module sets the NRDY bit in the INTSTS0 register to 1 and generates a USB interrupt.

The following describes the conditions on which the USB module generates the internal NRDY interrupt request for a given pipe.

Note that the internal NRDY interrupt request is not generated during setup transaction execution when the host controller function is selected. During setup transactions when the host controller function is selected, the SACK or SIGN interrupt is detected.

The internal NRDY interrupt request is not generated during status stage execution of the control transfer when the function controller function is selected.

(1) When the host controller function is selected

On any of the following conditions, the USB module detects an NRDY interrupt.

[For the pipe set to the transmitting direction]

• During communications other than setup transactions, when any combination of the following two cases occur three consecutive times: 1) no response is returned from the peripheral device (when timeout is detected before detection of the handshake packet from the peripheral device) and 2) an error is detected in the packet from the peripheral device.

In this case, the USB module sets the corresponding PIPEnNRDY bit to 1 and modifies the setting of the PID bits of the corresponding pipe to NAK.

• During communications other than setup transactions, when the STALL handshake is received from the peripheral device.

In this case, the USB module sets the corresponding PIPEnNRDY bit to 1 and modifies the setting of the PID bits of the corresponding pipe to STALL (11B).

[For the pipe set to the receiving direction]

• When any combination of the following two cases occur three consecutive times: 1) no response is returned from the peripheral device for the IN token issued by the USB module (when timeout is detected before detection of the DATA packet from the peripheral device) and 2) an error is detected in the packet from the peripheral device.

In this case, the USB module sets the PIPEnNRDY bit corresponding to the pipe to 1 and modifies the setting of the PID bits of the corresponding pipe to NAK.

• When the STALL handshake is received.

In this case, the USB module sets the PIPEnNRDY bit corresponding to the pipe to 1 and modifies the setting of the PID bits of the corresponding pipe to STALL (11B).

(2) When the function controller function is selected

On any of the following conditions, the USB module detects an NRDY interrupt.

[For the pipe set to the transmitting direction]

• When an IN token is received while there is no data to be transmitted in the FIFO buffer.

In this case, the USB module generates a NRDY interrupt request at the reception of the IN token and sets the PIPEnNRDY bit to 1.



[For the pipe set to the receiving direction]

• When an OUT token is received while there is no space available in the FIFO buffer.

The USB module generates a NRDY interrupt request when a NAK handshake is transferred after the data following the OUT token is received, and sets the PIPEnNRDY bit to 1.

However, during re-transmission (due to DATA-PID disagreement), the NRDY interrupt request is not generated. In addition, if an error occurs in the DATA packet, the NRDY interrupt request is not generated.

Figure 13 - 58 shows the Timing of NRDY Interrupt Generation When Function Controller Function is Selected.

#### Figure 13 - 58 Timing of NRDY Interrupt Generation When Function Controller Function is Selected

(1) Example of data transmission (single-buffer mode)

| USB bus -                                                                                     | IN Token Packet NAK Handshake                               |
|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| Buffer status -                                                                               | Ready for write access (there is no data to be transmitted) |
| NRDY interrupt<br>(change in corresponding <sup>¬</sup><br>bit in PIPENRDY) <sup>Note 1</sup> |                                                             |
| (2) Example of data recep                                                                     | tion: OUT token reception (single-buffer mode)              |
| USB bus -                                                                                     | OUT Token Packet Data Packet NAK Handshake                  |
| Buffer status                                                                                 | Ready for read access (there is no space to receive data)   |
| NRDY interrupt<br>(change in corresponding <sup>-</sup><br>bit in PIPENRDY) <sup>Note 1</sup> |                                                             |
| (CRC bit, etc.) Note 2 -                                                                      |                                                             |
| (3) Example of data rece                                                                      | ption: PING token reception (single-buffer mode)            |
| USB bus                                                                                       | PING Token Packet NAK Handshake                             |
| Buffer status                                                                                 | Ready for read access (there is no space to receive data)   |
| NRDY interrupt<br>(change in corresponding<br>bit in PIPENRDY) <sup>Note 1</sup>              |                                                             |
| Packet transmitted                                                                            | by host device Packet transmitted by peripheral device      |

**Note 1.** The PIPEnNRDY bit is set to 1 only while the PID bits for the target pipe are set to 1.

Note 2. The CRC and OVRN bits change only while the target pipe is set to isochronous transfers.



### 13.4.3.3 BEMP interrupt

On detecting a BEMP interrupt for the pipe whose PID bits are set to BUF by software, the USB module sets the corresponding PIPEnBEMP bit in the BEMPSTS register to 1. If the corresponding bit in the BEMPENB register has been set to 1 by software, the USB module sets the BEMP bit in the INTSTS0 register to 1 and generates a USB interrupt.

The following describes the conditions on which the USB module generates an internal BEMP interrupt request.

[For the pipe set to the transmitting direction]

• When the FIFO buffer of the corresponding pipe is empty on completion of transmission (including zero-length packet transmission).

In single buffer mode, an internal BEMP interrupt request is generated simultaneously with the BRDY interrupt for the pipe other than DCP.

However, the internal BEMP interrupt request is not generated on any of the following conditions.

- When software has already started writing data to the FIFO buffer of the CPU on completion of transmitting data from one FIFO buffer in double buffer mode.
- When the buffer is cleared (emptied) by setting the ACLRM or BCLR bit to 1.
- When IN transfer (zero-length packet transmission) is performed during the control transfer status stage while the function controller function is selected.

[For the pipe set to the receiving direction]

When data whose size is greater than the setting value of MaxPacketSize is successfully received.

In this case, the USB module generates a BEMP interrupt request, sets the corresponding PIPEnBEMP bit in the BEMPSTS register to 1, discards the received data, and modifies the setting of the PID bits of the corresponding pipe to STALL (11B).

Here, the USB module returns no response when used as the host controller, and returns STALL response when used as the function controller.

However, the internal BEMP interrupt request is not generated on any of the following conditions.

- When a CRC error or a bit stuffing error is detected in the received data.
- When a setup transaction is being performed.

Writing 0 to the PIPEnBEMP bit in the BEMPSTS register clears the status. Writing 1 to the PIPEnBEMP bit in the BEMPSTS register has no effect.



Figure 13 - 59 shows the Timing of BEMP Interrupt Generation When Function Controller Function is Selected.

#### Figure 13 - 59 Timing of BEMP Interrupt Generation When Function Controller Function is Selected

| (1) Example of data tra                                      | ansmission                                                |                                                   |
|--------------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------|
| USB bus                                                      | IN Token Packet     Data Packet     ACK Handshake         |                                                   |
| Buffer status                                                | Ready for transmission                                    | Ready for write access<br>(there is no data to be |
| BEMP interrupt<br>(change in correspondi<br>bit in PIPEBEMP) | ng                                                        | transmitted)                                      |
| (2) Example of data re                                       | ception                                                   |                                                   |
| USB bus                                                      | OUT Token Packet – Data Packet (Maximum – STALL Handshake | ]                                                 |
| BEMP interrupt<br>(change in correspondi<br>bit in PIPEBEMP) | ng                                                        |                                                   |
| Packet transmitted by                                        | host device Packet transmitted by peripheral device       |                                                   |



#### 13.4.3.4 Device state transition interrupt

Figure 13 - 60 is a diagram of Device State Transitions in the USB module. The USB module controls device state and generates device state transition interrupts. However, recovery from the suspended state (resume signal detection) is detected by means of the resume interrupt. The device state transition interrupts can be enabled or disabled individually using the INTENB0 register. The device state to which a transition was made can be confirmed using the DVSQ2 to DVSQ0 bits in the INTSTS0 register.

When a transition is made to the default state, a device state transition interrupt is generated after a USB bus reset is detected.

Device state can be controlled only when the function controller function is selected. The device state transition interrupts can also be generated only when the function controller function is selected.



Figure 13 - 60 Device State Transitions





### 13.4.3.5 Control transfer stage transition interrupt

Figure 13 - 61 is a diagram of Control Transfer Stage Transitions in the USB module. The USB module controls the control transfer sequence and generates control transfer stage transition interrupts. The control transfer stage transition interrupts can be enabled or disabled individually using the INTENB0 register. The transfer stage to which a transition was made can be confirmed using the CTSQ2 to CTSQ0 bits in the INTSTS0 register. Control transfer stage transition interrupts are generated only when the function controller function is selected. The control transfer sequence errors are listed below. If an error occurs, the PID bits in the DCPCTR register are set to 1xB (STALL response).

- (1) During control read transfer
- An OUT token is received while no data has been transferred for the IN token at the data stage.
- An IN token is received at the status stage.
- A data packet with DATAPID = DATA0 is received at the status stage.
- (2) During control write transfer
- An IN token is received while no ACK response has been returned for the OUT token at the data stage.
- A data packet with DATAPID = DATA0 is received for the first data packet at the data stage.
- An OUT token is received at the status stage.
- (3) During no-data control transfers
- An OUT token is received at the status stage.

At the control write transfer data stage, if the number of receive data exceeds the wLength value of the USB request, it cannot be recognized as a control transfer sequence error. At the control read transfer status stage, packets other than zero-length packets are received by an ACK response and the transfer ends normally. When a CTRT interrupt occurs in response to a sequence error (SERR = 1), the CTSQ2 to CTSQ0 bits = 110B value is retained until CTRT = 0 is written from the system (the interrupt status is cleared). Therefore, while the CTSQ2 to CTSQ0 bits = 110B is being held, the CTRT interrupt that ends the setup stage will not be generated even if a new USB request is received. (The USB module retains the setup stage end, and after the interrupt status has been cleared by software, a setup stage end interrupt is generated.)





Figure 13 - 61 Control Transfer Stage Transitions

# 13.4.3.6 Frame update interrupt

With the host controller function selected, an interrupt is generated at the timing when the frame number is updated. With the function controller function selected, an SOFR interrupt is generated when the frame number is updated.

When the function controller function is selected, the USB module updates the frame number and generates an SOFR interrupt if it detects a new SOF packet during full-speed operation.

# 13.4.3.7 VBUS interrupt

When the VBUS pin level changes, a VBUS interrupt is generated. The level of the VBUS pin can be checked with the VBSTS bit in the INTSTS0 register. Whether the host controller is connected or disconnected can be confirmed using the VBUS interrupt. However, if the system is activated with the host controller connected, the first VBUS interrupt is not generated because there is no change in the VBUS pin level.

### 13.4.3.8 Resume interrupt

When the function controller function is selected, a resume interrupt is generated when the device state is the suspended state and the USB bus state has changed (from J-state to K-state, or from J-state to SE0). Recovery from the suspended state is detected by means of the resume interrupt.

When the host controller function is selected, no resume interrupt is generated. Use the BCHG interrupt to detect a change in the USB bus state.

### 13.4.3.9 Overcurrent interrupt

For USB port 0, an overcurrent interrupt (OVRCR interrupt) is generated when the UOVRCUR0 pin level has changed. The level of the UOVRCUR0 pin can be checked with the OVCMON1 and OVCMON0 bits in the SYSSTS0 register. The external power-supply IC can check whether overcurrent has been detected using the OVRCR interrupt.



For USB port 1, an OVRCR interrupt is generated when the UOVRCUR1 pin level has changed. The level of the UOVRCUR1 pin can be checked with the OVCMON1 and OVCMON0 bits in the SYSSTS1 register. The external power-supply IC can check whether overcurrent has been detected using the OVRCR interrupt.

### 13.4.3.10 Bus change interrupt

A bus change interrupt (BCHG interrupt) is generated when the USB bus state has changed. The BCHG interrupt can be used to detect whether the peripheral device is connected and can also be used to detect a remote wakeup when the host controller function is selected. The BCHG interrupt is generated regardless of whether the host controller function or function controller function is selected.

### 13.4.3.11 USB disconnection detection interrupt

A USB disconnection detection interrupt (DTCH interrupt) is generated when disconnection of the USB bus is detected while the host controller function is selected. The USB module detects bus disconnection based on USB Specification 2.0.

After detecting a DTCH interrupt, the USB module controls hardware as described below (irrespective of the value set in the corresponding interrupt enable bit). Software should terminate all pipes in which communications are currently carried out for the pertinent port and make a transition to the wait state for bus connection to the pertinent port (wait state for ATTCH interrupt generation).

- Modifies the UACT bit for the port in which a DTCH interrupt has been detected to 0.
- Puts the port in which a DTCH interrupt has been generated into the idle state.

### 13.4.3.12 Setup transaction normal response interrupt

A setup transaction normal response interrupt (SACK interrupt) is generated when an ACK response for the transmitted setup packet has been received from the peripheral device with the host controller function selected. The SACK interrupt can be used to confirm that the setup transaction has been completed successfully.

### 13.4.3.13 Setup transaction error interrupt

A setup transaction error interrupt (SIGN interrupt) is generated when an ACK response for the transmitted setup packet has not been correctly received from the peripheral device three consecutive times with the host controller function selected. The SIGN interrupt can be used to detect no ACK response transmitted from the peripheral device or corruption of an ACK packet.

# 13.4.3.14 Connection interrupt

A connection interrupt (ATTCH interrupt) is generated when J-state or K-state of the full-speed/low-speed signal level is detected on the USB port for  $2.5 \,\mu$ s with the host controller function selected. To be more specific, an ATTCH interrupt is detected on any of the following conditions.

- $\bullet$  When K-state, SE0, or SE1 changes to J-state, and J-state continues 2.5  $\mu s.$
- $\bullet$  When J-state, SE0, or SE1 changes to K-state, and K-state continues 2.5  $\mu s.$

### 13.4.3.15 EOF error interrupt

An EOF error interrupt (EOFERR interrupt) is generated when it is detected that communication is not completed at the EOF2 timing prescribed in USB Specification 2.0.

After detecting an EOFERR interrupt, the USB module controls hardware as described below (irrespective of the value set in the corresponding interrupt enable bit). Software should terminate all pipes in which communications are currently carried out for the pertinent port and perform re-enumeration of the pertinent port.



- Modifies the UACT bit in the DVSTCTR0 register for the port in which an EOFERR interrupt has been detected to 0.
- Puts the port in which an EOFERR interrupt has been generated into the idle state.

### 13.4.3.16 Portable device detection interrupt

A Portable Device detection interrupt is generated when the USB module detects a level change (high from low or low from high) in the PDDET output from the USB-PHY. When a Portable Device detection interrupt is generated, use software to repeat reading the PDDETSTS bit until the same value is read three or more times, and eliminate chattering.



#### 13.4.4 Pipe control

Table 13 - 19 lists the Pipe Settings in the USB module. With USB data transfer, data transfer has to be carried out using the logic pipe called the endpoint. The USB module has five pipes that are used for data transfer. Appropriate settings should be made for each of the pipes according to the specifications of the system.

| Register Name       | Bit Name | Setting                                            | Remarks                                                                                                               |  |
|---------------------|----------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|
| DCPCFG TYPE         |          | Specifies the transfer type                        | PIPE4, PIPE5: Can be set                                                                                              |  |
| PIPECFG             | BFRE     | Selects the BRDY interrupt mode                    | PIPE4, PIPE5: Can be set                                                                                              |  |
|                     | DBLB     | Selects double buffer mode                         | PIPE4, PIPE5: Can be set                                                                                              |  |
|                     | DIR      | Selects transfer direction                         | IN or OUT can be set                                                                                                  |  |
|                     | EPNUM    | Endpoint number                                    | PIPE4, PIPE5: Can be set<br>A value other than 0000B should be set when the pipe is<br>used.                          |  |
|                     | SHTNAK   | Selects disabled state for pipe when transfer ends | PIPE4, PIPE5: Can be set                                                                                              |  |
| DCPMAXP<br>PIPEMAXP | DEVSEL   | Selects a device                                   | Referenced only when the host controller function is selected.                                                        |  |
|                     | MXPS     | Maximum packet size                                | Compliant with the USB standard.                                                                                      |  |
| PIPEPERI            | IFIS     | Buffer flush                                       | PIPE4 to PIPE7: Cannot be set                                                                                         |  |
|                     | IITV     | Interval counter                                   | PIPE4, PIPE5: Cannot be set<br>PIPE6, PIPE7: Can be set (only when the host controller<br>function has been selected) |  |
| DCPCTR<br>PIPEnCTR  | BSTS     | Buffer status                                      | For the DCP, receive buffer status and transmit buffer status are switched with the ISEL bit.                         |  |
|                     | INBUFM   | IN buffer monitor                                  | Available only for PIPE4, PIPE5.                                                                                      |  |
|                     | SUREQ    | SETUP request                                      | Can be set only for the DCP.<br>Can be controlled only when the host controller function<br>has been selected.        |  |
|                     | SUREQCLR | SUREQ request clear                                | Can be set only for the DCP.<br>Can be controlled only when the host controller function<br>has been selected.        |  |
|                     | ATREPM   | Auto response mode                                 | PIPE4, PIPE5: Can be set<br>Can be set only when the function controller function has<br>been selected.               |  |
|                     | ACLRM    | Auto buffer clear                                  | PIPE4 to PIPE7: Can be set                                                                                            |  |
|                     | SQCLR    | Sequence clear                                     | Clears the data toggle bit.                                                                                           |  |
|                     | SQSET    | Sequence set                                       | Sets the data toggle bit.                                                                                             |  |
|                     | SQMON    | Sequence monitor                                   | Monitors the data toggle bit.                                                                                         |  |
|                     | PBUSY    | Pipe busy status                                   | Monitors if the pipe is busy.                                                                                         |  |
|                     | PID      | Response PID                                       | Refer to 13.4.4.6 Response PID.                                                                                       |  |
| PIPEnTRE            | TRENB    | Transaction counter enable                         | PIPE4, PIPE5: Can be set                                                                                              |  |
|                     | TRCLR    | Current transaction counter clear                  | PIPE4, PIPE5: Can be set                                                                                              |  |
| PIPEnTRN            | TRNCNT   | Transaction counter                                | PIPE4, PIPE5: Can be set                                                                                              |  |

Table 13 - 19 Pipe Settings

### 13.4.4.1 Pipe control register switching procedures

The following bits in the pipe control registers can be modified only when USB communication is disabled (PID = NAK).

Registers that Should Not be Set in the USB Communication Enabled (PID = BUF) State:

- Bits in the DCPCFG and DCPMAXP registers
- The SQCLR and SQSET bits in the DCPCTR registers
- Bits in the PIPECFG, PIPEMAXP, and PIPEPERI registers
- The ATREPM, ACLRM, SQCLR, and SQSET bits in the PIPEnCTR register
- Bits in the PIPEnTRE and PIPEnTRN registers

In order to modify the above bits in the USB communication enabled (PID = BUF) state, follow the procedure shown below:

- (1) A request to modify bits in the pipe control register occurs.
- (2) Modify the PID corresponding to the pipe to NAK.
- (3) Wait until the corresponding PBUSY bit is cleared to 0.
- (4) Modify the bits in the pipe control register.

The following bits in the pipe control registers can be modified only when the pertinent pipe information has not been set by the CURPIPE bit in the CFIFOSEL, D0FIFOSEL, and D1FIFOSE registers.

Registers that Should Not be Set When CURPIPE in FIFO-PORT is set:

- Bits in the DCPCFG and DCPMAXP registers
- Bits in the PIPECFG, PIPEMAXP and PIPEPERI registers

In order to modify pipe information, the CURPIPE bits in the port select registers should be set to a pipe other than the pipe to be modified. For the DCP, the buffer should be cleared using BCLR after the pipe information is modified.

### 13.4.4.2 Transfer types

The TYPE bits in the PIPEPCFG register are used to specify the transfer type for each pipe. The transfer types that can be set for the pipes are as follows.

- DCP: No setting is necessary (fixed at control transfer).
- PIPE4, PIPE5: These should be set to bulk transfer.
- PIPE6, PIPE7: These should be set to interrupt transfer.

### 13.4.4.3 Endpoint number

The EPNUM bits in the PIPEPCFG register are used to set the endpoint number for each pipe. The DCP is fixed at endpoint 0. The other pipes can be set from endpoint 1 to endpoint 15.

- DCP: No setting is necessary (fixed at end point 0).
- PIPE4 to PIPE7: The endpoint numbers from 1 to 15 should be selected and set. These should be set so that the combination of the DIR bit and EPNUM bits is unique.

#### 13.4.4.4 Maximum packet size setting

The MXPS bits in the DCPMAXP and PIPEMAXP registers are used to specify the maximum packet size for each pipe. DCP and PIPE4, PIPE5 can be set to any of the maximum pipe sizes defined by the USB



specification. For PIPE6, PIPE7, 64 bytes are the upper limit of the maximum packet size. The maximum packet size should be set before beginning the transfer (PID = BUF).

- DCP: Set 8, 16, 32, or 64.
- PIPE4, PIPE5: Set 8, 16, 32, or 64 when using bulk transfer.
- PIPE6, PIPE7: Set a value between 1 and 64.

### 13.4.4.5 Transaction counter (for PIPE4, PIPE5 in reading direction)

When the specified number of transactions has been completed in the data packet receiving direction, the USB module recognizes that the transfer has ended. Two transaction counters are provided: one is the TRNCNT register that specifies the number of transactions to be executed and the other is the current counter that internally counts the number of executed transactions. With the SHTNAK bit set to 1, when the current counter value matches the specified number of transactions, the PID of the corresponding PIPE is set to NAK and the subsequent transfer is disabled. The transactions can be counted again from the beginning by initializing the current counter of the transaction counter function through the TRCLR bit. The information read from TRNCNT differs depending on the setting of the TRENB bit.

- TRENB = 0:The specified transaction counter value can be read.
- TRENB = 1:The current counter value indicating the internally counted number of executed transactions can be read.

When operating the TRCLR bit, the following should be noted.

- If the transactions are being counted and PID = BUF, the current counter cannot be cleared.
- If there is any data left in the buffer, the current counter cannot be cleared.

#### 13.4.4.6 Response PID

The PID bits in DCPCTR and PIPEnCTR are used to set the response PID for each pipe. The following shows the USB module operation with various response PID settings:

- (1) Response PID settings when the host controller function is selected
- The response PID is used to specify the execution of transactions.
- NAK setting: Using pipes is disabled. No transaction is executed.
- BUF setting: Transactions are executed based on the status of the buffer memory.
- For OUT direction: If there are transmit data in the buffer memory, an OUT token is issued.
- For IN direction: If there is an area to receive data in the buffer memory, an IN token is issued.
- STALL setting: Using pipes is disabled. No transaction is executed.

#### Caution Setup transactions for the DCP are set with the SUREQ bit.

(2) Response PID settings when the function controller function is selected

The response PID is used to specify the response to transactions from the host.

- NAK setting: The NAK response is always returned in response to the generated transaction.
- BUF setting: Responses are made to transactions according to the status of the buffer memory.
- STALL setting: The STALL response is always returned in response to the generated transaction.

# Caution For setup transactions, an ACK response is always returned regardless of the PID setting, and the USB request is stored in the register.

The USB module may write to the PID bits, depending on the results of the transaction as described below.

(3) When the host controller function has been selected and the response PID is set by hardware NAK setting: In the following cases, PID = NAK is set and issuing of tokens is automatically stopped:

- When an NRDY interrupt is generated.(For details, refer to 13.4.3.2 NRDY interrupt.)
- If a short packet is received when the SHTNAK bit in the PIPECFG register has been set to 1 for bulk transfer.
- If the transaction counting ends when the SHTNAK bit has been set to 1 for bulk transfer.

BUF setting: There is no BUF writing by the USB module.

- STALL setting: In the following cases, PID = STALL is set and issuing of tokens is automatically stopped:
- When STALL is received in response to the transmitted token.
- When the size of the receive data packet exceeds the maximum packet size.

(4) When the function controller function has been selected and the response PID is set by hardware NAK setting: In the following cases, PID = NAK is set and NAK is always returned in response to transactions:

- When the SETUP token is received normally (DCP only).
- If the transaction counting ends or a short packet is received when the SHTNAK bit in PIPECFG has been set to 1 for bulk transfer.

BUF setting: There is no BUF writing by the USB module.

STALL setting: In the following cases, PID = STALL is set and STALL is always returned in response to transactions:

- When a maximum packet size exceeded error is detected in the received data packet.
- When a control transfer sequence error has been detected (DCP only).

#### 13.4.4.7 Data PID sequence bit

The USB module automatically toggles the sequence bit in the data PID when data is transferred successfully in the control transfer data stage, bulk transfer, and interrupt transfer. The sequence bit of the next data PID to be transmitted can be confirmed with the SQMON bit in the DCPCTR and PIPEnCTR registers. When data is transmitted, the sequence bit switches at the timing of ACK handshake reception. When data is received, the sequence bit switches at the timing of ACK handshake transmission. The SQCLR bit in the DCPCTR register and the SQSET bit in the PIPEnCTR register can be used to change the data PID sequence bit. When the function controller function has been selected and control transfer is used, the USB module automatically sets the sequence bit when a stage transition is made. DATA0 is returned when the setup stage is ended and DATA1 is returned in a status stage. Therefore, software settings are not required. However, when the host controller function has been selected and control transfer is used, the sequence bit should be set by software at a stage transition.

For the ClearFeature request transmission or reception, the data PID sequence bit should be set by software regardless of whether the host controller function or function controller function is selected.

#### 13.4.4.8 Response PID = NAK function

The USB module has a function that disables pipe operation (PID response = NAK) at the timing at which the final data packet of a transaction is received (the USB module automatically distinguishes this based on reception of a short packet or the transaction counter) by setting the SHTNAK bit in the PIPECFG register to 1. When the double buffer mode is being used for the buffer memory, using this function enables reception of data packets in transfer units. If pipe operation has been disabled, software should set the pipe to the enabled state again (PID response = BUF).

The response PID = NAK function can be used only when bulk transfers are used.

#### 13.4.4.9 Auto response mode

With the pipes for bulk transfer (PIPE4, PIPE5), when the ATREPM bit in the PIPEnCTR register is set to 1, a transition is made to auto response mode. During an OUT transfer (DIR = 0), OUT-NAK mode is entered, and during an IN transfer (DIR = 1), null auto response mode is entered.



### 13.4.4.10 OUT-NAK mode

With the pipes for bulk OUT transfer, NAK is returned in response to an OUT token and an NRDY interrupt is output when the ATREPM bit is set to 1. To make a transition from normal mode to OUT-NAK mode, OUT-NAK mode should be specified in the pipe operation disabled state (response PID = NAK) before enabling pipe operation (response PID = BUF). After pipe operation has been enabled, OUT-NAK mode becomes valid. However, if an OUT token is received immediately before pipe operation is disabled, the token data is normally received, and an ACK is retuned to the host.

To make a transition from OUT-NAK mode to normal mode, OUT-NAK mode should be canceled in the pipe operation disabled state (response PID = NAK) before enabling pipe operation (response PID = BUF). In normal mode, reception of OUT data is enabled.

### 13.4.4.11 Null auto response mode

With the pipes for bulk IN transfer, zero-length packets are continuously transmitted when the ATREPM bit is set to 1.

To make a transition from normal mode to null auto response mode, null auto response mode should be set in the pipe operation disabled state (response PID = NAK) before enabling pipe operation (response PID = BUF). After pipe operation has been enabled, null auto response mode becomes valid. Before setting null auto response mode, the INBUFM bit = 0 should be confirmed because the mode can be set only when the buffer is empty. If the INBUFM bit is 1, the buffer should be emptied with the ACLRM bit. While a transition to null auto response mode is being made, data should not be written from the FIFO port.

To make a transition from null auto response mode to normal mode, pipe operation disabled state (response PID = NAK) should be retained for the period of zero-length packet transmission (about 10  $\mu$ s) before canceling null auto response mode. In normal mode, data can be written from the FIFO port; therefore, packet transmission to the host is enabled by enabling pipe operation (response PID = BUF).



# 13.4.5 FIFO buffer memory

#### 13.4.5.1 FIFO buffer memory

The USB module has FIFO buffer memory for data transfer. The memory area used for each pipe is managed by the USB module. The FIFO buffer memory has two states depending on whether the access right is assigned to the system (CPU side) or the USB module (SIE side).

#### (1) Buffer Status

Tables 13 - 20 and 13 - 21 show the buffer status in the USB module. The buffer memory status can be confirmed using the BSTS bit in the DCPCTR register and the INBUFM bit in the PIPEnCTR register. The access direction for the buffer memory can be specified using either the DIR bit in the PIPEnCFG register or the ISEL bit in the CFIFOSEL register (when DCP is selected).

The INBUFM bit is valid for PIPE4, PIPE5 in the transmitting direction.

When a transmitting pipe uses the double buffer configuration, software can read the BSTS bit to monitor the buffer memory status on the CPU side and the INBUFM bit to monitor the buffer memory status on the SIE side. When the BEMP interrupt may not show the buffer empty status because the write access to the FIFO port by the CPU is slow, software can use the INBUFM bit to confirm the end of transmission.

| ISEL or DIR                | BSTS | Buffer Memory Status                                                                                                                                                                                                        |
|----------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 (receiving direction)    | 0    | There is no received data, or data is being received.<br>Reading from the FIFO port is disabled.                                                                                                                            |
| 0 (receiving direction)    | 1    | There is received data, or a zero-length packet has been received.<br>Reading from the FIFO port is allowed.<br>Note that when a zero-length packet is received, reading is not possible and the buffer<br>must be cleared. |
| 1 (transmitting direction) | 0    | The transmission has not been completed.<br>Writing to the FIFO port is disabled.                                                                                                                                           |
| 1 (transmitting direction) | 1    | The transmission has been completed.<br>CPU write is allowed.                                                                                                                                                               |

#### Table 13 - 20 Buffer Status Indicated by BSTS Bit

#### Table 13 - 21 Buffer Status Indicated by INBUFM Bit

| DIR                        | INBUFM  | Buffer Memory Status                                                                |  |
|----------------------------|---------|-------------------------------------------------------------------------------------|--|
| 0 (receiving direction)    | Invalid | Invalid                                                                             |  |
| 1 (transmitting direction) | 0       | The transmission has been completed.<br>There is no waiting data to be transmitted. |  |
| 1 (transmitting direction) | 1       | The FIFO port has written data to the buffer.<br>There is data to be transmitted.   |  |



#### (2) FIFO Buffer Clearing

Tables 13 - 22 shows the clearing of the FIFO buffer memory by the USB module. The buffer memory can be cleared using the BCLR, DCLRM, and ACLRM bits.

| FIFO Buffer Clearing Mode | Clearing Buffer Memory on<br>CPU Side | Mode for Automatically Clearing<br>Buffer Memory after Reading<br>Specified Pipe Data | Auto Buffer Clear Mode for<br>Discarding All Received<br>Packets |
|---------------------------|---------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------|
| Register used             | CFIFOCTR<br>DnFIFOCTR                 | DnFIFOSEL                                                                             | PIPEnCTR                                                         |
| Bit used                  | BCLR                                  | DCLRM                                                                                 | ACLRM                                                            |
| Clearing condition        | Cleared by writing 1                  | 1: Mode valid<br>0: Mode invalid                                                      | 1: Mode valid<br>0: Mode invalid                                 |

#### (3) Auto Buffer Clear Mode Function

With the USB module, all received data packets are discarded if the ACLRM bit in the PIPEnCTR register is set to 1. If a correct data packet has been received, the ACK response is returned to the host controller. The auto buffer clear mode function can be set only in the buffer memory reading direction.

If the ACLRM bit is set to 1 and then to 0, the buffer memory of the selected pipe can be cleared regardless of the access direction.

However, an access cycle of at least 100 ns is required for the internal hardware sequence processing time between the ACLRM bit = 1 and the ACLRM bit = 0.

(4) Buffer Memory Specifications (Single or Double Setting)

Either a single or double buffer configuration can be selected for PIPE4 and PIPE5, using the DBLB bit in the PIPEnCFG register.



## 13.4.5.2 FIFO port functions

Tables 13 - 23 shows the FIFO Port Function Settings for the USB module. In write access, writing data until the maximum packet size is reached automatically enables transmission of the data. To enable transmission before the maximum packet size is reached, the BVAL bit in the CFIFOCTR or DnFIFOCTR register should be set to end writing. To send a zero-length packet, the BCLR bit in the register should be used to clear the buffer and then the BVAL bit set in order to end writing.

In read access, reception of new packets is automatically enabled when all data has been read. Data cannot be read when a zero-length packet has been received (DTLN = 0), so the BCLR bit in the register should be used to clear the buffer. The length of the receive data can be confirmed using the DTLN bits in the CFIFOCTR or DnFIFOCTR register.

| Register Name | Bit Name | Function                                                                             | Remark           |
|---------------|----------|--------------------------------------------------------------------------------------|------------------|
| CFIFOSEL      | RCNT     | Selects DTLN read mode.                                                              |                  |
| DnFIFOSEL     | REW      | Buffer memory rewind (re-read, rewrite).                                             |                  |
|               | DCLRM    | Automatically clears receive data for a specified pipe after the data has been read. | Only for DnFIFO. |
|               | MBW      | Selects the FIFO port access bit width.                                              |                  |
|               | BIGEND   | Selects FIFO port endian.                                                            |                  |
|               | ISEL     | FIFO port access direction.                                                          | Only for DCP.    |
|               | CURPIPE  | Selects the current pipe.                                                            |                  |
| CFIFOCTR      | BVAL     | Ends writing to the buffer memory.                                                   |                  |
| DnFIFOCTR     | BCLR     | Clears the buffer memory on the CPU side.                                            |                  |
|               | DTLN     | Checks the length of receive data.                                                   |                  |

#### Table 13 - 23 FIFO Port Function Settings

#### (1) FIFO Port Selection

Table 13 - 24 shows the pipes that can be selected with the various FIFO ports. The pipe to be accessed should be selected using the CURPIPE bits in the CFIFOSEL or DnFIFOCTR register. After the pipe is selected, whether the written value can be correctly read from the CURPIPE bits should be checked. (If the previous pipe number is read, it indicates that the pipe modification is being executed by the USB controller.) Then, the FIFO port can be accessed after FRDY = 1 is checked.

In addition, the bus width to be accessed should be selected using the MBW bit. The buffer memory access direction conforms to the DIR bit in the PIPEnCFG register. Only for the DCP, the ISEL bit determines the direction.

| Pipe           | Access Method | Port that can be Used                                                         |
|----------------|---------------|-------------------------------------------------------------------------------|
| DCP            | CPU access    | CFIFO port register (CFIFOM)                                                  |
| PIPE4 to PIPE7 |               | CFIFO port register (CFIFOM)<br>D0FIFO/D1FIFO port register (D0FIFOM/D1FIFOM) |



#### (2) REW Bit

It is possible to temporarily stop access to the pipe currently being accessed, access a different pipe, and then continue processing for the current pipe again. The REW bit in the CFIFOSEL or DnFIFOSEL register is used for this processing.

If a pipe is selected through the CURPIPE bits in the CFIFOSEL or DnFIFOSEL register with the REW bit set to 1, the pointer used for reading from and writing to the buffer memory is reset, and reading or writing can be carried out from the first byte. If a pipe is selected with 0 set for the REW bit, data can be read and written in continuation from the previous selection, without the pointer being reset.

To access the FIFO port, FRDY = 1 should be checked after selecting a pipe.



## 13.4.6 Control transfers (DCP)

In the data stage of control transfers, data is transferred using the default control pipe (DCP). The DCP buffer memory is a 64-byte single buffer and is a fixed area that is shared for both control reading and control writing. The buffer memory can be accessed only through the CFIFO port.

## 13.4.6.1 Control transfers when host controller function is selected

#### (1) Setup Stage

USQREQ, USBVAL, USBINDX, and USBLENG are the registers that are used to transmit a USB request for setup transactions. Writing setup packet data to the registers and writing 1 to the SUREQ and bit in the DCPCTR register transmits the specified data for setup transactions. Upon completion of the transaction, the SUREQ bit is cleared to 0. The above USB request registers should not be modified while SUREQ = 1.

After the attached state of the connected function device is detected, the first setup transaction for the device should be issued by using the sequence described above with the DEVSEL bits in the DCPMAXP register set to 0 and the USBSPD and RTPORT bits in the DEVADD0 register set appropriately.

After the connected function device is shifted to the Address state, setup transactions should be issued by using the sequence described above with the assigned USB address set in the DEVSEL bits and the bits in the DEVADDn register corresponding to the specified USB address set appropriately. For example, when the DEVSEL bit in the PIPEMAXP register = 2H, make appropriate settings in the DEVADD2 register; when the DEVSEL bit = 5H, make appropriate settings in the DEVADD5 register.

When the setup transaction data has been sent, an interrupt request is generated according to the response received from the peripheral device (SIGN1 or SACK bit in the INTSTS1 register), by means of which the result of the setup transactions can be confirmed.

A data packet of DATA0 (USB request) is transmitted as the data packet for a setup transaction regardless of the setting of the SQMON bit in the DCPCTR register.

#### (2) Data Stage

Data is transferred using the DCP buffer memory.

The access direction of the DCP buffer memory should be specified using the ISEL bit in the CFIFOSEL register. The transfer direction should be specified using the DIR bit in the DCPCFG register.

For the first data packet of the data stage, the data PID should be transferred as DATA1. Set data PID = DATA1 in the SQSET bit and the PID bits = BUF in the DCPCFG register. Completion of data transfer is detected using the BRDY or BEMP interrupt.

For control write transfers, when the number of data bytes to be sent is an integer multiple of the maximum packet size, software should control so as to send a zero-length packet at the end.

#### (3) Status Stage

Zero-length packet data is transferred in the direction opposite to that in the data stage. As in the data stage, data is transferred using the DCP buffer memory. Transactions are done in the same manner as the data stage. For the data packets of the status stage, the data PID should be set to DATA1 using the SQSET bit in the DCPCFG register.

For reception of a zero-length packet, the received data length should be confirmed using the DTLN bits in the CFIFOCTR register after a BRDY interrupt is generated, and the buffer memory should then be cleared using the BCLR bit.



## 13.4.6.2 Control transfers when function controller function is selected

#### (1) Setup Stage

The USB module always sends an ACK response for a correct setup packet targeted to the USB module. The operation of the USB module in the setup stage is described below.

- (a) When receiving a new setup packet, the USB module sets the following bits.
  - Set the VALID bit in the INTSTS0 register to 1.
  - Set the PID bits in the DCPCTR register to NAK.
  - Set the CCPL bit in the DCPCTR register to 0.
- (b) When receiving a data packet right after the setup packet, the USB module stores the USB request parameters in the USBREQ, USBVAL, USBINDX, and USBLENG registers.

Response processing with respect to the control transfer should always be carried out after setting VALID = 0. In VALID = 1 state, PID = BUF cannot be set, and the data stage cannot be terminated.

Using the function of the VALID bit, the USB module can suspend the current request processing when receiving a new USB request during a control transfer, and can send a response to the newest request.

In addition, the USB module automatically detects the direction bit (bit 8 of bmRequestType) and the request data length (wLength) of the received USB request, distinguishes between control read transfer, control write transfer, and no-data control transfer, and controls stage transitions. For a wrong sequence, the sequence error of the control transfer stage transition interrupt is generated, and the software is notified of occurrence of the error. For control on the stages of the USB module, refer to Figure 13 - 61.

#### (2) Data Stage

Data transfers corresponding to received USB requests should be done using the DCP. Before accessing the DCP buffer memory, the access direction should be specified using the ISEL bit in the CFIFOSEL register. If the transfer data is larger than the size of the DCP buffer memory, the data transfer should be carried out using the BRDY interrupt for control write transfers and the BEMP interrupt for control read transfers.

#### (3) Status Stage

Control transfers are terminated by setting the CCPL bit to 1 while the PID bits in the DCPCTR register are set to BUF.

After the above settings have been made, the USB module automatically executes the status stage in accordance with the data transfer direction determined at the setup stage. The specific procedure is as follows.

#### [For control read transfers]

The USB module receives a zero-length packet and transmits an ACK response.

[For control write transfers and no-data control transfers]

The USB module transmits a zero-length packet and receives an ACK response from the USB host.

#### (4) Control Transfer Auto Response Function

The USB module automatically responds to a correct SET\_ADDRESS request. If any of the following errors occurs in the SET\_ADDRESS request, a response from the software is necessary.

- Any transfer other than a control read transfer:  $bmRequestType \neq 00H$
- Request error: wIndex ≠ 00H
- Any transfer other than a no-data control transfer: wLength  $\neq$  00H
- Request error: wValue > 7FH
- Control transfer of a device state error: DVSQ2 to DVSQ2 bits = 011B (Configured)

For all requests other than the SET\_ADDRESS request, a response is required from the corresponding software.

## 13.4.7 Bulk transfers (PIPE4, PIPE5)

The buffer memory usage (single/double buffer setting) can be selected for bulk transfers. The USB provides the following functions for bulk transfers.

- BRDY interrupt function (BFRE bit: refer to 13.4.3.1 BRDY interrupt.)
- Transaction count function

(TRENB, TRCLR, and TRNCNT bits: refer to **13.4.4.5 Transaction counter (for PIPE4, PIPE5 in reading direction)** 

- Response PID = NAK function (SHTNAK bit: refer to 13.4.4.8 Response PID = NAK function)
- Auto response mode (ATREPM bit: refer to 13.4.4.9 Auto response mode)

## 13.4.8 Interrupt transfers (PIPE6, PIPE7)

When the function controller function is selected, the USB module carries out interrupt transfers in accordance with the timing controlled by the host controller.

When the host controller function is selected, the timing of issuing a token can be specified using the interval counter.

# 13.4.8.1 Interval counter during interrupt transfers when host controller function is selected

For interrupt transfers, intervals between transactions are set in the IITV bits in PIPEPERI. The USB controller issues interrupt transfer tokens based on the specified intervals.

(1) Counter Initialization

The USB controller initializes the interval counter under the following conditions.

• Power-on reset:

The IITV bits are initialized.

• Buffer memory initialization using the ACLRM bit:

The IITV bits are not initialized but the count value is initialized. Setting the ACLRM bit in the PIPEnCTR register to 0 starts counting from the value set in the IITV bits.

Note that the interval counter is not initialized in the following case.

USB bus reset or USB suspended

The IITV bits are not initialized. Setting 1 to the UACT bit in the DVSTCTR0 register starts counting from the value before entering the USB bus reset state or USB suspended state.

#### (2) Operation when Transmission/Reception is Impossible at Token Issuance Timing

The USB module cannot issue tokens even at token issuance timing in the following cases. In such a case, the USB module attempts transactions at the subsequent interval.

- When the PID is set to NAK or STALL.
- When the buffer memory is full at the token sending timing in the receiving (IN) direction.
- When there is no data to be sent in the buffer memory at the token sending timing in the transmitting (OUT) direction.



## **13.4.9** SOF interpolation function

When the function controller function is selected and if data could not be received at intervals of 1 ms because an SOF packet was corrupted or missing, the USB module interpolates the SOF. The SOF interpolation operation begins when the USBE and SCKE bits in the SYSCFG register have been set to 1 and an SOF packet is received. The interpolation function is initialized under the following conditions.

- Power-on reset
- USB bus reset
- Suspended state detected

The SOF interpolation operates as follows.

- The interpolation function is not activated until an SOF packet is received.
- After the first SOF packet is received, interpolation is carried out by counting 1 ms with an internal clock of 48 MHz.
- After the second and subsequent SOF packets are received, interpolation is carried out at the previous reception interval.
- Interpolation is not carried out in the suspended state or while a USB bus reset is being received.

The USB module supports the following functions based on the SOF packet reception. These functions also operate normally with SOF interpolation, if the SOF packet was missing.

- Updating of the frame number
- SOFR interrupt timing

If an SOF packet is missing, the FRNM bit in the FRMNUM register is not updated.



## 13.4.10 Pipe schedule

## 13.4.10.1 Conditions for generating a transaction

When the host controller function is selected and the UACT bit has been set to 1, the USB module generates a transaction under the conditions shown in Table 13 - 25.

| Transaction                                     | Conditions for Generation |        |         |                      |           |  |  |
|-------------------------------------------------|---------------------------|--------|---------|----------------------|-----------|--|--|
| Transaction                                     | DIR                       | PID    | IITV0   | Buffer State         | SUREQ     |  |  |
| Setup                                           | _ Note                    | _ Note | _ Note  | _ Note               | 1 setting |  |  |
| Control transfer data stage, status stage, bulk | IN                        | BUF    | Invalid | Receive area exists  | _ Note    |  |  |
| transfer                                        | OUT                       | BUF    | Invalid | Transmit data exists | _ Note    |  |  |
| Interrupt transfer                              | IN                        | BUF    | Valid   | Receive area exists  | _ Note    |  |  |
|                                                 | OUT                       | BUF    | Valid   | Transmit data exists | _ Note    |  |  |

**Note** Symbols (-) in the table indicate that the condition is unrelated to the generating of tokens. "Valid" indicates that, for interrupt transfers, a transaction is generated only in transfer frames that are based on the interval counter. "Invalid" indicates that a transaction is generated regardless of the interval counter.

## 13.4.10.2 Transfer schedule

This section describes the transfer scheduling within a frame of the USB module. After the USB module sends an SOF, the transfer is carried out in the sequence described below.

(1) Execution of periodic transfers

A pipe is searched in the order of PIPE6 $\rightarrow$ PIPE7, and then, if there is a pipe for interrupt transfer transaction can be generated, the transaction is generated.

(2) Setup transactions for control transfers

The DCP is checked, and if a setup transaction is possible, it is sent.

(3) Execution of bulk transfers, control transfer data stages, and control transfer status stages

A pipe is searched in the order of DCP $\rightarrow$ PIPE4 $\rightarrow$ PIPE5, and then, if there is a pipe for which a transaction for a bulk transfer, a control transfer data stage, or a control transfer status stage can be generated, the transaction is generated.

When a transaction is generated, processing moves to the next pipe transaction regardless of whether the response from the peripheral device is ACK or NAK. If there is time for transfer within the frame, step 3 is repeated.

## 13.4.10.3 Enabling USB communication

Setting the UACT bit in the DVSTCTR register to 1 initiates SOF transmission and transaction generation is enabled.

Setting the UACT bit to 0 stops SOF transmission and a suspend state is entered. If the setting of the UACT bit is changed from 1 to 0, processing stops after the next SOF is sent.



## 13.4.11 Controlling battery charging detection

It is possible to control the processing for data contact detection (D+ line contact check), primary detection (charger detection), and secondary detection (charger verification) in compliance with Battery Charging Specification Revision 1.2.

By executing these processes according to charger detection algorithms, it is possible to determine whether the connected device is a standard downstream port, charging downstream port, or dedicated charging port (function BC connection detection function; USB ports 0 and 1) as a portable device. It is also possible to operate as a charging downstream port or dedicated charging port for a portable device (host BC connection detection function; USB ports 0 and 1).

The above data contact detection, primary detection, and secondary detection are each detected by the interface detection circuit for BC connection detection that is provided along with the USB transceiver. This circuit has a function to connect necessary voltage sources (VDP\_SRC, VDM\_SRC), current source (IDP\_SRC), voltage (VDAT\_REF) detection function, and UDP and UDM pins via a resistor (RDCP\_DAT) to perform connection detection compliant to Battery Charging Specification Revision 1.2. These can be controlled and monitored by setting the bits in BC control register n (USBBCCTRLn) (n = 0, 1).

When using the BC connection detection function, specify PXXCON = 0 and VDDUSBE = 1 to externally apply power to the UVDD pin, or specify PXXCON = 1 and VDDUSBE = 1 (internal USB power supply is used) to internally generate 3.3 V.

The temperature sensor cannot be used and A/D conversion that uses the internal reference voltage cannot be performed when using the BC connection detection function.

Figures 13 - 62 and Figures 13 - 63 show the interface circuit for BC connection detection.

#### Figure 13 - 62 BC Connection Detection Interface Circuit (USB Port 0) with Host/Function BC Connection Detection Function











## 13.4.12 Battery charging connection detection optional functions

For extensibility of the battery charging specifications, the following optional functions are added to control connection detection.

USB port voltage output function (four patterns)

As an optional function of the host BC connection detection function, this function can divide 5 V applied to the UVBUS pin and output to the USB port. Furthermore, this function can detect whether the voltage of the USB port has risen and dropped while the divided voltage is output. It can also detect whether the signal has conflicted with the connected USB port output of the device.

• USB port voltage detection function (16 stages)

As an optional function of the function BC connection detection function, this function can detect the voltage level to be input to the USB port, using the 16-stage reference voltage that is obtained by dividing 5 V to be applied to the UVBUS pin.

After power is supplied to the UV<sub>DD</sub> pin (using an external supply or internal power supply for the USB) and the voltage is applied to the UV<sub>BUS</sub> pin, these functions can control various functions and detection results by setting BC option control register n (USBBCOPTn) (n = 0, 1).

Figure 13 - 64 and Figure 13 - 65 show the Interface Circuit for BC Connection Detection Optional Functions.















### 13.4.13 Battery charging detection processing

It is possible to control to the processing for Data Contact Detection (D+ line contact check), Primary Detection (Charger detection), and Secondary Detection (Charger verification), which are defined by the Battery Charging Specification.

The following shows required operations for a Peripheral Device and a Host Device, individually.

## **13.4.13.1 Processing when function controller is selected**

The following processing is required when operating the USB module as a Portable Device for Battery Charging.

- (1) Detect when the data lines (D+/D-) have made contact and start the processing for Primary Detection.
- (2) After Primary Detection starts, wait 40 ms for masking, and then check the D- voltage level to confirm the Primary Detection result.
- (3) If the Charger is detected during Primary Detection, also start Secondary Detection.
- (4) After Secondary Detection starts, wait 40 ms for masking, and then check the D+ voltage level to confirm the Secondary Detection result.

For the above step (1), after VBUS is detected using the VBINT interrupt and the VBSTS bit, wait for 300 ms to 900 ms by software, and then set the VDPSRCE and IDMSINKE bits in the USBBCCTRL register. Or set the IDPSRCE bit, and after a change from high to low on the D+ line is detected using the LNST bits, clear the IDPSRCE bit and set the VDPSRCE and IDMSINKE bits. The VDPSRCE and IDMSINKE bits must be set at the same time. Note 1

For the above step (2), set the VDPSRCE and IDMSINKE bits and wait for 40 ms by software, and then use the CHGDETSTS bit to verify the Primary Detection result. <sup>Note 2</sup>

For the above step (3), verify that the Charger is detected if the CHGDETSTS bit is set in the above step (2), and then clear the VDPSRCE and IDMSINKE bits and set the VDMSRCE and IDPSINKE bits.

For the above step (4), set the VDMSRCE and IDPSINKE bits and wait for 40 ms by software, and then use the PDDETSTS bit to verify the Secondary Detection result.

Figure 13 - 66 shows the Process Flow for Operating as Portable Device.

- **Note 1.** The Battery Charging Specification describes two implementation methods of the process flow for Data Contact Detection (D+/D- line contact check). One of the methods is to detect a change to logic low due to the pull-down resistor of the Host Device when the D+/D- lines have made contact with the target while the D+ line is held at logic high by applying a current of 7 to 13 uA on the D+ line. The other method is to wait for 300 ms to 900 ms after VBUS is detected.
- Note 2. During Primary Detection, when the voltage on the D- line is detected to be 0.25 V to 0.4 V or above and 0.8 V to 2.0 V or below, the target device is recognized as the Host Device for Battery Charging (Charging Downstream Port).
   When using a PHY in which the 0CHGDETSTS bit only indicates that the voltage on the D- line is

When using a PHY in which the OCHGDETSTS bit only indicates that the voltage on the D- line is 0.25 V to 0.4 V or above, add the processing to check that the voltage on D- line is 0.8 V to 2.0 V or below using the LNST bits, as necessary.









## 13.4.13.2 Processing when host controller is selected

The following processing is required when operating the USB module as a Charging Downstream Port for Battery Charging.

- (1) Start driving the VBUS.
- (2) Enable the Portable Device detection circuit.
- (3) Monitor the Portable Device detection signal, and start driving the D- line if the detection signal is high.
- (4) Detect when the Portable Device detection signal is low level and stop driving the D- line.

Or perform the following processing.

- (A) After disconnection is detected, start driving the D- line within 200 ms.
- (B) After connection is detected, stop driving the D- line within 10 ms.

The D- line must be driven to allow the Portable Device to detect the Primary Detection described in section 13.4.13.1. The above steps (1) to (4) apply when the Portable Device detection function is provided by hardware. This method is to drive the D- line when the Portable Device is detected. The above steps (A) and (B) apply when the Portable Device function is not provided or used by hardware. Regardless of detection of the Portable Device, the D- line is driven in the Dis-Connect state and the line is not driven in the Connect state. In the Battery Charging Specification, either of these methods can be used.

For the above steps (3) and (4), after a change in the Portable Device detection signal is detected using the PDDETINT interrupt, the current signal state can be confirmed by reading the PDDETSTS bit.

The above steps (A) and (B) can be performed only in a software timer.

Figure 13 - 67 shows the above process flow for the above steps (1) to (4) and Figure 13 - 68 shows the process flow for the above steps (A) to (B).





Figure 13 - 67 Process Flow for Operating as Charging Downstream Port (Steps (1) to (4))





#### Figure 13 - 68 Process Flow for Operating as Charging Downstream Port (Steps (A) to (B))



## **CHAPTER 14 INTERRUPT FUNCTIONS**

The interrupt function switches the program execution to other processing. When the branch processing is finished, the program returns to the interrupted processing.

The number of interrupt sources differs, depending on the product.

|                     |          | with USB | without USB |
|---------------------|----------|----------|-------------|
|                     |          | 32-pin   | 32-pin      |
| Maskable interrupts | External | 14       | 16          |
|                     | Internal | 22       | 21          |

## 14.1 Interrupt Function Types

The following two types of interrupt functions are used.

(1) Maskable interrupts

These interrupts undergo mask control. Maskable interrupts can be divided into four priority groups by setting the priority specification flag registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H).

Multiple interrupt servicing can be applied to low-priority interrupts when high-priority interrupts are generated. If two or more interrupt requests, each having the same priority, are simultaneously generated, then they are processed according to the default priority of vectored interrupt servicing. Default priority, see **Table 14 - 1**. A standby release signal is generated and STOP, HALT, and SNOOZE modes are released. External interrupt requests and internal interrupt requests are provided as maskable interrupts.

(2) Software interrupt

This is a vectored interrupt generated by executing the BRK instruction. It is acknowledged even when interrupts are disabled. The software interrupt does not undergo interrupt priority control.

## 14.2 Interrupt Sources and Configuration

Interrupt sources include maskable interrupts and software interrupts. In addition, they also have up to seven reset sources (see **Table 14 - 1**). The vector codes that store the program start address when branching due to the generation of a reset or various interrupt requests are two bytes each, so interrupts jump to a 64 K address of 00000H to 0FFFFH.



|                |                         |                                  | Interrupt Source                                                                                                                  |                   |                      | 2                             |              |              |
|----------------|-------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------|-------------------------------|--------------|--------------|
| Interrupt Type | Default Priority Note 1 | Name                             | Trigger                                                                                                                           | Internal/External | Vector Table Address | Basic Configuration Type Note | with USB     | without USB  |
|                | 0                       | INTWDTI                          | Watchdog timer interval <sup>Note 3</sup><br>(75% of overflow time + 1/2 fiL)                                                     | Internal          | 0004H                | (A)                           | ~            | ~            |
|                | 1                       | INTLVI                           | Voltage detection Note 4                                                                                                          |                   | 0006H                |                               | $\checkmark$ | $\checkmark$ |
|                | 2                       | INTP0                            | Pin input edge detection                                                                                                          | External          | 0008H                | (B)                           | ~            | ~            |
|                | 3                       | INTP1                            |                                                                                                                                   |                   | 000AH                |                               | $\checkmark$ | $\checkmark$ |
|                | 4                       | INTP2                            |                                                                                                                                   |                   | 000CH                |                               | $\checkmark$ | $\checkmark$ |
|                | 5                       | INTP3                            |                                                                                                                                   |                   | 000EH                |                               | $\checkmark$ | $\checkmark$ |
|                | 6                       | INTP4                            |                                                                                                                                   |                   | 0010H                |                               | $\checkmark$ | $\checkmark$ |
|                | 7                       | INTP5                            |                                                                                                                                   |                   | 0012H                |                               | $\checkmark$ | $\checkmark$ |
|                | 8                       | INTP6                            |                                                                                                                                   |                   | 0014H                |                               | $\checkmark$ | $\checkmark$ |
|                | 9                       | INTST0/<br>INTCSI00/<br>INTIIC00 | UART0 transmission transfer end or buffer empty interrupt/<br>CSI00 transfer end or buffer empty interrupt/<br>IIC00 transfer end | Internal          | 0016H                | (A)                           | ~            | ~            |
|                | 10                      | INTSR0/<br>INTCSI01/<br>INTIIC01 | UART0 reception transfer end/<br>CSI01 transfer end or buffer empty interrupt/<br>IIC01 transfer end                              | 0018H             |                      | ~                             | ~            |              |
|                | 11                      | INTSRE0                          | UART0 reception communication error occurrence                                                                                    |                   | 001EH                |                               | $\checkmark$ | $\checkmark$ |
| ole            | 12                      | INTTM00                          | End of TAU channel 00 count or capture<br>(at 16-bit operation or lower 8-bit operation)                                          |                   | 0020H                |                               | ~            | ~            |
| Maskable       | 13                      | INTTM01H                         | End of TAU channel 01 count or capture (at higher 8-bit operation)                                                                |                   | 0026H                |                               | $\checkmark$ | $\checkmark$ |
| Ma             | 14                      | INTTM03H                         | End of TAU channel 03 count or capture (at higher 8-bit operation)                                                                |                   | 0028H                |                               | $\checkmark$ | $\checkmark$ |
|                | 15                      | INTTM01                          | End of TAU channel 01 count or capture<br>(at 16-bit operation or lower 8-bit operation)                                          |                   | 002AH                |                               | ~            | ~            |
|                | 16                      | INTTM02                          | End of TAU channel 02 count or capture<br>(at 16-bit operation or lower 8-bit operation)                                          | 002CH             |                      | ~                             | ~            |              |
|                | 17                      | INTTM03                          | End of TAU channel 03 count or capture<br>(at 16-bit operation or lower 8-bit operation)                                          |                   | 002EH                |                               | ~            | ~            |
|                | 18                      | INTIICA0                         | End of IICA0 communication                                                                                                        |                   | 0030H                |                               | ~            | ~            |
|                | 19                      | INTIICA1                         | End of IICA1 communication                                                                                                        |                   | 0032H                |                               | $\checkmark$ | ~            |
|                | 20                      | INTAD                            | End of A/D conversion                                                                                                             |                   | 0034H                |                               | ~            | ~            |
|                | 21                      | INTIT                            | 12-bit interval timer interval signal detection                                                                                   |                   | 0038H                |                               | ~            | ~            |
|                | 22                      | INTUSB                           | USB INT interrupt                                                                                                                 |                   | 003CH                |                               | $\checkmark$ | —            |
|                | 23                      | INTRSUM                          | USB RESUME interrupt                                                                                                              |                   | 003EH                |                               | ~            | —            |
|                | 24                      | INTIICA2                         | End of IICA2 communication                                                                                                        |                   | 0040H                |                               | _            | $\checkmark$ |
|                | 25                      | INTTM04                          | End of timer channel 04 count or capture                                                                                          |                   | 0044H                |                               | $\checkmark$ | $\checkmark$ |
|                | 26                      | INTTM05                          | End of timer channel 05 count or capture                                                                                          |                   | 0046H                |                               | $\checkmark$ | $\checkmark$ |
|                | 27                      | INTTM06                          | End of timer channel 06 count or capture                                                                                          |                   | 0048H                |                               | ~            | $\checkmark$ |
|                | 28                      | INTTM07                          | End of timer channel 07 count or capture                                                                                          |                   | 004AH                |                               | $\checkmark$ | $\checkmark$ |

## Table 14 - 1 Interrupt Source List (1/2)



| <b></b>        |                                                   |        |                                         |                   |                      |                                          |              |              |
|----------------|---------------------------------------------------|--------|-----------------------------------------|-------------------|----------------------|------------------------------------------|--------------|--------------|
|                |                                                   |        | Interrupt Source                        |                   |                      | ote 2                                    |              |              |
| Interrupt Type | Interrupt Type<br>Default Priority Note 1<br>awev |        | Trigger                                 | Internal/External | Vector Table Address | Basic Configuration Type <sup>Note</sup> | with USB     | without USB  |
|                | 29                                                | INTP7  | Pin input edge detection                | External          | 004CH                | (B)                                      | $\checkmark$ | $\checkmark$ |
|                | 30                                                | INTP8  |                                         |                   | 004EH                |                                          | ~            | ~            |
|                | 31                                                | INTP9  |                                         |                   | 0050H                |                                          | ~            | ~            |
|                | 32                                                | INTP10 |                                         |                   | 0052H                |                                          | ~            | ~            |
| able           | 33                                                | INTP11 |                                         |                   | 0054H                |                                          | ~            | $\checkmark$ |
| Maskable       | 34                                                | INTP12 |                                         |                   | 0056H                |                                          | ~            | $\checkmark$ |
| ~              | 35                                                | INTP13 |                                         |                   | 0058H                |                                          | $\checkmark$ | ~            |
|                | 36                                                | INTP14 |                                         |                   | 005AH                |                                          | _            | ~            |
|                | 37                                                | INTP15 |                                         |                   | 005CH                |                                          |              | $\checkmark$ |
|                | 38                                                | INTFL  | End of Sequencer Note 5                 | Internal          | 0062H                | (A)                                      | ~            | ~            |
| Software       | _                                                 | BRK    | Execution of BRK instruction            | _                 | 007EH                | (C)                                      | ~            | ~            |
|                | _                                                 | RESET  | RESET pin input                         | _                 | 0000H                | —                                        | ~            | ~            |
|                |                                                   | POR    | Power-on-reset                          |                   |                      |                                          | ~            | $\checkmark$ |
|                |                                                   | LVD    | Voltage detection Note 6                |                   |                      |                                          | ~            | ~            |
| Reset          |                                                   | WDT    | Overflow of watchdog timer              |                   |                      |                                          | $\checkmark$ | ~            |
| Ľ              |                                                   | TRAP   | Execution of illegal instruction Note 7 |                   |                      |                                          | $\checkmark$ | ~            |
|                |                                                   | IAW    | Illegal-memory access                   |                   |                      |                                          | $\checkmark$ | ~            |
|                |                                                   | RPE    | RAM parity error                        |                   |                      |                                          | $\checkmark$ | ~            |

 Table 14 - 1 Interrupt Source List (2/2)

**Note 1.** The default priority determines the sequence of interrupts if two or more maskable interrupts occur simultaneously. Zero indicates the highest priority and 38 indicates the lowest priority.

Note 2. Basic configuration types (A) to (C) correspond to (A) to (C) in Figures 14 - 1 and 14 - 2.

Note 3. When bit 7 (WDTINT) of the option byte (000C0H) is set to 1.

Note 4. When bit 7 (LVIMD) of the voltage detection level register (LVIS) is cleared to 0.

Note 5. Be used at the flash self programming library or the data flash library.

Note 6. When bit 7 (LVIMD) of the voltage detection level register (LVIS) is set to 1.

**Note 7.** When the instruction code in FFH is executed. Reset by the illegal instruction execution not issued by emulation with the in-circuit emulator or on-chip debug emulator.





(A) Internal maskable interrupt



#### (B) External maskable interrupt (INTPn)



| IF:    | Interrupt request flag |               |  |  |  |  |
|--------|------------------------|---------------|--|--|--|--|
| IE:    | Interrupt enabl        | e flag        |  |  |  |  |
| ISP0:  | In-service prior       | ity flag 0    |  |  |  |  |
| ISP1:  | In-service prior       | ity flag 1    |  |  |  |  |
| MK:    | Interrupt mask         | flag          |  |  |  |  |
| PR0:   | Priority specific      | cation flag 0 |  |  |  |  |
| PR1:   | Priority specific      | cation flag 1 |  |  |  |  |
|        |                        |               |  |  |  |  |
| Remark | with USB:              | n = 0 to 13   |  |  |  |  |
|        | without USB:           | n = 0 to 15   |  |  |  |  |





(C) Software interrupt





## 14.3 Registers Controlling Interrupt Functions

The following 6 types of registers are used to control the interrupt functions.

- Interrupt request flag registers (IF0L, IF0H, IF1L, IF1H, IF2L, IF2H)
- Interrupt mask flag registers (MK0L, MK0H, MK1L, MK1H, MK2L, MK2H)
- Priority specification flag registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H)
- External interrupt rising edge enable registers (EGP0, EGP1)
- External interrupt falling edge enable registers (EGN0, EGN1)
- Program status word (PSW)

Table 14 - 2 show a list of interrupt request flags, interrupt mask flags, and priority specification flags corresponding to interrupt request sources.



| Interrupt Source           | Interrupt Rec | quest Flag | Interrupt Mask Flag |          | Priority Specification F | lag      | with | without |
|----------------------------|---------------|------------|---------------------|----------|--------------------------|----------|------|---------|
|                            |               | Register   | 1                   | Register | 1                        | Register | USB  | USB     |
| INTWDTI                    | WDTIIF        | IF0L       | WDTIMK              | MK0L     | WDTIPR0, WDTIPR1         | PR00L,   | ~    | √       |
| INTLVI                     | LVIIF         | -          | LVIMK               |          | LVIPR0, LVIPR1           | PR10L    | ~    | √       |
| INTP0                      | PIF0          | -          | PMK0                |          | PPR00, PPR10             | -        | ~    | √       |
| INTP1                      | PIF1          |            | PMK1                |          | PPR01, PPR11             |          | ~    | ~       |
| INTP2                      | PIF2          | -          | PMK2                |          | PPR02, PPR12             |          | ~    | ~       |
| INTP3                      | PIF3          | -          | PMK3                |          | PPR03, PPR13             |          | ~    | ~       |
| INTP4                      | PIF4          |            | PMK4                |          | PPR04, PPR14             |          | ~    | ~       |
| INTP5                      | PIF5          | -          | PMK5                |          | PPR05, PPR15             |          | ~    | ~       |
| INTP6                      | PIF6          | IF0H       | PMK6                | МК0Н     | PPR06, PPR16             | PR00H,   | ~    | ~       |
| INTST0 Note 1              | STIF0         | -          | STMK0               |          | STPR00, STPR10           | PR10H    | ~    | ~       |
| INTCSI00 Note 1            | CSIIF00       |            | CSIMK00             | -        | CSIPR000, CSIPR100       | -        | ~    | ~       |
| INTIIC00 Note 1            | IICIF00       | -          | ІІСМКОО             | -        | IICPR000, IICPR100       | -        | ~    | ~       |
| INTSR0 Note 2              | SRIF0         | -          | SRMK0               | -        | SRPR00, SRPR10           | -        | ~    | ~       |
| INTCSI01 <sup>Note 2</sup> | CSIIF01       | -          | CSIMK01             | -        | CSIPR001, CSIPR101       | -        | ~    | √       |
| INTIIC01 Note 2            | IICIF01       |            | ІІСМК01             | -        | IICPR001, IICPR101       | -        | ~    | √       |
| INTSRE0                    | SREIF0        | -          | SREMK0              | -        | SREPR00, SREPR10         | -        | ~    | ~       |
| INTTM00                    | TMIF00        |            | ТММК00              | -        | TMPR000, TMPR100         | -        | ~    | ~       |
| INTTM01H                   | TMIF01H       | IF1L       | TMMK01H             | MK1L     | TMPR001H, TMPR101H       | PR01L,   | ~    | √       |
| INTTM03H                   | TMIF03H       |            | ТММК03Н             | -        | TMPR003H, TMPR103H       | PR11L    | ~    | ~       |
| INTTM01                    | TMIF01        |            | TMMK01              |          | TMPR001, TMPR101         | -        | ~    | ~       |
| INTTM02                    | TMIF02        | -          | TMMK02              | -        | TMPR002, TMPR102         | -        | ~    | ~       |
| INTTM03                    | TMIF03        |            | ТММК03              | -        | TMPR003, TMPR103         | -        | ~    | ~       |
| INTIICA0                   | IICAIF0       | -          | IICAMK0             | -        | IICAPR00, ICAPR10        | -        | ~    | √       |
| INTIICA1                   | IICAIF1       |            | IICAMK1             | -        | IICAPR01, ICAPR11        |          | ~    | ~       |
| INTAD                      | ADIF          | IF1H       | ADMK                | MK1H     | ADPR0, ADPR1             | PR01H,   | ~    | √       |
| INTIT                      | TMKAIF        | -          | ТМКАМК              | -        | TMKAPR0, TMKAPR1         | PR11H    | ~    | √       |
| INTUSB                     | USBIF         | -          | USBMK               | -        | USBPR0, USBPR1           | -        | ~    | _       |
| INTRSUM                    | RSUIF         | -          | RSUMK               |          | RSUPR0, RSUPR1           | -        | ~    | _       |
| INTIICA2                   | IICAIF2       |            | IICAMK2             |          | IICAPR02, IICAPR12       |          | _    | ~       |
| INTTM04                    | TMIF04        | IF2L       | TMMK04              | MK2L     | TMPR004, TMPR104         | PR02L,   | ~    | ~       |
| INTTM05                    | TMIF05        |            | TMMK05              |          | TMPR005, TMPR105         | PR12L    | ~    | ~       |
| INTTM06                    | TMIF06        |            | TMMK06              |          | TMPR006, TMPR106         |          | ~    | √       |
| INTTM07                    | TMIF07        |            | TMMK07              |          | TMPR007, TMPR107         |          | ~    | √       |
| INTP7                      | PIF7          |            | PMK7                |          | PPR07, PPR17             |          | ~    | √       |
| INTP8                      | PIF8          |            | PMK8                |          | PPR08, PPR18             |          | ~    | √       |
| INTP9                      | PIF9          |            | PMK9                |          | PPR09, PPR19             |          | ~    | ~       |
| INTP10                     | PIF10         |            | PMK10               |          | PPR010, PPR110           |          | ~    | ~       |
| INTP11                     | PIF11         | IF2H       | PMK11               | MK2H     | PPR011, PPR111           | PR02H,   | ~    | ~       |
| INTP12                     | PIF12         |            | PMK12               | 1        | PPR012, PPR112           | PR12H    | ~    | ~       |
| INTP13                     | PIF13         |            | PMK13               | 1        | PPR013, PPR113           | 1        | ~    | ~       |
| INTP14                     | PIF14         |            | PMK14               | 1        | PPR014, PPR114           | 1        | _    | √       |
| INTP15                     | PIF15         |            | PMK15               | 1        | PPR015, PPR115           | 1        | _    | ~       |
| INTFL                      | FLIF          | 1          | FLMK                | 1        | FLPR0, FLPR1             | 1        | ~    | ~       |

Table 14 - 2 Flags Corresponding to Interrupt Request Sources (1/2)

**Note 1.** If one of the interrupt sources INTSTO, INTCSI00, and INTIIC00 is generated, bit 1 of the IF0H register is set to 1. Bit 1 of the MK0H, PR00H, and PR10H registers supports these three interrupt sources.

Note 2.If one of the interrupt sources INTSR0, INTCSI01, and INTIIC01 is generated, bit 2 of the IF0H register is set to 1.Bit 2 of the MK0H, PR00H, and PR10H registers supports these three interrupt sources.



## 14.3.1 Interrupt request flag registers (IF0L, IF0H, IF1L, IF1H, IF2L, IF2H)

The interrupt request flags are set to 1 when the corresponding interrupt request is generated or an instruction is executed. They are cleared to 0 when an instruction is executed upon acknowledgment of an interrupt request or upon reset signal generation.

When an interrupt is acknowledged, the interrupt request flag is automatically cleared and then the interrupt routine is entered.

The IF0L, IF0H, IF1L, IF1H, IF2L and IF2H registers can be set by a 1-bit or 8-bit memory manipulation instruction. When the IF0L and IF0H registers and the IF1L and IF1H registers and the IF2L and IF2H registers are combined to form 16-bit registers IF0, IF1 and IF2, they can be set by a 16-bit memory manipulation instruction.

Reset signal generation clears these registers to 00H.

**Remark** If an instruction that writes data to this register is executed, the number of instruction execution clocks increases by 2 clocks.



| Address:                             | FFFE0H  | After reset: 00H | H R/W                                    |        |                  |                             |                             |        |  |
|--------------------------------------|---------|------------------|------------------------------------------|--------|------------------|-----------------------------|-----------------------------|--------|--|
| Symbol                               | <7>     | <6>              | <5>                                      | <4>    | <3>              | <2>                         | <1>                         | <0>    |  |
| IF0L                                 | PIF5    | PIF4             | PIF3                                     | PIF2   | PIF1             | PIF0                        | LVIIF                       | WDTIIF |  |
| Address:                             | FFFE1H  | After reset: 00H | H R/W                                    |        |                  |                             |                             |        |  |
| Symbol                               | 7       | <6>              | <5>                                      | 4      | 3                | <2>                         | <1>                         | <0>    |  |
| IF0H                                 | 0       | TMIF00           | SREIF0                                   | 0      | 0                | SRIF0<br>CSIIF01<br>IICIF01 | STIF0<br>CSIIF00<br>IICIF00 | PIF6   |  |
| Address: FFFE2H After reset: 00H R/W |         |                  |                                          |        |                  |                             |                             |        |  |
| Symbol                               | <7>     | <6>              | <5>                                      | <4>    | <3>              | <2>                         | <1>                         | 0      |  |
| IF1L                                 | IICAIF1 | IICAIF0          | TMIF03                                   | TMIF02 | TMIF01           | TMIF03H                     | TMIF01H                     | 0      |  |
| Address:                             | FFFE3H  | After reset: 00H | H R/W                                    |        |                  |                             |                             |        |  |
| Symbol                               | 7       | <6>              | <5>                                      | <4>    | 3                | <2>                         | 1                           | <0>    |  |
| IF1H                                 | 0       | IICAIF2          | RSUIF                                    | USBIF  | 0                | TMKAIF                      | 0                           | ADIF   |  |
| Address:                             | FFFD0H  | After reset: 00H | H R/W                                    |        |                  |                             |                             |        |  |
| Symbol                               | <7>     | <6>              | <5>                                      | <4>    | <3>              | <2>                         | <1>                         | <0>    |  |
| IF2L                                 | PIF10   | PIF9             | PIF8                                     | PIF7   | TMIF07           | TMIF06                      | TMIF05                      | TMIF04 |  |
| Address:                             | FFFD1H  | After reset: 00H | H R/W                                    |        |                  |                             |                             |        |  |
| Symbol                               | <7>     | 6                | 5                                        | <4>    | <3>              | <2>                         | <1>                         | <0>    |  |
| IF2H                                 | INTFL   | 0                | 0                                        | PIF15  | PIF14            | PIF13                       | PIF12                       | PIF11  |  |
| Г                                    | XXIFX   |                  |                                          | Inte   | errupt request f | lag                         |                             |        |  |
|                                      | 0       | No interrupt re  | lo interrupt request signal is generated |        |                  |                             |                             |        |  |

#### Figure 14 - 3 Format of Interrupt Request Flag Registers (IF0L, IF0H, IF1L, IF1H, IF2L, IF2H)

Caution 1. The available registers and bits differ depending on the product. For details about the registers and bits available for each product, see Table 14 - 2. Be sure to set bits that are not available to the initial value.

Interrupt request is generated, interrupt request status

Caution 2. When manipulating a flag of the interrupt request flag register, use a 1-bit memory manipulation instruction (CLR1). When describing in C language, use a bit manipulation instruction such as "IF0L.0 = 0;" or "\_asm ("clr1 IF0L.0");" because the compiled assembler must be a 1-bit memory manipulation instruction (CLR1).

If a program is described in C language using an 8-bit memory manipulation instruction such as "IF0L &= 0xfe;" and compiled, it becomes the assembler of three instructions.

1

and a, #0FEH

mov IF0L, a

In this case, even if the request flag of the another bit of the same interrupt request flag register (IF0L) is set to 1 at the timing between "mov a, IF0L" and "mov IF0L, a", the flag is cleared to 0 at "mov IF0L, a". Therefore, care must be exercised when using an 8-bit memory manipulation instruction in C language.

mov a, IF0L

### 14.3.2 Interrupt mask flag registers (MK0L, MK0H, MK1L, MK1H, MK2L, MK2H)

The interrupt mask flags are used to enable/disable the corresponding maskable interrupt. The MK0L, MK0H, MK1L, MK1H, MK2L and MK2H registers can be set by a 1-bit or 8-bit memory manipulation instruction. When the MK0L and MK0H registers and the MK1L and MK1H registers and the MK2L and MK2H registers are combined to form 16-bit registers MK0, MK1 and MK2 they can be set by a 16-bit memory manipulation instruction.

Reset signal generation sets these registers to FFH.

**Remark** If an instruction that writes data to this register is executed, the number of instruction execution clocks increases by 2 clocks.

#### Figure 14 - 4 Format of Interrupt Mask Flag Registers (MK0L, MK0H, MK1L, MK1H, MK2L, MK2H)

| Address: | FFFE4H  | After reset: FFI | H R/W                        |        |                  |                             |                             |        |  |  |
|----------|---------|------------------|------------------------------|--------|------------------|-----------------------------|-----------------------------|--------|--|--|
| Symbol   | <7>     | <6>              | <5>                          | <4>    | <3>              | <2>                         | <1>                         | <0>    |  |  |
| MK0L     | PMK5    | PMK4             | PMK3                         | PMK2   | PMK1             | PMK0                        | LVIMK                       | WDTIMK |  |  |
| Address: | FFFE5H  | After reset: FFI | H R/W                        |        |                  |                             |                             |        |  |  |
| Symbol   | 7       | <6>              | <5>                          | 4      | 3                | <2>                         | <1>                         | <0>    |  |  |
| МКОН     | 0       | ТММК00           | SREMK0                       | 0      | 0                | SRMK0<br>CSIMK01<br>IICMK01 | STMK0<br>CSIMK00<br>IICMK00 | PMK6   |  |  |
| Address: | FFFE6H  | After reset: FFI | H R/W                        |        |                  |                             |                             |        |  |  |
| Symbol   | <7>     | <6>              | <5>                          | <4>    | <3>              | <2>                         | <1>                         | 0      |  |  |
| MK1L     | IICAMK1 | IICAMK0          | TMMK03                       | TMMK02 | TMMK01           | TMMK03H                     | TMMK01H                     | 0      |  |  |
| Address: | FFFE7H  | After reset: FFI | H R/W                        |        |                  |                             |                             |        |  |  |
| Symbol   | 7       | <6>              | <5>                          | <4>    | 3                | <2>                         | 1                           | <0>    |  |  |
| MK1H     | 0       | IICAMK2          | RSUMK                        | USBMK  | 0                | TMKAMK                      | 0                           | ADMK   |  |  |
| Address: | FFFD4H  | After reset: FFI | H R/W                        |        |                  |                             |                             |        |  |  |
| Symbol   | <7>     | <6>              | <5>                          | <4>    | <3>              | <2>                         | <1>                         | <0>    |  |  |
| MK2L     | PMK10   | PMK9             | PMK8                         | PMK7   | TMMK07           | TMMK06                      | TMMK05                      | TMMK04 |  |  |
| Address: | FFFD5H  | After reset: FFI | H R/W                        |        |                  |                             |                             |        |  |  |
| Symbol   | <7>     | 6                | 5                            | <4>    | <3>              | <2>                         | <1>                         | <0>    |  |  |
| MK2H     | FLMK    | 0                | 0                            | PMK15  | PMK14            | PMK13                       | PMK12                       | PMK11  |  |  |
|          | XXMKX   |                  |                              | Interr | upt servicing co | ontrol                      |                             |        |  |  |
|          | 0       | Interrupt servic | ing enabled                  |        |                  |                             |                             |        |  |  |
|          | 1       | Interrupt servic | Interrupt servicing disabled |        |                  |                             |                             |        |  |  |

Caution The available registers and bits differ depending on the product. For details about the registers and bits available for each product, see Table 14 - 2. Be sure to set bits that are not available to the initial value.

# 14.3.3 Priority specification flag registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H)

The priority specification flag registers are used to set the corresponding maskable interrupt priority level. A priority level is set by using the PR0xy and PR1xy registers in combination (xy = 0L, 0H, 1L, 1H, 2L or 2H). The PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L and PR12H registers can be set by a 1-bit or 8-bit memory manipulation instruction. If the PR00L and PR00H registers, the PR01L and PR01H registers, the PR10L and PR10H registers, the PR11L and PR11H registers, and the PR12L and PR12H registers are combined to form 16-bit registers PR00, PR01, PR10, PR11 and PR12, they can be set by a 16-bit memory manipulation instruction.

Reset signal generation sets these registers to FFH.

#### Figure 14 - 5 Format of Priority Specification Flag Registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) (1/2)

| Address:                             | FFFE8H   | After reset: FF | H R/W   |         |         |                                |                                |         |
|--------------------------------------|----------|-----------------|---------|---------|---------|--------------------------------|--------------------------------|---------|
| Symbol                               | <7>      | <6>             | <5>     | <4>     | <3>     | <2>                            | <1>                            | <0>     |
| PR00L                                | PPR05    | PPR04           | PPR03   | PPR02   | PPR01   | PPR00                          | LVIPR0                         | WDTIPR0 |
| Address:                             | FFFECH   | After reset: FF | H R/W   |         |         |                                |                                |         |
| Symbol                               | <7>      | <6>             | <5>     | <4>     | <3>     | <2>                            | <1>                            | <0>     |
| PR10L                                | PPR15    | PPR14           | PPR13   | PPR12   | PPR11   | PPR10                          | LVIPR1                         | WDTIPR1 |
| Address:                             | FFFE9H   | After reset:FFF | H R/W   |         |         |                                |                                |         |
| Symbol                               | 7        | <6>             | <5>     | 4       | 3       | <2>                            | <1>                            | <0>     |
| PR00H                                | 0        | TMPR000         | SREPR00 | 0       | 0       | SRPR00<br>CSIPR001<br>IICPR001 | STPR00<br>CSIPR000<br>IICPR000 | PPR06   |
| Address:                             | FFFEDH   | After reset: FF | H R/W   |         |         |                                |                                |         |
| Symbol                               | 7        | <6>             | <5>     | 4       | 3       | <2>                            | <1>                            | <0>     |
| PR10H                                | 0        | TMPR100         | SREPR10 | 0       | 0       | SRPR10<br>CSIPR101<br>IICPR101 | STPR10<br>CSIPR100<br>IICPR100 | PPR16   |
| Address:                             | FFFEAH   | After reset: FF | H R/W   |         |         |                                |                                |         |
| Symbol                               | <7>      | <6>             | <5>     | <4>     | <3>     | <2>                            | <1>                            | 0       |
| PR01L                                | IICAPR01 | IICAPR00        | TMPR003 | TMPR002 | TMPR001 | TMPR003H                       | TMPR001H                       | 0       |
| Address: FFFEEH After reset: FFH R/W |          |                 |         |         |         |                                |                                |         |
| Symbol                               | <7>      | <6>             | <5>     | <4>     | <3>     | <2>                            | <1>                            | 0       |
| PR11L                                | IICAPR11 | IICAPR10        | TMPR103 | TMPR102 | TMPR101 | TMPR103H                       | TMPR101H                       | 0       |



**Remark** If an instruction that writes data to this register is executed, the number of instruction execution clocks increases by 2 clocks.

#### Figure 14 - 6 Format of Priority Specification Flag Registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) (2/2)

| Address:                                          | : FFFEBH                                                        | After reset: FFH                                                        | R/W                                            |                                                      |                                                |                                |                      |                      |
|---------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------|------------------------------------------------|--------------------------------|----------------------|----------------------|
| Symbol                                            | 7                                                               | <6>                                                                     | <5>                                            | <4>                                                  | 3                                              | <2>                            | 1                    | <0>                  |
| PR01H                                             | 0                                                               | IICAPR02                                                                | RSUPR0                                         | USBPR0                                               | 0                                              | TMKAPR0                        | 0                    | ADPR0                |
| Address:                                          | FFFEFH                                                          | After reset: FFH                                                        | R/W                                            |                                                      |                                                |                                |                      |                      |
| Symbol                                            | 7                                                               | <6>                                                                     | <5>                                            | <4>                                                  | 3                                              | <2>                            | 1                    | <0>                  |
| PR11H                                             | 0                                                               | IICAPR12                                                                | RSUPR1                                         | USBPR1                                               | 0                                              | TMKAPR1                        | 0                    | ADPR1                |
| Address:                                          | FFFD8H                                                          | After reset: FFF                                                        | R/W                                            |                                                      |                                                |                                |                      |                      |
| Symbol                                            | <7>                                                             | <6>                                                                     | <5>                                            | <4>                                                  | <3>                                            | <2>                            | <1>                  | <0>                  |
| PR02L                                             | PPR010                                                          | PPR09                                                                   | PPR08                                          | PPR07                                                | TMPR007                                        | TMPR006                        | TMPR005              | TMPR004              |
| Address:                                          | FFFDCH                                                          | After reset: FFH                                                        | R/W                                            |                                                      |                                                |                                |                      |                      |
| Symbol                                            | <7>                                                             | <6>                                                                     | <5>                                            | <4>                                                  | <3>                                            | <2>                            | <1>                  | <0>                  |
|                                                   |                                                                 |                                                                         |                                                |                                                      |                                                |                                |                      |                      |
| PR12L                                             | PPR110                                                          | PPR19                                                                   | PPR18                                          | PPR17                                                | TMPR107                                        | TMPR106                        | TMPR105              | TMPR104              |
| I                                                 | PPR110<br>: FFFD9H                                              | PPR19<br>After reset: FFH                                               |                                                | PPR17                                                | TMPR107                                        | TMPR106                        | TMPR105              | TMPR104              |
| I                                                 |                                                                 | 1 1                                                                     |                                                | PPR17<br><4>                                         | TMPR107<br><3>                                 | TMPR106                        | TMPR105<br><1>       | TMPR104              |
| Address:                                          | : FFFD9H<br><7>                                                 | After reset: FFH                                                        | R/W                                            |                                                      | L                                              |                                |                      |                      |
| Address:<br>Symbol<br>PR02H                       | : FFFD9H<br><7>                                                 | After reset: FFF                                                        | R/W<br>5<br>0                                  | <4>                                                  | <3>                                            | <2>                            | <1>                  | <0>                  |
| Address:<br>Symbol<br>PR02H                       | FFFD9H<br><7><br>FLPR0                                          | After reset: FF⊢<br>6<br>0                                              | R/W<br>5<br>0                                  | <4>                                                  | <3>                                            | <2>                            | <1>                  | <0>                  |
| Address:<br>Symbol<br>PR02H<br>Address:           | : FFFD9H<br><7><br>FLPR0<br>: FFFDDH                            | After reset: FFF<br>6<br>0<br>After reset: FFF                          | R/W<br>5<br>0<br>R/W                           | <4><br>PPR015                                        | <3><br>PPR014                                  | <2><br>PPR013                  | <1><br>PPR012        | <0><br>PPR011        |
| Address:<br>Symbol<br>PR02H<br>Address:<br>Symbol | : FFFD9H<br><7><br>FLPR0<br>: FFFDDH<br><7>                     | After reset: FFF<br>6<br>0<br>After reset: FFF<br>6                     | R/W<br>5<br>0<br>R/W<br>5                      | <4><br>PPR015<br><4>                                 | <3><br>PPR014<br><3><br>PPR114                 | <2><br>PPR013<br><2><br>PPR113 | <1><br>PPR012<br><1> | <0><br>PPR011<br><0> |
| Address:<br>Symbol<br>PR02H<br>Address:<br>Symbol | : FFFD9H<br><7><br>FLPR0<br>: FFFDDH<br><7><br>FLPR1            | After reset: FFF<br>6<br>0<br>After reset: FFF<br>6<br>0                | R/W<br>5<br>0<br>R/W<br>5<br>0                 | <4><br>PPR015<br><4>                                 | <3><br>PPR014<br><3><br>PPR114<br>Priority lev | <2><br>PPR013<br><2>           | <1><br>PPR012<br><1> | <0><br>PPR011<br><0> |
| Address:<br>Symbol<br>PR02H<br>Address:<br>Symbol | : FFFD9H<br><7><br>FLPR0<br>: FFFDDH<br><7><br>FLPR1<br>XXPR1X  | After reset: FFF<br>6<br>0<br>After reset: FFF<br>6<br>0<br>XXPR0X      | R/W<br>5<br>0<br>R/W<br>5<br>0                 | <4><br>PPR015<br><4><br>PPR115                       | <3><br>PPR014<br><3><br>PPR114<br>Priority lev | <2><br>PPR013<br><2><br>PPR113 | <1><br>PPR012<br><1> | <0><br>PPR011<br><0> |
| Address:<br>Symbol<br>PR02H<br>Address:<br>Symbol | FFFD9H<br><7><br>FLPR0<br>FFFDDH<br><7><br>FLPR1<br>XXPR1X<br>0 | After reset: FFH<br>6<br>0<br>After reset: FFH<br>6<br>0<br>XXPR0X<br>0 | R/W<br>5<br>0<br>R/W<br>5<br>0<br>Specify leve | <4><br>PPR015<br><4><br>PPR115<br>I 0 (high priority | <3><br>PPR014<br><3><br>PPR114<br>Priority lev | <2><br>PPR013<br><2><br>PPR113 | <1><br>PPR012<br><1> | <0><br>PPR011<br><0> |

Caution The available registers and bits differ depending on the product. For details about the registers and bits available for each product, see Table 14 - 2. Be sure to set bits that are not available to the initial value.



# 14.3.4 External interrupt rising edge enable register (EGP0, EGP1), external interrupt falling edge enable register (EGN0, EGN1)

These registers specify the valid edge for INTP0 to INT15.

The EGP0, EGP1, EGN0, EGN1 registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears these registers to 00H.

| Address | : FFF38H | After reset: 00 | H R/W           |                 |                |                  |        |      |
|---------|----------|-----------------|-----------------|-----------------|----------------|------------------|--------|------|
| Symbol  | 7        | 6               | 5               | 4               | 3              | 2                | 1      | 0    |
| EGP0    | EGP7     | EGP6            | EGP5            | EGP4            | EGP3           | EGP2             | EGP1   | EGP0 |
| Address | : FFF39H | After reset: 00 | H R/W           |                 |                |                  |        |      |
| Symbol  | 7        | 6               | 5               | 4               | 3              | 2                | 1      | 0    |
| EGN0    | EGN7     | EGN6            | EGN5            | EGN4            | EGN3           | EGN2             | EGN1   | EGN0 |
| Address | : FFF3AH | After reset: 00 | H R/W           |                 |                |                  |        |      |
| Symbol  | 7        | 6               | 5               | 4               | 3              | 2                | 1      | 0    |
| EGP1    | EGP15    | EGP14           | EGP13           | EGP12           | EGP11          | EGP10            | EGP9   | EGP8 |
| Address | : FFF3BH | After reset: 00 | H R/W           |                 |                |                  |        |      |
| Symbol  | 7        | 6               | 5               | 4               | 3              | 2                | 1      | 0    |
| EGN1    | EGN15    | EGN14           | EGN13           | EGN12           | EGN11          | EGN10            | EGN9   | EGN8 |
|         |          |                 |                 |                 |                |                  |        |      |
|         | EGPn     | EGNn            |                 | INTPn           | pin valid edge | selection (n = 0 | to 15) |      |
|         | 0        | 0               | Edge detection  | n disabled      |                |                  |        |      |
|         | 0        | 1               | Falling edge    |                 |                |                  |        |      |
|         | 1        | 0               | Rising edge     |                 |                |                  |        |      |
|         | 1        | 1               | Both rising and | d falling edges |                |                  |        |      |

### Figure 14 - 7 Format of External Interrupt Rising Edge Enable Register (EGP0, EGP1) and External Interrupt Falling Edge Enable Register (EGN0, EGN1)



Table 14 - 3 shows the Ports Corresponding to EGPn and EGNn Bits.

| Detection | Enable Bit | Interment Deguast Signal | with USB     | without USB  |
|-----------|------------|--------------------------|--------------|--------------|
| Detection | Enable bit | Interrupt Request Signal | 32-pin       | 32-pin       |
| EGP0      | EGN0       | INTP0                    | $\checkmark$ | ~            |
| EGP1      | EGN1       | INTP1                    | $\checkmark$ | √            |
| EGP2      | EGN2       | INTP2                    | $\checkmark$ | √            |
| EGP3      | EGN3       | INTP3                    | $\checkmark$ | √            |
| EGP4      | EGN4       | INTP4                    | $\checkmark$ | √            |
| EGP5      | EGN5       | INTP5                    | $\checkmark$ | √            |
| EGP6      | EGN6       | INTP6                    | $\checkmark$ | √            |
| EGP7      | EGN7       | INTP7                    | $\checkmark$ | √            |
| EGP8      | EGN8       | INTP8                    | $\checkmark$ | √            |
| EGP9      | EGN9       | INTP9                    | $\checkmark$ | √            |
| EGP10     | EGN10      | INTP10                   | $\checkmark$ | √            |
| EGP11     | EGN11      | INTP11                   | $\checkmark$ | √            |
| EGP12     | EGN12      | INTP12                   | $\checkmark$ | √            |
| EGP13     | EGN13      | INTP13                   | $\checkmark$ | $\checkmark$ |
| EGP14     | EGN14      | INTP14                   | _            | $\checkmark$ |
| EGP15     | EGN15      | INTP15                   | _            | $\checkmark$ |

Caution When the input port pins used for the external interrupt functions are switched to the output mode, the INTPn interrupt might be generated upon detection of a valid edge. When switching the input port pins to the output mode, set the port mode register (PMxx) to 0 after disabling the edge detection (by setting EGPn and EGNn to 0).

**Remark 1.** For edge detection port, see **2.1 Port Functions**. **Remark 2.** n = 0 to 15



## 14.3.5 Program status word (PSW)

The program status word is a register used to hold the instruction execution result and the current status for an interrupt request. The IE flag that sets maskable interrupt enable/disable and the ISP0 and ISP1 flags that controls multiple interrupt servicing are mapped to the PSW.

Besides 8-bit read/write, this register can carry out operations using bit manipulation instructions and dedicated instructions (EI and DI). When a vectored interrupt request is acknowledged, if the BRK instruction is executed, the contents of the PSW are automatically saved into a stack and the IE flag is reset to 0. Upon acknowledgment of a maskable interrupt request, if the value of the priority specification flag register of the acknowledged interrupt is not 00, its value minus 1 is transferred to the ISP0 and ISP1 flags. The PSW contents are also saved into the stack with the PUSH PSW instruction. They are restored from the stack with the RETI, RETB, and POP PSW instructions.

Reset signal generation sets PSW to 06H.



Figure 14 - 8 Configuration of Program Status Word



## 14.4 Interrupt Servicing Operations

## 14.4.1 Maskable interrupt request acknowledgment

A maskable interrupt request becomes acknowledgeable when the interrupt request flag is set to 1 and the mask (MK) flag corresponding to that interrupt request is cleared to 0. A vectored interrupt request is acknowledged if interrupts are in the interrupt enabled state (when the IE flag is set to 1). However, a low-priority interrupt request is not acknowledged during servicing of a higher priority interrupt request.

The times from generation of a maskable interrupt request until vectored interrupt servicing is performed are listed in Table 14 - 4 below.

For the interrupt request acknowledgment timing, see Figures 14 - 10 and 14 - 11.

|                | Minimum Time | Maximum Time <sup>Note</sup> |
|----------------|--------------|------------------------------|
| Servicing time | 9 clocks     | 16 clocks                    |

**Note** Maximum time does not apply when an instruction from the internal RAM area is executed.

#### Remark 1 clock: 1/fCLK (fCLK: CPU clock)

If two or more maskable interrupt requests are generated simultaneously, the request with a higher priority level specified in the priority specification flag is acknowledged first. If two or more interrupts requests have the same priority level, the request with the highest default priority is acknowledged first.

An interrupt request that is held pending is acknowledged when it becomes acknowledgeable.

Figure 14 - 9 shows the Interrupt Request Acknowledgment Processing Algorithm.

If a maskable interrupt request is acknowledged, the contents are saved into the stacks in the order of PSW, then PC, the IE flag is reset (0), and the contents of the priority specification flag corresponding to the acknowledged interrupt are transferred to the ISP1 and ISP0 flags. The vector table data determined for each interrupt request is the loaded into the PC and branched.

Restoring from an interrupt is possible by using the RETI instruction.





#### Figure 14 - 9 Interrupt Request Acknowledgment Processing Algorithm

xxIF: Interrupt request flag

xxMK: Interrupt mask flag

xxPR0: Priority specification flag 0

xxPR1: Priority specification flag 1

IE: Flag that controls acknowledgment of maskable interrupt request (1 = Enable, 0 = Disable)

ISP0, ISP1: Flag that indicates the priority level of the interrupt currently being serviced (see Figure 14 - 8)

Note For the default priority, refer to Table 14 - 1 Interrupt Source List.





#### Figure 14 - 10 Interrupt Request Acknowledgment Timing (Minimum Time)

Remark 1 clock: 1/fCLK (fCLK: CPU clock)

#### Figure 14 - 11 Interrupt Request Acknowledgment Timing (Maximum Time)



Remark 1 clock: 1/fCLK (fCLK: CPU clock)



### 14.4.2 Software interrupt request acknowledgment

A software interrupt request is acknowledged by BRK instruction execution. Software interrupts cannot be disabled.

If a software interrupt request is acknowledged, the contents are saved into the stacks in the order of the program status word (PSW), then program counter (PC), the IE flag is reset (0), and the contents of the vector table (0007EH, 0007FH) are loaded into the PC and branched.

Restoring from a software interrupt is possible by using the RETB instruction.

#### Caution Can not use the RETI instruction for restoring from the software interrupt.

# 14.4.3 Multiple interrupt servicing

Multiple interrupt servicing occurs when another interrupt request is acknowledged during execution of an interrupt.

Multiple interrupt servicing does not occur unless the interrupt request acknowledgment enabled state is selected (IE = 1). When an interrupt request is acknowledged, interrupt request acknowledgment becomes disabled (IE = 0). Therefore, to enable multiple interrupt servicing, it is necessary to set (1) the IE flag with the EI instruction during interrupt servicing to enable interrupt acknowledgment.

Moreover, even if interrupts are enabled, multiple interrupt servicing may not be enabled, this being subject to interrupt priority control. Two types of priority control are available: default priority control and programmable priority control. Programmable priority control is used for multiple interrupt servicing.

In the interrupt enabled state, if an interrupt request with a priority equal to or higher than that of the interrupt currently being serviced is generated, it is acknowledged for multiple interrupt servicing. If an interrupt with a priority equal to or lower than that of the interrupt currently being serviced is generated during interrupt servicing, it is not acknowledged for multiple interrupt servicing. However, when setting the IE flag to 1 during the interruption at level 0, other level 0 interruptions can be allowed.

Interrupt requests that are not enabled because interrupts are in the interrupt disabled state or because they have a lower priority are held pending. When servicing of the current interrupt ends, the pending interrupt request is acknowledged following execution of at least one main processing instruction execution.

Table 14 - 5 shows Relationship Between Interrupt Requests Enabled for Multiple Interrupt Servicing During Interrupt Servicing and Figures 14 - 12 and 14 - 13 show multiple interrupt servicing examples.



| Multiple Interrupt Request |                      | Maskable Interrupt Request                         |        |              |                               |              |                               |              |                               |              |
|----------------------------|----------------------|----------------------------------------------------|--------|--------------|-------------------------------|--------------|-------------------------------|--------------|-------------------------------|--------------|
|                            |                      | Priority Level 0Priority Level 1(PR = 00)(PR = 01) |        |              | Priority Level 2<br>(PR = 10) |              | Priority Level 3<br>(PR = 11) |              | Software<br>Interrupt Request |              |
| Interrupt Being Service    | d                    | IE = 1                                             | IE = 0 | IE = 1       | IE = 0                        | IE = 1       | IE = 0                        | IE = 1       | IE = 0                        |              |
|                            | ISP1 = 0<br>ISP0 = 0 | $\checkmark$                                       | ×      | ×            | ×                             | ×            | ×                             | ×            | ×                             | $\checkmark$ |
| Maskable interrupt         | ISP1 = 0<br>ISP0 = 1 | $\checkmark$                                       | ×      | $\checkmark$ | ×                             | ×            | ×                             | ×            | ×                             | $\checkmark$ |
|                            | ISP1 = 1<br>ISP0 = 0 | $\checkmark$                                       | ×      | ~            | ×                             | $\checkmark$ | ×                             | ×            | ×                             | $\checkmark$ |
|                            | ISP1 = 1<br>ISP0 = 1 | $\checkmark$                                       | ×      | $\checkmark$ | ×                             | $\checkmark$ | ×                             | $\checkmark$ | ×                             | $\checkmark$ |
| Software interrupt         |                      | $\checkmark$                                       | ×      | $\checkmark$ | ×                             | $\checkmark$ | ×                             | $\checkmark$ | ×                             | $\checkmark$ |

# Table 14 - 5 Relationship Between Interrupt Requests Enabled for Multiple Interrupt Servicing During Interrupt Servicing

Remark 1. V: Multiple interrupt servicing enabled

Remark 2. ×: Multiple interrupt servicing disabled

Remark 3. ISP0, ISP1, and IE are flags contained in the PSW.

ISP1 = 0, ISP0 = 0: An interrupt of level 1 or level 0 is being serviced.

ISP1 = 0, ISP0 = 1: An interrupt of level 2 is being serviced.

ISP1 = 1, ISP0 = 0: An interrupt of level 3 is being serviced.

ISP1 = 1, ISP0 = 1: Wait for An interrupt acknowledgment (all interrupts enabled).

IE = 0: Interrupt request acknowledgment is disabled.

IE = 1: Interrupt request acknowledgment is enabled.

**Remark 4.** PR is a flag contained in the PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, and PR12H registers.

PR = 00: Specify level 0 with ××PR1× = 0, ××PR0× = 0 (higher priority level)

PR = 01: Specify level 1 with  $\times$  PR1 $\times$  = 0,  $\times$  PR0 $\times$  = 1

PR = 10: Specify level 2 with ××PR1× = 1, ××PR0× = 0

PR = 11: Specify level 3 with ××PR1× = 1, ××PR0× = 1 (lower priority level)



#### Figure 14 - 12 Examples of Multiple Interrupt Servicing (1/2)

Example 1. Multiple interrupt servicing occurs twice



During servicing of interrupt INTxx, two interrupt requests, INTyy and INTzz, are acknowledged, and multiple interrupt servicing takes place. Before each interrupt request is acknowledged, the EI instruction must always be issued to enable interrupt request acknowledgment.





Interrupt request INTyy issued during servicing of interrupt INTxx is not acknowledged because its priority is lower than that of INTxx, and multiple interrupt servicing does not take place. The INTyy interrupt request is held pending, and is acknowledged following execution of one main processing instruction.

- PR = 00: Specify level 0 with xxPR1x = 0, xxPR0x = 0 (higher priority level)
- PR = 01: Specify level 1 with xxPR1x = 0, xxPR0x = 1
- PR = 10: Specify level 2 with xxPR1x = 1, xxPR0x = 0
- PR = 11: Specify level 3 with xxPR1x = 1, xxPR0x = 1 (lower priority level)
- IE = 0: Interrupt request acknowledgment is disabled
- IE = 1: Interrupt request acknowledgment is enabled.

#### Figure 14 - 13 Examples of Multiple Interrupt Servicing (2/2)

Example 3. Multiple interrupt servicing does not occur because interrupts are not enabled



Interrupts are not enabled during servicing of interrupt INTxx (EI instruction is not issued), therefore, interrupt request INTyy is not acknowledged and multiple interrupt servicing does not take place. The INTyy interrupt request is held pending, and is acknowledged following execution of one main processing instruction.

- PR = 00: Specify level 0 with xxPR1x = 0, xxPR0x = 0 (higher priority level)
- PR = 01: Specify level 1 with xxPR1x = 0, xxPR0x = 1
- PR = 10: Specify level 2 with xxPR1x = 1, xxPR0x = 0
- PR = 11: Specify level 3 with xxPR1x = 1, xxPR0x = 1 (lower priority level)
- IE = 0: Interrupt request acknowledgment is disabled
- IE = 1: Interrupt request acknowledgment is enabled.



# 14.4.4 Interrupt servicing during division instruction

The R9A02G015 handles interrupts during the DIVHU/DIVWU instruction in order to enhance the interrupt response when a division instruction is executed.

- When an interrupt is generated while the DIVHU/DIVWU instruction is executed, the instruction is suspended
- After the instruction is suspended, the PC indicates the next instruction after DIVHU/DIVWU
- · An interrupt is generated by the next instruction
- PC-3 is stacked to execute the DIVHU/DIVWU instruction again

| Normal interrupt          | Interrupts while Executing DIVHU/DIVWU Instruction |
|---------------------------|----------------------------------------------------|
| $(SP-1) \leftarrow PSW$   | $(SP-1) \leftarrow PSW$                            |
| (SP-2) ← (PC)s            | (SP-2) ← (PC-3)s                                   |
| (SP-3) ← (PC)H            | (SP-3) ← (PC-3)H                                   |
| (SP-4) ← (PC)L            | (SP-4) ← (PC-3)L                                   |
| PCs ← 0000                | PCs ← 0000                                         |
| $PCH \leftarrow (Vector)$ | PCH ← (Vector)                                     |
| $PCL \leftarrow (Vector)$ | PCL ← (Vector)                                     |
| SP ← SP-4                 | $SP \leftarrow SP-4$                               |
| IE ← 0                    | IE ← 0                                             |

The AX, BC, DE, and HL registers are used for DIVHU/DIVWU. Use these registers by stacking them for interrupt servicing.





Caution Disable interrupts when executing the DIVHU or DIVWU instruction in an interrupt servicing routine.

Alternatively, unless they are executed in the RAM area, note that execution of a DIVHU or DIVWU instruction is possible even with interrupts enabled as long as a NOP instruction is added immediately after the DIVHU or DIVWU instruction in the assembly language source code. The following compilers automatically add a NOP instruction immediately after any DIVHU or DIVWU instruction output during the build process.

- V. 1.71 and later versions of the CA78K0R (Renesas Electronics compiler), for both C and assembly language source code
- Service pack 1.40.3 and later versions of the EWRL78 (IAR compiler), for C language source code
- GNURL78 (KPIT compiler), for C language source code



## 14.4.5 Interrupt request hold

There are instructions where, even if an interrupt request is issued while the instructions are being executed, interrupt request acknowledgment is held pending until the end of execution of the next instruction. These instructions (interrupt request hold instructions) are listed below.

- MOV PSW, #byte
- MOV PSW, A
- MOV1 PSW. bit, CY
- SET1 PSW. bit
- CLR1 PSW. bit
- RETB
- RETI
- POP PSW
- BTCLR PSW. bit, \$addr20
- El
- DI
- SKC
- SKNC
- SKZ
- SKNZ
- SKH
- SKNH
- MULHU
- MULH
- MACHU
- MACH
- Write instructions for the IF0L, IF0H, IF1L, IF1H, IF2L, IF2H, MK0L, MK0H, MK1L, MK1H, MK2L, MK2H, PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, and PR12H registers

Figure 14 - 14 shows the timing at which interrupt requests are held pending.

#### Figure 14 - 14 Interrupt Request Hold

| -<br>CPU processing | Instruction N | Instruction M | PSW and PC saved, jump to interrupt servicing | Interrupt servicing program |
|---------------------|---------------|---------------|-----------------------------------------------|-----------------------------|
| ××IF                |               |               |                                               |                             |

Remark 1. Instruction N: Interrupt request hold instruction

Remark 2. Instruction M: Instruction other than interrupt request hold instruction



# **CHAPTER 15 STANDBY FUNCTION**

# 15.1 Standby Function

The standby function reduces the operating current of the system, and the following three modes are available.

#### (1) HALT mode

HALT instruction execution sets the HALT mode. In the HALT mode, the CPU operation clock is stopped. If the high-speed system clock oscillator, or high-speed on-chip oscillator is operating before the HALT mode is set, oscillation of each clock continues. In this mode, the operating current is not decreased as much as in the STOP mode, but the HALT mode is effective for restarting operation immediately upon interrupt request generation and carrying out intermittent operations frequently.

#### (2) STOP mode

STOP instruction execution sets the STOP mode. In the STOP mode, the high-speed system clock oscillator and high-speed on-chip oscillator stop, stopping the whole system, thereby considerably reducing the CPU operating current.

Because this mode can be cleared by an interrupt request, it enables intermittent operations to be carried out. However, because a wait time is required to secure the oscillation stabilization time after the STOP mode is released when the X1 clock is selected, select the HALT mode if it is necessary to start processing immediately upon interrupt request generation.

#### (3) SNOOZE mode

In the case of CSI00 or UART0 data reception, an A/D conversion request by the timer trigger signal (the interrupt request signal (INTIT) the STOP mode is exited, the CSI00 or UART0 data is received without operating the CPU, and A/D conversion is performed. This can only be specified when the high-speed on-chip oscillator is selected for the CPU/peripheral hardware clock (fCLK).

In either of these two modes, all the contents of registers, flags and data memory just before the standby mode is set are held. The I/O port output latches and output buffer statuses are also held.



- Caution 1. When shifting to the STOP mode, be sure to stop the peripheral hardware operation operating with main system clock before executing STOP instruction (except SNOOZE mode setting unit).
- Caution 2. When using CSI00, UART0, or the A/D converter in the SNOOZE mode, set up serial standby control register m (SSCm) and A/D converter mode register 2 (ADM2) before switching to the STOP mode. For details, see 11.3 Registers Controlling Serial Array Unit and 10.3 Registers Controlling A/D Converter.
- Caution 3. The following sequence is recommended for operating current reduction of the A/D converter when the standby function is used: First clear bit 7 (ADCS) and bit 0 (ADCE) of A/D converter mode register 0 (ADM0) to 0 to stop the A/D conversion operation, and then execute the STOP instruction.
- Caution 4. It can be selected by the option byte whether the low-speed on-chip oscillator continues oscillating or stops in the HALT or STOP mode. For details, see CHAPTER 21 OPTION BYTE.

# 15.2 Registers controlling standby function

The registers which control the standby function are described below.

- Subsystem clock supply mode control register (OSMC)
- Oscillation stabilization time counter status register (OSTC)
- Oscillation stabilization time select register (OSTS)
- **Remark** For details of registers described above, see CHAPTER 5 CLOCK GENERATOR. For registers which control the SNOOZE mode, CHAPTER 10 A/D CONVERTER and CHAPTER 11 SERIAL ARRAY UNIT.



# 15.3 Standby Function Operation

# 15.3.1 HALT mode

(1) HALT mode

The HALT mode is set by executing the HALT instruction. HALT mode can be set regardless of whether the CPU clock before the setting was the high-speed system clock, or high-speed on-chip oscillator clock. The operating statuses in the HALT mode are shown below.

Caution Because the interrupt request signal is used to clear the HALT mode, if the interrupt mask flag is 0 (the interrupt processing is enabled) and the interrupt request flag is 1 (the interrupt request signal is generated), the HALT mode is not entered even if the HALT instruction is executed in such a situation.



| /      |                          | HALT Mode Setting   | When HAL                                                                                                                                                                                                                                                                                                                         | Instruction Is Executed While              | e CPU Is Operating on Main S                                                 | ystem Clock                                                 |  |  |  |
|--------|--------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------|--|--|--|
| Item   |                          |                     | When CPU Is Operating on<br>High-speed On-chip<br>Oscillator Clock (fHOCO)                                                                                                                                                                                                                                                       | When CPU Is Operating on X1 Clock (fx)     | When CPU Is Operating on<br>External Main System Clock<br>(f <sub>EX</sub> ) | When CPU Is Operating on<br>PLL Clock (fPLL)                |  |  |  |
| Syst   | em clock                 |                     | Clock supply to the CPU is stopped                                                                                                                                                                                                                                                                                               |                                            |                                                                              |                                                             |  |  |  |
|        | Main system clock        | fносо               | Operation continues<br>(cannot be stopped)                                                                                                                                                                                                                                                                                       | Operation disabled                         |                                                                              |                                                             |  |  |  |
|        |                          | fx                  | Operation disabled                                                                                                                                                                                                                                                                                                               | Operation continues<br>(cannot be stopped) | Cannot operate                                                               | Cannot be stopped while the<br>clock is supplied to the PLL |  |  |  |
|        |                          | fex                 |                                                                                                                                                                                                                                                                                                                                  | Cannot operate                             | Operation continues<br>(cannot be stopped)                                   | Cannot be stopped while the<br>clock is supplied to the PLL |  |  |  |
|        |                          | fpll                |                                                                                                                                                                                                                                                                                                                                  | Operation disabled                         | Operation disabled                                                           | Operation continues<br>(cannot be stopped)                  |  |  |  |
| fiL    |                          |                     | Set by bits 0 (WDSTBYON) and 4 (WDTON) of option byte (000C0H), and WUTMMCK0 bit of subsystem clock supply<br>mode control register (OSMC)<br>• WUTMMCK0 = 1: Oscillates<br>• WUTMMCK0 = 0 and WDTON = 0: Stops<br>• WUTMMCK0 = 0, WDTON = 1, and WDSTBYON = 1: Oscillates<br>• WUTMMCK0 = 0, WDTON = 1, and WDSTBYON = 0: Stops |                                            |                                                                              |                                                             |  |  |  |
| CPU    |                          |                     | Operation stopped                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
| Code   | e flash memory           |                     |                                                                                                                                                                                                                                                                                                                                  |                                            |                                                                              |                                                             |  |  |  |
| Data   | Data flash memory        |                     |                                                                                                                                                                                                                                                                                                                                  |                                            |                                                                              |                                                             |  |  |  |
| RAN    |                          |                     |                                                                                                                                                                                                                                                                                                                                  |                                            |                                                                              |                                                             |  |  |  |
| Port   | (latch)                  |                     | Status before HALT mode was set is retained                                                                                                                                                                                                                                                                                      |                                            |                                                                              |                                                             |  |  |  |
| Time   | r array unit             |                     | Operable                                                                                                                                                                                                                                                                                                                         |                                            |                                                                              |                                                             |  |  |  |
| 12-b   | it Interval timer        |                     | 1                                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
| Wato   | hdog timer               |                     | See CHAPTER 9 WATCHDOG TIMER                                                                                                                                                                                                                                                                                                     |                                            |                                                                              |                                                             |  |  |  |
| Cloc   | k output/buzzer output   |                     | Operable                                                                                                                                                                                                                                                                                                                         |                                            |                                                                              |                                                             |  |  |  |
| A/D    | converter                |                     |                                                                                                                                                                                                                                                                                                                                  |                                            |                                                                              |                                                             |  |  |  |
| Seria  | al array unit (SAU)      |                     |                                                                                                                                                                                                                                                                                                                                  |                                            |                                                                              |                                                             |  |  |  |
| Seria  | al interface (IICA)      |                     |                                                                                                                                                                                                                                                                                                                                  |                                            |                                                                              |                                                             |  |  |  |
| USB    |                          |                     | Operable (low speed mode transmission only)                                                                                                                                                                                                                                                                                      | Operation disabled                         |                                                                              | Operable                                                    |  |  |  |
| Pow    | er-on-reset function     |                     | Operable                                                                                                                                                                                                                                                                                                                         | •                                          |                                                                              |                                                             |  |  |  |
| Volta  | ge detection function    |                     |                                                                                                                                                                                                                                                                                                                                  |                                            |                                                                              |                                                             |  |  |  |
| Exte   | rnal interrupt           |                     | 1                                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
| CRC    | operation function       | High-speed CRC      | 1                                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
|        |                          | General-purpose CRC | Operation stopped                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
| RA№    | parity error detection f | unction             | Operation stopped                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
| RA№    | guard function           |                     | 1                                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
| SFR    | guard function           |                     | 1                                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |
| Illega | al-memory access dete    | ction function      | 1                                                                                                                                                                                                                                                                                                                                |                                            |                                                                              |                                                             |  |  |  |

#### Table 15 - 1 Operating Statuses in HALT Mode

**Remark** Operation stopped: Operation is automatically stopped before switching to HALT mode.

Operation disabled: Operation is stopped before switching to the HALT mode.

fHOCO: High-speed on-chip oscillator clock

fiL: Low-speed on-chip oscillator clock

fx: X1 clock

fex: External main system clock

#### (2) HALT mode release

The HALT mode can be released by the following two sources.

(a) Release by unmasked interrupt request

When an unmasked interrupt request is generated, the HALT mode is released. If interrupt acknowledgment is enabled, vectored interrupt servicing is carried out. If interrupt acknowledgment is disabled, the next address instruction is executed.





Note 1. For details of the standby release signal, see Figure 14 - 1 Basic Configuration of Interrupt Function (1/2).

- Note 2. Wait time for HALT mode release
  - When vectored interrupt servicing is carried out
     Main system clock: 15 to 16 clocks
  - When vectored interrupt servicing is not carried out Main system clock: 9 to 10 clocks

**Remark** The broken lines indicate the case when the interrupt request which has released the standby mode is acknowledged.



(b) Release by reset signal generation

When the reset signal is generated, HALT mode is released, and then, as in the case with a normal reset operation, the program is executed after branching to the reset vector address.



(1) When high-speed on-chip oscillator clock is used as CPU clock



(2) When high-speed system clock is used as CPU clock



 Note
 For the reset processing time, see CHAPTER 16 RESET FUNCTION.

 For the reset processing time of the power-on-reset circuit (POR) and voltage detector (LVD), see CHAPTER 17

 POWER-ON-RESET CIRCUIT.



## 15.3.2 STOP mode

(1) STOP mode setting and operating statuses

The STOP mode is set by executing the STOP instruction, and it can be set only when the CPU clock before the setting was the high-speed on-chip oscillator clock, X1 clock, or external main system clock.

Caution 1. Because the interrupt request signal is used to clear the STOP mode, if the interrupt mask flag is 0 (the interrupt processing is enabled) and the interrupt request flag is 1 (the interrupt request signal is generated), the STOP mode is immediately cleared if set when the STOP instruction is executed in such a situation.

Accordingly, once the STOP instruction is executed, the system returns to its normal operating mode after the elapse of release time from the STOP mode.

Caution 2. When shifting to STOP mode, be sure to stop the PLL operation by setting the DSCON bit (bit 0 in the DSCCTL register) before executing the STOP instruction.

The operating statuses in the STOP mode are shown below.



|                     |                             | STOP Mode Setting | When STO                                                                                                                                                                                                                                                                                                                         | P Instruction Is Executed While        | e CPU Is Operating on Main S                                    | ystem Clock                                  |  |  |  |
|---------------------|-----------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------------|----------------------------------------------|--|--|--|
| Item                | 1                           |                   | When CPU Is Operating on<br>High-speed on-chip<br>oscillator clock (fHoco)                                                                                                                                                                                                                                                       | When CPU Is Operating on X1 Clock (fx) | When CPU Is Operating on<br>External Main System Clock<br>(fex) | When CPU Is Operating on<br>PLL Clock (fPLL) |  |  |  |
| Sys                 | tem clock                   |                   | Clock supply to the CPU is stopped                                                                                                                                                                                                                                                                                               |                                        |                                                                 |                                              |  |  |  |
|                     | Main system clock           | fносо             | Stopped                                                                                                                                                                                                                                                                                                                          |                                        |                                                                 |                                              |  |  |  |
|                     |                             | fx                |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
|                     |                             | fex               |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
|                     |                             | fpll              | Operation disabled                                                                                                                                                                                                                                                                                                               |                                        |                                                                 |                                              |  |  |  |
|                     | fι                          |                   | Set by bits 0 (WDSTBYON) and 4 (WDTON) of option byte (000C0H), and WUTMMCK0 bit of subsystem clock supply<br>mode control register (OSMC)<br>• WUTMMCK0 = 1: Oscillates<br>• WUTMMCK0 = 0 and WDTON = 0: Stops<br>• WUTMMCK0 = 0, WDTON = 1, and WDSTBYON = 1: Oscillates<br>• WUTMMCK0 = 0, WDTON = 1, and WDSTBYON = 0: Stops |                                        |                                                                 |                                              |  |  |  |
| CPL                 | J                           |                   | Operation stopped                                                                                                                                                                                                                                                                                                                |                                        |                                                                 |                                              |  |  |  |
| Cod                 | le flash memory             |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| Data                | a flash memory              |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| RAM                 | M                           |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| Port                | t (latch)                   |                   | Status before STOP mode was set is retained                                                                                                                                                                                                                                                                                      |                                        |                                                                 |                                              |  |  |  |
| Tim                 | er array unit               |                   | Operation disabled                                                                                                                                                                                                                                                                                                               |                                        |                                                                 |                                              |  |  |  |
| 12-t                | oit Interval timer          |                   | Operable                                                                                                                                                                                                                                                                                                                         |                                        |                                                                 |                                              |  |  |  |
| Wat                 | chdog timer                 |                   | See CHAPTER 9 WATCHDOG TIMER                                                                                                                                                                                                                                                                                                     |                                        |                                                                 |                                              |  |  |  |
| Cloc                | ck output/buzzer output     |                   | Operation stopped                                                                                                                                                                                                                                                                                                                |                                        |                                                                 |                                              |  |  |  |
| A/D                 | converter                   |                   | Wakeup operation is enabled (switching to the SNOOZE mode)                                                                                                                                                                                                                                                                       |                                        |                                                                 |                                              |  |  |  |
| Seri                | ial array unit (SAU)        |                   | Wakeup operation is enabled only for CSI00 (switching to the SNOOZE mode)<br>Operation is disabled for anything other than CSI00                                                                                                                                                                                                 |                                        |                                                                 |                                              |  |  |  |
| Seri                | ial interface (IICA)        |                   | Wakeup by address match operable                                                                                                                                                                                                                                                                                                 |                                        |                                                                 |                                              |  |  |  |
| USE                 | 3                           |                   | Operation disabled                                                                                                                                                                                                                                                                                                               |                                        |                                                                 |                                              |  |  |  |
| Pow                 | ver-on-reset function       |                   | Operable                                                                                                                                                                                                                                                                                                                         |                                        |                                                                 |                                              |  |  |  |
| Volt                | age detection function      |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| Exte                | ernal interrupt             |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| CRO                 | C operation function        | High-speed CRC    | Operation stopped                                                                                                                                                                                                                                                                                                                |                                        |                                                                 |                                              |  |  |  |
| General-purpose CRC |                             |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| RAM                 | M parity error detection fu | Inction           |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
|                     | M guard function            |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| SFF                 | R guard function            |                   |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |
| Illeg               | al-memory access detec      | tion function     |                                                                                                                                                                                                                                                                                                                                  |                                        |                                                                 |                                              |  |  |  |

#### Table 15 - 2 Operating Statuses in STOP Mode

**Remark** Operation stopped: Operation is automatically stopped before switching to STOP mode.

Operation disabled: Operation is stopped before switching to the STOP mode.

fHoco: High-speed on-chip oscillator clock

fil: Low-speed on-chip oscillator clock

fx: X1 clock

fex: External main system clock



#### (2) STOP mode release

The STOP mode can be released by the following two sources.

(a) Release by unmasked interrupt request

When an unmasked interrupt request is generated, the STOP mode is released. After the oscillation stabilization time has elapsed, if interrupt acknowledgment is enabled, vectored interrupt servicing is carried out. If interrupt acknowledgment is disabled, the next address instruction is executed.

#### Figure 15 - 3 STOP Mode Release by Interrupt Request Generation (1/2)

(1) When high-speed on-chip oscillator clock is used as CPU clock



Note 1. For details of the standby release signal, see Figure 14 - 1 Basic Configuration of Interrupt Function (1/2).

- Note 2. STOP mode release time
  - Supply of the clock is stopped:

When high-speed on-chip oscillator clock: 18  $\mu s$  to 65  $\mu s$ 

Wait:

(common to the high-speed on-chip oscillator clock)

•When vectored interrupt servicing is carried out: 7 clocks

•When vectored interrupt servicing is not carried out: 1 clock

- Caution To shorten oscillation stabilization time after the STOP mode is released when the CPU operates with the highspeed system clock (X1 oscillation), temporarily switch the CPU clock to the high-speed on-chip oscillator clock before the execution of the STOP instruction.
- Remark 1. The clock supply stop time varies depending on the temperature conditions and STOP mode period.
- Remark 2. The broken lines indicate the case when the interrupt request that has released the standby mode is acknowledged.



#### Figure 15 - 4 STOP Mode Release by Interrupt Request Generation (2/2)

(2) When high-speed system clock (X1 oscillation) is used as CPU clock



- Note 1. For details of the standby release signal, see Figure 14 1 Basic Configuration of Interrupt Function (1/2).
- **Note 2.** STOP mode release time
  - Supply of the clock is stopped:

18 µs to "whichever is longer 65 µs or the oscillation stabilization time (set by OSTS)"

Wait:

- When vectored interrupt servicing is carried out: 10 to 11 clocks
- When vectored interrupt servicing is not carried out: 4 to 5 clocks
- (3) When high-speed system clock (external clock input) is used as CPU clock



- Note 1. For details of the standby release signal, see Figure 14 1 Basic Configuration of Interrupt Function (1/2).
- Note 2. STOP mode release time
  - Supply of the clock is stopped:

18 µs to 65 µs

Wait:

- When vectored interrupt servicing is carried out: 7 clocks
- When vectored interrupt servicing is not carried out: 1 clock
- Caution To reduce the oscillation stabilization time after release from the STOP mode while CPU operates based on the high-speed system clock (X1 oscillation), switch the clock to the high-speed on-chip oscillator clock temporarily before executing the STOP instruction.
- Remark 1. The clock supply stop time varies depending on the temperature conditions and STOP mode period.
- Remark 2. The broken lines indicate the case when the interrupt request that has released the standby mode is acknowledged.



(b) Release by reset signal generation

When the reset signal is generated, STOP mode is released, and then, as in the case with a normal reset operation, the program is executed after branching to the reset vector address.



(1) When high-speed on-chip oscillator clock is used as CPU clock



(2) When high-speed system clock is used as CPU clock



Starting X1 oscillation is specified by software.

 Note
 For the reset processing time, see CHAPTER 16 RESET FUNCTION.

 For the reset processing time of the power-on-reset circuit (POR) and voltage detector (LVD), see CHAPTER 17

 POWER-ON-RESET CIRCUIT.



# 15.3.3 SNOOZE mode

(1) SNOOZE mode setting and operating statuses

The SNOOZE mode can be set by the CSI00, UART0, and A/D converter. Note that this mode can only be specified if the CPU clock is the high-speed on-chip oscillator clock.

When using CSI00 or UART0 in the SNOOZE mode, set up serial standby control register m (SSCm) before switching to the STOP mode. For details, see **11.3 Registers Controlling Serial Array Unit**. When using the A/D converter in the SNOOZE mode, set up A/D converter mode register 2 (ADM2) before

switching to the STOP mode. For details, see 10.3 Registers Controlling A/D Converter.

In SNOOZE mode transition, wait status to be only following time.

Transition time from STOP mode to SNOOZE mode:

When high-speed on-chip oscillator clock: 18  $\mu s$  to 65  $\mu s$ 

**Remark** Transition time from STOP mode to SNOOZE mode varies depending on the temperature conditions and the STOP mode period.

Transition time from SNOOZE mode to normal operation:

When high-speed on-chip oscillator clock:

- When vectored interrupt servicing is carried out: HS (High-speed main) mode: "5.2 µs to 9.4 µs" + 7 clocks
- When vectored interrupt servicing is not carried out: HS (High-speed main) mode: "5.2 µs to 9.4 µs" + 1 clock

The operating statuses in the SNOOZE mode are shown next.



|                                | SNOOZE Mode Setting | When Inputting CSI00 Data Reception Signal or A/D Converter Timer Trigger Signal While in STOP Mode                                                                                                                                                                                                                              |  |  |  |  |
|--------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Item                           |                     | When CPU Is Operating on High-speed on-chip oscillator clock (fHOCO)                                                                                                                                                                                                                                                             |  |  |  |  |
| System clock                   |                     | Clock supply to the CPU is stopped                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Main system clock              | fносо               | Operation started                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                                | fx                  | Stopped                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                                | fex                 |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                                | fpll                |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| fı.                            |                     | Set by bits 0 (WDSTBYON) and 4 (WDTON) of option byte (000C0H), and WUTMMCK0 bit of subsystem clock supply<br>mode control register (OSMC)<br>• WUTMMCK0 = 1: Oscillates<br>• WUTMMCK0 = 0 and WDTON = 0: Stops<br>• WUTMMCK0 = 0, WDTON = 1, and WDSTBYON = 1: Oscillates<br>• WUTMMCK0 = 0, WDTON = 1, and WDSTBYON = 0: Stops |  |  |  |  |
| CPU                            |                     | Operation stopped                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| Code flash memory              |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Data flash memory              |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| RAM                            |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Port (latch)                   |                     | Use of the status while in the STOP mode continues                                                                                                                                                                                                                                                                               |  |  |  |  |
| Timer array unit               |                     | Operation disabled                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 12-bit Interval timer          |                     | Operable                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Watchdog timer                 |                     | See CHAPTER 9 WATCHDOG TIMER                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| Clock output/buzzer output     |                     | Operation disabled                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| A/D converter                  |                     | Operable                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Serial array unit (SAU)        |                     | Operable only CSI00 only. Operation disabled other than CSI00.                                                                                                                                                                                                                                                                   |  |  |  |  |
| Serial interface (IICA)        |                     | Operation disabled                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| USB                            |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Power-on-reset function        |                     | Operable                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Voltage detection function     |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| External interrupt             |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| CRC operation function         | High-speed CRC      | Operation disabled                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|                                | General-purpose CRC |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| RAM parity error detection for | unction             |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| RAM guard function             |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| SFR guard function             |                     |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Illegal-memory access detect   | ction function      |                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |

#### Table 15 - 3 Operating Statuses in SNOOZE Mode

Operation stopped: Operation is automatically stopped before switching to the SNOOZE mode. Remark

Operation disabled: Operation is stopped before switching to the SNOOZE mode. fHOCO: High-speed on-chip oscillator clock

fx:

fil: Low-speed on-chip oscillator clock

X1 clock

fEx: External main system clock



#### (2) Timing diagram when the interrupt request signal is generated in the SNOOZE mode



#### Figure 15 - 6 When the Interrupt Request Signal is Generated in the SNOOZE Mode

- **Note 1.** For details of the standby release signal, see **Figure 14 1**.
- Note 2. Transition time from STOP mode to SNOOZE mode
- Note 3. Transition time from SNOOZE mode to normal operation
- Note 4. Enable the SNOOZE mode (AWC = 1 or SWC = 1) immediately before switching to the STOP mode.
- Note 5. Be sure to release the SNOOZE mode (AWC = 0 or SWC = 0) immediately after return to the normal operation.
  - (3) Timing diagram when the interrupt request signal is not generated in the SNOOZE mode



#### Figure 15 - 7 When the Interrupt Request Signal is not Generated in the SNOOZE Mode

- **Note 1.** For details of the standby release signal, see **Figure 14 1**.
- **Note 2.** Transition time from STOP mode to SNOOZE mode
- Note 3. Enable the SNOOZE mode (AWC = 1 or SWC = 1) immediately before switching to the STOP mode.
- **Note 4.** If a standby release signal is generated in response to an interrupt from a module which is not set to operate in the SNOOZE mode during a transition of the chip from SNOOZE mode to STOP mode, the high-speed on-chip oscillator clock may run slowly for up to 15 µs from when the CPU starts to operate. If the clock frequency accuracy specified in the electrical characteristics is required immediately after release from standby, wait for the number of cycles at the actual CPU clock frequency that is equivalent to 15 µs.
- Remark For details of the SNOOZE mode function, see CHAPTER 10 A/D CONVERTER and CHAPTER 11 SERIAL ARRAY UNIT.

# **CHAPTER 16 RESET FUNCTION**

The following seven operations are available to generate a reset signal.

- (1) External reset input via RESETB pin
- (2) Internal reset by watchdog timer program loop detection
- (3) Internal reset by comparison of supply voltage and detection voltage of power-on-reset (POR) circuit
- (4) Internal reset by comparison of supply voltage of the voltage detector (LVD) and detection voltage
- (5) Internal reset by execution of illegal instruction Note
- (6) Internal reset by RAM parity error
- (7) Internal reset by illegal-memory access

External and internal resets start program execution from the address at 0000H and 0001H when the reset signal is generated.

A reset is effected when a low level is input to the RESETB pin, the watchdog timer overflows, or by POR and LVD circuit voltage detection, execution of illegal instruction <sup>Note</sup>, RAM parity error or illegal-memory access, and each item of hardware is set to the status shown in Table 16 - 1.

- Note
   The illegal instruction is generated when instruction code FFH is executed.

   Reset by the illegal instruction execution not issued by emulation with the in-circuit emulator or on-chip debug emulator.
- Caution 1. For an external reset, input a low level for 10 µs or more to the RESETB pin. To perform an external reset upon power application, input a low level to the RESETB pin, turn power on, continue to input a low level to the pin for 10 µs or more within the operating voltage range shown in 2.4 AC Characteristics of the R9A02G015 Data Sheet (R19DS0101E), and then input a high level to the pin.
- Caution 2. During generation of a reset signal, the high-speed on-chip oscillator clock, and low-speed on-chip oscillator clock stop oscillating. External main system clock input become invalid.
- Caution 3. The port pins become the following state because each SFR and 2nd SFR are initialized after reset.
  - P40: High-impedance during the external reset period or reset period by the POR. High level during other types of reset or after receiving a reset signal (connected to the on-chip pull-up resistance).
  - Ports other than P40: High-impedance during the reset period or after receiving a reset signal.





Figure 16 - 1 Block Diagram of Reset Function

Caution An LVD circuit internal reset does not reset the LVD circuit.

Remark 1. LVIM: Voltage detection register

Remark 2. LVIS: Voltage detection level register



## 16.1 Timing of Reset Operation

The R9A02G015 is reset by input of the low level on the RESETB pin and released from the reset state by input of the high level on the RESETB pin. After reset processing, execution of the program with the high-speed on-chip oscillator clock as the operating clock starts.





(Notes and Caution are listed on the next page.)

Release from the reset state is automatic in the case of a reset due to a watchdog timer overflow, execution of an illegal instruction, detection of a RAM parity error, or detection of illegal memory access. After reset processing, program execution starts with the high-speed on-chip oscillator clock as the operating clock.





(Notes and Caution are listed on the next page.)

| Note 1. | Reset times (times for release from the                                                                                    | e external reset state)                                  |  |  |  |  |
|---------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--|--|--|--|
|         | After the first release of the POR:                                                                                        | 0.672 ms (TYP.), 0.832 ms (MAX.) when the LVD is in use. |  |  |  |  |
|         |                                                                                                                            | 0.399 ms (TYP.), 0.519 ms (MAX.) when the LVD is off.    |  |  |  |  |
|         | After the second release of the POR:                                                                                       | 0.531 ms (TYP.), 0.675 ms (MAX.) when the LVD is in use. |  |  |  |  |
|         |                                                                                                                            | 0.259 ms (TYP.), 0.362 ms (MAX.) when the LVD is off.    |  |  |  |  |
|         | After power is supplied, a voltage stabilization waiting time of about 0.99 ms (TYP.) and up to 2.30 ms (MAX.) is required |                                                          |  |  |  |  |

- before reset processing starts after release of the external reset.
- **Note 2.** The state of P40 is as follows.

• High-impedance during the external reset period or reset period by the POR.

• High level during other types of reset or after receiving a reset signal (connected to the on-chip pull-up resistance).

Reset by POR and LVD circuit supply voltage detection is automatically released when  $VDD \ge VPOR$  or  $VDD \ge VLVD$  after the reset. After reset processing, execution of the program with the high-speed on-chip oscillator clock as the operating clock starts. For details, see **CHAPTER 17 POWER-ON-RESET CIRCUIT** or **CHAPTER 18 VOLTAGE DETECTOR**.

 Remark
 VPOR: POR power supply rise detection voltage

 VLVD: LVD detection voltage



| Item                                |                        | During Reset Period                                                                                |  |  |
|-------------------------------------|------------------------|----------------------------------------------------------------------------------------------------|--|--|
| System clock                        |                        | Clock supply to the CPU is stopped.                                                                |  |  |
| Main system clock                   | fносо                  | Operation stopped                                                                                  |  |  |
|                                     | fx                     | Operation stopped (the X1 and X2 pins are input port mode)                                         |  |  |
|                                     | fex                    | Clock input invalid (the pin is input port mode)                                                   |  |  |
|                                     | fpll                   | Operation stopped                                                                                  |  |  |
| fı∟                                 |                        | Operation stopped                                                                                  |  |  |
| CPU                                 |                        |                                                                                                    |  |  |
| Code flash memory                   |                        | Operation stopped                                                                                  |  |  |
| Data flash memory                   |                        | Operation stopped                                                                                  |  |  |
| RAM                                 |                        | Operation stopped                                                                                  |  |  |
| Port (latch)                        |                        | High impedance <sup>Note</sup>                                                                     |  |  |
| Timer array unit                    |                        | Operation stopped                                                                                  |  |  |
| 12-bit Interval timer               |                        |                                                                                                    |  |  |
| Watchdog timer                      |                        |                                                                                                    |  |  |
| Clock output/buzzer output          |                        |                                                                                                    |  |  |
| A/D converter                       |                        |                                                                                                    |  |  |
| Serial array unit (SAU)             |                        |                                                                                                    |  |  |
| Serial interface (IICA)             |                        |                                                                                                    |  |  |
| USB                                 |                        |                                                                                                    |  |  |
| Power-on-reset function             |                        | Detection operation possible                                                                       |  |  |
| Voltage detection function          |                        | Operation is possible in the case of an LVD reset and stopped in the case of other types of reset. |  |  |
| External interrupt                  |                        | Operation stopped                                                                                  |  |  |
| CRC operation function              | High-speed CRC         |                                                                                                    |  |  |
|                                     | General-purpose<br>CRC |                                                                                                    |  |  |
| RAM parity error detection function |                        |                                                                                                    |  |  |
| RAM guard function                  |                        |                                                                                                    |  |  |
| SFR guard function                  |                        |                                                                                                    |  |  |
| Illegal-memory access detection     | function               |                                                                                                    |  |  |

**Note** P40 become the following state.

• P40: High-impedance during the external reset period or reset period by the POR. High level during other types of reset (connected to the internal pull-up resistor).

Remark fHOCO: High-speed on-chip oscillator clock

- fx: X1 oscillation clock
- fEX: External main system clock
- fiL: Low-speed on-chip oscillator clock



|                           | Hardware                     | After Reset Acknowledgment Note                                |  |
|---------------------------|------------------------------|----------------------------------------------------------------|--|
| Program counter (PC)      |                              | The contents of the reset vector table (0000H, 0001H) are set. |  |
| Stack pointer (SP)        | Stack pointer (SP) Undefined |                                                                |  |
| Program status word (PSW) |                              | 06H                                                            |  |
| RAM                       | Data memory                  | Undefined                                                      |  |
|                           | General-purpose registers    | Undefined                                                      |  |

#### Table 16 - 2 Hardware Statuses After Reset Acknowledgment

**Note** During reset signal generation or oscillation stabilization time wait, only the PC contents among the hardware statuses become undefined. All other hardware statuses remain unchanged after reset.

Remark For the state of the special function register (SFR) after receiving a reset signal, see 3.1.4 Special function register (SFR) area and 3.1.5 Extended special function register (2nd SFR: 2nd Special Function Register) area.



# 16.2 Register for Confirming Reset Source

# 16.2.1 Reset control flag register (RESF)

Many internal reset generation sources exist in the R9A02G015. The reset control flag register (RESF) is used to store which source has generated the reset request.

The RESF register can be read by an 8-bit memory manipulation instruction.

RESETB input, reset by power-on-reset (POR) circuit, and accessing SFR other than the RESF register after reading the RESF register clear TRAP, WDTRF, RPERF, IAWRF, and LVIRF flags.

| ldress:                                | FFFA8H                                                                      | After reset: Un                                                           | defined Note 1 | R                  |                 |                             |           |       |  |
|----------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------|--------------------|-----------------|-----------------------------|-----------|-------|--|
| /mbol                                  | 7                                                                           | 6                                                                         | 5              | 4                  | 3               | 2                           | 1         | 0     |  |
| RESF                                   | TRAP                                                                        | 0                                                                         | 0              | WDTRF              | 0               | RPERF                       | IAWRF     | LVIRF |  |
| Γ                                      | TRAP                                                                        |                                                                           | Interna        | al reset request b | y execution o   | f illegal instruction       | on Note 2 |       |  |
| F                                      | 0 Internal reset request is not generated, or the RESF register is cleared. |                                                                           |                |                    |                 |                             |           |       |  |
|                                        | 1                                                                           | Internal reset                                                            | request is ger | nerated.           |                 |                             |           |       |  |
| Г                                      | WDTRF                                                                       |                                                                           |                | Internal reset rec | uest by watcl   | hdog timer (WD <sup>-</sup> | Г)        |       |  |
| F                                      | 0                                                                           | Internal reset                                                            | request is not | generated, or the  | RESF regist     | er is cleared.              |           |       |  |
| Ē                                      | 1                                                                           | Internal reset request is generated.                                      |                |                    |                 |                             |           |       |  |
| Г                                      | RPERF                                                                       |                                                                           |                | Internal reso      | et request t by | y RAM parity                |           |       |  |
| F                                      | 0                                                                           | Internal reset                                                            | request is not | generated, or the  | RESF regist     | er is cleared.              |           |       |  |
|                                        | 1                                                                           | Internal reset                                                            | request is ger | nerated.           |                 |                             |           |       |  |
| Г                                      | IAWRF                                                                       | Internal reset request t by illegal-memory access                         |                |                    |                 |                             |           |       |  |
| F                                      | 0                                                                           | Internal reset request is not generated, or the RESF register is cleared. |                |                    |                 |                             |           |       |  |
| Ľ                                      | 1                                                                           | Internal reset                                                            | request is ger | nerated.           |                 |                             |           |       |  |
| Γ                                      | LVIRF                                                                       |                                                                           |                | Internal reset rec | uest by volta   | ge detector (LVI            | ))        |       |  |
| F                                      | 0                                                                           | Internal reset                                                            | request is not | generated, or the  | RESF regist     | er is cleared.              |           |       |  |
| 1 Internal reset request is generated. |                                                                             |                                                                           |                |                    |                 |                             |           |       |  |

Figure 16 - 4 Format of Reset control flag register (RESF)

Note 1. The value after reset varies depending on the reset source. See Table 16 - 3.

**Note 2.** The illegal instruction is generated when instruction code FFH is executed.

Reset by the illegal instruction execution not issued by emulation with the in-circuit emulator or on-chip debug emulator.

Caution 1. Do not read data by a 1-bit memory manipulation instruction.

Caution 2. When enabling RAM parity error resets (RPERDIS = 0), be sure to initialize the used RAM area at data access or the used RAM area + 10 bytes at execution of instruction from the RAM area. Reset generation enables RAM parity error resets (RPERDIS = 0). For details, see 19.3.3 RAM parity error detection function.



The status of the RESF register when a reset request is generated is shown in Table 16 - 3.

| Reset Source<br>Flag | RESETB<br>Input | Reset by POR | Reset by<br>Execution of<br>Illegal<br>Instruction | Reset by<br>WDT | Reset by<br>RAM parity<br>error | Reset by<br>illegal-<br>memory<br>access | Reset by LVD |
|----------------------|-----------------|--------------|----------------------------------------------------|-----------------|---------------------------------|------------------------------------------|--------------|
| TRAP                 | Cleared (0)     | Cleared (0)  | Set (1)                                            | Held            | Held                            | Held                                     | Held         |
| WDTRF                |                 |              | Held                                               | Set (1)         |                                 |                                          |              |
| RPERF                |                 |              |                                                    | Held            | Set (1)                         |                                          |              |
| IAWRF                |                 |              |                                                    |                 | Held                            | Set (1)                                  |              |
| LVIRF                |                 |              |                                                    |                 |                                 | Held                                     | Set (1)      |

Accessing SFR other than the RESF register after reading the RESF register by an 8-bit memory manipulation instruction clears the RESF register automatically. Figure 16 - 5 shows the procedure for checking a reset source.





Figure 16 - 5 Example of Procedure for Checking Reset Source



# 16.2.2 Peripheral reset control register 0 (PRR0)

This register is used for individual reset control of each peripheral hardware.

The R9A02G015 controls reset and reset release of each peripheral hardware supported by the PRR0 register.

#### Figure 16 - 6 Format of Peripheral reset control register 0 (PRR0)



**Note** This bit is incorporated with R9A02G0151, but is not incorporated with R9A02G0150.

**Remark** n = 0, 2, 4, 5, 6 or 7

The controlled hardware by each bit are as follows.

| Bit | Bit Name | Controlled Hardware        |  |  |
|-----|----------|----------------------------|--|--|
| 0   | TAUORES  | Timer array unit (Unit 0)  |  |  |
| 2   | SAU0RES  | Serial array unit (Unit 0) |  |  |
| 4   | IICA0RES | Serial interface IICA0     |  |  |
| 5   | ADCRES   | A/D Converter              |  |  |
| 6   | IICA1RES | Serial interface IICA1     |  |  |
| 7   | IICA2RES | Serial interface IICA2     |  |  |



# 16.2.3 Peripheral reset control register 2 (PRR2)

This register is used for individual reset control of each peripheral hardware.

The R9A02G015 controls reset and reset release of each peripheral hardware supported by the PRR2 register.

#### Figure 16 - 7 Format of Peripheral reset control register 2 (PRR2)

| Address: | F00FDH  | After reset: 00H                                           | H R/W |   |   |   |   |   |
|----------|---------|------------------------------------------------------------|-------|---|---|---|---|---|
| Symbol   | <7>     | 6                                                          | 5     | 4 | 3 | 2 | 1 | 0 |
| PRR2     | TMKARES | 0                                                          | 0     | 0 | 0 | 0 | 0 | 0 |
|          | PRR2n   | Peripheral reset control on each peripheral hardware macro |       |   |   |   |   |   |
|          | 0       | Peripheral reset release                                   |       |   |   |   |   |   |
|          | 1       | Peripherals reset state                                    |       |   |   |   |   |   |
|          |         | •                                                          |       |   |   |   |   |   |

#### Remark n = 7

The controlled hardware by each bit are as follows.

#### Table 16 - 5 Macro Controlled by Each Bit in PRR2

| Bit | Bit Name | Controlled Hardware   |  |
|-----|----------|-----------------------|--|
| 7   | TMKARES  | 12-bit interval timer |  |



# **CHAPTER 17 POWER-ON-RESET CIRCUIT**

# 17.1 Functions of Power-on-reset Circuit

The power-on-reset circuit (POR) has the following functions.

• Generates internal reset signal at power on.

The reset signal is released when the supply voltage (VDD) exceeds the detection voltage (VPOR). Note that the reset state must be retained until the operating voltage becomes in the range defined in **2.4 AC Characteristics** of the R9A02G015 Data Sheet (R19DS0101E).

This is done by utilizing the voltage detection circuit or controlling the externally input reset signal.

 Compares supply voltage (VDD) and detection voltage (VPDR), generates internal reset signal when VDD < VPDR. Note that, after power is supplied, this LSI should be placed in the STOP mode, or in the reset state by utilizing the voltage detection circuit or externally input reset signal, before the operation voltage falls below the range defined in 2.4 AC Characteristics of the R9A02G015 Data Sheet (R19DS0101E). When restarting the operation, make sure that the operation voltage has returned within the range of operation.

# Caution If an internal reset signal is generated in the power-on-reset circuit, the reset control flag register (RESF) and the power-on-reset status register (PORSR) are cleared (00H).

- Remark 1. The R9A02G015 incorporates multiple hardware functions that generate an internal reset signal. A flag that indicates the reset source is located in the reset control flag register (RESF) for when an internal reset signal is generated by the watchdog timer (WDT), voltage-detector (LVD), illegal instruction execution, RAM parity error, or illegal-memory access. The RESF register is not cleared to 00H and the flag is set to 1 when an internal reset signal is generated by the watchdog timer (WDT), voltage-detector (LVD), illegal instruction execution, RAM parity error, or illegal-memory access. For details of the RESF register, see CHAPTER 16 RESET FUNCTION.
- **Remark 2.** The occurrence of an internal reset in the power-on-reset circuit can be checked by the power-on reset status register (PORSR). For details on the PORSR register, refer to **CHAPTER 16 RESET FUNCTION**.

Remark 3. VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage For details, see 2.6.3 POR circuit characteristics in the R9A02G015 Data Sheet (R19DS0101E).



# 17.2 Configuration of Power-on-reset Circuit

The block diagram of the power-on-reset circuit is shown in Figure 17 - 1.





# 17.3 Operation of Power-on-reset Circuit

The timing of generation of the internal reset signal by the power-on-reset circuit and voltage detector is shown next.



#### Figure 17 - 2 Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector (1/3)

(1) When using an external reset by the RESETB pin



- Note 1. The internal reset processing time includes the oscillation accuracy stabilization time of the high-speed on-chip oscillator clock.
- **Note 2.** The high-speed on-chip oscillator clock and a high-speed system clock can be selected as the CPU clock. To use the X1 clock, use the oscillation stabilization time counter status register (OSTC) to confirm the lapse of the oscillation stabilization time.
- **Note 3.** The time until normal operation starts includes the following reset processing time when the external reset is released (after the first release of POR) after the RESETB signal is driven high (1) as well as the voltage stabilization wait time after VPOR (1.51 V, TYP.) is reached.

Reset processing time when the external reset is released is shown below.

After the first release of POR: 0.672 ms (TYP.), 0.832 ms (MAX.) (when the LVD is in use)

0.399 ms (TYP.), 0.519 ms (MAX.) (when the LVD is off)

Reset processing time when the external reset is released after the second release of POR is shown below. After the second release of POR: 0.531 ms (TYP.), 0.675 ms (MAX.) (when the LVD is in use)

0.259 ms (TYP.), 0.362 ms (MAX.) (when the LVD is off)

Note 4. After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 2.4 AC Characteristics of the R9A02G015 Data Sheet (R19DS0101E). This is done by controlling the externally input reset signal.

After power supply is turned off, this LSI should be placed in the STOP mode, or in the reset state by utilizing the voltage detection circuit or externally input reset signal, before the voltage falls below the operating range. When restarting the operation, make sure that the operation voltage has returned within the range of operation.

- **Remark** VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage
- Caution For power-on reset, be sure to use the externally input reset signal on the RESETB pin when the LVD is off. For details, see CHAPTER 18 VOLTAGE DETECTOR.



#### Figure 17 - 3 Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector (2/3)



(2) LVD is interrupt & reset mode (option byte 000C1: LVIMDS1, LVIMDS0 = 1, 0)

- Note 1. The internal reset processing time includes the oscillation accuracy stabilization time of the high-speed on-chip oscillator clock.
- **Note 2.** The high-speed on-chip oscillator clock and a high-speed system clock can be selected as the CPU clock. To use the X1 clock, use the oscillation stabilization time counter status register (OSTC) to confirm the lapse of the oscillation stabilization time.
- Note 3. After the interrupt request signal (INTLVI) is generated, the LVILV and LVIMD bits of the voltage detection level register (LVIS) are automatically set to 1. After INTLVI is generated, appropriate settings should be made according to Figure 18
   9 Setting Procedure for Operating Voltage Check and Reset, taking into consideration that the supply voltage might return to the high voltage detection level (VLVDH) or higher without falling below the low voltage detection level (VLVDL).
- Note 4. The time until normal operation starts includes the following LVD reset processing time after the LVD detection level (VLVDH) is reached as well as the voltage stabilization wait + POR reset processing time after the VPOR (1.51 V, TYP.) is reached.

LVD reset processing time: 0 ms to 0.0701 ms (MAX.)

 Remark
 VLVDH, VLVDL:
 LVD detection voltage

 VPOR:
 POR power supply rise detection voltage

 VPDR:
 POR power supply fall detection voltage



#### Figure 17 - 4 Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector (3/3)

(3) LVD reset mode (option byte 000C1H: LVIMDS1, LVIMDS0 = 1, 1)



- Note 1. The internal reset processing time includes the oscillation accuracy stabilization time of the high-speed on-chip oscillator clock.
- **Note 2.** The high-speed on-chip oscillator clock and a high-speed system clock can be selected as the CPU clock. To use the X1 clock, use the oscillation stabilization time counter status register (OSTC) to confirm the lapse of the oscillation stabilization time.
- Note 3. The time until normal operation starts includes the following LVD reset processing time after the LVD detection level (VLVD) is reached as well as the voltage stabilization wait + POR reset processing time after the VPOR (1.51 V, TYP.) is reached.

LVD reset processing time: 0 ms to 0.0701 ms (MAX.)

- Note 4. When the power supply voltage is below the lower limit for operation and the power supply voltage is then restored after an internal reset is generated only by the voltage detector (LVD), the following LVD reset processing time is required after the LVD detection level (VLVD) is reached.
   LVD reset processing time: 0.0511 ms (TYP.), 0.0701 ms (MAX.)
- Remark 1.
   VLVDH, VLVDL:
   LVD detection voltage

   VPOR:
   POR power supply rise detection voltage

   VPDR:
   POR power supply fall detection voltage
- **Remark 2.** When the LVD interrupt mode is selected (option byte 000C1H: LVIMD1 = 0, LVIMD0 = 1), the time until normal operation starts after power is turned on is the same as the time specified in Note 3 of Figure 17 4 (3).



## **CHAPTER 18 VOLTAGE DETECTOR**

### 18.1 Functions of Voltage Detector

The operation mode and detection voltages (VLVDH, VLVDL, VLVD) for the voltage detector is set by using the option byte (000C1H). The detection voltages can be reset using the LVIS register. The voltage detector (LVD) has the following functions.

- The LVD circuit compares the supply voltage (VDD) with the detection voltage (VLVDH, VLVDL, VLVD), and generates an internal reset or internal interrupt signal.
- The detection level for the power supply detection voltage (VLVDH, VLVDL) can be selected as one of 14 levels (For details, see 18.3.2 Voltage detection level register (LVIS) and CHAPTER 21 OPTION BYTE).
- Operable in STOP mode.
- After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in **2.4 AC Characteristics** of the R9A02G015 Data Sheet (R19DS0101E). This is done by utilizing the voltage detection circuit or controlling the externally input reset signal. After the power supply is turned off, this LSI should be placed in the STOP mode, or placed in the reset state by utilizing the voltage detection circuit or controlling the externally below the operating range. The range of operating voltage varies with the setting of the user option byte (000C2H or 010C2H).
- (a) Interrupt & reset mode (option byte LVIMDS1, LVIMDS0 = 1, 0)
   The two detection voltages (VLVDH, VLVDL) are selected by the option byte 000C1H. The high-voltage detection level (VLVDH) is used for releasing resets and generating interrupts. This level is also used for generating resets. The low-voltage detection level (VLVDL) is used for generating resets.
- (b) Reset mode (option byte LVIMDS1, LVIMDS0 = 1, 1)
   The detection voltage (VLVD) selected by the option byte 000C1H is used for triggering and ending resets.
   The detection voltages can be reset using the LVIS register.
- (c) Interrupt mode (option byte LVIMDS1, LVIMDS0 = 0, 1)
   The detection voltage (VLVD) selected by the option byte 000C1H is used for generating interrupts/reset release. The detection voltages can be reset using the LVIS register.



The reset and internal interrupt signals are generated in each mode as follows.

| Interrupt & reset mode                                                                                                                                                                                               | Reset mode                                                                                                        | Interrupt mode                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (LVIMDS1, LVIMDS0 = 1, 0)                                                                                                                                                                                            | (LVIMDS1, LVIMDS0 = 1, 1)                                                                                         | (LVIMDS1, LVIMDS0 = 0, 1)                                                                                                                                                                                                                                                                                                  |
| Generates an interrupt request signal by<br>detecting VDD < VLVDH when the operating<br>voltage falls, and an internal reset by<br>detecting VDD < VLVDL.<br>Releases an internal reset by detecting<br>VDD ≥ VLVDH. | Releases an internal reset by detecting<br>VDD ≥ VLVD.<br>Generates an internal reset by detecting<br>VDD < VLVD. | Retains the state of an internal reset by<br>the LVD immediately after a reset until<br>$VDD \ge VLVD$ . Releases the LVD internal<br>reset by detecting $VDD \ge VLVD$ .<br>Generates an interrupt request signal<br>(INTLVI) by detecting $VDD < VLVD$ or $VDD \ge$<br>VLVD after the LVD internal reset is<br>released. |

While the voltage detector is operating, whether the supply voltage is more than or less than the detection level can be checked by reading the voltage detection flag (LVIF: bit 0 of the voltage detection register (LVIM)).

Bit 0 (LVIRF) of the reset control flag register (RESF) is set to 1 if reset occurs. For details of the RESF register, see **CHAPTER 16 RESET FUNCTION**.



### 18.2 Configuration of Voltage Detector

The block diagram of the voltage detector is shown in Figure 18 - 1.



#### Figure 18 - 1 Block Diagram of Voltage Detector

### 18.3 Registers Controlling Voltage Detector

The voltage detector is controlled by the following registers.

- Voltage detection register (LVIM)
- Voltage detection level register (LVIS)



### 18.3.1 Voltage detection register (LVIM)

This register is used to specify whether to enable or disable rewriting the voltage detection level register (LVIS), as well as to check the LVD output mask status.

This register can be set by a 1-bit or 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 18 - 2 Format of Voltage detection register (LVIM)

| Address: F | FFA9H  | After reset: 00H Note 1 R/W Note 2 |   |   |   |   |         |      |  |  |
|------------|--------|------------------------------------|---|---|---|---|---------|------|--|--|
| Symbol     | <7>    | 6                                  | 5 | 4 | 3 | 2 | <1>     | <0>  |  |  |
| LVIM       | LVISEN | 0                                  | 0 | 0 | 0 | 0 | LVIOMSK | LVIF |  |  |

| LVISEN | Specification of whether to enable or disable rewriting the voltage detection level register (LVIS) |
|--------|-----------------------------------------------------------------------------------------------------|
| 0      | Disabling of rewriting the LVIS register (LVIOMSK = 0 (Mask of LVD output is invalid)               |
| 1      | Enabling of rewriting the LVIS register Note 3 (LVIOMSK = 1 (Mask of LVD output is valid)           |

| 0 | Mask of LVD output is invalid                 |
|---|-----------------------------------------------|
| 1 | Mask of LVD output is valid <sup>Note 3</sup> |

| LVIF | Voltage detection flag                                                   |
|------|--------------------------------------------------------------------------|
| 0    | Supply voltage (VDD) $\geq$ detection voltage (VLVD), or when LVD is off |
| 1    | Supply voltage (VDD) < detection voltage (VLVD)                          |

Note 1. The reset value changes depending on the reset source.

If the LVIS register is reset by LVD, it is not reset but holds the current value. In other reset, LVISEN is cleared to 0.

**Note 2.** Bits 0 and 1 are read-only.

```
Note 3. The LVIOMSK bit is automatically set to 1 for the following periods and generation of an LVD reset or interrupt is masked.
```

• Period when LVISEN = 1

In either of the following cases, generation of an LVD reset or interrupt is masked only in interrupt & reset mode.

- Wait time until the LVD detection voltage stabilizes after an LVD interrupt is generated
- Wait time until the LVD detection voltage stabilizes after the value of the LVILV bit is changed



### 18.3.2 Voltage detection level register (LVIS)

This register selects the voltage detection level. The minimum supply voltage (LVD detection voltage) and LVD detection level settings that are set by the user option byte can be changed by software. This register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation input sets this register to Note 1.

Caution Do not change the detection voltage in interrupt & reset mode.



| mbol | <7>                                                                                | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 5                                                                   | 4                | 3                | 2                 | 1                 | <0>          |  |  |
|------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------|------------------|-------------------|-------------------|--------------|--|--|
| LVIS | LVIMD Note 2                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | LVISEL4 Note 6                                                      | LVISEL3          | LVISEL2          | LVISEL1           | LVISEL0           | LVILV Note 2 |  |  |
|      | LVIMD Note 2                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                     | Operation        | mode of voltage  | e detection       |                   |              |  |  |
|      | 0                                                                                  | Interrupt mod                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | le                                                                  |                  |                  |                   |                   |              |  |  |
|      | 1                                                                                  | Reset mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                     |                  |                  |                   |                   |              |  |  |
|      | LVISEL4 Note<br>6                                                                  | LVISEL3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | LVISEL2                                                             | Mini             | mum operating    | voltage (typica   | al falling value) | Note 5       |  |  |
|      | 0                                                                                  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                                                   | 1.84 V           |                  |                   |                   |              |  |  |
|      | 0                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                                                                   | 2.45 V           |                  |                   |                   |              |  |  |
|      | 0                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                                                   | 2.75 V           |                  |                   |                   |              |  |  |
|      | 1                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                                                   | 1.53 V (LVD C    | OFF)             |                   |                   |              |  |  |
|      | (                                                                                  | Other than abo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ve                                                                  | Setting prohib   | ited             |                   |                   |              |  |  |
|      | LVISEL1                                                                            | LVISEL0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                     | L                | .VD detection le | evel setting Note | 9 5               |              |  |  |
|      | 0                                                                                  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Setting voltage according to LVISEL4/LVISEL3/LVISEL2 + 1.2 V Note 3 |                  |                  |                   |                   |              |  |  |
|      | 0                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Setting voltage according to LVISEL4/LVISEL3/LVISEL2 + 0.2 V Note 3 |                  |                  |                   |                   |              |  |  |
|      | 1                                                                                  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Setting voltage                                                     | e according to I | VISEL4/LVISE     | L3/LVISEL2 +      | 0.1 V Note 3      |              |  |  |
|      | 1                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Setting voltage according to LVISEL4/LVISEL3/LVISEL2 Note 4         |                  |                  |                   |                   |              |  |  |
|      | LVILV Note 2                                                                       | LVD detection level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                     |                  |                  |                   |                   |              |  |  |
|      | 0                                                                                  | High-voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | High-voltage detection level (VLVDH)                                |                  |                  |                   |                   |              |  |  |
|      | 1                                                                                  | Low-voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | detection level (                                                   | VLVDL or VLVD)   |                  |                   |                   |              |  |  |
|      | Af<br>rei<br>Th<br>W<br>W<br>W<br>W<br>Note 2. W<br>se<br>in<br>Note 3. Ind<br>cin | <ul> <li>After a reset is released, the values of VPOC2 to VPOC0 and LVIS1 and LVIS0 in the user option byte a reflected in LVISEL4 to LVISEL2, LVISEL1, and LVISEL0, respectively.</li> <li>The reset values of LVIMD and LVIVL are set as follows.</li> <li>When LVIMDS1, LVIMDS0 in the option byte = 1, 0: LVIMD = 0, LVILV = 0</li> <li>When LVIMDS1, LVIMDS0 in the option byte = 1, 1: LVIMD = 1, LVILV = 1</li> <li>When LVIMDS1, LVIMDS0 in the option byte = 0, 1: LVIMD = 0, LVILV = 1</li> <li>Writing "0" can only be allowed in the interrupt &amp; reset mode (option byte LVIMDS1, LVIMDS0 = 1, 0). Do set LVIMD and LVILV in other cases. The value is switched automatically when reset or interrupt is general in the interrupt &amp; reset mode.</li> <li>Indicates an approximate detection value. For details on the actual detection voltage, refer to 2.6.4 LVD circuit characteristics in the R9A02G015 Data Sheet (R19DS0101E).</li> </ul> |                                                                     |                  |                  |                   |                   |              |  |  |
|      | Note 5. W                                                                          | hen changing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ted when LVIMD<br>LVISEL4 to LVIS<br>nest voltage valu              | EL0 to use two   | or more LVD d    | -                 | -                 |              |  |  |
|      |                                                                                    | cates the highest voltage value among the LVD detection voltages to be used should be set in the VPOC<br>/POC0 bits and LVIS1 and LVIS0 bits before using the voltages.<br>vriting LVISEL4 is prohibited. Keep the initial value unchanged.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                  |                  |                   |                   |              |  |  |

#### Figure 18 - 3 Format of Voltage detection level register (LVIS)

Caution 2. Specify the LVD operation mode and initial detection voltage (VLVDH, VLVDL, VLVD) of each mode by using the option byte 000C1H. Figure 18 - 4 shows the format of the user option byte (000C1H/010C1H). For details about the option byte, see CHAPTER 21 OPTION BYTE.

#### Figure 18 - 4 Format of User Option Byte (000C1H/010C1H) (1/2)

Address: 000C1H/010C1H<sup>Note</sup>

| 7     | 6     | 5     | 4 | 3     | 2     | 1       | 0       |
|-------|-------|-------|---|-------|-------|---------|---------|
| VPOC2 | VPOC1 | VPOC0 | 1 | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 |

• LVD setting (interrupt & reset mode)

| C           | Detection Voltage |              |        | Option Byte Setting Value                         |       |       |       |         |         |  |  |
|-------------|-------------------|--------------|--------|---------------------------------------------------|-------|-------|-------|---------|---------|--|--|
| VL          | Vlvdh             |              | VPOC2  | VPOC1                                             | VPOC0 | LVIS1 | LVIS0 | Mode    | setting |  |  |
| Rising edge | Falling edge      | Falling edge | VI 002 | 1001                                              | 1000  | LVIOT | LVIGO | LVIMDS1 | LVIMDS0 |  |  |
| 2.92 V      | 2.86 V            | 2.75 V       | 0      | 1                                                 | 1     | 1     | 0     | 1       | 0       |  |  |
| 3.02 V      | 2.96 V            |              |        |                                                   |       | 0     | 1     |         |         |  |  |
| 4.06 V      | 3.98 V            |              |        |                                                   |       | 0     | 0     |         |         |  |  |
|             |                   |              |        | Setting of values other than above is prohibited. |       |       |       |         |         |  |  |

• LVD setting (reset mode)

| Detectio    | n Voltage    |         | Option Byte Setting Value |              |              |       |              |         |  |  |  |
|-------------|--------------|---------|---------------------------|--------------|--------------|-------|--------------|---------|--|--|--|
| Vi          | Vlvd         |         | VPOC1                     | VPOC0        | LVIS1        | LVIS0 | Mode setting |         |  |  |  |
| Rising edge | Falling edge | - VPOC2 | VFOCT                     | VI 000       | LVIOT        | LVISU | LVIMDS1      | LVIMDS0 |  |  |  |
| 2.81 V      | 2.75 V       | 0       | 1                         | 1            | 1            | 1     | 1            | 1       |  |  |  |
| 2.92 V      | 2.86 V       |         | 1                         | 1            | 1            | 0     |              |         |  |  |  |
| 3.02 V      | 2.96 V       |         | 1                         | 1            | 0            | 1     |              |         |  |  |  |
| 3.13 V      | 3.06 V       |         | 0                         | 1            | 0            | 0     |              |         |  |  |  |
| 3.75 V      | 3.67 V       |         | 1                         | 0            | 0            | 0     |              |         |  |  |  |
| 4.06 V      | 3.98 V       |         | 1                         | 1            | 0            | 0     |              |         |  |  |  |
| -           | —            |         |                           | er than abov | e is prohibi | ted.  | •            | •       |  |  |  |

**Note** Set the same value as 000C1H to 010C1H when the boot swap operation is used because 000C1H is replaced by 010C1H.

Remark 1. For details on the LVD circuit, see CHAPTER 18 VOLTAGE DETECTOR.

**Remark 2.** The detection voltage is a TYP. value. For details, see **2.6.4 LVD circuit characteristics** in the R9A02G015 Data Sheet (R19DS0101E).

(Cautions are listed on the next page.)



#### Figure 18 - 4 Format of User Option Byte (000C1H/010C1H) (2/2)

Address: 000C1H/010C1H<sup>Note</sup>

| 7     | 6     | 5     | 4 | 3     | 2     | 1       | 0       |
|-------|-------|-------|---|-------|-------|---------|---------|
| VPOC2 | VPOC1 | VPOC0 | 1 | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 |

• LVD setting (interrupt mode)

| Detectio    | n Voltage    | Option Byte Setting Value |                                                   |        |       |       |         |         |  |
|-------------|--------------|---------------------------|---------------------------------------------------|--------|-------|-------|---------|---------|--|
| Vi          | Vlvd         |                           | VPOC1                                             | VPOC0  | LVIS1 | LVIS0 | Mode    | setting |  |
| Rising edge | Falling edge | VPOC2                     | VFOCT                                             | VI 000 | LVIOT | LVISU | LVIMDS1 | LVIMDS0 |  |
| 2.81 V      | 2.75 V       | 0                         | 1                                                 | 1      | 1     | 1     | 0       | 1       |  |
| 2.92 V      | 2.86 V       |                           | 1                                                 | 1      | 1     | 0     |         |         |  |
| 3.02 V      | 2.96 V       |                           | 1                                                 | 1      | 0     | 1     |         |         |  |
| 3.13 V      | 3.06 V       |                           | 0                                                 | 1      | 0     | 0     |         |         |  |
| 3.75 V      | 3.67 V       |                           | 1                                                 | 0      | 0     | 0     |         |         |  |
| 4.06 V      | 3.98 V       |                           | 1                                                 | 1      | 0     | 0     |         |         |  |
| -           |              | Setting of                | Setting of values other than above is prohibited. |        |       |       |         |         |  |

· LVD off setting (external reset input from the RESETB pin is used)

| Detection   | n voltage    | Option byte Setting Value |                                              |       |       |       |              |         |  |  |
|-------------|--------------|---------------------------|----------------------------------------------|-------|-------|-------|--------------|---------|--|--|
| VLVD        |              | VPOC2                     | VPOC1                                        | VPOC0 | LVIS1 | LVIS0 | Mode setting |         |  |  |
| Rising edge | Falling edge | VF002                     | VFUCI                                        | VFUCU | LVIST | LVISU | LVIMDS1      | LVIMDS0 |  |  |
| _           | _            | 1                         | ×                                            | ×     | ×     | ×     | ×            | 1       |  |  |
| —           |              | Settings of               | Settings other than the above are prohibited |       |       |       |              |         |  |  |

**Note** Set the same value as 000C1H to 010C1H when the boot swap operation is used because 000C1H is replaced by 010C1H.

Caution 1. Set bit 4 to 1.

Caution 2. After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 2.4 AC Characteristics of the R9A02G015 Data Sheet (R19DS0101E). This is done by utilizing the voltage detection circuit or controlling the externally input reset signal. After the power supply is turned off, this LSI should be placed in the STOP mode, or placed in the reset state by utilizing the voltage detection circuit or controlling the externally input reset signal, before the voltage falls below the operating range. The range of operating voltage varies with the setting of the user option byte (000C2H or 010C2H).

Remark 1. ×: Don't care

Remark 2. For details on the LVD circuit, see CHAPTER 18 VOLTAGE DETECTOR.

Remark 3. The detection voltage is a TYP. value. For details, see 2.6.4 LVD circuit characteristics in the R9A02G015 Data Sheet (R19DS0101E).



### 18.4 Operation of Voltage Detector

### 18.4.1 When used as reset mode

Specify the operation mode (the reset mode (LVIMDS1, LVIMDS0 = 1, 1)) and the initial detection voltage (VLVD) by using the option byte 000C1H. The detection voltages can be reset using the LVIS register.

The operation is started in the following initial setting state when the reset mode is set.

- Bit 7 (LVISEN) of the voltage detection register (LVIM) is set to 0 (disable rewriting of voltage detection level register (LVIS))
- The initial value of the voltage detection level select register (LVIS) is set to 81H.

See **18.3.2 Voltage detection level register (LVIS)** for details on the initial value of the voltage detection level register (LVIS).

- Bit 7 (LVIMD) is 1 (reset mode).
- Bit 0 (LVILV) is 1 (low-voltage detection level: VLVD).
- Operation in LVD reset mode

In the reset mode (option byte LVIMDS1, LVIMDS0 = 1, 1), the state of an internal reset by LVD is retained until the supply voltage (VDD) exceeds the voltage detection level (VLVD) after power is supplied. The internal reset is released when the supply voltage (VDD) exceeds the voltage detection level (VLVD).

At the fall of the operating voltage, an internal reset by LVD is generated when the supply voltage (VDD) falls below the voltage detection level (VLVD).

The reset release voltage when an LVD reset is generated is the detection voltage set by the option byte or detection voltage set by the LVIS register, whichever is higher. The state of an internal reset by the LVD is retained until the supply voltage exceeds the voltage detection level.

The reset release voltage used for resets other than an LVD reset is the same voltage detection level set by the option byte.

Figure 18 - 5 shows the timing of the internal reset signal generated in the LVD reset mode.





#### Figure 18 - 5 Timing of Voltage Detector Internal Reset Signal Generation (Option Byte LVIMDS1, LVIMDS0 = 1, 1)

 Remark
 VPOR: POR power supply rise detection voltage

 VPDR: POR power supply fall detection voltage



### 18.4.2 When used as interrupt mode

Specify the operation mode (the interrupt mode (LVIMDS1, LVIMDS0 = 0, 1)) and the initial detection voltage (VLVD) by using the option byte 000C1H. The detection voltages can be reset using the LVIS register.

The operation is started in the following initial setting state when the interrupt mode is set.

- Bit 7 (LVISEN) of the voltage detection register (LVIM) is set to 0 (disable rewriting of voltage detection level register (LVIS))
- See **18.3.2 Voltage detection level register (LVIS)** for details on the initial value of the voltage detection level register (LVIS).

Bit 7 (LVIMD) is 0 (interrupt mode).

Bit 0 (LVILV) is 1 (low-voltage detection level: VLVD).

Operation in LVD interrupt mode

In the interrupt mode (option byte LVIMDS1, LVIMDS0 = 0, 1), the state of an internal reset by LVD is retained immediately after a reset until the supply voltage (VDD) exceeds the voltage detection level (VLVD) after power is supplied (after the first release of the POR). The LVD internal reset is released when the supply voltage (VDD) exceeds the voltage detection level (VLVD).

After the LVD internal reset is released, an interrupt request signal (INTLVI) by the LVD is generated when the supply voltage (VDD) exceeds the voltage detection level (VLVD). When the voltage falls, this LSI should be placed in the STOP mode, or placed in the reset state by controlling the externally input reset signal, before the voltage falls below the operating voltage range defined in **2.4 AC Characteristics** of the R9A02G015 Data Sheet (R19DS0101E). When restarting the operation, make sure that the operation voltage has returned within the range of operation.

After the LVISEN bit is set to 1 (LVD is masked) by changing the detection level, if the supply voltage (VDD) falls below the voltage detection level (VLVD) when LVISEN is set to 0, an interrupt request signal (INTLVI) by the LVD is generated.

Figure 18 - 6 shows the timing of the interrupt request signal generated in the LVD interrupt mode.





### Figure 18 - 6 Timing of Voltage Detector Internal Interrupt Signal Generation (Option Byte LVIMDS1, LVIMDS0 = 0, 1)

- Note 1. The LVIMK flag is set to "1" by reset signal generation.
- **Note 2.** When the voltage falls, this LSI should be placed in the STOP mode, or placed in the reset state by controlling the externally input reset signal, before the voltage falls below the operating voltage range defined in **2.4 AC Characteristics** of the R9A02G015 Data Sheet (R19DS0101E). When restarting the operation, make sure that the operation voltage has returned within the range of operation.
- Remark VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage



### 18.4.3 When used as interrupt and reset mode

Specify the operation mode (the interrupt & reset (LVIMDS1, LVIMDS0 = 1, 0)) and the detection voltage (VLVDH, VLVDL) by using the option byte 000C1H. Do not manipulate the detection voltage using the LVIS register.

The operation is started in the following initial setting state when the interrupt & reset mode is set.

- Bit 7 (LVISEN) of the voltage detection register (LVIM) is set to 0 (disable rewriting of voltage detection level register (LVIS))
- See **18.3.2 Voltage detection level register (LVIS)** for details on the initial value of the voltage detection level register (LVIS).

Bit 7 (LVIMD) is 0 (interrupt mode).

Bit 0 (LVILV) is 0 (high-voltage detection level: VLVDH).

Operation in LVD interrupt & reset mode

In the interrupt & reset mode (option byte LVIMDS1, LVIMDS0 = 1, 0), the state of an internal reset by LVD is retained until the supply voltage (VDD) exceeds the high-voltage detection level (VLVDH) after power is supplied. The internal reset is released when the supply voltage (VDD) exceeds the high-voltage detection level (VLVDH). An interrupt request signal by LVD (INTLVI) is generated and arbitrary save processing is performed when the supply voltage (VDD) falls below the high-voltage detection level (VLVDH). After that, an internal reset by LVD is generated when the supply voltage (VDD) falls below the high-voltage detection level (VLVDH). After that, an internal reset by LVD is generated when the supply voltage (VDD) falls below the low-voltage detection level (VLVDL). After INTLVI is generated, an interrupt request signal is not generated even if the supply voltage becomes equal to or higher than the high-voltage detection voltage (VLVDH) without falling below the low-voltage detection voltage (VLVDL). To use the LVD reset & interrupt mode, perform the processing according to **Figure 18 - 9 Setting Procedure for Operating Voltage Check and Reset**.

Figures 18 - 7 and 18 - 8 show the timing of the internal reset signal and interrupt signal generated in the LVD interrupt & reset mode.





### Figure 18 - 7 Timing of Voltage Detector Reset Signal and Interrupt Signal Generation (Option Byte LVIMDS1, LVIMDS0 = 1, 0) (1/2)

(Notes and Remark are listed on the next page.)

- **Note 1.** The LVIMK flag is set to "1" by reset signal generation.
- **Note 2.** After an interrupt is generated, perform the processing according to Figure 18 9 Setting Procedure for Operating Voltage Check and Reset in interrupt and reset mode.
- Remark
   VPOR: POR power supply rise detection voltage

   VPOR: POR power supply fall detection voltage





### Figure 18 - 8 Timing of Voltage Detector Reset Signal and Interrupt Signal Generation (Option Byte LVIMDS1, LVIMDS0 = 1, 0) (2/2)

(Notes and Remark are listed on the next page.)

- Note 1. The LVIMK flag is set to "1" by reset signal generation.
- **Note 2.** After an interrupt is generated, perform the processing according to Figure 18 9 Setting Procedure for Operating Voltage Check and Reset in interrupt and reset mode.
- Remark
   VPOR: POR power supply rise detection voltage

   VPDR: POR power supply fall detection voltage



#### Figure 18 - 9 Setting Procedure for Operating Voltage Check and Reset



### 18.5 Changing of LVD Detection Voltage Setting

To change the LVD detection voltage by software, use the following procedure.

The LVD detection voltage can be changed in interrupt mode and reset mode.

In interrupt & reset mode, the value of the LVD detection voltage cannot be changed. Keep the initial value (set value in the option byte) unchanged.

To use two or more LVD detection voltages by changing LVISEL4 to LVISEL0 in the LVIS register by software, the highest voltage value of the used LVD detection voltages must be specified in the VPOC2 to VPOC0, LVIS1, and LVIS0 bits in the option byte (000C1H).



Figure 18 - 10 Changing of LVD Detection Voltage Setting

**Note** After LVISEN is set to 0, LVD is detected if VLVD > VDD, and a reset/interrupt is generated.



### 18.5.1 Changing of LVD detection voltage setting in LVD reset mode

Figure 18 - 11 shows an Example of Timing for Changing LVD Detection Voltage Setting in LVD Reset Mode.



#### Figure 18 - 11 Example of Timing for Changing LVD Detection Voltage Setting in LVD Reset Mode

#### Operation

- (1) When the supply voltage rises, the detection voltage set by the option byte is used to release the reset.
- (2) The value of the LVIS register is changed.
- (3) Waiting for stabilization by software is completed (400 µs or five fi∟ clock cycles after (2))
- (4) At LVD detection (falling), the detection voltage set by the LVIS register
- (5) At the LVD reset release (rising), the detection voltage set by the option byte

When changing the LVD detection voltage setting, note the following.

Caution The value of the reset release voltage in LVD reset mode is set to the set value in the option byte.



### 18.5.2 Changing of LVD detection voltage setting in LVD interrupt mode

Figure 18 - 12 shows an Example of Timing for Changing LVD Detection Voltage Setting in LVD Interrupt Mode.



#### Figure 18 - 12 Example of Timing for Changing LVD Detection Voltage Setting in LVD Interrupt Mode

#### Operation

- (1) When the supply voltage rises, the detection voltage set by the option byte is used to release the reset.
- (2) The value of the LVIS register is changed.
- (3) At LVD detection (falling and rising), the detection voltage set by the LVIS register
- (4) An internal reset is generated.
- (5) The voltage value is changed to the set value in the option byte again when the internal reset is released.

When changing the LVD detection voltage setting, note the following.

Caution 1. Immediately after all resets are generated, the LVD internal reset retains its reset state until VDD ≥ VLVD (set value in the option byte). The LVD internal reset is released when VDD ≥ VLVD is detected (set value in the option byte).

After that, an interrupt request signal (INTLVI) is generated when VDD < VLVD or  $VDD \ge VLVD$  is detected.

Caution 2. If the LVD set voltage is changed by setting LVISEL4 to LVISEL0 in the LVIS register while VDD < VLVD, an LVD interrupt is generated when the masking is released (LVISEN = 0). See Figure 18 - 13.





#### Figure 18 - 13 Example of Timing for Changing LVD Detection Voltage Using LVDIS When VDD < VLVD

#### Operation

- (1) When the supply voltage rises, the detection voltage set by the option byte is used to release the reset.
- (2) At LVD detection (falling), the detection voltage set by the option byte
- (3) The value of the LVIS register is changed.
- (4) If  $V_{DD} < V_{LVD}$  at the same time the masking is released, an interrupt is generated.



### 18.6 Cautions for Voltage Detector

(1) Voltage fluctuation when power is supplied

In a system where the supply voltage (VDD) fluctuates for a certain period in the vicinity of the LVD detection voltage, the system may be repeatedly reset and released from the reset status. In this case, the time from release of reset to the start of the operation of the R9A02G015 can be arbitrarily set by taking the following action.

<Action>

After releasing the reset signal, wait for the supply voltage fluctuation period of each system by means of a software counter that uses a timer, and then initialize the ports.

#### Figure 18 - 14 Example of Software Processing If Supply Voltage Fluctuation is 50 ms or Less in Vicinity of LVD Detection Voltage



Note If reset is generated again during this period, initialization processing <2> is not started.

**Remark** m = 0 n = 0 to 3



(2) Delay from the time LVD reset source is generated until the time LVD reset has been generated or released There is some delay from the time supply voltage (VDD) < LVD detection voltage (VLVD) until the time LVD reset has been generated.

In the same way, there is also some delay from the time LVD detection voltage (VLVD)  $\leq$  supply voltage (VDD) until the time LVD reset has been released (see **Figure 18 - 15**).

## Figure 18 - 15 Delay from the time LVD reset source is generated until the time LVD reset has been generated or released



<1>: Detection delay (300 µs (MAX.))

(3) Power on when LVD is off

Use the external rest input via the RESETB pin when the LVD is off.

For an external reset, input a low level for 10  $\mu$ s or more to the RESETB pin. To perform an external reset upon power application, input a low level to the RESETB pin, turn power on, continue to input a low level to the pin for 10  $\mu$ s or more within the operating voltage range shown in **2.4 AC Characteristics** of the R9A02G015 Data Sheet (R19DS0101E), and then input a high level to the pin.

#### (4) Operating voltage fall when LVD is off or LVD interrupt mode is selected

When the operating voltage falls with the LVD is off or with the LVD interrupt mode is selected, this LSI should be placed in the STOP mode, or placed in the reset state by controlling the externally input reset signal, before the voltage falls below the operating voltage range defined in **2.4 AC Characteristics** of the R9A02G015 Data Sheet (R19DS0101E). When restarting the operation, make sure that the operation voltage has returned within the range of operation.



### **CHAPTER 19 SAFETY FUNCTIONS**

### 19.1 Overview of Safety Functions

The following safety functions are provided in R9A02G015 to comply with the IEC60730 and IEC61508 safety standards.

These functions enable the microcontroller to self-diagnose abnormalities and stop operating if an abnormality is detected.

(1) Flash memory CRC operation function (high-speed CRC, general-purpose CRC)

This detects data errors in the flash memory by performing CRC operations.

Two CRC functions are provided in R9A02G015 that can be used according to the application or purpose of use.

- High-speed CRC: The CPU can be stopped and a high-speed check executed on its entire code flash
   memory area during the initialization routine.
- General CRC: This can be used for checking various data in addition to the code flash memory area while the CPU is running.
- RAM parity error detection functionThis detects parity errors when the RAM is read as data.
- (3) RAM guard functionThis prevents RAM data from being rewritten when the CPU freezes.
- (4) SFR guard functionThis prevents SFRs from being rewritten when the CPU freezes.
- (5) Invalid memory access detection function This detects illegal accesses to invalid memory areas (such as areas where no memory is allocated and areas to which access is restricted).
- (6) Frequency detection function
   This uses the timer array unit to perform a self-check of the CPU/peripheral hardware clock frequency.
- (7) A/D test function

This is used to perform a self-check of A/D converter by performing A/D conversion on the positive internal reference voltage, negative reference voltage, analog input channel (ANI), temperature sensor output, and internal reference voltage output.

- (8) Digital output signal level detection function for I/O pins When the I/O pins are output mode, the output level of the pin can be read.
- **Remark** Refer to the IEC60730/60335 self-test library application notes (R01AN1062, R01AN1296) for the RL78 MCU Series, for more information on usage examples of the safety functions required to comply with the IEC60730 and IEC61508 safety standards.



### 19.2 Registers Used by Safety Functions

The safety functions use the following registers:

| Register                                                                | Each Function of Safety Function                            |
|-------------------------------------------------------------------------|-------------------------------------------------------------|
| Flash memory CRC control register (CRC0CTL)                             | Flash memory CRC operation function (high-speed CRC)        |
| <ul> <li>Flash memory CRC operation result register (PGCRCL)</li> </ul> |                                                             |
| CRC input register (CRCIN)                                              | CRC operation function (general-purpose CRC)                |
| CRC data register (CRCD)                                                |                                                             |
| RAM parity error control register (RPECTL)                              | RAM parity error detection function                         |
| Invalid memory access detection control register (IAWCTL)               | RAM guard function                                          |
|                                                                         | SFR guard function                                          |
|                                                                         | Invalid memory access detection function                    |
| Timer input select register 0 (TIS0)                                    | Frequency detection function                                |
| A/D test register (ADTES)                                               | A/D test function                                           |
| Port mode select register (PMS)                                         | Digital output signal level detection function for I/O pins |

The content of each register is described in 19.3 Operation of Safety Functions.

### 19.3 Operation of Safety Functions

### **19.3.1** Flash memory CRC operation function (high-speed CRC)

The IEC60730 standard mandates the checking of data in the flash memory, and recommends using CRC to do it. The high-speed CRC provided in R9A02G015 can be used to check the entire code flash memory area during the initialization routine. The high-speed CRC can be executed only when the program is allocated on the RAM and in the HALT mode of the main system clock.

The high-speed CRC performs an operation by reading 32-bit data per clock from the flash memory while stopping the CPU. This function therefore can finish a check in a shorter time (for example, 341 µs@24 MHz with 32-KB flash memory).

The CRC generator polynomial used complies with " $X^{16} + X^{12} + X^5 + 1$ " of CRC-16-CCITT. The high-speed CRC operates in MSB first order from bit 31 to bit 0.

# Caution The CRC operation result might differ during on-chip debugging because the monitor program is allocated.

**Remark** The operation result is different between the high-speed CRC and the general CRC, because the general CRC operates in LSB first order.



### 19.3.1.1 Flash memory CRC control register (CRC0CTL)

This register is used to control the operation of the high-speed CRC ALU, as well as to specify the operation range.

The CRC0CTL register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 19 - 1 Format of Flash memory CRC control register (CRC0CTL)

| Address | F02F0H | After reset:00H | R/W                                                          |                |               |              |      |      |  |
|---------|--------|-----------------|--------------------------------------------------------------|----------------|---------------|--------------|------|------|--|
| Symbol  | <7>    | 6               | 5                                                            | 4              | 3             | 2            | 1    | 0    |  |
| CRC0CTL | CRC0EN | 0               | FEA5                                                         | FEA4           | FEA3          | FEA2         | FEA1 | FEA0 |  |
|         |        | · ·             |                                                              |                |               |              |      | 1    |  |
|         | CRC0EN |                 |                                                              | Control of hig | h-speed CRC A | LU operation |      |      |  |
|         | 0      | Stop the opera  | Stop the operation.                                          |                |               |              |      |      |  |
|         | 1      | Start the opera | Start the operation according to HALT instruction execution. |                |               |              |      |      |  |
|         |        |                 |                                                              |                |               |              |      |      |  |

| FEA5                                    | FEA4 | FEA3 | FEA2 | FEA1 | FEA0               | High-speed CRC operation range |  |  |
|-----------------------------------------|------|------|------|------|--------------------|--------------------------------|--|--|
| 0                                       | 0    | 0    | 0    | 0    | 0                  | 0 to 3FFBH (16 K - 4 byte)     |  |  |
| 0                                       | 0    | 0    | 0    | 0    | 1                  | 0 to 7FFBH (32 K - 4 byte)     |  |  |
| 0                                       | 0    | 0    | 0    | 1    | 0                  | 0 to BFFBH (48 K - 4 byte)     |  |  |
| 0                                       | 0    | 0    | 0    | 1    | 1                  | 0 to FFFBH (64 K - 4 byte)     |  |  |
| 0                                       | 0    | 0    | 1    | 0    | 0                  | 0 to 13FFBH (80 K - 4 byte)    |  |  |
| 0                                       | 0    | 0    | 1    | 0    | 1                  | 0 to 17FFBH (96 K - 4 byte)    |  |  |
| 0                                       | 0    | 0    | 1    | 1    | 0                  | 0 to 1BFFBH (112 K - 4 byte)   |  |  |
| 0                                       | 0    | 0    | 1    | 1    | 1                  | 0 to 1FFFBH (128 K - 4 byte)   |  |  |
| Other than the above Setting prohibited |      |      |      |      | Setting prohibited |                                |  |  |

**Remark** Input the expected CRC operation result value to be used for comparison in the lowest 4 bytes of the flash memory. Note that the operation range will thereby be reduced by 4 bytes.



### 19.3.1.2 Flash memory CRC operation result register (PGCRCL)

This register is used to store the high-speed CRC operation results. The PGCRCL register can be set by a 16-bit memory manipulation instruction. Reset signal generation clears this register to 0000H.

#### Address: F02F2H After reset: 0000H R/W 10 8 Symbol 15 14 13 12 11 9 PGCRCL PGCRC14 PGCRC15 PGCRC13 PGCRC12 PGCRC11 PGCRC10 PGCRC9 PGCRC8 7 6 5 4 3 2 1 0 PGCRC7 PGCRC6 PGCRC5 PGCRC4 PGCRC3 PGCRC2 PGCRC1 PGCRC0 PGCRC15 to 0 High-speed CRC operation results 0000H to FFFFH Store the high-speed CRC operation results.

### Figure 19 - 2 Format of Flash memory CRC operation result register (PGCRCL)

Caution The PGCRCL register can only be written if CRC0EN (bit 7 of the CRC0CTL register) = 1.

Figure 19 - 3 shows the Flowchart of Flash Memory CRC Operation Function (High-speed CRC).



#### <Operation flow>



#### Figure 19 - 3 Flowchart of Flash Memory CRC Operation Function (High-speed CRC)

Caution 1. The CRC operation is executed only on the code flash.

Caution 2. Store the expected CRC operation value in the area below the operation range in the code flash.

Caution 3. The CRC operation is enabled by executing the HALT instruction in the RAM area.

#### Be sure to execute the HALT instruction in RAM area.

The expected CRC operation value can be calculated by using the integrated development environment CubeSuite+ development environment. Refer to the CubeSuite+ integrated development environment user's manual for details.

### 19.3.2 CRC operation function (general-purpose CRC)

In order to guarantee safety during operation, the IEC61508 standard mandates the checking of data even while the CPU is operating.

In R9A02G015, a general CRC operation can be executed as a peripheral function while the CPU is operating. The general CRC can be used for checking various data in addition to the code flash memory area. The data to be checked can be specified by using software (a user-created program).

The CRC generator polynomial used is " $X^{16} + X^{12} + X^5 + 1$ " of CRC-16-CCITT. The data to be input is inverted in bit order and then calculated to allow for LSB-first communication. For example, if the data 12345678H is sent from the LSB, values are written to the CRCIN register in the order of 78H, 56H, 34H, and 12H, enabling a value of 08F6H to be obtained from the CRCD register. This is the result obtained by executing a CRC operation on the bit rows shown below, which consist of the data 12345678H inverted in bit order.



Caution Because the debugger rewrites the software break setting line to a break instruction during program execution, the CRC operation result differs if a software break is set in the CRC operation target area.



### 19.3.2.1 CRC input register (CRCIN)

CRCIN register is an 8-bit register that is used to set the CRC operation data of general-purpose CRC. The possible setting range is 00H to FFH.

The CRCIN register can be set by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 19 - 4 Format of CRC input register (CRCIN)

| Address: | :FFFACH | After reset:00 | H R/W       |      |       |   |   |   |
|----------|---------|----------------|-------------|------|-------|---|---|---|
| Symbol   | 7       | 6              | 5           | 4    | 3     | 2 | 1 | 0 |
| CRCIN    |         |                |             |      |       |   |   |   |
| ſ        | Bits    | s 7 to 0       |             | Fund | ction |   |   |   |
|          | 00H     | to FFH         | Data input. |      |       |   |   |   |



### 19.3.2.2 CRC data register (CRCD)

This register is used to store the general-purpose CRC operation result.

The possible setting range is 0000H to FFFFH.

After 1 clock of CPU/peripheral hardware clock (fCLK) has elapsed from the time CRCIN register is written, the CRC operation result is stored to the CRCD register.

The CRCD register can be set by a 16-bit memory manipulation instruction.

Reset signal generation clears this register to 0000H.

#### Figure 19 - 5 Format of CRC data register (CRCD)

| Address: | F02FA | Н  | After re | set: 000 | 00H | R/W |   |   |   |   |   |   |   |   |   |   |
|----------|-------|----|----------|----------|-----|-----|---|---|---|---|---|---|---|---|---|---|
| Symbol   | 15    | 14 | 13       | 12       | 11  | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CRCD     |       |    |          |          |     |     |   |   |   |   |   |   |   |   |   |   |

Caution 1. Read the value written to CRCD register before writing to CRCIN register. Caution 2. If writing and storing operation result to CRCD register conflict, the writing is ignored.

<Operation flow>





### **19.3.3 RAM parity error detection function**

The IEC60730 standard mandates the checking of RAM data. A single-bit parity bit is therefore added to all 8-bit data in R9A02G015's RAM. By using this RAM parity error detection function, the parity bit is appended when data is written, and the parity is checked when the data is read. This function can also be used to trigger a reset when a parity error occurs.

### 19.3.3.1 RAM parity error control register (RPECTL)

This register is used to control parity error generation check bit and reset generation due to parity errors. The RPECTL register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

| Figure 19 - 7 Format of RAM parity error control regis | ter (RPECTL) |
|--------------------------------------------------------|--------------|
|--------------------------------------------------------|--------------|

| Address: | F00F5H                          | After reset: 00H                 | H R/W         |     |                  |      |   |      |
|----------|---------------------------------|----------------------------------|---------------|-----|------------------|------|---|------|
| Symbol   | <7>                             | 6                                | 5             | 4   | 3                | 2    | 1 | <0>  |
| RPECTL   | RPERDIS                         | 0                                | 0             | 0   | 0                | 0    | 0 | RPEF |
|          |                                 |                                  |               |     |                  |      |   |      |
|          | RPERDIS                         | DIS Parity error reset mask flag |               |     |                  |      |   |      |
|          | 0                               | Enable parity e                  | error resets. |     |                  |      |   |      |
|          | 1                               | Disable parity                   | error resets. |     |                  |      |   |      |
| -        |                                 |                                  |               |     |                  |      |   |      |
| RPEF     |                                 |                                  |               | Par | ity error status | flag |   |      |
|          | 0 No parity error has occurred. |                                  |               |     |                  |      |   |      |
|          | 1 A parity error has occurred.  |                                  |               |     |                  |      |   |      |

Caution The parity bit is appended when data is written, and the parity is checked when the data is read. Therefore, while RAM parity error resets are enabled (RPERDIS = 0), be sure to initialize RAM areas where data access is to proceed before reading data. R9A02G015's CPU executes look-ahead due to the pipeline operation, the CPU might read an uninitialized RAM area that is allocated beyond the RAM used, which causes a RAM parity error. Therefore, while RAM parity error resets are enabled (RPERDIS = 0), be sure to initialize the RAM area + 10 bytes when instructions are fetched from RAM areas.

- Remark 1. The parity error reset is enabled by default (RPERDIS = 0).
- **Remark 2.** Even if the parity error reset is disabled (RPERDIS = 1), the RPEF flag will be set (1) if a parity error occurs. If the parity error reset is enabled (RPERDIS = 0) while RPEF = 1, a parity error reset occurs when RPERDIS is cleared (0).
- Remark 3. The RPECTL flag in the RESF register is set (1) by RAM parity errors and cleared (0) by writing 0 to it or by any reset source. When RPEF = 1, the value is retained even if RAM for which no parity error has occurred is read.
- **Remark 4.** General-purpose registers are not included in the range of RAM parity error detection.





Figure 19 - 8 RAM Parity Error Check Flow

Note See CHAPTER 16 RESET FUNCTION for details on how to confirm internal resets due to RAM parity errors.



### 19.3.4 RAM guard function

1

In order to guarantee safety during operation, the IEC61508 standard mandates that important data stored in the RAM be protected, even if the CPU freezes.

This RAM guard function is used to protect data in the specified memory space.

If the RAM guard function is specified, writing to the specified RAM space is disabled, but reading from the space can be carried out as usual.

### 19.3.4.1 Invalid memory access detection control register (IAWCTL)

This register is used to control the detection of invalid memory access and RAM/SFR guard function. GRAM1 and GRAM0 bits are used in RAM guard function.

The IAWCTL register can be set by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

1

#### Figure 19 - 9 Format of Invalid memory access detection control register (IAWCTL)

| Address | F0077H | After reset: 00 | H R/W                                           |                   |                |                         |      |      |
|---------|--------|-----------------|-------------------------------------------------|-------------------|----------------|-------------------------|------|------|
| Symbol  | 7      | 6               | 5                                               | 4                 | 3              | 2                       | 1    | 0    |
| IAWCTL  | IAWEN  | 0               | GRAM1                                           | GRAM0             | 0              | GPORT                   | GINT | GCSC |
| -       |        |                 |                                                 |                   |                |                         |      |      |
|         | GRAM1  | GRAM0           |                                                 |                   | RAM guard      | l space <sup>Note</sup> |      |      |
|         | 0      | 0               | Disabled. RAM                                   | /I can be writter | ı to.          |                         |      |      |
|         | 0      | 1               | The 128 bytes starting at the start RAM address |                   |                |                         |      |      |
|         | 1      | 0               | The 256 bytes                                   | starting at the   | start RAM addı | ress                    |      |      |

Note The RAM start address differs depending on the size of the RAM provided with the product.

The 512 bytes starting at the start RAM address



### **19.3.5** SFR guard function

In order to guarantee safety during operation, the IEC61508 standard mandates that important SFRs be protected from being overwritten, even if the CPU freezes.

This SFR guard function is used to protect data in the control registers used by the port function, interrupt function, clock control function, voltage detection function, and RAM parity error detection function.

If the SFR guard function is specified, writing to the specified SFRs is disabled, but reading from the SFRs can be carried out as usual.

### 19.3.5.1 Invalid memory access detection control register (IAWCTL)

This register is used to control the detection of invalid memory access and RAM/SFR guard function. GPORT, GINT and GCSC bits are used in SFR guard function.

The IAWCTL register can be set by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 19 - 10 Format of Invalid memory access detection control register (IAWCTL)

| Address: | F0077H | After reset: 00 | H R/W |       |   |       |      |      |  |
|----------|--------|-----------------|-------|-------|---|-------|------|------|--|
| Symbol   | 7      | 6               | 5     | 4     | 3 | 2     | 1    | 0    |  |
| IAWCTL   | IAWEN  | 0               | GRAM1 | GRAM0 | 0 | GPORT | GINT | GCSC |  |

| GPORT | Control registers of port function guard                                                                                                                 |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Disabled. Control registers of port function can be read or written to.                                                                                  |
| 1     | Enabled. Writing to control registers of port function is disabled. Reading is enabled.<br>[Guarded SFR] PMxx, PUxx, PIMxx, POMxx, PMCxx <sup>Note</sup> |

| GINT | Registers of interrupt function guard                                                                                              |
|------|------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Disabled. Registers of interrupt function can be read or written to.                                                               |
| 1 1  | Enabled. Writing to registers of interrupt function is disabled. Reading is enabled.<br>[Guarded SFR] IFxx, MKxx, PRxx, EGPx, EGNx |

| GCSC | CSC Control registers of clock control function, voltage detector, and RAM parity error detection function guard                                                                                                                                    |  |  |  |  |  |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0    | Disabled. Control registers of clock control function, voltage detector and RAM parity error detection function can be read or written to.                                                                                                          |  |  |  |  |  |  |
| 1    | Enabled. Writing to control registers of clock control function, voltage detector and RAM parity error detection function is disabled. Reading is enabled.<br>[Guarded SFR] CMC, CSC, OSTS, CKC, PERx, PRRx, OSMC, LVIM, LVIS, RPECTL, DSCCTL, MCKC |  |  |  |  |  |  |

**Note** Pxx (Port register) is not guarded.





## 19.3.6 Invalid memory access detection function

The IEC60730 standard mandates checking that the CPU and interrupts are operating correctly.

The illegal memory access detection function triggers a reset if a memory space specified as access-prohibited is accessed.

The illegal memory access detection function applies to the areas indicated by NG in Figure 19 - 11.

Figure 19 - 11 Invalid access detection area





## 19.3.6.1 Invalid memory access detection control register (IAWCTL)

This register is used to control the detection of invalid memory access and RAM/SFR guard function. IAWEN bit is used in invalid memory access detection function.

The IAWCTL register can be set by an 8-bit memory manipulation instruction.

Reset signal generation clears this register to 00H.

#### Figure 19 - 12 Format of Invalid memory access detection control register (IAWCTL)

| Address: F0077H |            | After reset: 00H | H R/W |       |   |       |      |      |
|-----------------|------------|------------------|-------|-------|---|-------|------|------|
| Symbol          | 7          | 6                | 5     | 4     | 3 | 2     | 1    | 0    |
| IAWCTL          | IAWEN Note | 0                | GRAM1 | GRAM0 | 0 | GPORT | GINT | GCSC |

|                                                   | IAWEN Note | Control of invalid memory access detection     |  |  |  |
|---------------------------------------------------|------------|------------------------------------------------|--|--|--|
| 0 Disable the detection of invalid memory access. |            |                                                |  |  |  |
|                                                   | 1          | Enable the detection of invalid memory access. |  |  |  |

**Note** Only writing 1 to the IAWEN bit is enabled, not writing 0 to it after setting it to 1.

**Remark** By specifying WDTON = 1 for the option byte (watchdog timer operation enable), the invalid memory access detection function is enabled even if IAWEN = 0.



## **19.3.7** Frequency detection function

The IEC60730 standard mandates checking that the oscillation frequency is correct.

By using the CPU/peripheral hardware clock frequency (fCLK) and measuring the pulse width of the input signal to channel 1 of the timer array unit 0 (TAU0), whether the proportional relationship between the two clock frequencies is correct can be determined. Note that, however, if one or both clock operations are completely stopped, the proportional relationship between the clocks cannot be determined.

<Clocks to be compared>

- <1> CPU/peripheral hardware clock frequency (fCLK):
  - High-speed on-chip oscillator clock (fiH)
  - High-speed system clock (fMX)

<2> Input to channel 1 of the timer array unit 0

- Timer input to channel 1 (TI01)
- Low-speed on-chip oscillator clock (fiL: 15 kHz (typ.))





If pulse interval measurement results in an abnormal value, it can be concluded that the clock frequency is abnormal.

For how to execute pulse interval measurement, see 6.8.3 Operation as input pulse interval measurement.



## 19.3.7.1 Timer input select register 0 (TIS0)

The TIS0 register is used to select the timer input of channels 0 and 1 of the timer array unit 0 (TAU0). The TIS0 register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H.

#### Figure 19 - 14 Format of Timer input select register 0 (TIS0)

| Address: | F0074H | After reset: 00H | R/W   |                                        |                  |                          |                |       |  |
|----------|--------|------------------|-------|----------------------------------------|------------------|--------------------------|----------------|-------|--|
| Symbol   | 7      | 6                | 5     | 4                                      | 3                | 2                        | 1              | 0     |  |
| TIS0     | 0      | 0                | 0     | 0                                      | 0                | TIS02                    | TIS01          | TIS00 |  |
| r        |        | · · · ·          |       | 1                                      |                  |                          |                |       |  |
|          | TIS02  | TIS01            | TIS00 |                                        | Selection of ti  | mer input used           | with channel 1 |       |  |
|          | 0 0    |                  | 0     | Input signal of timer input pin (TI01) |                  |                          |                |       |  |
|          | 0      | 0                | 1     |                                        |                  |                          |                |       |  |
|          | 0      | 1                | 0     |                                        |                  |                          |                |       |  |
|          | 0      | 1                | 1     |                                        |                  |                          |                |       |  |
|          | 1      | 0                | 0     | Low-speed on                           | -chip oscillator | <sup>.</sup> clock (fi∟) |                |       |  |
|          |        | Other than above | •     | Setting prohibi                        | ited             |                          |                |       |  |

Caution At least 1/fMCK + 10 ns is necessary as the high-level and low-level widths of the timer input to be selected.



## 19.3.8 A/D test function

The IEC60730 standard mandates testing the A/D converter. The A/D test function is used to check whether the A/D converter is operating normally by executing A/D conversions of the positive reference voltage and negative reference voltage of the A/D converter, analog input channel (ANI), temperature sensor output voltage, and internal reference voltage. For details on the checking method, refer to the safety function (A/D test) application note (R01AN0955).

The analog multiplexer can be checked using the following procedure.

- (1) Select the ANIx pin as the target for A/D conversion by setting the ADTES register (ADTES1, ADTES0 = 0, 0).
- (2) Perform A/D conversion for the ANIx pin (conversion result 1-1).
- (3) Select the negative reference voltage of the A/D converter as the target for A/D conversion by setting the ADTES register (ADTES1, ADTES0 = 1, 0).
- (4) Perform A/D conversion of the negative reference voltage of the A/D converter (conversion result 2-1).
- (5) Select the ANIx pin as the target for A/D conversion by setting the ADTES register (ADTES1, ADTES0 = 0, 0).
- (6) Perform A/D conversion for the ANIx pin (conversion result 1-2).
- (7) Select the positive reference voltage of the A/D converter as the target for A/D conversion by setting the ADTES register (ADTES1, ADTES0 = 1, 1).
- (8) Perform A/D conversion of the positive reference voltage of the A/D converter (conversion result 2-2).
- (9) Select the ANIx pin as the target for A/D conversion by setting the ADTES register (ADTES1, ADTES0 = 0, 0).
- (10) Perform A/D conversion for the ANIx pin (conversion result 1-3).
- (11) Make sure that "conversion result 1-1" = "conversion result 1-2" = "conversion result 1-3".
- (12) Make sure that the A/D conversion results of "conversion result 2-1" are all 0 and those of "conversion result 2-2" are all 1.

Using the procedure above can confirm that the analog multiplexer is selected and all wiring is connected.

- **Remark 1.** If the analog input voltage is variable during conversion in steps (1) to (10) above, use another method to check the analog multiplexer.
- **Remark 2.** The conversion results might contain an error. Consider an appropriate level of error when comparing the conversion results.
- **Remark 3.** Set A/D test register (ADTES) to 00H when measuring the ANIxx/temperature sensor output /internal reference voltage (1.45 V).
- Remark 4. For details on Analog input channel specification register, refer to Figure 10 12 Format of Analog Input Channel Specification Register (ADS).

For details on the A/D test register, refer to Figure 10 - 16 Format of A/D Test Register (ADTES).





Figure 19 - 15 Configuration of A/D Test Function



#### 19.3.9 Digital output signal level detection function for I/O pins

In the IEC60730, it is required to check that the I/O function correctly operates. By using the digital output signal level detection function for I/O pins, the digital output level of the pin can be read when the port is set to output mode.

#### 19.3.9.1 Port mode select register (PMS)

This register is used to select the output level from output latch level or pin output level when the pin is output mode in which PMm bit of port mode register (PMm) is 0.

. .

This register can be set by a 1-bit or 8-bit memory manipulation instruction.

....

Reset signal generation clears this register to 00H.

|                                            | Figure 19 - 16 Format of Port mode select register (PMS) |                  |              |                 |                    |                 |             |      |  |  |  |
|--------------------------------------------|----------------------------------------------------------|------------------|--------------|-----------------|--------------------|-----------------|-------------|------|--|--|--|
| Address:                                   | F007BH                                                   | After reset: 00H | R/W          |                 |                    |                 |             |      |  |  |  |
| Symbol                                     | 7                                                        | 6                | 5            | 4               | 3                  | 2               | 1           | 0    |  |  |  |
| PMS                                        | 0                                                        | 0                | 0            | 0               | 0                  | 0               | 0           | PMS0 |  |  |  |
|                                            | PMS0                                                     |                  | Method for s | selecting outpu | it level to be rea | d when pin is c | output mode |      |  |  |  |
| F                                          | 0                                                        | Pmn register va  | lue is read. |                 |                    |                 |             |      |  |  |  |
| 1 Digital output level of the pin is read. |                                                          |                  |              |                 |                    |                 |             |      |  |  |  |

- Caution 1. While the PMS0 bit in the PMS register is set to 1, do not change the value of the port register (Pxx) using a bit manipulation instruction. To change the value of the port register (Pxx), use an 8-bit data manipulation instruction.
- Caution 2. When P60 to P64 are used as general-purpose ports, the pin output level cannot read using PMS0. The read value is 0.

Remark m = 0, 2, 4 to 7 n = 0 to 5



## **CHAPTER 20 REGULATOR**

## 20.1 Regulator Overview

R9A02G015 contains a circuit for operating the device with a constant voltage. At this time, in order to stabilize the regulator output voltage, connect the REGC pin to Vss via a capacitor (0.47 to 1  $\mu$ F). Also, use a capacitor with good characteristics, since it is used to stabilize internal voltage.



#### Caution Keep the wiring length as short as possible for the broken-line part in the above figure.

The regulator output voltage, see **Table 20 - 1**.

| Table 20 - 1 Regulator | r Output Voltage Conditions |  |
|------------------------|-----------------------------|--|
|------------------------|-----------------------------|--|

| Mode                      | Output Voltage | Condition                                       |
|---------------------------|----------------|-------------------------------------------------|
| HS (high-speed main) mode | 1.8 V          | In STOP mode                                    |
|                           | 2.1 V          | Other than above (include during OCD mode) Note |

Note When it shifts to STOP mode during the on-chip debugging, the regulator output voltage is kept at 2.1 V (not decline to 1.8 V).



## **CHAPTER 21 OPTION BYTE**

## 21.1 Functions of Option Bytes

Addresses 000C0H to 000C3H of the flash memory of the R9A02G015 form an option byte area. Option bytes consist of user option byte (000C0H to 000C2H) and on-chip debug option byte (000C3H). Upon power application or resetting and starting, an option byte is automatically referenced and a specified function is set. When using the product, be sure to set the following functions by using the option bytes. For the bits to which no function is allocated, do not change their initial values. To use the boot swap operation during self-programming, 000C0H to 000C3H are replaced by 010C0H to 010C3H.

Therefore, set the same values as 000C0H to 000C3H to 010C0H to 010C3H.

**Remark** The option bytes should always be set regardless of whether each function is used.

## 21.1.1 User option byte (000C0H to 000C2H/010C0H to 010C2H)

- (1) 000C0H/010C0H
  - $\bigcirc\;$  Setting of watchdog timer operation
    - Enabling or disabling of counter operation
    - Enabling or disabling of counter operation in the HALT or STOP mode
  - $\bigcirc\,$  Setting of interval time of watchdog timer
  - $\bigcirc$  Setting of window open period of watchdog timer
  - O Setting of interval interrupt of watchdog timer
    - Interval interrupt is used or not used

## Caution Set the same value as 000C0H to 010C0H when the boot swap operation is used because 000C0H is replaced by 010C0H.

- (2) 000C1H/010C1H
  - $\bigcirc$  Setting of LVD operation mode
    - Interrupt & reset mode
    - Reset mode
    - Interrupt mode
    - LVD off (external reset input from the RESETB pin is used)
  - Setting of LVD detection level (VLVDH, VLVDL, VLVD)
- Caution 1. After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 2.4 AC Characteristics of the R9A02G015 Data Sheet (R19DS0101E). This is done by utilizing the voltage detection circuit or controlling the externally input reset signal. After the power supply is turned off, this LSI should be placed in the STOP mode, or placed in the reset state by utilizing the voltage detection circuit or controlling the externally input reset signal, before the voltage falls below the operating range. The range of operating voltage varies with the setting of the user option byte (000C2H or 010C2H).
- Caution 2. Set the same value as 000C1H to 010C1H when the boot swap operation is used because 000C1H is replaced by 010C1H.



#### (3) 000C2H/010C2H

 $\bigcirc\,$  Setting of flash operation mode

Make the setting depending on the main system clock frequency (fMAIN) and power supply voltage (VDD) to be used.

- HS (high-speed main) mode
- Setting of the frequency of the high-speed on-chip oscillator
  - Select from 48MHz, 24MHz, 16MHz, 12MHz, 8MHz, 6MHz, 4MHz, 3MHz, 2MHz or 1MHz(TYP).

## Caution Set the same value as 000C2H to 010C2H when the boot swap operation is used because 000C2H is replaced by 010C2H.

## 21.1.2 On-chip debug option byte (000C3H/010C3H)

- $\bigcirc$  Control of on-chip debug operation
  - On-chip debug operation is disabled or enabled.
- $\bigcirc$  Handling of data of flash memory in case of failure in on-chip debug security ID authentication
  - Data of flash memory is erased or not erased in case of failure in on-chip debug security ID authentication.

## Caution Set the same value as 000C3H to 010C3H when the boot swap operation is used because 000C3H is replaced by 010C3H.



## 21.2 Format of User Option Byte

The format of user option byte is shown below.

#### Figure 21 - 1 Format of User Option Byte (000C0H/010C0H)

Address: 000C0H/010C0H Note 1

| 7        | 6                | 5                                                                                  | 4                            | 3                 | 2                | 1       | 0        |  |  |  |  |
|----------|------------------|------------------------------------------------------------------------------------|------------------------------|-------------------|------------------|---------|----------|--|--|--|--|
| WDTINT   | WINDOW1          | WINDOW0                                                                            | WDTON                        | WDCS2             | WDCS1            | WDCS0   | WDSTBYON |  |  |  |  |
| WDTINT   |                  |                                                                                    | Lloo of intony               | al interrupt of w | atab dag timar   |         |          |  |  |  |  |
|          |                  | Use of interval interrupt of watchdog timer                                        |                              |                   |                  |         |          |  |  |  |  |
| 0        |                  | terval interrupt is not used.                                                      |                              |                   |                  |         |          |  |  |  |  |
| 1        | Interval interru | nterval interrupt is generated when 75% + 1/2 fi∟ of the overflow time is reached. |                              |                   |                  |         |          |  |  |  |  |
| WINDOW1  | WINDOW0          | VINDOW0 Watchdog timer window open period Note 2                                   |                              |                   |                  |         |          |  |  |  |  |
| 0        | 0                | Setting prohib                                                                     | bited                        |                   |                  |         |          |  |  |  |  |
| 0        | 1                | 50%                                                                                |                              |                   |                  |         |          |  |  |  |  |
| 1        | 0                | 0 75%Note 3                                                                        |                              |                   |                  |         |          |  |  |  |  |
| 1        | 1                | 1 100%                                                                             |                              |                   |                  |         |          |  |  |  |  |
|          |                  |                                                                                    |                              |                   |                  |         |          |  |  |  |  |
| WDTON    |                  | Operation control of watchdog timer counter                                        |                              |                   |                  |         |          |  |  |  |  |
| 0        |                  | Counter operation disabled (counting stopped after reset)                          |                              |                   |                  |         |          |  |  |  |  |
| 1        | Counter opera    | ation enabled (                                                                    | counting started             | l after reset)    |                  |         |          |  |  |  |  |
|          |                  |                                                                                    |                              | Watcho            | log timer overfl | ow time |          |  |  |  |  |
| WDCS2    | WDCS1            | WDCS0                                                                              |                              |                   | = 17.25 kHz (M   |         |          |  |  |  |  |
| 0        | 0                | 0                                                                                  | 2 <sup>6</sup> /fı∟ (3.71 ms | 5)                |                  |         |          |  |  |  |  |
| 0        | 0                | 1                                                                                  | 2 <sup>7</sup> /fı∟ (7.42 ms | 6)                |                  |         |          |  |  |  |  |
| 0        | 1                | 0                                                                                  | 2 <sup>8</sup> /fı∟ (14.84 m | ns)               |                  |         |          |  |  |  |  |
| 0        | 1                | 1                                                                                  | 2 <sup>9</sup> /fı∟ (29.68 m | ns)               |                  |         |          |  |  |  |  |
| 1        | 0                | 0                                                                                  | 2 <sup>11</sup> /fı∟ (118.72 | : ms)             |                  |         |          |  |  |  |  |
| 1        | 0                | 1                                                                                  | 2 <sup>13</sup> /fi∟ (474.90 | ) ms)             |                  |         |          |  |  |  |  |
| 1        | 1                | 0                                                                                  | 2 <sup>14</sup> /fi∟ (949.80 | ) ms)             |                  |         |          |  |  |  |  |
| 1        | 1                | 1 2 <sup>16</sup> /fiL (3799.19 ms)                                                |                              |                   |                  |         |          |  |  |  |  |
|          | 1                | -                                                                                  |                              |                   |                  |         |          |  |  |  |  |
| WDSTBYON |                  | Operation control of watchdog timer counter (HALT/STOP mode)                       |                              |                   |                  |         |          |  |  |  |  |

| WDSTBYON | Operation control of watchdog timer counter (HALT/STOP mode) |
|----------|--------------------------------------------------------------|
| 0        | Counter operation stopped in HALT/STOP mode Note 2           |
| 1        | Counter operation enabled in HALT/STOP mode                  |

**Note 1.** Set the same value as 000C0H to 010C0H when the boot swap operation is used because 000C0H is replaced by 010C0H.

**Note 2.** The window open period is 100% when WDSTBYON = 0, regardless the value of the WINDOW1 and WINDOW0 bits.

(Note continues on the next page.)



**Note 3.** When the window open period is set to 75%, clearing the counter of the watchdog timer (writing ACH to WDTE) must proceed outside the corresponding period from among those listed below, over which clearing of the counter is prohibited (for example, confirming that the interval timer interrupt request flag (WDTIIF) of the watchdog timer is set).

| WDCS2 | WDCS1 | WDCS0 | Watchdog timer overflow time<br>(fi∟ = 17.25 kHz (MAX.)) | Period over which clearing the counter is prohibited when the window open period is set to 75% |
|-------|-------|-------|----------------------------------------------------------|------------------------------------------------------------------------------------------------|
| 0     | 0     | 0     | 2 <sup>6</sup> /fi∟ (3.71 ms)                            | 1.85 ms to 2.51 ms                                                                             |
| 0     | 0     | 1     | 2 <sup>7</sup> /fi∟ (7.42 ms)                            | 3.71 ms to 5.02 ms                                                                             |
| 0     | 1     | 0     | 2 <sup>8</sup> /fi∟ (14.84 ms)                           | 7.42 ms to 10.04 ms                                                                            |
| 0     | 1     | 1     | 2 <sup>9</sup> /fi∟ (29.68 ms)                           | 14.84 ms to 20.08 ms                                                                           |
| 1     | 0     | 0     | 2 <sup>11</sup> /fi∟ (118.72 ms)                         | 56.36 ms to 80.32 ms                                                                           |
| 1     | 0     | 1     | 2 <sup>13</sup> /fi∟ (474.90 ms)                         | 237.44 ms to 321.26 ms                                                                         |
| 1     | 1     | 0     | 2 <sup>14</sup> /fi∟ (949.80 ms)                         | 474.89 ms to 642.51 ms                                                                         |
| 1     | 1     | 1     | 2 <sup>16</sup> /fi∟ (3799.19 ms)                        | 1899.59 ms to 2570.04 ms                                                                       |

Remark fil: Low-speed on-chip oscillator clock frequency



#### Figure 21 - 2 Format of User Option Byte (000C1H/010C1H) (1/4)

Address: 000C1H/010C1H Note

| 7     | 6     | 5     | 4 | 3     | 2     | 1       | 0       |
|-------|-------|-------|---|-------|-------|---------|---------|
| VPOC2 | VPOC1 | VPOC0 | 1 | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 |

• LVD setting (interrupt & reset mode)

| C           | Detection Voltage |              |       | Option Byte Setting Value                         |        |       |       |              |         |  |
|-------------|-------------------|--------------|-------|---------------------------------------------------|--------|-------|-------|--------------|---------|--|
| Vlvdh       |                   | Vlvdl        | VPOC2 | VPOC1                                             | VPOC0  | LVIS1 | LVIS0 | Mode setting |         |  |
| Rising edge | Falling edge      | Falling edge | VF002 | VFOCT                                             | VI 000 | EVIOT | LVIGO | LVIMDS1      | LVIMDS0 |  |
| 2.92 V      | 2.86 V            | 2.75 V       | 0     | 1                                                 | 1      | 1     | 0     | 1            | 0       |  |
| 3.02 V      | 2.96 V            |              |       |                                                   |        | 0     | 1     |              |         |  |
| 4.06 V      | 3.98 V            |              |       |                                                   |        | 0     | 0     |              |         |  |
|             | <u> </u>          |              |       | Setting of values other than above is prohibited. |        |       |       |              |         |  |

**Note** Set the same value as 000C1H to 010C1H when the boot swap operation is used because 000C1H is replaced by 010C1H.

Caution Be sure to set bit 4 to "1".

Remark 1. For details on the LVD circuit, see CHAPTER 18 VOLTAGE DETECTOR.

**Remark 2.** The detection voltage is a typical value. For details, see **2.6.4 LVD circuit characteristics** in the R9A02G015 Data Sheet (R19DS0101E).





Address: 000C1H/010C1H Note

|   | 7     | 6     | 5     | 4 | 3     | 2     | 1       | 0       |
|---|-------|-------|-------|---|-------|-------|---------|---------|
| Γ | VPOC2 | VPOC1 | VPOC0 | 1 | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 |

• LVD setting (reset mode)

| Detectio    | n Voltage    | Option Byte Setting Value |                                                   |        |       |       |              |         |  |
|-------------|--------------|---------------------------|---------------------------------------------------|--------|-------|-------|--------------|---------|--|
| V           | Vlvd         |                           | VPOC1                                             | VPOC0  | LVIS1 | LVIS0 | Mode setting |         |  |
| Rising edge | Falling edge | - VPOC2                   | 1 001                                             | 11 000 | LVIST | EVIOU | LVIMDS1      | LVIMDS0 |  |
| 2.81 V      | 2.75 V       | 0                         | 1                                                 | 1      | 1     | 1     | 1            | 1       |  |
| 2.92 V      | 2.86 V       |                           | 1                                                 | 1      | 1     | 0     | -            |         |  |
| 3.02 V      | 2.96 V       |                           | 1                                                 | 1      | 0     | 1     | -            |         |  |
| 3.13 V      | 3.06 V       |                           | 0                                                 | 1      | 0     | 0     | -            |         |  |
| 3.75 V      | 3.67 V       |                           | 1                                                 | 0      | 0     | 0     | -            |         |  |
| 4.06 V      | 3.98 V       |                           | 1                                                 | 1      | 0     | 0     | 1            |         |  |
| -           |              |                           | Setting of values other than above is prohibited. |        |       |       |              |         |  |

**Note** Set the same value as 000C1H to 010C1H when the boot swap operation is used because 000C1H is replaced by 010C1H.

Caution Be sure to set bit 4 to "1".

Remark 1. For details on the LVD circuit, see CHAPTER 18 VOLTAGE DETECTOR.

**Remark 2.** The detection voltage is a typical value. For details, see **2.6.4 LVD circuit characteristics** in the R9A02G015 Data Sheet (R19DS0101E).



#### Figure 21 - 4 Format of User Option Byte (000C1H/010C1H) (3/4)

Address: 000C1H/010C1H Note

|   | 7     | 6     | 5     | 4 | 3     | 2     | 1       | 0       |
|---|-------|-------|-------|---|-------|-------|---------|---------|
| [ | VPOC2 | VPOC1 | VPOC0 | 1 | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 |

• LVD setting (interrupt mode)

| Detectio    | Detection Voltage |       |       | Option Byte Setting Value                         |       |       |              |         |  |  |  |
|-------------|-------------------|-------|-------|---------------------------------------------------|-------|-------|--------------|---------|--|--|--|
| V           | Vlvd              |       | VPOC1 | VPOC0                                             | LVIS1 | LVIS0 | Mode setting |         |  |  |  |
| Rising edge | Falling edge      | VPOC2 | VIOCI | 11 000                                            |       | EVIOU | LVIMDS1      | LVIMDS0 |  |  |  |
| 2.81 V      | 2.75 V            | 0     | 1     | 1                                                 | 1     | 1     | 0            | 1       |  |  |  |
| 2.92 V      | 2.86 V            |       | 1     | 1                                                 | 1     | 0     |              |         |  |  |  |
| 3.02 V      | 2.96 V            |       | 1     | 1                                                 | 0     | 1     |              |         |  |  |  |
| 3.13 V      | 3.06 V            |       | 0     | 1                                                 | 0     | 0     |              |         |  |  |  |
| 3.75 V      | 3.67 V            |       | 1     | 0                                                 | 0     | 0     |              |         |  |  |  |
| 4.06 V      | 3.98 V            |       | 1     | 1                                                 | 0     | 0     |              |         |  |  |  |
| -           | —                 |       |       | Setting of values other than above is prohibited. |       |       |              |         |  |  |  |

**Note** Set the same value as 000C1H to 010C1H when the boot swap operation is used because 000C1H is replaced by 010C1H.

Caution Be sure to set bit 4 to "1".

- Remark 1. For details on the LVD circuit, see CHAPTER 18 VOLTAGE DETECTOR.
- **Remark 2.** The detection voltage is a typical value. For details, see **2.6.4 LVD circuit characteristics** in the R9A02G015 Data Sheet (R19DS0101E).



#### Figure 21 - 5 Format of User Option Byte (000C1H/010C1H) (4/4)

Address: 000C1H/010C1H Note

|   | 7     | 6     | 5     | 4 | 3     | 2     | 1       | 0       |
|---|-------|-------|-------|---|-------|-------|---------|---------|
| Γ | VPOC2 | VPOC1 | VPOC0 | 1 | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 |

• LVD off setting (external reset input from the RESETB pin is used)

| Detectio    | Detection Voltage |                                              |       | Option Byte Setting Value |       |       |              |         |  |  |  |
|-------------|-------------------|----------------------------------------------|-------|---------------------------|-------|-------|--------------|---------|--|--|--|
| Vlvd        |                   | VPOC2                                        | VPOC1 | VPOC0                     | LVIS1 | LVIS0 | Mode setting |         |  |  |  |
| Rising edge | Falling edge      | VF002                                        |       | VFOCU                     | LVIST | LVIGO | LVIMDS1      | LVIMDS0 |  |  |  |
| —           |                   |                                              | ×     | ×                         | ×     | ×     | ×            | 1       |  |  |  |
|             |                   | Settings other than the above are prohibited |       |                           |       |       |              |         |  |  |  |

**Note** Set the same value as 000C1H to 010C1H when the boot swap operation is used because 000C1H is replaced by 010C1H.

Caution 1. Be sure to set bit 4 to "1".

- Caution 2. After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 2.4 AC Characteristics of the R9A02G015 Data Sheet (R19DS0101E). This is done by utilizing the voltage detection circuit or controlling the externally input reset signal. After the power supply is turned off, this LSI should be placed in the STOP mode, or placed in the reset state by utilizing the voltage detection circuit or controlling the externally input reset signal, before the voltage falls below the operating range. The range of operating voltage varies with the setting of the user option byte (000C2H or 010C2H).
- Remark 1. ×: Don't care
- Remark 2. For details on the LVD circuit, see CHAPTER 18 VOLTAGE DETECTOR.
- **Remark 3.** The detection voltage is a typical value. For details, see **2.6.4 LVD circuit characteristics** in the R9A02G015 Data Sheet (R19DS0101E).



#### Figure 21 - 6 Format of Option Byte (000C2H/010C2H)

Address: 000C2H/010C2H Note 1

| 7                                   | 6      | 5                                                                                                                     | 4             | 3           | 2       | 1            | 0       |
|-------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------|---------------|-------------|---------|--------------|---------|
| CMODE1                              | CMODE0 | 1                                                                                                                     | FRQSEL4       | FRQSEL3     | FRQSEL2 | FRQSEL1      | FRQSEL0 |
| CMODE1                              | CMODE0 | Setting of flash operation mode         Operating Frequency       Operating Voltage         Range (fMAIN)       (VDD) |               |             |         |              | 0 0     |
| 1                                   | 1      | HS (high-spee                                                                                                         | ed main) mode | 1 to 24 MHz |         | 2.7 to 5.5 V |         |
| Other than above Setting prohibited |        |                                                                                                                       |               |             |         |              |         |

| FRQSEL4 | FRQSEL3 | FRQSEL2         | FRQSEL1            | FRQSEL0 |               | nigh-speed on-chip<br>or clock             |  |
|---------|---------|-----------------|--------------------|---------|---------------|--------------------------------------------|--|
| 11010   |         |                 |                    |         | fносо         | fін                                        |  |
| 1       | 0       | 0               | 0                  | 0       | 48 MHz Note 3 | 24 MHz, 12 MHz,<br>6 MHz <sup>Note 2</sup> |  |
| 0       | 0       | 0               | 0                  | 0       | 24 MHz        | 24 MHz                                     |  |
| 0       | 1       | 0               | 0                  | 1       | 16 MHz        | 16 MHz                                     |  |
| 0       | 0       | 0               | 0                  | 1       | 12 MHz        | 12 MHz                                     |  |
| 0       | 1       | 0               | 1                  | 0       | 8 MHz         | 8 MHz                                      |  |
| 0       | 0       | 0               | 1                  | 0       | 6 MHz         | 6 MHz                                      |  |
| 0       | 1       | 0               | 1                  | 1       | 4 MHz         | 4 MHz                                      |  |
| 0       | 0       | 0               | 1                  | 1       | 3 MHz         | 3 MHz                                      |  |
| 0       | 1       | 1               | 0                  | 0       | 2 MHz         | 2 MHz                                      |  |
| 0       | 1       | 1               | 0                  | 1       | 1 MHz         | 1 MHz                                      |  |
|         | C       | other than abov | Setting prohibited |         |               |                                            |  |

**Note 1.** Set the same value as 000C2H to 010C2H when the boot swap operation is used because 000C2H is replaced by 010C2H.

Note 2. See the MCKC register for fiH division ratio settings.

**Note 3.** When using the high-speed on-chip oscillator clock (fHOCO) to operate the USB controller, be sure to set fHOCO = 48MHz.

Note 4. When using R9A02G0151 (without USB), be sure to set FRQSEL4 to 0.



## 21.3 Format of On-chip Debug Option Byte

The format of on-chip debug option byte is shown below.

#### Figure 21 - 7 Format of On-chip Debug Option Byte (000C3H/010C3H)

Address: 000C3H/010C3H Note

| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|----------|---|---|---|---|---|---|---------|
| OCDENSET | 0 | 0 | 0 | 0 | 1 | 0 | OCDERSD |

| OCDENSET | OCDERSD | Control of on-chip debug operation                                                                                                     |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------|
| 0        | 0       | Disables on-chip debug operation.                                                                                                      |
| 0        | 1       | Setting prohibited                                                                                                                     |
| 1        | 0       | Enables on-chip debugging.<br>Erases data of flash memory in case of failures in authenticating on-chip debug<br>security ID.          |
| 1        | 1       | Enables on-chip debugging.<br>Does not erases data of flash memory in case of failures in authenticating on-chip<br>debug security ID. |

**Note** Set the same value as 000C3H to 010C3H when the boot swap operation is used because 000C3H is replaced by 010C3H.

#### Caution Bits 7 and 0 (OCDENSET and OCDERSD) can only be specified a value. Be sure to set 000010B to bits 6 to 1.

**Remark** The value on bits 3 to 1 will be written over when the on-chip debug function is in use and thus it will become unstable after the setting.

However, be sure to set the default values (0, 1, and 0) to bits 3 to 1 at setting.



## 21.4 Setting of Option Byte

The user option byte and on-chip debug option byte can be set using the assembler linker option, in addition to describing in the source. When doing so, the contents set by using the link option take precedence, even if descriptions exist in the source, as mentioned below.

A software description example of the option byte setting is shown below.

| OPT | CSEG | OPT_BYTE |                                                                        |
|-----|------|----------|------------------------------------------------------------------------|
|     | DB   | 36H      | ; Does not use interval interrupt of watchdog timer,                   |
|     |      |          | ; Enables watchdog timer operation,                                    |
|     |      |          | ; Window open period of watchdog timer is 50%,                         |
|     |      |          | ; Overflow time of watchdog timer is 2 <sup>9</sup> /fiL,              |
|     |      |          | ; Stops watchdog timer operation during HALT/STOP mode                 |
|     | DB   | 7AH      | ; Select 2.75 V for VLVDL                                              |
|     |      |          | ; Select rising edge 2.92 V, falling edge 2.86 V for VLVDH             |
|     |      |          | ; Select the interrupt & reset mode as the LVD operation mode          |
|     | DB   | F0H      | ; Select the HS (high speed main) mode as the flash operation mode     |
|     |      |          | and 48 MHz as the frequency of the high-speed on-chip oscillator clock |
|     | DB   | 85H      | ; Enables on-chip debug operation, does not erase flash memory         |
|     |      |          | data when security ID authorization fails                              |

When the boot swap function is used during self-programming, 000C0H to 000C3H is switched to 010C0H to 010C3H. Describe to 010C0H to 010C3H, therefore, the same values as 000C0H to 000C3H as follows.

| OPT2 | CSEG | AT | 010C0H |                                                                        |
|------|------|----|--------|------------------------------------------------------------------------|
|      | DB   |    | 36H    | ; Does not use interval interrupt of watchdog timer,                   |
|      |      |    |        | ; Enables watchdog timer operation,                                    |
|      |      |    |        | ; Window open period of watchdog timer is 50%,                         |
|      |      |    |        | ; Overflow time of watchdog timer is 2 <sup>9</sup> /fiL,              |
|      |      |    |        | ; Stops watchdog timer operation during HALT/STOP mode                 |
|      | DB   |    | 7AH    | ; Select 2.75 V for VLVDL                                              |
|      |      |    |        | ; Select rising edge 2.92 V, falling edge 2.86 V for VLVDH             |
|      |      |    |        | ; Select the interrupt & reset mode as the LVD operation mode          |
|      | DB   |    | F0H    | ; Select the HS (high speed main) mode as the flash operation mode     |
|      |      |    |        | and 48 MHz as the frequency of the high-speed on-chip oscillator clock |
|      | DB   |    | 85H    | ; Enables on-chip debug operation, does not erase flash memory         |
|      |      |    |        | data when security ID authorization fails                              |

Caution To specify the option byte by using assembly language, use OPT\_BYTE as the relocation attribute name of the CSEG pseudo instruction. To specify the option byte to 010C0H to 010C3H in order to use the boot swap function, use the relocation attribute AT to specify an absolute address.



## **CHAPTER 22 FLASH MEMORY**

R9A02G015 incorporates the flash memory to which a program can be written, erased, and overwritten while mounted on the board. The flash memory includes the "code flash memory", in which programs can be executed, and the "data flash memory", an area for storing data.



The following methods for programming the flash memory are available.

The code flash memory can be rewritten to through serial programming using a flash memory programmer or an external device (UART communication), or through self-programming.

• Serial Programming Using Flash Memory Programmer (see 22.1)

- Data can be written to the flash memory on-board or off-board by using a dedicated flash memory programmer.
- Serial Programming Using External Device (that Incorporates UART) (see 22.2)

Data can be written to the flash memory on-board through UART communication with an external device (microcontroller or ASIC).

• Self-Programming (see 22.6)

The user application can execute self-programming of the code flash memory by using the flash self-programming library.

The data flash memory can be rewritten to by using the data flash library during user program execution (background operation). For access and writing to the data flash memory, see **22.8 Data Flash**.

## 22.1 Serial Programming Using Flash Memory Programmer

The following dedicated flash memory programmer can be used to write data to the internal flash memory of R9A02G015.

#### • PG-FP6

• E1, E2, E2 Lite, E20 on-chip debugging emulator

Data can be written to the flash memory on-board or off-board, by using a dedicated flash memory programmer.

(1) On-board programming

The contents of the flash memory can be rewritten after R9A02G015 has been mounted on the target system. The connectors that connect the dedicated flash memory programmer must be mounted on the target system.

(2) Off-board programming

Data can be written to the flash memory with a dedicated program adapter before the RL78 microcontroller is mounted on the target system.



|        | Din Configuration of Dadiast                           |                   | )*o arommor                                 |           | Pin No.               |
|--------|--------------------------------------------------------|-------------------|---------------------------------------------|-----------|-----------------------|
|        | Pin Configuration of Dedicate                          | ed Flash Memory F | rogrammer                                   |           | 32-pin                |
| Sig    | nal Name                                               |                   |                                             | Pin Name  | HVQFN (4 x 4)         |
| PG-FP6 | E1, E2, E2 Lite, E20 on-<br>chip debugging<br>emulator | I/O               | Pin Function                                |           |                       |
|        | TOOL0                                                  | I/O               | Transmit/<br>receive signal                 | TOOL0/    | 1                     |
| SI/RxD | _                                                      | I/O               | Transmit/<br>receive signal                 | P40       |                       |
| _      | RESET                                                  | Output            | Reset signal                                | RESETB    | 2                     |
| /RESET | _                                                      | Output            | Reset signal                                | RESEID    |                       |
|        | Vdd                                                    |                   | VDD voltage generation/<br>power monitoring | Vdd       | 7                     |
|        | GND                                                    |                   | Orregard                                    | Vss       | exposed die pad (VSS) |
|        |                                                        |                   | Ground                                      | REGC Note | 6                     |
| FLMD1  | EMVdd                                                  | _                 | Driving power for TOOL0 pin                 | Vdd       | 7                     |

#### Table 22 - 1 Wiring Between R9A02G015 and Dedicated Flash Memory Programmer

Note Connect REGC pin to ground via a capacitor (0.47 to 1 µF).

**Remark** Pins that are not indicated in the above table can be left open when using the flash memory programmer for flash programming.



## 22.1.1 Programming Environment

The environment required for writing a program to the flash memory of R9A02G015 is illustrated below.

#### Figure 22 - 1 Environment for Writing Program to Flash Memory



A host machine that controls the dedicated flash memory programmer is necessary. To interface between the dedicated flash memory programmer and R9A02G015, the TOOL0 pin is used for manipulation such as writing and erasing via a dedicated single-line UART.

## 22.1.2 Communication Mode

Communication between the dedicated flash memory programmer and R9A02G015 is established by serial communication using the TOOL0 pin via a dedicated single-line UART of R9A02G015.

Transfer rate: 1 M, 500 k, 250 k, 115.2 kbps

memory programmer



► TOOL0

TOOL0 Note 1

SI/RxD Note 2

#### Figure 22 - 2 Communication with Dedicated Flash Memory Programmer

- **Note 1.** When using E1, E2, E2 Lite, E20 on-chip debugging emulator.
- Note 2. When using PG-FP6.
- Note 3. Connect REGC pin to ground via a capacitor (0.47 to 1  $\mu$ F).



The dedicated flash memory programmer generates the following signals for R9A02G015. See the manual of PG-FP6 or E1, E2, E2 Lite, E20 on-chip debugging emulator for details.

| Dedicated Flash Memory Programmer |                                                 |                  |                                         | R9A02G015                  |  |
|-----------------------------------|-------------------------------------------------|------------------|-----------------------------------------|----------------------------|--|
| Signal Name                       |                                                 |                  |                                         |                            |  |
| PG-FP6                            | E1, E2, E2 Lite, E20 on-chip debugging emulator | I/O Pin Function |                                         | Pin Name <sup>Note 2</sup> |  |
|                                   | Vdd                                             |                  | VDD voltage generation/power monitoring | Vdd                        |  |
| GND                               |                                                 | —                | Ground                                  | Vss, REGC Note 1           |  |
| FLMD1                             | EMVDD                                           | —                | Driving power for TOOL0 pin             | Vdd                        |  |
| /RESET                            | _                                               | Output           | Poort signal                            | RESETB                     |  |
| _                                 | RESET                                           | Output           | Reset signal                            | RESEID                     |  |
| _                                 | TOOL0                                           | I/O              | Transmit/receive signal TOOL0           |                            |  |
| SI/RxD                            | —                                               | I/O              | Transmit/receive signal                 |                            |  |

Note 1. Connect REGC pin to ground via a capacitor (0.47 to 1  $\mu F).$ 

Note 2. Pins to be connected differ with the product. For details, see Table 22 - 1.

## 22.2 Serial Programming Using External Device (that Incorporates UART)

On-board data writing to the internal flash memory is possible by using R9A02G015 and an external device (a microcontroller or ASIC) connected to a UART.

On the development of flash memory programmer by user, refer to the RL78 Microcontrollers (RL78 Protocol A) Programmer Edition Application Note (R01AN0815).

## 22.2.1 Programming Environment

The environment required for writing a program to the flash memory of R9A02G015 is illustrated below.





Processing to write data to or delete data from R9A02G015 by using an external device is performed on-board. Off-board writing is not possible.

## 22.2.2 Communication Mode

Communication between the external device R9A02G015 is established by serial communication using the TOOLTxD and TOOLRxD pins via the dedicated UART of R9A02G015.

Transfer rate: 1 M, 500 k, 250 k, 115.2 kbps





Note Connect REGC pin to ground via a capacitor (0.47 to 1  $\mu$ F).

The external device generates the following signals for R9A02G015.

| External Device |        |                                         | R9A02G015                 |
|-----------------|--------|-----------------------------------------|---------------------------|
| Signal Name     | I/O    | Pin Function                            | Pin Name                  |
| Vdd             | I/O    | VDD voltage generation/power monitoring | Vdd                       |
| GND             | —      | Ground                                  | Vss, REGC <sup>Note</sup> |
| RESETOUT        | Output | Reset signal output                     | RESETB                    |
| RxD             | Input  | Receive signal                          | TOOLTxD                   |
| TxD             | Output | Transmit signal                         | TOOLRxD                   |
| PORT            | Output | Mode signal                             | TOOL0                     |

**Note** Connect REGC pin to ground via a capacitor (0.47 to 1 µF).



### 22.3 Connection of Pins on Board

To write the flash memory on-board by using the flash memory programmer, connectors that connect the dedicated flash memory programmer must be provided on the target system. First provide a function that selects the normal operation mode or flash memory programming mode on the board.

When the flash memory programming mode is set, all the pins not used for programming the flash memory are in the same status as immediately after reset. Therefore, if the external device does not recognize the state immediately after reset, the pins must be handled as described below.

Remark For details on flash memory programming mode, refer to 22.4.2 Flash memory programming mode.

## 22.3.1 P40/TOOL0 pin

In the flash memory programming mode, connect this pin to the dedicated flash memory programmer via an external 1 k $\Omega$  pull-up resistor.

When this pin is used as the port pin, use that by the following method.

- When used as an input pin: Input of low-level is prohibited for tHD period after external reset release. However, when this pin is used via pull-down resistors, use the 500 k $\Omega$  or more resistors.
- When used as an output pin: When this pin is used via pull-down resistors, use the 500 k $\Omega$  or more resistors.
- Remark 1. tHD: How long to keep the TOOL0 pin at the low level from when the external and internal resets end for setting of the flash memory programming mode. For details, refer to R9A02G015 Data Sheet (R19DS0101E).
- **Remark 2.** The SAU and IICA pins are not used for communication between R9A02G015 and dedicated flash memory programmer, because single-line UART (TOOL0 pin) is used.

## 22.3.2 RESETB pin

Signal conflict will occur if the reset signal of the dedicated flash memory programmer and external device are connected to the RESETB pin that is connected to the reset signal generator on the board. To prevent this conflict, isolate the connection with the reset signal generator.

The flash memory will not be correctly programmed if the reset signal is input from the user system while the flash memory programming mode is set. Do not input any signal other than the reset signal of the dedicated flash memory programmer and external device.



Figure 22 - 5 Signal Conflict (RESETB Pin)

In the flash memory programming mode, a signal output by another device will conflict with the signal output by the dedicated flash memory programmer. Therefore, isolate the signal of another device.



## 22.3.3 Port pins

Example When the flash memory programming mode is set, all the pins not used for flash memory programming enter the same status as that immediately after reset. If external devices connected to the ports do not recognize the port status immediately after reset, the port pin must be connected to VDD, or Vss via a resistor

## 22.3.4 REGC pin

Connect the REGC pin to GND via a capacitor having excellent characteristics (0.47 to 1  $\mu$ F) in the same manner as during normal operation. Also, use a capacitor with good characteristics, since it is used to stabilize internal voltage.

## 22.3.5 X1 and X2 pins

Connect X1 and X2 in the same status as in the normal operation mode.

Remark In the flash memory programming mode, the high-speed on-chip oscillator clock (fiH) is used.

## 22.3.6 Power supply

To use the supply voltage output of the flash memory programmer, connect the VDD pin to VDD of the flash memory programmer, and the exposed die pad (Vss) to GND of the flash memory programmer.

To use the on-board supply voltage, connect in compliance with the normal operation mode.

However, when writing to the flash memory by using the flash memory programmer and using the on-board supply voltage, be sure to connect the VDD and exposed die pad (VSS) to VDD and GND of the flash memory programmer to use the power monitor function with the flash memory programmer.



## 22.4 Programming Method

## 22.4.1 Serial programming procedure

The following figure illustrates a flow for rewriting the code flash memory through serial programming.







## 22.4.2 Flash memory programming mode

To rewrite the contents of the code flash memory through serial programming, specify the flash memory programming mode. To enter the mode, set as follows.

<When serial programming by using the dedicated flash memory programmer>

Connect R9A02G015 to a dedicated flash memory programmer. Communication from the dedicated flash memory programmer is performed to automatically switch to the flash memory programming mode.

<When serial programming by using an external device>

Set the TOOL0 pin to the low level, and then cancel the reset (see **Table 22 - 4**). After that, enter flash memory programming mode according to the procedures <1> to <4> shown in **Figure 22 - 7**. For details, refer to the **RL78 microcontrollers (RL78 Protocol A) Programmer Edition Application Note (R01AN0815)**.

Table 22 - 4 Relationship Between TOOL0 Pin and Operation Mode After Reset Release

| TOOL0 | Operation Mode                |
|-------|-------------------------------|
| VDD   | Normal operation mode         |
| 0 V   | Flash memory programming mode |





<1> The low level is input to the TOOL0 pin.

<2> The external reset ends (POR and LVD reset must end before the external reset ends).

<3> The TOOL0 pin is set to the high level.

<4> Setting of the flash memory programming mode by UART reception and complete the baud rate setting.

| Remark | tsuinit: | The segment shows that it is necessary to finish specifying the initial communication settings within 100 ms |
|--------|----------|--------------------------------------------------------------------------------------------------------------|
|        |          | from when the external resets end.                                                                           |
|        | tsu:     | How long from when the TOOL0 pin is placed at the low level until a pin reset ends.                          |
|        | thd:     | How long to keep the TOOL0 pin at the low level from when the external resets end (the flash firmware        |
|        |          | processing time is excluded).                                                                                |

For details, refer to R9A02G015 Data Sheet (R19DS0101E).

The supply voltage value applied to R9A02G015 during write operations and the setting information of the user option byte for setting of the flash memory programming mode determine which mode is selected. When a dedicated flash memory programmer is used for serial programming, setting the voltage on GUI selects the mode automatically.

| Table 22 - 5 Programming Modes and Voltages at Which Data Can Be Written, Erased | d, or Verified |
|----------------------------------------------------------------------------------|----------------|
|----------------------------------------------------------------------------------|----------------|

| Power Supply Voltage (VDD)                                   | User Option Byte Setting for<br>Programn | Flash Programming Mode     |                 |
|--------------------------------------------------------------|------------------------------------------|----------------------------|-----------------|
|                                                              | Flash Operation Mode                     | Operating Frequency (fCLK) |                 |
| $2.7 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V}$ | Blank state                              |                            | Full speed mode |
|                                                              | HS (high-speed main) mode                | 1 MHz to 24 MHz            | Full speed mode |

Remark For details about communication commands, see 22.4.4 Communication commands.



## 22.4.3 Selecting communication mode

Communication mode of R9A02G015 as follows.

| Communication Mode                                                                              | Standard Setting Note 1 |                                                     |           |               | Pins Used           |
|-------------------------------------------------------------------------------------------------|-------------------------|-----------------------------------------------------|-----------|---------------|---------------------|
| Communication mode                                                                              | Port                    | Speed Note 2                                        | Frequency | Multiply Rate | Fills Used          |
| 1-line mode<br>(when flash memory<br>programmer is used, or<br>when external device is<br>used) | UART                    | 115200 bps,<br>250000 bps,<br>500000 bps,<br>1 Mbps | _         | _             | TOOL0               |
| Dedicated UART<br>(when external device is<br>used)                                             | UART                    | 115200 bps,<br>250000 bps,<br>500000 bps,<br>1 Mbps | _         | _             | TOOLTxD,<br>TOOLRxD |

Note 1. Selection items for Standard settings on GUI of the flash memory programmer.

**Note 2.** Because factors other than the baud rate error, such as the signal waveform slew, also affect UART communication, thoroughly evaluate the slew as well as the baud rate error.



## 22.4.4 Communication commands

R9A02G015 executes serial programming through the commands listed in **Table 22 - 7**. The signals sent from the dedicated flash memory programmer or external device to R9A02G015 are called commands, and programming functions corresponding to the commands are executed. For details, refer to the **RL78 microcontroller (RL78 Protocol A) Programmer Edition Application Note (R01AN0815)**.

| Classification      | Command Name      | Function                                                                                                            |
|---------------------|-------------------|---------------------------------------------------------------------------------------------------------------------|
| Verify              | Verify            | Compares the contents of a specified area of the flash memory with data transmitted from the programmer.            |
| Erase               | Block Erase       | Erases a specified area in the flash memory.                                                                        |
| Blank check         | Block Blank Check | Checks if a specified block in the flash memory has been correctly erased                                           |
| Write               | Programming       | Writes data to a specified area in the flash memory <sup>Note</sup> .                                               |
| Getting information | Silicon Signature | Gets R9A02G015 information (such as the part number, flash memory configuration, and programming firmware version). |
|                     | Checksum          | Gets the checksum data for a specified area.                                                                        |
| Security            | Security Set      | Sets security information.                                                                                          |
|                     | Security Get      | Gets security information.                                                                                          |
|                     | Security Release  | Release setting of prohibition of writing.                                                                          |
| Others              | Reset             | Used to detect synchronization status of communication.                                                             |
|                     | Baud Rate Set     | Sets baud rate when UART communication mode is selected.                                                            |

**Note** Confirm that no data has been written to the write area. Because data cannot be erased after block erase is prohibited, do not write data if the data has not been erased.



Product information (such as product name and firmware version) can be obtained by executing the "Silicon Signature" command.

Tables 22 - 8 and 22 - 9 show signature data list and example of signature data list.

| Field name                          | Description Number of transm                                                                                                      |          |  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------|--|
| Device code                         | The serial number assigned to the device 3 bytes                                                                                  |          |  |
| Device name                         | Device name (ASCII code)                                                                                                          | 10 bytes |  |
| Code flash memory area last address | Last address of code flash memory area<br>(Sent from lower address.<br>Example. 00000H to 07FFFH (32 KB) → FFH, 7FH, 00H)         | 3 bytes  |  |
| Data flash memory area last address | Last address of data flash memory area<br>(Sent from lower address.<br>Example. F1000H to F17FFH (2 KB) → FFH, 17H, 0FH)          | 3 bytes  |  |
| Firmware version                    | Version information of firmware for programming (Sent from upper address.<br>Example. From Ver. 1.23 $\rightarrow$ 01H, 02H, 03H) | 3 bytes  |  |

#### Table 22 - 8 Signature Data List

#### Table 22 - 9 Signature Data List

| Field name                          | Description                                         | Number of transmit data | Data (hexadecimal)                                                                                         |                                  |     |
|-------------------------------------|-----------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------|-----|
| Device code                         | RL78 protocol A                                     | 3 bytes                 | 10                                                                                                         | 00                               | 06  |
| Device name                         | R9A02G0150                                          | 10 bytes                | 52 = "F<br>39 = "S<br>41 = "A<br>30 = "C<br>32 = "2<br>47 = "C<br>30 = "C<br>31 = "1<br>35 = "S<br>30 = "C | )"<br>\"<br>]"<br>]"<br>]"<br>5" |     |
| Code flash memory area last address | Code flash memory area<br>00000H to 1FFFFH (128 KB) | 3 bytes                 | FFH                                                                                                        | FFH                              | 01H |
| Data flash memory area last address | Data flash memory area<br>F1000H to F17FFH (2 KB)   | 3 bytes                 | FFH                                                                                                        | 17H                              | 0FH |
| Firmware version                    | Ver.1.23                                            | 3 bytes                 | 01                                                                                                         | 02                               | 03  |



# 22.5 Processing Time for Each Command When PG-FP6 Is in Use (Reference Value)

The following shows the processing time for each command (reference value) when PG-FP6 is used as a dedicated flash memory programmer.

#### Table 22 - 10 Processing Time for Each Command When PG-FP6 Is in Use (Reference Value)

|                       | Port: TOOL0 (UART) |  |
|-----------------------|--------------------|--|
| PG-FP6 Command        | Speed: 1M bps      |  |
|                       | 128 Kbytes         |  |
| Erasing               | 2 s                |  |
| Writing               | 3.2 s              |  |
| Verification          | 3.5 s              |  |
| Writing after erasing | 4.5 s              |  |

**Remark** The command processing times (reference values) shown in the table are typical values under the following conditions. Port: TOOL0 (single-line UART)

Speed: 1,000,000 bps

Mode: Full speed mode (flash operation mode: HS (high speed main) mode)



## 22.6 Self-Programming

R9A02G015 supports a self-programming function that can be used to rewrite the flash memory via a user program. Because this function allows a user application to rewrite the flash memory by using the RL78 microcontroller selfprogramming library, it can be used to upgrade the program in the field.

- Caution 1. To prohibit an interrupt during self-programming, in the same way as in the normal operation mode, execute the flash self-programming library in the state where the IE flag is cleared (0) by the DI instruction. To enable an interrupt, clear (0) the interrupt mask flag to accept in the state where the IE flag is set (1) by the EI instruction, and then execute the flash self-programming library.
- Caution 2. The high-speed on-chip oscillator should be kept operating during self-programming. If it is stopped, its clock should be operated (HIOSTOP = 0), and the flash self-programming library should be executed after 65 µs have elapsed.
- Remark 1. For details of the self-programming function, refer to the RL78 microcontroller Flash Self-Programming Library Type01 User's Manual (R01US0050).
- **Remark 2.** For details of the time required to execute self-programming, see the notes on use that accompany the flash self-programming library tool.

The self-programming function has two flash memory programming modes; wide voltage mode and full speed mode. Specify the mode that corresponds to the flash operation mode specified in bits CMODE1 and CMODE0 in option byte 000C2H.

Specify the full speed mode when the HS (high-speed main) mode is specified.

If the argument fsl\_flash\_voltage\_u08 is 00H when the FSL\_Init function of the flash self-programming library provided by Renesas Electronics is executed, full speed mode is specified. If the argument is other than 00H, the wide voltage mode is specified.

**Remark** The only Full speed mode can be used for R9A02G015.



## 22.6.1 Self-programming procedure

The following figure illustrates a flow for rewriting the code flash memory by using a flash self-programming library.



Figure 22 - 8 Flow of Self-Programming (Rewriting Flash Memory)



#### 22.6.2 Boot swap function

If rewriting the boot area failed by temporary power failure or other reasons, restarting a program by resetting or overwriting is disabled due to data destruction in the boot area.

The boot swap function is used to avoid this problem.

Before erasing boot cluster 0 <sup>Note</sup>, which is a boot program area, by self-programming, write a new boot program to boot cluster 1 in advance. When the program has been correctly written to boot cluster 1, swap this boot cluster 1 and boot cluster 0 by using the set information function of the firmware of R9A02G015, so that boot cluster 1 is used as a boot area. After that, erase or write the original boot program area, boot cluster 0. As a result, even if a power failure occurs while the area is being rewritten, the program is executed correctly because it is booted from boot cluster 1 to be swapped when the program is reset and started next.

**Note** A boot cluster is a 4 KB area and boot clusters 0 and 1 are swapped by the boot swap function.



Figure 22 - 9 Boot Swap Function

In an example of above figure, it is as follows. Boot cluster 0: Boot area before boot swap Boot cluster 1: Boot area after boot swap









#### 22.6.3 Flash shield window function

The flash shield window function is provided as one of the security functions for self-programming. It disables writing to and erasing areas outside the range specified as a window only during self-programming.

The window range can be set by specifying the start and end blocks. The window range can be set or changed during both serial programming and self-programming.

Writing to and erasing areas outside the window range are disabled during self-programming. During serial programming, however, areas outside the range specified as a window can be written and erased.



#### Figure 22 - 11 Flash Shield Window Setting Example (Target Devices: R9A02G015, Start Block: 04H, End Block: 06H)

- Caution 1. If the rewrite-prohibited area of the boot cluster 0 overlaps with the flash shield window range, prohibition to rewrite the boot cluster 0 takes priority.
- Caution 2. The flash shield window can only be used for the code flash memory (and is not supported for the data flash memory).

| Table 22 - 11 Relationship | o between Flash Sh | hield Window Function | on Setting/Change | e Methods and Commands |
|----------------------------|--------------------|-----------------------|-------------------|------------------------|
|                            |                    |                       | on ootting/onlang |                        |

| Programming conditions | Window Range Setting/                                                                          | Execution Commands                                      |                                                           |  |  |
|------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------|--|--|
| Frogramming conditions | Change Methods                                                                                 | Block erase                                             | Write                                                     |  |  |
| Self-programming       | Specify the starting and ending<br>blocks by the flash self-<br>programming library.           | Block erasing is enabled only within the window range.  | Writing is enabled only within the range of window range. |  |  |
| Serial programming     | Specify the starting and ending<br>blocks on GUI of dedicated flash<br>memory programmer, etc. | Block erasing is enabled also outside the window range. | Writing is enabled also outside the window range.         |  |  |

Remark See 22.7 Security Settings to prohibit writing/erasing during serial programming.



#### 22.7 Security Settings

R9A02G015 supports a security function that prohibits rewriting the user program written to the internal flash memory, so that the program cannot be changed by an unauthorized person.

The operations shown below can be performed using the Security Set command.

Disabling block erase

Execution of the block erase command for a specific block in the flash memory is prohibited during serial programming. However, blocks can be erased by means of self-programming.

Disabling write

Execution of the write command for entire blocks in the flash memory is prohibited during serial programming. However, blocks can be written by means of self-programming.

After the setting of prohibition of writing is specified, releasing the setting by the Security Release command is enabled by a reset.

• Disabling rewriting boot cluster 0

Execution of the block erase command and write command on boot cluster 0 (00000H to 00FFFH) in the flash memory is prohibited by this setting.

The block erase, write commands, and rewriting boot cluster 0 are enabled by the default setting when the flash memory is shipped. Security can be set by serial programming and self-programming. Each security setting can be used in combination.

Table 22 - 12 shows the relationship between the erase and write commands when R9A02G015 security function is enabled.

After the security settings are specified, releasing the security settings by the Security Release command is enabled by a reset.

#### Caution The security function of the flash programmer does not support self-programming.

**Remark** To prohibit writing and erasing during self-programming, use the flash shield window function (see **22.6.3** for detail).



#### Table 22 - 12 Relationship Between Enabling Security Function and Command

#### (1) During serial programming

| Valid Security                          | Executed Command                 |                                   |  |  |
|-----------------------------------------|----------------------------------|-----------------------------------|--|--|
| Valu Security                           | Block Erase                      | Write                             |  |  |
| Prohibition of block erase              | Blocks cannot be erased.         | Can be performed. <sup>Note</sup> |  |  |
| Prohibition of writing                  | Blocks can be erased.            | Cannot be performed.              |  |  |
| Prohibition of rewriting boot cluster 0 | Boot cluster 0 cannot be erased. | Boot cluster 0 cannot be written. |  |  |

**Note** Confirm that no data has been written to the write area. Because data cannot be erased after block erase is prohibited, do not write data if the data has not been erased.

#### (2) During self-programming

| Valid Security                          | Executed Command                 |                                   |  |  |
|-----------------------------------------|----------------------------------|-----------------------------------|--|--|
| Valid Security                          | Block Erase                      | Write                             |  |  |
| Prohibition of block erase              | Blocks can be erased.            | Can be performed.                 |  |  |
| Prohibition of writing                  |                                  |                                   |  |  |
| Prohibition of rewriting boot cluster 0 | Boot cluster 0 cannot be erased. | Boot cluster 0 cannot be written. |  |  |

Remark To prohibit writing and erasing during self-programming, use the flash shield window function (see 22.6.3 for detail).

#### Table 22 - 13 Setting Security in Each Programming Mode

#### (1) During serial programming

| Security                                | Security Setting                      | How to Disable Security Setting                        |
|-----------------------------------------|---------------------------------------|--------------------------------------------------------|
| Prohibition of block erase              | Set via GUI of dedicated flash memory | Cannot be disabled after set.                          |
| Prohibition of writing                  | programmer, etc.                      | Set via GUI of dedicated flash memory programmer, etc. |
| Prohibition of rewriting boot cluster 0 |                                       | Cannot be disabled after set.                          |

# Caution Releasing the setting of prohibition of writing is enabled only when the security is not set as the block erase prohibition and the boot cluster 0 rewrite prohibition with code flash memory area and data flash memory area being blanks.

#### (2) During self-programming

| Security                                | Security Setting                    | How to Disable Security Setting                                                                                                             |
|-----------------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Prohibition of block erase              | Set by using flash self-programming | Cannot be disabled after set.                                                                                                               |
| Prohibition of writing                  | library.                            | Cannot be disabled during self-<br>programming<br>(set via GUI of dedicated flash memory<br>programmer, etc. during serial<br>programming). |
| Prohibition of rewriting boot cluster 0 |                                     | Cannot be disabled after set.                                                                                                               |



## 22.8 Data Flash

#### 22.8.1 Data flash overview

An overview of the data flash memory is provided below.

- The user program can rewrite the data flash memory by using the flash data library. For details, refer to RL78 Family Flash Data Library User's Manual.
- The data flash memory can also be rewritten to through serial programming using the dedicated flash memory programmer or an external device.
- The data flash can be erased in 1-block (1 KB) units.
- The data flash can be accessed only in 8-bit units.
- The data flash can be directly read by CPU instructions.
- Instructions can be executed from the code flash memory while rewriting the data flash memory (that is, background operation (BGO) is supported).
- Because the data flash memory is an area exclusively used for data, it cannot be used to execute instructions.
- Accessing the data flash memory is not possible while rewriting the code flash memory (during self-programming).
- Manipulating the DFLCTL register is not possible while rewriting the data flash memory.
- Transition to the STOP mode is not possible while rewriting the data flash memory.
- Caution 1. The data flash memory is stopped after a reset is canceled. The data flash control register (DFLCTL) must be set up in order to use the data flash memory.
- Caution 2. The high-speed on-chip oscillator should be kept operating during data flash rewrite. If it is stopped, its clock should be operated (HIOSTOP = 0), and the data flash library should be executed after 65 µs have elapsed.
- **Remark** For the flash programming mode, see **22.6 Self-Programming**.



## 22.8.2 Register controlling data flash memory

#### 22.8.2.1 Data flash control register (DFLCTL)

This register is used to enable or disable accessing to the data flash. The DFLCTL register is set by a 1-bit or 8-bit memory manipulation instruction. Reset input sets this register to 00H.

#### Figure 22 - 12 Format of Data flash control register (DFLCTL)

| Address: | F0090H | After reset: 00ł           | H R/W |      |                 |        |   |       |
|----------|--------|----------------------------|-------|------|-----------------|--------|---|-------|
| Symbol   | 7      | 6                          | 5     | 4    | 3               | 2      | 1 | <0>   |
| DFLCTL   | 0      | 0                          | 0     | 0    | 0               | 0      | 0 | DFLEN |
| ]        | DFLEN  |                            |       | Data | flash access co | ontrol |   |       |
|          | 0      | Disables data flash access |       |      |                 |        |   |       |
|          | 1      | Enables data flash access  |       |      |                 |        |   |       |

Caution Manipulating the DFLCTL register is not possible while rewriting the data flash memory.



#### 22.8.3 Procedure for accessing data flash memory

The data flash memory is initially stopped after a reset ends and cannot be accessed (read or programmed). To access the memory, perform the following procedure:

- <1> Write 1 to bit 0 (DFLEN) of the data flash control register (DFLCTL).
- <2> Wait for the setup to finish for software timer, etc.
  - <Setup time for main clock mode>
  - HS (high-speed main) mode: 5 µs
- <3> After the wait, the data flash memory can be accessed.

Caution 1. Accessing the data flash memory is not possible during the setup time.

Caution 2. Transition to the STOP mode is not possible during the setup time. To enter the STOP mode during the setup time, clear DFLEN to 0 and then execute the STOP instruction.

Caution 3. The high-speed on-chip oscillator should be kept operating during data flash rewrite. If it is kept stopped, its clock should be operated (HIOSTOP = 0), and the data flash library should be executed after 65 µs have elapsed.



# **CHAPTER 23 ON-CHIP DEBUG FUNCTION**

#### 23.1 Connecting E1 On-chip Debugging Emulator

R9A02G015 uses the VDD, RESETB, TOOL0, and Vss pins to communicate with the host machine via an E1 onchip debugging emulator. Serial communication is performed by using a single-line UART that uses the TOOL0 pin.

Caution R9A02G015 has an on-chip debug function, which is provided for development and evaluation. Do not use the on-chip debug function in products designated for mass production, because the guaranteed number of rewritable times of the flash memory may be exceeded when this function is used, and product reliability therefore cannot be guaranteed. Renesas Electronics is not liable for problems occurring when the on-chip debug function is used.



#### Figure 23 - 1 Connection Example of E1 On-chip Debugging Emulator

- Note 1. Connecting the dotted line is not necessary during serial programming.
- **Note 2.** If the reset circuit on the target system does not have a buffer and generates a reset signal only with resistors and capacitors, this pull-up resistor is not necessary.
- Caution This circuit diagram is assumed that the reset signal outputs from an N-ch O.D. buffer (output resistor: 100 Ω or less)



#### 23.2 **On-Chip Debug Security ID**

R9A02G015 has an on-chip debug operation control bit in the flash memory at 000C3H (see CHAPTER 21 OPTION BYTE) and an on-chip debug security ID setting area at 000C4H to 000CDH, to prevent third parties from reading memory content.

When the boot swap function is used, also set a value that is the same as that of 010C3H and 010C4H to 010CDH in advance, because 000C3H, 000C4H to 000CDH and 010C3H, and 010C4H to 010CDH are switched.

| Table 23 - 1 On-Chip Debug Security ID |
|----------------------------------------|
|                                        |

| Address          | On-Chip Debug Security ID                |
|------------------|------------------------------------------|
| 000C4H to 000CDH | Any ID code of 10 bytes (except All FFH) |
| 010C4H to 010CDH |                                          |

#### 23.3 Securing of User Resources

To perform communication between R9A02G015 and E1 on-chip debugging emulator, as well as each debug function, the securing of memory space must be done beforehand.

If Renesas Electronics assembler or compiler is used, the items can be set by using link options.

#### (1) Securement of memory space

The shaded portions in Figure 23 - 2 are the areas reserved for placing the debug monitor program, so user programs or data cannot be allocated in these spaces. When using the on-chip debug function, these spaces must be secured so as not to be used by the user program. Moreover, this area must not be rewritten by the user program.





#### Figure 23 - 2 Memory Spaces Where Debug Monitor Programs Are Allocated

Note 1. When real-time RAM monitor (RRM) function and dynamic memory modification (DMM) function are not used, it is 256 bytes.

Note 2. In debugging, reset vector is rewritten to address allocated to a monitor program.

Note 3. Since this area is allocated immediately before the stack area, the address of this area varies depending on the stack increase and decrease. That is, 4 extra bytes are consumed for the stack area used. When using self-programming, 12 extra bytes are consumed for the stack area used.



# **CHAPTER 24 BCD CORRECTION CIRCUIT**

#### 24.1 BCD Correction Circuit Function

The result of addition/subtraction of the BCD (binary-coded decimal) code and BCD code can be obtained as BCD code with this circuit.

The decimal correction operation result is obtained by performing addition/subtraction having the A register as the operand and then adding/ subtracting the BCD correction result register (BCDADJ).

#### 24.2 Registers Used by BCD Correction Circuit

The BCD correction circuit uses the following registers.

• BCD correction result register (BCDADJ)

#### 24.2.1 BCD correction result register (BCDADJ)

The BCDADJ register stores correction values for obtaining the add/subtract result as BCD code through add/subtract instructions using the A register as the operand.

The value read from the BCDADJ register varies depending on the value of the A register when it is read and those of the CY and AC flags.

The BCDADJ register is read by an 8-bit memory manipulation instruction.

Reset input sets this register to undefined.

#### Figure 24 - 1 Format of BCD correction result register (BCDADJ)

| Address: | F00FEH | After reset: Un | defined F | R |   |   |   |   |
|----------|--------|-----------------|-----------|---|---|---|---|---|
| Symbol   | 7      | 6               | 5         | 4 | 3 | 2 | 1 | 0 |
| BCDADJ   |        |                 |           |   |   |   |   |   |



#### 24.3 BCD Correction Circuit Operation

The basic operation of the BCD correction circuit is as follows.

- (1) Addition: Calculating the result of adding a BCD code value and another BCD code value by using a BCD code value
  - <1> The BCD code value to which addition is performed is stored in the A register.
  - <2> By adding the value of the A register and the second operand (value of one more BCD code to be added) as are in binary, the binary operation result is stored in the A register and the correction value is stored in the BCD correction result register (BCDADJ).
  - <3> Decimal correction is performed by adding in binary the value of the A register (addition result in binary) and the BCDADJ register (correction value), and the correction result is stored in the A register and CY flag.
  - Caution The value read from the BCDADJ register varies depending on the value of the A register when it is read and those of the CY and AC flags. Therefore, execute the instruction <3> after the instruction <2> instead of executing any other instructions. To perform BCD correction in the interrupt enabled state, saving and restoring the A register is required within the interrupt function. PSW (CY flag and AC flag) is restored by the RETI instruction.

An example is shown below.

Examples 1: 99 + 89 = 188

| Instruction |            |       | A Register | CY Flag | AC Flag | BCDADJ Register |
|-------------|------------|-------|------------|---------|---------|-----------------|
| MOV         | A, #99H    | ; <1> | 99H        | —       | _       | —               |
| ADD         | A, #89H    | ; <2> | 22H        | 1       | 1       | 66H             |
| ADD         | A, IBCDADJ | ; <3> | 88H        | 1       | 0       | —               |

#### Examples 2: 85 + 15 = 100

| Instruction |            |       | A Register | CY Flag | AC Flag | BCDADJ Register |
|-------------|------------|-------|------------|---------|---------|-----------------|
| MOV         | A, #85H    | ; <1> | 85H        | —       | _       | —               |
| ADD         | A, #15H    | ; <2> | 9AH        | 0       | 0       | 66H             |
| ADD         | A, !BCDADJ | ; <3> | 00H        | 1       | 1       | —               |

Examples 3: 80 + 80 = 160

| Instruction |               |       | A Register | CY Flag | AC Flag | BCDADJ Register |
|-------------|---------------|-------|------------|---------|---------|-----------------|
| MOV         | A, #80H ; <1> |       | 80H        | _       | _       | —               |
| ADD         | A, #80H       | ; <2> | 00H        | 1       | 0       | 60H             |
| ADD         | A, IBCDADJ    | ; <3> | 60H        | 1       | 0       | —               |



- (2) Subtraction: Calculating the result of subtracting a BCD code value from another BCD code value by using a BCD code value
  - <1> The BCD code value from which subtraction is performed is stored in the A register.
  - <2> By subtracting the value of the second operand (value of BCD code to be subtracted) from the A register as is in binary, the calculation result in binary is stored in the A register, and the correction value is stored in the BCD correction result register (BCDADJ).
  - <3> Decimal correction is performed by subtracting the value of the BCDADJ register (correction value) from the A register (subtraction result in binary) in binary, and the correction result is stored in the A register and CY flag.
  - Caution The value read from the BCDADJ register varies depending on the value of the A register when it is read and those of the CY and AC flags. Therefore, execute the instruction <3> after the instruction <2> instead of executing any other instructions. To perform BCD correction in the interrupt enabled state, saving and restoring the A register is required within the interrupt function. PSW (CY flag and AC flag) is restored by the RETI instruction.

An example is shown below.

Example: 91 - 52 = 39

| Instruction |            |               | A Register | CY Flag | AC Flag | BCDADJ Register |
|-------------|------------|---------------|------------|---------|---------|-----------------|
| MOV         | A, #91H    | A, #91H ; <1> |            | —       |         | —               |
| SUB         | A, #52H    | ; <2>         | 3FH        | 0       | 1       | 06H             |
| SUB         | A, IBCDADJ | ; <3>         | 39H        | 0       | 0       | —               |



# **CHAPTER 25 INSTRUCTION SET**

This chapter lists the instructions in the R9A02G015 instruction set. For details of each operation and operation code, refer to the separate document **RL78 Family User's Manual Software (R01US0015)**.

#### 25.1 Conventions Used in Operation List

#### 25.1.1 Operand identifiers and specification methods

Operands are described in the "Operand" column of each instruction in accordance with the description method of the instruction operand identifier (refer to the assembler specifications for details). When there are two or more description methods, select one of them. Alphabetic letters in capitals and the symbols, #, !, !!, \$, \$!, [], and ES: are keywords and are described as they are. Each symbol has the following meaning.

- #: Immediate data specification
- !: 16-bit absolute address specification
- !!: 20-bit absolute address specification
- \$: 8-bit relative address specification
- \$!: 16-bit relative address specification
- [ ]: Indirect address specification
- ES:: Extension address specification

In the case of immediate data, describe an appropriate numeric value or a label. When using a label, be sure to describe the #, !, !!, \$, \$!, [], and ES: symbols.

For operand register identifiers, r and rp, either function names (X, A, C, etc.) or absolute names (names in parentheses in the table below, R0, R1, R2, etc.) can be used for description.

| Identifier | Description Method                                                                                             |
|------------|----------------------------------------------------------------------------------------------------------------|
| r          | X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7)                                                 |
| rp         | AX (RP0), BC (RP1), DE (RP2), HL (RP3)                                                                         |
| sfr        | Special-function register symbol (SFR symbol) FFF00H to FFFFFH                                                 |
| sfrp       | Special-function register symbols (16-bit manipulatable SFR symbol. Even addresses only Note) FFF00H to FFFFFH |
| saddr      | FFE20H to FFF1FH Immediate data or labels                                                                      |
| saddrp     | FFE20H to FF1FH Immediate data or labels (even addresses only <sup>Note</sup> )                                |
| addr20     | 00000H to FFFFH Immediate data or labels                                                                       |
| addr16     | 0000H to FFFFH Immediate data or labels (only even addresses for 16-bit data transfer instructions Note)       |
| addr5      | 0080H to 00BFH Immediate data or labels (even addresses only)                                                  |
| word       | 16-bit immediate data or label                                                                                 |
| byte       | 8-bit immediate data or label                                                                                  |
| bit        | 3-bit immediate data or label                                                                                  |
| RBn        | RB0 to RB3                                                                                                     |
| Note B     | $\dot{t} 0 = 0$ when an odd address is specified                                                               |

#### Table 25 - 1 Operand Identifiers and Specification Methods

**Note** Bit 0 = 0 when an odd address is specified.

Remark The special function registers can be described to operand sfr as symbols. See Table 3 - 5 Special Function Register (SFR) List for the symbols of the special function registers. The extended special function registers can be described to operand !addr16 as symbols. See Table 3 - 6 Extended Special Function Register (2nd SFR) List for the symbols of the extended special function registers.

RENESAS

## 25.1.2 Description of operation column

The operation when the instruction is executed is shown in the "Operation" column using the following symbols.

| Symbol     | Function                                                                        |
|------------|---------------------------------------------------------------------------------|
| A          | A register; 8-bit accumulator                                                   |
| Х          | X register                                                                      |
| В          | B register                                                                      |
| С          | C register                                                                      |
| D          | D register                                                                      |
| E          | E register                                                                      |
| Н          | H register                                                                      |
| L          | L register                                                                      |
| ES         | ES register                                                                     |
| CS         | CS register                                                                     |
| AX         | AX register pair; 16-bit accumulator                                            |
| BC         | BC register pair                                                                |
| DE         | DE register pair                                                                |
| HL         | HL register pair                                                                |
| PC         | Program counter                                                                 |
| SP         | Stack pointer                                                                   |
| PSW        | Program status word                                                             |
| CY         | Carry flag                                                                      |
| AC         | Auxiliary carry flag                                                            |
| Z          | Zero flag                                                                       |
| RBS        | Register bank select flag                                                       |
| IE         | Interrupt request enable flag                                                   |
| ()         | Memory contents indicated by address or register contents in parentheses        |
| XH, XL     | 16-bit registers: XH = higher 8 bits, XL = lower 8 bits                         |
| Xs, Xh, Xl | 20-bit registers: Xs = (bits 19 to 16), XH = (bits 15 to 8), XL = (bits 7 to 0) |
| ^          | Logical product (AND)                                                           |
| V          | Logical sum (OR)                                                                |
| V          | Exclusive logical sum (exclusive OR)                                            |
| _          | Inverted data                                                                   |
| addr5      | 16-bit immediate data (even addresses only in 0080H to 00BFH)                   |
| addr16     | 16-bit immediate data                                                           |
| addr20     | 20-bit immediate data                                                           |
| jdisp8     | Signed 8-bit data (displacement value)                                          |
| jdisp16    | Signed 16-bit data (displacement value)                                         |
|            |                                                                                 |



## 25.1.3 Description of flag operation column

The change of the flag value when the instruction is executed is shown in the "Flag" column using the following symbols.

| Symbol  | Change of Flag Value                |
|---------|-------------------------------------|
| (Blank) | Unchanged                           |
| 0       | Cleared to 0                        |
| 1       | Set to 1                            |
| ×       | Set/cleared according to the result |
| R       | Previously saved value is restored  |

#### Table 25 - 3 Symbols in "Flag" Column

#### 25.1.4 PREFIX instruction

Instructions with "ES:" have a PREFIX operation code as a prefix to extend the accessible data area to the 1 MB space (00000H to FFFFFH), by adding the ES register value to the 64 KB space from F0000H to FFFFFH. When a PREFIX operation code is attached as a prefix to the target instruction, only one instruction immediately after the PREFIX operation code is executed as the addresses with the ES register value added.

A interrupt is not acknowledged between a PREFIX instruction code and the instruction immediately after.

| Instruction           | Opcode |          |      |         |   |  |  |  |  |
|-----------------------|--------|----------|------|---------|---|--|--|--|--|
| Instruction           | 1      | 2        | 3    | 4       | 5 |  |  |  |  |
| MOV !addr16, #byte    | CFH    | !ado     | dr16 | #byte   | — |  |  |  |  |
| MOV ES:!addr16, #byte | 11H    | CFH !add |      | !addr16 |   |  |  |  |  |
| MOV A, [HL]           | 8BH    |          |      | —       | — |  |  |  |  |
| MOV A, ES: [HL]       | 11H    | 8BH      | —    | —       | — |  |  |  |  |

Caution Set the ES register value with MOV ES, A, etc., before executing the PREFIX instruction.



# 25.2 Operation List

|            | Mnemonic | Operands            | Bytes | Clocks |        | Clocks                      | Flag |    |          |
|------------|----------|---------------------|-------|--------|--------|-----------------------------|------|----|----------|
| Group      |          |                     |       | Note 1 | Note 2 |                             | Z    | AC | CY       |
| 8-bit data | MOV      | r, #byte            | 2     | 1      | -      | r ← byte                    |      |    |          |
| transfer   |          | PSW, #byte          | 3     | 3      | -      | PSW ← byte                  | ×    | ×  | ×        |
|            |          | CS, #byte           | 3     | 1      | -      | CS ← byte                   |      |    |          |
|            |          | ES, #byte           | 2     | 1      | —      | ES ← byte                   |      |    |          |
|            |          | !addr16, #byte      | 4     | 1      | -      | (addr16) ← byte             |      |    |          |
|            |          | ES:!addr16, #byte   | 5     | 2      | -      | (ES, addr16) ← byte         |      |    |          |
|            |          | saddr, #byte        | 3     | 1      | _      | (saddr) ← byte              |      |    |          |
|            |          | sfr, #byte          | 3     | 1      | _      | sfr ← byte                  |      |    |          |
|            |          | [DE+byte], #byte    | 3     | 1      | _      | (DE + byte) ← byte          |      |    |          |
|            |          | ES:[DE+byte], #byte | 4     | 2      | _      | ((ES, DE) + byte) ← byte    |      |    |          |
|            |          | [HL+byte], #byte    | 3     | 1      | _      | (HL + byte) ← byte          |      |    | -        |
|            |          | ES:[HL+byte], #byte | 4     | 2      | _      | ((ES, HL) + byte) ← byte    |      |    | -        |
|            |          | [SP+byte], #byte    | 3     | 1      | _      | (SP + byte) ← byte          |      |    |          |
|            |          | word[B], #byte      | 4     | 1      | _      | (B + word) ← byte           |      |    |          |
|            |          | ES:word[B], #byte   | 5     | 2      | _      | ((ES, B) + word) ← byte     |      |    |          |
|            |          | word[C], #byte      | 4     | 1      | _      | (C+word) ← byte             |      |    |          |
|            |          | ES:word[C], #byte   | 5     | 2      | _      | ((ES, C) + word) ← byte     |      |    |          |
|            |          | word[BC], #byte     | 4     | 1      | _      | (BC+word) ← byte            |      |    |          |
|            |          | ES:word[BC], #byte  | 5     | 2      | _      | ((ES, BC) + word) ← byte    |      |    |          |
|            |          | A, r Note 3         | 1     | 1      | _      | A ← r                       |      |    |          |
|            |          | r, A Note 3         | 1     | 1      | _      | r ← A                       |      |    |          |
|            |          | Á, PSW              | 2     | 1      | _      | $A \leftarrow PSW$          |      |    |          |
|            |          | PSW, A              | 2     | 3      | _      | PSW ← A                     | ×    | ×  | ×        |
|            |          | A, CS               | 2     | 1      | _      | A ← CS                      |      |    |          |
|            |          | CS, A               | 2     | 1      | _      | CS ← A                      |      |    |          |
|            |          | A, ES               | 2     | 1      | _      | A ← ES                      |      |    | -        |
|            |          | ES, A               | 2     | 1      | _      | ES ← A                      |      |    |          |
|            |          | A, !addr16          | 3     | 1      | 4      | A ← (addr16)                |      |    |          |
|            |          | A, ES:laddr16       | 4     | 2      | 5      | $A \leftarrow (ES, addr16)$ |      |    |          |
|            |          | !addr16, A          | 3     | - 1    | _      | (addr16) ← A                |      |    | -        |
|            |          | ES:laddr16, A       | 4     | 2      | _      | (ES, addr16) ← A            |      |    | -        |
|            |          | A, saddr            | 2     | - 1    | _      | $A \leftarrow (saddr)$      |      |    |          |
|            |          | saddr, A            | 2     | 1      | _      | $(saddr) \leftarrow A$      |      |    |          |
|            |          | A, sfr              | 2     | 1      | _      | $A \leftarrow sfr$          |      |    |          |
|            |          | sfr, A              | 2     | 1      | _      | sfr ← A                     |      |    |          |
|            |          | A, [DE]             | 1     | 1      | 4      | A ← (DE)                    |      |    | -        |
|            |          | [DE], A             | 1     | 1      | _      | $(DE) \leftarrow A$         |      |    |          |
|            |          | A, ES:[DE]          | 2     | 2      | 5      | A ← (ES, DE)                |      |    | -        |
|            |          | ES:[DE], A          | 2     | 2      |        | (ES, DE) ← A                |      |    | ┢        |
|            |          | A, [HL]             | 1     | 1      | 4      | $A \leftarrow (HL)$         |      |    | ┢──      |
|            |          | [HL], A             | 1     | 1      | _      | $(HL) \leftarrow A$         |      |    | ┢        |
|            |          | A, ES:[HL]          | 2     | 2      | 5      | $A \leftarrow (ES, HL)$     |      |    | -        |
|            |          | ES:[HL], A          | 2     | 2      | -      | $(ES, HL) \leftarrow A$     |      |    | -        |
|            |          |                     |       |        |        |                             |      | -  | <u> </u> |
|            |          | A, [DE+byte]        | 2     | 1      | 4      | A ← (DE + byte)             |      |    |          |

Table 25 - 5 Operation List (1/12)



|                        |          |                 | Table 25                             | -      |        | · ·                                     |      |    |                                              |
|------------------------|----------|-----------------|--------------------------------------|--------|--------|-----------------------------------------|------|----|----------------------------------------------|
| Instruction<br>Group   | Mnemonic | Operands        | Bytes                                |        | cks    | Clocks                                  | Flag |    | 1                                            |
| -                      |          |                 |                                      | Note 1 | Note 2 |                                         | Z    | AC | CY                                           |
| 8-bit data<br>transfer | MOV      | [DE+byte], A    | 2                                    | 1      | _      | (DE + byte) ← A                         |      |    | <u> </u>                                     |
| lansier                |          | A, ES:[DE+byte] | 3                                    | 2      | 5      | A ← ((ES, DE) + byte)                   |      |    | <u> </u>                                     |
|                        |          | ES:[DE+byte], A | 3                                    | 2      | —      | $((ES, DE) + byte \leftarrow A$         |      |    | <u> </u>                                     |
|                        |          | A, [HL+byte]    | 2                                    | 1      | 4      | A ← (HL + byte)                         |      |    | _                                            |
|                        |          | [HL+byte], A    | 2                                    | 1      | —      | (HL + byte) ← A                         |      |    | <u> </u>                                     |
|                        |          | A, ES:[HL+byte] | 3                                    | 2      | 5      | $A \leftarrow ((ES, HL) + byte)$        |      |    | <u> </u>                                     |
|                        |          | ES:[HL+byte], A | 3                                    | 2      | —      | ((ES, HL) + byte) ← A                   |      |    |                                              |
|                        |          | A, [SP+byte]    | 2                                    | 1      | _      | $A \leftarrow (SP + byte)$              |      |    | -                                            |
|                        |          | [SP+byte], A    | 2                                    | 1      | _      | (SP + byte) ← A                         |      |    |                                              |
|                        |          | A, word[B]      | 3                                    | 1      | 4      | $A \leftarrow (B + word)$               |      |    |                                              |
|                        |          | word[B], A      | 3                                    | 1      | —      | $(B + word) \leftarrow A$               |      |    |                                              |
|                        |          | A, ES:word[B]   | 4                                    | 2      | 5      | $A \leftarrow ((ES, B) + word)$         |      |    |                                              |
|                        |          | ES:word[B], A   | 4                                    | 2      | —      | $((ES, B) + word) \leftarrow A$         |      |    |                                              |
|                        |          | A, word[C]      | 3                                    | 1      | 4      | $A \leftarrow (C + word)$               |      |    |                                              |
|                        |          | word[C], A      | 3                                    | 1      | _      | $(C + word) \leftarrow A$               |      |    |                                              |
|                        |          | A, ES:word[C]   | 4                                    | 2      | 5      | $A \leftarrow ((ES, C) + word)$         |      |    |                                              |
|                        |          | ES:word[C], A   | 4                                    | 2      | -      | $((ES,C)+word)\leftarrowA$              |      |    |                                              |
|                        |          | A, word[BC]     | 3                                    | 1      | 4      | $A \leftarrow (BC + word)$              |      |    |                                              |
|                        |          | word[BC], A     | 3                                    | 1      | —      | $(BC + word) \leftarrow A$              |      |    |                                              |
|                        |          | A, ES:word[BC]  | 4                                    | 2      | 5      | $A \leftarrow ((ES, BC) + word)$        |      |    |                                              |
|                        |          | ES:word[BC], A  | 4                                    | 2      | _      | $((ES,BC) + word) \leftarrow A$         |      |    |                                              |
|                        |          | A, [HL+B]       | 2                                    | 1      | 4      | $A \leftarrow (HL + B)$                 |      |    |                                              |
|                        |          | [HL+B], A       | 2                                    | 1      | -      | (HL + B) ← A                            |      |    |                                              |
|                        |          | A, ES:[HL+B]    | 3                                    | 2      | 5      | $A \leftarrow ((ES, HL) + B)$           |      |    |                                              |
|                        |          | ES:[HL+B], A    | 3                                    | 2      | -      | $((ES,HL) + B) \leftarrow A$            |      |    |                                              |
|                        |          | A, [HL+C]       | 2                                    | 1      | 4      | $A \leftarrow (HL + C)$                 |      |    | 1                                            |
|                        |          | [HL+C], A       | 2                                    | 1      |        | $(HL+C) \gets A$                        |      |    |                                              |
|                        |          | A, ES:[HL+C]    | 3                                    | 2      | 5      | A ← ((ES, HL) + C)                      |      |    | 1                                            |
|                        |          | ES:[HL+C], A    | 3                                    | 2      | —      | ((ES, HL) + C) ← A                      |      |    |                                              |
|                        |          | X, !addr16      | 3                                    | 1      | 4      | X ← (addr16)                            |      |    |                                              |
|                        |          | X, ES:!addr16   | 4                                    | 2      | 5      | X ← (ES, addr16)                        |      |    |                                              |
|                        |          | X, saddr        | 2                                    | 1      | _      | X ← (saddr)                             |      |    | 1                                            |
|                        |          | B, !addr16      | 3                                    | 1      | 4      | B ← (addr16)                            |      |    | -                                            |
|                        |          | B, ES:!addr16   | 4                                    | 2      | 5      | B ← (ES, addr16)                        |      |    | -                                            |
|                        |          | B, saddr        | 2                                    | 1      | _      | B ← (saddr)                             |      |    | <u> </u>                                     |
|                        |          | C, !addr16      | 3                                    | 1      | 4      | C ← (addr16)                            |      |    |                                              |
|                        |          | C, ES:!addr16   | 4                                    | 2      | 5      | C ← (ES, addr16)                        |      |    | -                                            |
|                        |          | C, saddr        | 2                                    | 1      | _      | C ← (saddr)                             |      |    | -                                            |
|                        |          | ES, saddr       | 3                                    | 1      | _      | ES ← (saddr)                            |      |    | -                                            |
|                        | ХСН      | A, r Note 3     | 1 (r = X)<br>2 (other<br>than r = X) | 1      | _      | $A \leftarrow r$                        |      |    |                                              |
|                        |          | A, !addr16      | 4                                    | 2      | _      | $A \leftarrow \rightarrow (addr16)$     | 1    |    | <u>†                                    </u> |
|                        |          | A, ES:laddr16   | 5                                    | 3      | _      | $A \leftarrow \rightarrow (ES, addr16)$ |      |    | <u> </u>                                     |
|                        |          | A, saddr        | 3                                    | 2      | _      | $A \leftarrow \rightarrow (saddr)$      |      |    | <u> </u>                                     |
|                        |          | A, sfr          | 3                                    | 2      | _      | $A \leftarrow \rightarrow sfr$          |      |    | +                                            |
|                        |          | A, [DE]         | 2                                    | 2      | _      | $A \leftarrow \rightarrow (DE)$         |      |    | ├──                                          |

#### Table 25 - 5 Operation List (2/12)



| Instruction             | Mnemonic | Operands                  | Bytes | Clocks |        | Clocks                                                                     | Flag |    |    |
|-------------------------|----------|---------------------------|-------|--------|--------|----------------------------------------------------------------------------|------|----|----|
| Group                   | Whethome | operando                  | Dytes | Note 1 | Note 2 |                                                                            | Z    |    |    |
| 8-bit data              | ХСН      | A, ES:[DE]                | 3     | 3      |        | $A \leftarrow \rightarrow (ES, DE)$                                        | -    | AC | 0. |
| transfer                | Xon      | A, [HL]                   | 2     | 2      |        | $A \longleftrightarrow (HL)$                                               |      |    |    |
|                         |          | A, ES:[HL]                | 3     | 3      |        | $A \leftarrow \rightarrow (ES, HL)$                                        |      |    |    |
|                         |          | A, [DE+byte]              | 3     | 2      | _      | $A \leftarrow \rightarrow (DE + byte)$                                     |      |    |    |
|                         |          | A, ES:[DE+byte]           | 4     | 3      |        | $A \leftarrow \rightarrow ((ES, DE) + byte)$                               |      |    |    |
|                         |          |                           | 3     | 2      |        | $A \leftarrow \rightarrow (HL + byte)$                                     |      |    |    |
|                         |          | A, [HL+byte]              | 4     | 3      |        | $A \leftrightarrow ((ES, HL) + byte)$                                      |      |    |    |
|                         |          | A, ES:[HL+byte]           | 4     | 2      |        | $A \longleftrightarrow ((ES, HL) + byte)$ $A \longleftrightarrow (HL + B)$ |      |    |    |
|                         |          | A, [HL+B]<br>A, ES:[HL+B] | 3     | 3      | _      | $A \longleftrightarrow ((ES, HL) + B)$                                     |      |    |    |
|                         |          |                           |       |        |        |                                                                            |      |    |    |
|                         |          | A, [HL+C]                 | 2     | 2      | _      | $A \leftarrow \rightarrow (HL + C)$                                        |      |    | -  |
|                         |          | A, ES:[HL+C]              | 3     | 3      | _      | $A \leftarrow \rightarrow ((ES, HL) + C)$                                  |      |    |    |
|                         | ONEB     | A                         | 1     | 1      | —      | A ← 01H                                                                    |      |    |    |
|                         |          | X                         | 1     | 1      | —      | X ← 01H                                                                    |      |    |    |
|                         |          | В                         | 1     | 1      | —      | B ← 01H                                                                    |      |    |    |
|                         |          | C                         | 1     | 1      | —      | C ← 01H                                                                    |      |    |    |
|                         |          | !addr16                   | 3     | 1      | —      | (addr16) ← 01H                                                             |      |    |    |
|                         |          | ES:laddr16                | 4     | 2      | —      | (ES, addr16) ← 01H                                                         |      |    |    |
|                         | 01.55    | saddr                     | 2     | 1      | —      | (saddr) ← 01H                                                              |      |    |    |
| C                       | CLRB     | A                         | 1     | 1      | _      | $A \leftarrow 00H$                                                         |      |    |    |
|                         |          | X                         | 1     | 1      | _      | X ← 00H                                                                    |      |    |    |
|                         |          | В                         | 1     | 1      | —      | B ← 00H                                                                    |      |    |    |
|                         |          | С                         | 1     | 1      | —      | C ← 00H                                                                    |      |    |    |
|                         |          | !addr16                   | 3     | 1      | —      | (addr16) ← 00H                                                             |      |    |    |
|                         |          | ES:laddr16                | 4     | 2      | —      | (ES,addr16) ← 00H                                                          |      |    |    |
|                         |          | saddr                     | 2     | 1      | —      | (saddr) ← 00H                                                              |      |    |    |
|                         | MOVS     | [HL+byte], X              | 3     | 1      | —      | (HL + byte) ← X                                                            | ×    |    | ×  |
|                         |          | ES:[HL+byte], X           | 4     | 2      | —      | (ES, HL + byte) ← X                                                        | ×    |    | ×  |
| 16-bit data<br>transfer | MOVW     | rp, #word                 | 3     | 1      | —      | $rp \leftarrow word$                                                       |      |    |    |
| lansier                 |          | saddrp, #word             | 4     | 1      | —      | (saddrp) ← word                                                            |      |    |    |
|                         |          | sfrp, #word               | 4     | 1      | _      | sfrp ← word                                                                |      |    |    |
|                         |          | AX, rp Note 4             | 1     | 1      | —      | AX ← rp                                                                    |      |    |    |
|                         |          | rp, AX Note 4             | 1     | 1      | —      | rp ← AX                                                                    |      |    |    |
|                         |          | AX, !addr16               | 3     | 1      | 4      | AX ← (addr16)                                                              |      |    |    |
|                         |          | !addr16, AX               | 3     | 1      | —      | (addr16) ← AX                                                              |      |    |    |
|                         |          | AX, ES:laddr16            | 4     | 2      | 5      | $AX \leftarrow (ES, addr16)$                                               |      |    |    |
|                         |          | ES:!addr16, AX            | 4     | 2      | —      | (ES, addr16) ← AX                                                          |      |    |    |
|                         |          | AX, saddrp                | 2     | 1      | —      | $AX \leftarrow (saddrp)$                                                   |      |    |    |
|                         |          | saddrp, AX                | 2     | 1      | —      | $(saddrp) \leftarrow AX$                                                   |      |    |    |
|                         |          | AX, sfrp                  | 2     | 1      | _      | $AX \gets sfrp$                                                            |      |    |    |
|                         |          | sfrp, AX                  | 2     | 1      | _      | sfrp ← AX                                                                  |      |    |    |
|                         |          | AX, [DE]                  | 1     | 1      | 4      | $AX \leftarrow (DE)$                                                       |      |    |    |
|                         |          | [DE], AX                  | 1     | 1      | _      | $(DE) \leftarrow AX$                                                       |      |    |    |
|                         |          | AX, ES:[DE]               | 2     | 2      | 5      | $AX \leftarrow (ES, DE)$                                                   |      |    |    |
|                         |          | ES:[DE], AX               | 2     | 2      | —      | (ES, DE) ← AX                                                              |      |    |    |
|                         |          | AX, [HL]                  | 1     | 1      | 4      | $AX \leftarrow (HL)$                                                       |      |    |    |
|                         |          | [HL], AX                  | 1     | 1      | _      | $(HL) \leftarrow AX$                                                       |      |    |    |

#### Table 25 - 5 Operation List (3/12)



|                         |          | <b>c</b> .             |       | -      |        |                                    | 1 |      |          |
|-------------------------|----------|------------------------|-------|--------|--------|------------------------------------|---|------|----------|
| Instruction<br>Group    | Mnemonic | Operands               | Bytes |        | ocks   | Clocks                             |   | Flag |          |
|                         |          |                        |       | Note 1 | Note 2 |                                    | Z | AC   | CY       |
| 16-bit data<br>transfer | MOVW     | AX, ES:[HL]            | 2     | 2      | 5      | $AX \leftarrow (ES, HL)$           |   |      |          |
|                         |          | ES:[HL], AX            | 2     | 2      | _      | (ES, HL) ← AX                      |   |      | -        |
|                         |          | AX, [DE+byte]          | 2     | 1      | 4      | AX ← (DE + byte)                   |   |      | _        |
|                         |          | [DE+byte], AX          | 2     | 1      | _      | (DE + byte) ← AX                   |   |      |          |
|                         |          | AX, ES:[DE+byte]       | 3     | 2      | 5      | AX ← ((ES, DE) + byte)             |   |      | <u> </u> |
|                         |          | ES:[DE+byte], AX       | 3     | 2      | —      | ((ES, DE) + byte) ← AX             |   |      | <u> </u> |
|                         |          | AX, [HL+byte]          | 2     | 1      | 4      | AX ← (HL + byte)                   |   |      | _        |
|                         |          | [HL+byte], AX          | 2     | 1      | _      | (HL + byte) ← AX                   |   |      |          |
|                         |          | AX, ES:[HL+byte]       | 3     | 2      | 5      | AX ← ((ES, HL) + byte)             |   |      |          |
|                         |          | ES:[HL+byte], AX       | 3     | 2      | _      | ((ES, HL) + byte) ← AX             |   |      |          |
|                         |          | AX, [SP+byte]          | 2     | 1      | —      | AX ← (SP + byte)                   |   |      |          |
|                         |          | [SP+byte], AX          | 2     | 1      | -      | (SP + byte) ← AX                   |   |      |          |
|                         |          | AX, word[B]            | 3     | 1      | 4      | $AX \leftarrow (B + word)$         |   |      |          |
|                         |          | word[B], AX            | 3     | 1      | —      | $(B + word) \gets AX$              |   |      |          |
|                         |          | AX, ES:word[B]         | 4     | 2      | 5      | $AX \leftarrow ((ES,B) + word)$    |   |      |          |
|                         |          | ES:word[B], AX         | 4     | 2      | —      | $((ES,B)\text{+}word)\leftarrowAX$ |   |      |          |
|                         |          | AX, word[C]            | 3     | 1      | 4      | $AX \leftarrow (C + word)$         |   |      |          |
|                         |          | word[C], AX            | 3     | 1      | _      | $(C + word) \leftarrow AX$         |   |      |          |
|                         |          | AX, ES:word[C]         | 4     | 2      | 5      | $AX \gets ((ES,C) + word)$         |   |      |          |
|                         |          | ES:word[C], AX         | 4     | 2      | -      | $((ES, C) + word) \leftarrow AX$   |   |      |          |
|                         |          | AX, word[BC]           | 3     | 1      | 4      | $AX \leftarrow (BC + word)$        |   |      |          |
|                         |          | word[BC], AX           | 3     | 1      | _      | $(BC + word) \leftarrow AX$        |   |      |          |
|                         |          | AX, ES:word[BC]        | 4     | 2      | 5      | $AX \leftarrow ((ES, BC) + word)$  |   |      |          |
|                         |          | ES:word[BC], AX        | 4     | 2      | _      | $((ES, BC) + word) \leftarrow AX$  |   |      | -        |
|                         |          | BC, !addr16            | 3     | 1      | 4      | BC ← (addr16)                      |   |      | -        |
|                         |          | BC, ES:laddr16         | 4     | 2      | 5      | BC ← (ES, addr16)                  |   |      | 1        |
|                         |          | DE, !addr16            | 3     | 1      | 4      | DE ← (addr16)                      |   |      | 1        |
|                         |          | DE, ES:laddr16         | 4     | 2      | 5      | DE ← (ES, addr16)                  |   |      | 1        |
|                         |          | HL, laddr16            | 3     | 1      | 4      | HL ← (addr16)                      |   |      | -        |
|                         |          | HL, ES:!addr16         | 4     | 2      | 5      | HL ← (ES, addr16)                  |   |      | +        |
|                         |          | BC, saddrp             | 2     | 1      | _      | BC ← (saddrp)                      |   |      | +        |
|                         |          | DE, saddrp             | 2     | 1      | _      | DE ← (saddrp)                      |   |      | -        |
|                         |          | HL, saddrp             | 2     | 1      | _      | HL ← (saddrp)                      |   |      | -        |
|                         | XCHW     | AX, rp Note 4          | 1     | 1      | _      | $AX \leftarrow \rightarrow rp$     |   |      | -        |
|                         | ONEW     | AX                     | 1     | 1      | -      | AX ← 0001H                         |   |      |          |
|                         |          | BC                     | 1     | 1      | -      | BC ← 0001H                         |   |      |          |
|                         | CLRW     | AX                     | 1     | 1      | _      | AX ← 0000H                         |   |      |          |
|                         |          | BC                     | 1     | 1      | -      | BC ← 0000H                         |   | 1    | +        |
| 8-bit                   | ADD      | A, #byte               | 2     | 1      | _      | A, CY ← A + byte                   | × | ×    | ×        |
| operation               |          | saddr, #byte           | 3     | 2      |        | (saddr), CY ← (saddr) + byte       | × | ×    | ×        |
|                         |          | A, r <sup>Note 3</sup> | 2     | 1      | -      | A, CY ← A + r                      | × | ×    | ×        |
|                         |          | r, A                   | 2     | 1      | _      | r, CY ← r + A                      | × | ×    | ×        |
|                         |          | A, !addr16             | 3     | 1      | 4      | A, CY $\leftarrow$ A + (addr16)    | × | ×    | ×        |
|                         |          | A, ES:!addr16          | 4     | 2      | 5      | A, CY ← A + (ES, addr16)           | × | ×    | ×        |



| Instruction | Mnemonic  | Operands               | Bytes | Clocks |                                  | Clocks                                         |   | Flag       |    |  |  |  |
|-------------|-----------|------------------------|-------|--------|----------------------------------|------------------------------------------------|---|------------|----|--|--|--|
| Group       | winemonic | Operanus               | bytes | Note 1 | Note 2                           | UIUCKS                                         | Z | Flag<br>AC | CY |  |  |  |
| 8-bit       | ADD       | A, saddr               | 2     | 1      | _                                | A, C ← A + (saddr)                             | × | ×          | ×  |  |  |  |
| operation   |           | A, [HL]                | 1     | 1      | 4                                | $A, CY \leftarrow A + (HL)$                    | × | ×          | ×  |  |  |  |
|             |           | A, ES:[HL]             | 2     | 2      | 5                                | $A,CY \leftarrow A + (ES, HL)$                 | × | ×          | ×  |  |  |  |
|             |           | A, [HL+byte]           | 2     | 1      | 4                                | A, CY $\leftarrow$ A + (HL + byte)             | × | ×          | ×  |  |  |  |
|             |           | A, ES:[HL+byte]        | 3     | 2      | 5                                | $A,CY \leftarrow A + ((ES, HL) + byte)$        | × | ×          | ×  |  |  |  |
|             |           | A, [HL+B]              | 2     | 1      | 4                                | $A, CY \leftarrow A + (HL + B)$                | × | ×          | ,  |  |  |  |
|             |           | A, ES:[HL+B]           | 3     | 2      | 5                                | $A,CY \leftarrow A + ((ES, HL) + B)$           | × | ×          | ,  |  |  |  |
|             |           | A, [HL+C]              | 2     | 1      | 4                                | $A, CY \leftarrow A + (HL + C)$                | × | ×          | ,  |  |  |  |
|             |           | A, ES:[HL+C]           | 3     | 2      | 5                                | $A,CY \leftarrow A + ((ES, HL) + C)$           | × | ×          | ,  |  |  |  |
| ADDC        | A, #byte  | 2                      | 1     | _      | A, CY $\leftarrow$ A + byte + CY | ×                                              | × | ,          |    |  |  |  |
|             | -         | saddr, #byte           | 3     | 2      | _                                | (saddr), $CY \leftarrow$ (saddr) + byte + $CY$ | × | ×          | ,  |  |  |  |
|             |           | A, rv Note 3           | 2     | 1      | _                                | $A, CY \leftarrow A + r + CY$                  | × | ×          | ,  |  |  |  |
|             |           | r, A                   | 2     | 1      | _                                | $r, CY \leftarrow r + A + CY$                  | × | ×          | ,  |  |  |  |
|             |           | A, !addr16             | 3     | 1      | 4                                | A, CY $\leftarrow$ A + (addr16) + CY           | × | ×          | ,  |  |  |  |
|             |           | A, ES:laddr16          | 4     | 2      | 5                                | A, CY $\leftarrow$ A + (ES, addr16) + CY       | × | ×          | ,  |  |  |  |
|             |           | A, saddr               | 2     | 1      | _                                | A, CY $\leftarrow$ A + (saddr) + CY            | × | ×          | ,  |  |  |  |
|             |           | A, [HL]                | 1     | 1      | 4                                | A, CY $\leftarrow$ A + (HL) + CY               | × | ×          | ,  |  |  |  |
|             |           | A, ES:[HL]             | 2     | 2      | 5                                | $A,CY \leftarrow A + (ES, HL) + CY$            | × | ×          | ;  |  |  |  |
|             |           | A, [HL+byte]           | 2     | 1      | 4                                | A, CY $\leftarrow$ A + (HL + byte) + CY        | × | ×          | :  |  |  |  |
|             |           | A, ES:[HL+byte]        | 3     | 2      | 5                                | $A,CY \leftarrow A + ((ES, HL) + byte) + CY$   | × | ×          | :  |  |  |  |
|             |           | A, [HL+B]              | 2     | 1      | 4                                | $A, CY \leftarrow A + (HL + B) + CY$           | × | ×          | :  |  |  |  |
|             |           | A, ES:[HL+B]           | 3     | 2      | 5                                | $A,CY \leftarrow A + ((ES, HL) + B) + CY$      | × | ×          |    |  |  |  |
|             |           | A, [HL+C]              | 2     | 1      | 4                                | $A, CY \leftarrow A + (HL + C) + CY$           | × | ×          | ;  |  |  |  |
|             |           | A, ES:[HL+C]           | 3     | 2      | 5                                | $A,CY \leftarrow A + ((ES, HL) + C) + CY$      | × | ×          | ;  |  |  |  |
|             | SUB       | A, #byte               | 2     | 1      | _                                | A, CY $\leftarrow$ A - byte                    | × | ×          | :  |  |  |  |
|             |           | saddr, #byte           | 3     | 2      | _                                | (saddr), CY ← (saddr) - byte                   | × | ×          | :  |  |  |  |
|             |           | A, r Note 3            | 2     | 1      | _                                | A, CY ← A - r                                  | × | ×          | :  |  |  |  |
|             |           | r, A                   | 2     | 1      | _                                | r, CY ← r - A                                  | × | ×          | :  |  |  |  |
|             |           | A, !addr16             | 3     | 1      | 4                                | A, CY ← A - (addr16)                           | × | ×          | :  |  |  |  |
|             |           | A, ES:!addr16          | 4     | 2      | 5                                | A, CY $\leftarrow$ A - (ES, addr16)            | × | ×          | :  |  |  |  |
|             |           | A, saddr               | 2     | 1      | _                                | A, CY $\leftarrow$ A - (saddr)                 | × | ×          | :  |  |  |  |
|             |           | A, [HL]                | 1     | 1      | 4                                | A, CY ← A - (HL)                               | × | ×          | :  |  |  |  |
|             |           | A, ES:[HL]             | 2     | 2      | 5                                | A,CY ← A - (ES, HL)                            | × | ×          | :  |  |  |  |
|             |           | A, [HL+byte]           | 2     | 1      | 4                                | A, CY ← A - (HL + byte)                        | × | ×          | :  |  |  |  |
|             |           | A, ES:[HL+byte]        | 3     | 2      | 5                                | $A,CY \leftarrow A - ((ES, HL) + byte)$        | × | ×          | :  |  |  |  |
|             |           | A, [HL+B]              | 2     | 1      | 4                                | A, CY ← A - (HL + B)                           | × | ×          | :  |  |  |  |
|             |           | A, ES:[HL+B]           | 3     | 2      | 5                                | A,CY ← A - ((ES, HL) + B)                      | × | ×          | :  |  |  |  |
|             |           | A, [HL+C]              | 2     | 1      | 4                                | A, CY $\leftarrow$ A - (HL + C)                | × | ×          |    |  |  |  |
|             |           | A, ES:[HL+C]           | 3     | 2      | 5                                | A,CY ← A - ((ES, HL) + C)                      | × | ×          | :  |  |  |  |
|             | SUBC      | A, #byte               | 2     | 1      | _                                | A, CY ← A - byte - CY                          | × | ×          | :  |  |  |  |
|             |           | saddr, #byte           | 3     | 2      | _                                | (saddr), CY ← (saddr) - byte - CY              | × | ×          | :  |  |  |  |
|             |           | A, r <sup>Note 3</sup> | 2     | 1      | _                                | A, CY ← A - r - CY                             | × | ×          |    |  |  |  |
|             |           | r, A                   | 2     | 1      | _                                | r, CY ← r - A - CY                             | × | ×          | :  |  |  |  |
|             |           | A, !addr16             | 3     | 1      | 4                                | A, CY ← A - (addr16) - CY                      | × | ×          |    |  |  |  |
|             |           | A, ES:!addr16          | 4     | 2      | 5                                | A, CY ← A - (ES, addr16) - CY                  | × | ×          | :  |  |  |  |
|             |           | A, saddr               | 2     | 1      | _                                | A, CY $\leftarrow$ A - (saddr) - CY            | × | ×          |    |  |  |  |



| Instruction | Mnemonic | Operands        | Bytes | Clo    | ocks   | Clocks                                            |   | Flag |    |
|-------------|----------|-----------------|-------|--------|--------|---------------------------------------------------|---|------|----|
| Group       |          |                 |       | Note 1 | Note 2 |                                                   | Z | AC   | CY |
| 8-bit       | SUBC     | A, [HL]         | 1     | 1      | 4      | A, CY ← A - (HL) - CY                             | × | ×    | ×  |
| operation   |          | A, ES:[HL]      | 2     | 2      | 5      | $A,CY \gets A \text{ - } (ES, HL) \text{ - } CY$  | × | ×    | ×  |
|             |          | A, [HL+byte]    | 2     | 1      | 4      | A, CY ← A - (HL + byte) - CY                      | × | ×    | ×  |
|             |          | A, ES:[HL+byte] | 3     | 2      | 5      | A,CY ← A - ((ES, HL) + byte) - CY                 | × | ×    | ×  |
|             |          | A, [HL+B]       | 2     | 1      | 4      | A, CY ← A - (HL + B) - CY                         | × | ×    | ×  |
|             |          | A, ES:[HL+B]    | 3     | 2      | 5      | A,CY ← A - ((ES, HL) + B) - CY                    | × | ×    | ×  |
|             |          | A, [HL+C]       | 2     | 1      | 4      | $A,CY \leftarrow A \text{-} (HL + C) \text{-} CY$ | × | ×    | ×  |
|             |          | A, ES:[HL+C]    | 3     | 2      | 5      | A, CY ← A - ((ES:HL) + C) - CY                    | × | ×    | ×  |
|             | AND      | A, #byte        | 2     | 1      | _      | $A \gets A_{\wedge} \text{ byte}$                 | × |      |    |
|             |          | saddr, #byte    | 3     | 2      | —      | $(saddr) \leftarrow (saddr) \land byte$           | × |      |    |
|             |          | A, r Note 3     | 2     | 1      | _      | $A \leftarrow A_{\wedge} r$                       | × |      |    |
|             |          | r, A            | 2     | 1      | —      | $R \gets r \land A$                               | × |      |    |
|             |          | A, !addr16      | 3     | 1      | 4      | $A \leftarrow A \land (addr16)$                   | × |      |    |
|             |          | A, ES:laddr16   | 4     | 2      | 5      | $A \leftarrow A \land (ES:addr16)$                | × |      |    |
|             |          | A, saddr        | 2     | 1      | —      | $A \leftarrow A \land (saddr)$                    | × |      |    |
|             |          | A, [HL]         | 1     | 1      | 4      | $A \leftarrow A_{\wedge} (HL)$                    | × |      |    |
|             |          | A, ES:[HL]      | 2     | 2      | 5      | $A \leftarrow A \land (ES:HL)$                    | × |      |    |
|             |          | A, [HL+byte]    | 2     | 1      | 4      | $A \leftarrow A \land (HL + byte)$                | × |      |    |
|             |          | A, ES:[HL+byte] | 3     | 2      | 5      | $A \leftarrow A \land ((ES:HL) + byte)$           | × |      |    |
|             |          | A, [HL+B]       | 2     | 1      | 4      | $A \leftarrow A_{\wedge} (HL + B)$                | × |      |    |
|             |          | A, ES:[HL+B]    | 3     | 2      | 5      | $A \leftarrow A_{\wedge} ((ES:HL) + B)$           | × |      |    |
|             |          | A, [HL+C]       | 2     | 1      | 4      | $A \leftarrow A_{\wedge} (HL + C)$                | × |      |    |
|             |          | A, ES:[HL+C]    | 3     | 2      | 5      | $A \leftarrow A \land ((ES:HL) + C)$              | × |      |    |
|             | OR       | A, #byte        | 2     | 1      | —      | $A \leftarrow A \lor byte$                        | × |      |    |
|             |          | saddr, #byte    | 3     | 2      | _      | $(saddr) \leftarrow (saddr) \lor byte$            | × |      |    |
|             |          | A, r Note 3     | 2     | 1      | —      | $A \leftarrow A \lor r$                           | × |      |    |
|             |          | r, A            | 2     | 1      | —      | $r \leftarrow r \lor A$                           | × |      |    |
|             |          | A, !addr16      | 3     | 1      | 4      | $A \leftarrow A \lor (addr16)$                    | × |      |    |
|             |          | A, ES:laddr16   | 4     | 2      | 5      | $A \leftarrow A \lor (ES:addr16)$                 | × |      |    |
|             |          | A, saddr        | 2     | 1      | _      | $A \leftarrow A \lor (saddr)$                     | × |      |    |
|             |          | A, [HL]         | 1     | 1      | 4      | $A \leftarrow A \lor (HL)$                        | × |      |    |
|             |          | A, ES:[HL]      | 2     | 2      | 5      | $A \leftarrow A \lor (ES:HL)$                     | × |      |    |
|             |          | A, [HL+byte]    | 2     | 1      | 4      | $A \leftarrow A \lor (HL + byte)$                 | × |      |    |
|             |          | A, ES:[HL+byte] | 3     | 2      | 5      | $A \leftarrow A_{\vee} ((ES:HL) + byte)$          | × |      |    |
|             |          | A, [HL+B]       | 2     | 1      | 4      | $A \gets A \lor (HL + B)$                         | × |      |    |
|             |          | A, ES:[HL+B]    | 3     | 2      | 5      | $A \leftarrow A \lor ((ES:HL) + B)$               | × |      |    |
|             |          | A, [HL+C]       | 2     | 1      | 4      | $A \gets A \lor (HL + C)$                         | × |      |    |
|             |          | A, ES:[HL+C]    | 3     | 2      | 5      | $A \leftarrow A \lor ((ES:HL) + C)$               | × |      |    |
|             | XOR      | A, #byte        | 2     | 1      | _      | $A \leftarrow A \neq byte$                        | × |      |    |
|             |          | saddr, #byte    | 3     | 2      | —      | $(saddr) \leftarrow (saddr) \lor byte$            | × |      |    |
|             |          | A, r Note 3     | 2     | 1      | —      | $A \leftarrow A \nleftrightarrow r$               | × |      |    |
|             |          | r, A            | 2     | 1      | —      | $r \leftarrow r \nleftrightarrow A$               | × |      |    |
|             |          | A, !addr16      | 3     | 1      | 4      | $A \leftarrow A \neq (addr16)$                    | × |      |    |
|             |          | A, ES:laddr16   | 4     | 2      | 5      | A ← A ↔ (ES:addr16)                               | × |      |    |
|             |          | A, saddr        | 2     | 1      | _      | $A \leftarrow A \lor (saddr)$                     | × |      |    |
|             |          | A, [HL]         | 1     | 1      | 4      | $A \leftarrow A \neq (HL)$                        | × |      |    |

#### Table 25 - 5 Operation List (6/12)



| Instruction | Mnemonic | Operands               | Bytes | Clo    | ocks   | Clocks                                          |   | Flag |    |
|-------------|----------|------------------------|-------|--------|--------|-------------------------------------------------|---|------|----|
| Group       |          |                        |       | Note 1 | Note 2 |                                                 | Z | AC   | CY |
| 8-bit       | XOR      | A, ES:[HL]             | 2     | 2      | 5      | $A \leftarrow A \nleftrightarrow (ES:HL)$       | × |      |    |
| operation   |          | A, [HL+byte]           | 2     | 1      | 4      | A ← A ৬ (HL + byte)                             | × |      |    |
|             |          | A, ES:[HL+byte]        | 3     | 2      | 5      | $A \leftarrow A \lor ((ES:HL) + byte)$          | × |      |    |
|             |          | A, [HL+B]              | 2     | 1      | 4      | $A \leftarrow A \nleftrightarrow (HL + B)$      | × |      |    |
|             |          | A, ES:[HL+B]           | 3     | 2      | 5      | $A \leftarrow A \nleftrightarrow ((ES:HL) + B)$ | × |      |    |
|             |          | A, [HL+C]              | 2     | 1      | 4      | $A \leftarrow A \nleftrightarrow (HL + C)$      | × |      |    |
|             |          | A, ES:[HL+C]           | 3     | 2      | 5      | $A \leftarrow A \nleftrightarrow ((ES:HL) + C)$ | × |      |    |
|             | CMP      | A, #byte               | 2     | 1      | _      | A - byte                                        | × | ×    | ×  |
|             |          | !addr16, #byte         | 4     | 1      | 4      | (addr16) - byte                                 | × | ×    | ×  |
|             |          | ES:laddr16, #byte      | 5     | 2      | 5      | (ES:addr16) - byte                              | × | ×    | ×  |
|             |          | saddr, #byte           | 3     | 1      | _      | (saddr) - byte                                  | × | ×    | ×  |
|             |          | A, r <sup>Note 3</sup> | 2     | 1      | _      | A - r                                           | × | ×    | ×  |
|             |          | r, A                   | 2     | 1      | _      | r - A                                           | × | ×    | ×  |
|             |          | A, !addr16             | 3     | 1      | 4      | A - (addr16)                                    | × | ×    | ×  |
|             |          | A, ES:!addr16          | 4     | 2      | 5      | A - (ES:addr16)                                 | × | ×    | ×  |
|             |          | A, saddr               | 2     | 1      | _      | A - (saddr)                                     | × | ×    | ×  |
|             |          | A, [HL]                | 1     | 1      | 4      | A - (HL)                                        | × | ×    | ×  |
|             |          | A, ES:[HL]             | 2     | 2      | 5      | A - (ES:HL)                                     | × | ×    | ×  |
|             |          | A, [HL+byte]           | 2     | 1      | 4      | A - (HL + byte)                                 | × | ×    | ×  |
|             |          | A, ES:[HL+byte]        | 3     | 2      | 5      | A - ((ES:HL) + byte)                            | × | ×    | ×  |
|             |          | A, [HL+B]              | 2     | 1      | 4      | A - (HL + B)                                    | × | ×    | ×  |
|             |          | A, ES:[HL+B]           | 3     | 2      | 5      | A - ((ES:HL) + B)                               | × | ×    | ×  |
|             |          | A, [HL+C]              | 2     | 1      | 4      | A - (HL + C)                                    | × | ×    | ×  |
|             |          | A, ES:[HL+C]           | 3     | 2      | 5      | A - ((ES:HL) + C)                               | × | ×    | ×  |
|             | CMP0     | A                      | 1     | 1      | _      | A - 00H                                         | × | 0    | 0  |
|             |          | Х                      | 1     | 1      | _      | Х - 00Н                                         | × | 0    | 0  |
|             |          | В                      | 1     | 1      | _      | В - 00Н                                         | × | 0    | 0  |
|             |          | С                      | 1     | 1      | —      | С - 00Н                                         | × | 0    | 0  |
|             |          | !addr16                | 3     | 1      | 4      | (addr16) - 00H                                  | × | 0    | 0  |
|             |          | ES:!addr16             | 4     | 2      | 5      | (ES:addr16) - 00H                               | × | 0    | 0  |
|             |          | saddr                  | 2     | 1      | _      | (saddr) - 00H                                   | × | 0    | 0  |
|             | CMPS     | X, [HL+byte]           | 3     | 1      | 4      | X - (HL + byte)                                 | × | ×    | ×  |
|             |          | X, ES:[HL+byte]        | 4     | 2      | 5      | X - ((ES:HL) + byte)                            | × | ×    | ×  |
| 16-bit      | ADDW     | AX, #word              | 3     | 1      | _      | AX, CY $\leftarrow$ AX + word                   | × | ×    | ×  |
| operation   |          | AX, AX                 | 1     | 1      | _      | $AX,CY \leftarrow AX + AX$                      | × | ×    | ×  |
|             |          | AX, BC                 | 1     | 1      | —      | $AX, CY \gets AX + BC$                          | × | ×    | ×  |
|             |          | AX, DE                 | 1     | 1      | _      | AX, CY $\leftarrow$ AX + DE                     | × | ×    | ×  |
|             |          | AX, HL                 | 1     | 1      | —      | AX, CY $\leftarrow$ AX + HL                     | × | ×    | ×  |
|             |          | AX, !addr16            | 3     | 1      | 4      | AX, CY $\leftarrow$ AX + (addr16)               | × | ×    | ×  |
|             |          | AX, ES:!addr16         | 4     | 2      | 5      | AX, CY $\leftarrow$ AX + (ES:addr16)            | × | ×    | ×  |
|             |          | AX, saddrp             | 2     | 1      | —      | AX, CY $\leftarrow$ AX + (saddrp)               | × | ×    | ×  |
|             |          | AX, [HL+byte]          | 3     | 1      | 4      | AX, CY $\leftarrow$ AX + (HL + byte)            | × | ×    | ×  |
|             |          | AX, ES: [HL+byte]      | 4     | 2      | 5      | AX, CY ← AX + ((ES:HL) + byte)                  | × | ×    | ×  |

#### Table 25 - 5 Operation List (7/12)

| Instruction           | Mnemonic    | Operands          | Bytes |        | cks    | Clocks                                                        |   | Flag |    |
|-----------------------|-------------|-------------------|-------|--------|--------|---------------------------------------------------------------|---|------|----|
| Group                 | wittermonic | Operands          | Bytes | Note 1 | Note 2 | CIUCKS                                                        | Z | AC   | CY |
| 16-bit                | SUBW        | AX, #word         | 3     | 1      | _      | AX, CY $\leftarrow$ AX - word                                 | × | ×    | ×  |
| operation             |             | AX, BC            | 1     | 1      | _      | $AX, CY \leftarrow AX - BC$                                   | × | ×    | ×  |
|                       |             | AX, DE            | 1     | 1      | _      | AX, CY ← AX - DE                                              | × | ×    | ×  |
|                       |             | AX, HL            | 1     | 1      | _      | AX, CY $\leftarrow$ AX - HL                                   | × | ×    | ×  |
|                       |             | AX, !addr16       | 3     | 1      | 4      | AX, CY ← AX - (addr16)                                        | × | ×    | ×  |
|                       |             | AX, ES:!addr16    | 4     | 2      | 5      | AX, CY ← AX - (ES:addr16)                                     | × | ×    | ×  |
|                       |             | AX, saddrp        | 2     | 1      | _      | AX, CY $\leftarrow$ AX - (saddrp)                             | × | ×    | ×  |
|                       |             | AX, [HL+byte]     | 3     | 1      | 4      | AX, CY ← AX - (HL + byte)                                     | × | ×    | ×  |
|                       |             | AX, ES: [HL+byte] | 4     | 2      | 5      | AX, CY ← AX - ((ES:HL) + byte)                                | × | ×    | ×  |
|                       | CMPW        | AX, #word         | 3     | 1      | —      | AX - word                                                     | × | ×    | ×  |
|                       |             | AX, BC            | 1     | 1      | —      | AX - BC                                                       | × | ×    | ×  |
|                       |             | AX, DE            | 1     | 1      | —      | AX - DE                                                       | × | ×    | ×  |
|                       |             | AX, HL            | 1     | 1      | —      | AX - HL                                                       | × | ×    | ×  |
|                       |             | AX, !addr16       | 3     | 1      | 4      | AX - (addr16)                                                 | × | ×    | ×  |
|                       |             | AX, ES:!addr16    | 4     | 2      | 5      | AX - (ES:addr16)                                              | × | ×    | ×  |
|                       |             | AX, saddrp        | 2     | 1      | —      | AX - (saddrp)                                                 | × | ×    | ×  |
|                       |             | AX, [HL+byte]     | 3     | 1      | 4      | AX - (HL + byte)                                              | × | ×    | ×  |
|                       |             | AX, ES: [HL+byte] | 4     | 2      | 5      | AX - ((ES:HL) + byte)                                         | × | ×    | ×  |
| Multiply,             | MULU        | Х                 | 1     | 1      | —      | $AX \leftarrow A \times X$                                    |   |      |    |
| Divide,<br>Multiply & | MULHU       |                   | 3     | 2      | —      | $BCAX \leftarrow AX \times BC$ (unsigned)                     |   |      |    |
| accumulate            | MULH        |                   | 3     | 2      | —      | $BCAX \leftarrow AX \times BC$ (signed)                       |   |      |    |
|                       | DIVHU       |                   | 3     | 9      | —      | AX (quotient), DE (remainder) ←<br>AX ÷ DE (unsigned)         |   |      |    |
|                       | DIVWU       |                   | 3     | 17     | _      | BCAX (quotient), HLDE (remainder) ←<br>BCAX ÷ HLDE (unsigned) |   |      |    |
|                       | MACHU       |                   | 3     | 3      | —      | $MACR \gets MACR + AX \times BC \text{ (unsigned)}$           |   | ×    | ×  |
|                       | MACH        |                   | 3     | 3      | —      | $MACR \leftarrow MACR + AX \times BC(signed)$                 |   | ×    | ×  |
| Increment/            | INC         | r                 | 1     | 1      | —      | r ← r + 1                                                     | × | ×    |    |
| decrement             |             | !addr16           | 3     | 2      | —      | (addr16) ← (addr16) + 1                                       | × | ×    |    |
|                       |             | ES:!addr16        | 4     | 3      | _      | (ES, addr16) $\leftarrow$ (ES, addr16) + 1                    | × | ×    |    |
|                       |             | saddr             | 2     | 2      | _      | $(saddr) \leftarrow (saddr) + 1$                              | × | ×    |    |
|                       |             | [HL+byte]         | 3     | 2      | _      | $(HL + byte) \leftarrow (HL + byte) + 1$                      | × | ×    |    |
|                       |             | ES: [HL+byte]     | 4     | 3      | _      | $((ES:HL) + byte) \leftarrow ((ES:HL) + byte) + 1$            | × | ×    |    |
|                       | DEC         | r                 | 1     | 1      | —      | r ← r - 1                                                     | × | ×    |    |
|                       |             | !addr16           | 3     | 2      | —      | (addr16) ← (addr16) - 1                                       | × | ×    |    |
|                       |             | ES:laddr16        | 4     | 3      | —      | (ES, addr16) $\leftarrow$ (ES, addr16) - 1                    | × | ×    |    |
|                       |             | saddr             | 2     | 2      | —      | (saddr) ← (saddr) - 1                                         | × | ×    |    |
|                       |             | [HL+byte]         | 3     | 2      | _      | (HL + byte) ← (HL + byte) - 1                                 | × | ×    |    |
|                       |             | ES: [HL+byte]     | 4     | 3      | —      | $((ES:HL) + byte) \leftarrow ((ES:HL) + byte) - 1$            | × | ×    |    |
|                       | INCW        | rp                | 1     | 1      | —      | rp ← rp + 1                                                   |   |      |    |
|                       |             | !addr16           | 3     | 2      | —      | (addr16) ← (addr16) + 1                                       |   |      |    |
|                       |             | ES:!addr16        | 4     | 3      | _      | (ES, addr16) ← (ES, addr16) + 1                               |   |      |    |
|                       |             | saddrp            | 2     | 2      | —      | $(saddrp) \leftarrow (saddrp) + 1$                            |   |      |    |
|                       |             | [HL+byte]         | 3     | 2      | _      | (HL + byte) ← (HL + byte) + 1                                 |   |      |    |
|                       |             | ES: [HL+byte]     | 4     | 3      | —      | $((ES:HL) + byte) \leftarrow ((ES:HL) + byte) + 1$            |   |      |    |



| Instruction             | Maamania | Onerende        | Table 25 | -      |        | Clocks                                                                                  | 1   | Flag |    |
|-------------------------|----------|-----------------|----------|--------|--------|-----------------------------------------------------------------------------------------|-----|------|----|
| Group                   | Mnemonic | Operands        | Bytes    |        | ocks   | CIOCKS                                                                                  | 7   | Flag | -  |
|                         | DEOW     |                 |          | Note 1 | Note 2 |                                                                                         | Z   | AC   | CI |
| Increment/<br>decrement | DECW     | rp              | 1        | 1      | —      | $rp \leftarrow rp - 1$                                                                  |     |      |    |
|                         |          | !addr16         | 3        | 2      | —      | (addr16) ← (addr16) - 1                                                                 |     |      |    |
|                         |          | ES:!addr16      | 4        | 3      | —      | (ES, addr16) ← (ES, addr16) - 1                                                         |     |      |    |
|                         |          | saddrp          | 2        | 2      | _      | (saddrp) ← (saddrp) - 1                                                                 |     |      |    |
|                         |          | [HL+byte]       | 3        | 2      | —      | (HL + byte) ← (HL + byte) - 1                                                           |     |      |    |
|                         |          | ES: [HL+byte]   | 4        | 3      | —      | ((ES:HL) + byte) ← ((ES:HL) + byte) - 1                                                 |     |      |    |
| Shift                   | SHR      | A, cnt          | 2        | 1      | —      | $(CY \leftarrow A0, Am - 1 \leftarrow Am, A7 \leftarrow 0) \times cnt$                  |     |      | ×  |
|                         | SHRW     | AX, cnt         | 2        | 1      | -      | $(CY \leftarrow AX_0, AX_m - 1 \leftarrow AX_m, AX_{15} \leftarrow 0) \times cnt$       |     |      | ×  |
|                         | SHL      | A, cnt          | 2        | 1      | —      | $(CY \leftarrow A7, Am \leftarrow Am - 1, A0 \leftarrow 0) \times cnt$                  |     |      | ×  |
|                         |          | B, cnt          | 2        | 1      | —      | $(CY \leftarrow B7, Bm \leftarrow Bm - 1, B0 \leftarrow 0) \times cnt$                  |     |      | ×  |
|                         |          | C, cnt          | 2        | 1      | —      | $(CY \leftarrow C7, Cm \leftarrow Cm - 1, C0 \leftarrow 0) \times cnt$                  |     |      | ×  |
|                         | SHLW     | AX, cnt         | 2        | 1      | -      | $(CY \leftarrow AX15, AXm \leftarrow AXm - 1, AX0 \leftarrow 0) \times cnt$             |     |      | ×  |
|                         |          | BC, cnt         | 2        | 1      | _      | $(CY \leftarrow BC15, BCm \leftarrow BCm - 1, BC0 \leftarrow 0) \times cnt$             |     |      | ×  |
|                         | SAR      | A, cnt          | 2        | 1      | _      | $(CY \leftarrow A_0, A_{m-1} \leftarrow A_{m}, A_7 \leftarrow A_7) \times cnt$          |     |      | ×  |
|                         | SARW     | AX, cnt         | 2        | 1      | _      | $(CY \leftarrow AX_0, AX_m - 1 \leftarrow AX_m, AX_{15} \leftarrow AX_{15}) \times cnt$ |     |      | ×  |
| Rotate                  | ROR      | A, 1            | 2        | 1      | _      | (CY, A7 ← A0, Am - 1 ← Am) × 1                                                          |     |      | ×  |
|                         | ROL      | A, 1            | 2        | 1      | _      | (CY, A₀ ← A7, Am + 1 ← Am) × 1                                                          |     |      | ×  |
|                         | RORC     | A, 1            | 2        | 1      | _      | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_m - 1 \leftarrow A_m) \times 1$               |     |      | ×  |
|                         | ROLC     | A, 1            | 2        | 1      | _      | $(CY \leftarrow A7, A0 \leftarrow CY, Am + 1 \leftarrow Am) \times 1$                   |     |      | ×  |
|                         | ROLWC    | AX,1            | 2        | 1      | _      | $(CY \leftarrow AX_{15}, AX_0 \leftarrow CY, AX_m + 1 \leftarrow AX_m) \times 1$        |     |      | ×  |
|                         | NOLWO    | BC,1            | 2        | 1      |        | $(CY \leftarrow BC_{15}, BC_0 \leftarrow CY, BC_m + 1 \leftarrow BC_m) \times 1$        |     |      | ×  |
| Bit                     | MOV1     | -               | 2        | 1      | _      | $CY \leftarrow A.bit$                                                                   |     |      | ×  |
| manipulate              |          | CY, A.bit       |          |        |        |                                                                                         |     |      | Ŷ  |
| ·                       |          | A.bit, CY       | 2        | 1      | —      | A.bit ← CY                                                                              |     |      |    |
|                         |          | CY, PSW.bit     | 3        | 1      | _      |                                                                                         | ×   | ×    | ×  |
|                         |          | PSW.bit, CY     | 3        | 4      | —      | PSW.bit ← CY                                                                            | ^   | ^    |    |
|                         |          | CY, saddr.bit   | 3        | 1      | —      | CY ← (saddr).bit                                                                        |     |      | ×  |
|                         |          | saddr.bit, CY   | 3        | 2      | _      | (saddr).bit ← CY                                                                        |     |      |    |
|                         |          | CY, sfr.bit     | 3        | 1      | —      | CY ← sfr.bit                                                                            |     |      | ×  |
|                         |          | sfr.bit, CY     | 3        | 2      | _      | sfr.bit ← CY                                                                            |     |      |    |
|                         |          | CY,[HL].bit     | 2        | 1      | 4      | CY ← (HL).bit                                                                           |     |      | ×  |
|                         |          | [HL].bit, CY    | 2        | 2      | —      | (HL).bit ← CY                                                                           |     |      |    |
|                         |          | CY, ES:[HL].bit | 3        | 2      | 5      | CY ← (ES, HL).bit                                                                       |     |      | ×  |
|                         |          | ES:[HL].bit, CY | 3        | 3      | —      | (ES, HL).bit ← CY                                                                       |     |      |    |
|                         | AND1     | CY, A.bit       | 2        | 1      | -      | $CY \leftarrow CY \land A.bit$                                                          |     |      | ×  |
|                         |          | CY, PSW.bit     | 3        | 1      | —      | $CY \leftarrow CY \land PSW.bit$                                                        |     |      | ×  |
|                         |          | CY, saddr.bit   | 3        | 1      | —      | $CY \leftarrow CY \land (saddr).bit$                                                    |     |      | ×  |
|                         |          | CY, sfr.bit     | 3        | 1      | —      | $CY \leftarrow CY \land sfr.bit$                                                        |     |      | ×  |
|                         |          | CY, [HL].bit    | 2        | 1      | 4      | $CY \leftarrow CY \land (HL).bit$                                                       |     |      | ×  |
|                         |          | CY, ES:[HL].bit | 3        | 2      | 5      | $CY \leftarrow CY \land (ES, HL).bit$                                                   |     |      | ×  |
|                         | OR1      | CY, A.bit       | 2        | 1      | _      | $CY \leftarrow CY \lor A.bit$                                                           |     |      | ×  |
|                         |          | CY, PSW.bit     | 3        | 1      | _      | $CY \leftarrow CY \lor PSW.bit$                                                         |     |      | ×  |
|                         |          | CY, saddr.bit   | 3        | 1      | _      | $CY \leftarrow CY \lor (saddr).bit$                                                     |     |      | ×  |
|                         |          | CY, sfr.bit     | 3        | 1      | _      | $CY \leftarrow CY \lor sfr.bit$                                                         |     |      | ×  |
|                         |          | CY, [HL].bit    | 2        | 1      | 4      | $CY \leftarrow CY \lor (HL).bit$                                                        |     |      | ×  |
|                         | 1        | 1               | 1        | 1      | 1      | · · ·                                                                                   | I I | 1    | 1  |

#### Table 25 - 5 Operation List (9/12)



|                      | 1        | 1                      |       |               |                | LIST (10/12)                                                                                                                                                                                                                                                                                                                                                                                                       | - |            |        |
|----------------------|----------|------------------------|-------|---------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------|--------|
| Instruction<br>Group | Mnemonic | Operands               | Bytes | Clo<br>Note 1 | ocks<br>Note 2 | Clocks                                                                                                                                                                                                                                                                                                                                                                                                             | z | Flag<br>AC | 1      |
| Bit                  | XOR1     | CY, A.bit              | 2     | 1             |                | CY ← CY → bit                                                                                                                                                                                                                                                                                                                                                                                                      | 2 | 70         | ×      |
| manipulate           | JURI     | CY, PSW.bit            | 3     | 1             |                | $CY \leftarrow CY \neq Dit$<br>$CY \leftarrow CY \neq PSW.bit$                                                                                                                                                                                                                                                                                                                                                     |   |            | ^<br>× |
|                      |          | CY, saddr.bit          | 3     | 1             | _              | $CY \leftarrow CY \lor (saddr).bit$                                                                                                                                                                                                                                                                                                                                                                                |   |            | ^<br>× |
|                      |          | CY, sfr.bit            | 3     | 1             | _              | $CY \leftarrow CY \neq sfr.bit$                                                                                                                                                                                                                                                                                                                                                                                    |   |            | ×      |
|                      |          |                        | 2     | 1             | 4              | $CY \leftarrow CY \neq Sil.bit$<br>$CY \leftarrow CY \neq (HL).bit$                                                                                                                                                                                                                                                                                                                                                |   |            | ×      |
|                      |          | CY, [HL].bit           |       |               |                |                                                                                                                                                                                                                                                                                                                                                                                                                    |   |            | ^<br>× |
|                      | 0574     | CY, ES:[HL].bit        | 3     | 2             | 5              | $CY \leftarrow CY \neq (ES, HL).bit$                                                                                                                                                                                                                                                                                                                                                                               |   |            |        |
|                      | SET1     | A.bit                  | 2     | 1             | —              | A.bit ← 1                                                                                                                                                                                                                                                                                                                                                                                                          | × | ×          | ×      |
|                      |          | PSW.bit<br>!addr16.bit |       |               |                | PSW.bit ← 1                                                                                                                                                                                                                                                                                                                                                                                                        |   | ^          |        |
|                      |          | ES:!addr16.bit         | 4     | 2             | _              | (addr16).bit ← 1                                                                                                                                                                                                                                                                                                                                                                                                   |   |            |        |
|                      |          |                        | 3     | 2             | _              | (ES, addr16).bit ← 1                                                                                                                                                                                                                                                                                                                                                                                               |   |            |        |
|                      |          | saddr.bit              |       |               | _              | (saddr).bit ← 1                                                                                                                                                                                                                                                                                                                                                                                                    |   |            |        |
|                      |          | sfr.bit                | 3     | 2             |                | sfr.bit ← 1                                                                                                                                                                                                                                                                                                                                                                                                        | _ |            |        |
|                      |          | [HL].bit               | 2     | 2             | —              | (HL).bit ← 1                                                                                                                                                                                                                                                                                                                                                                                                       |   |            |        |
|                      |          | ES:[HL].bit            | 3     | 3             |                | (ES, HL).bit ← 1                                                                                                                                                                                                                                                                                                                                                                                                   |   |            |        |
|                      | CLR1     | A.bit                  | 2     | 1             | _              | A.bit ← 0                                                                                                                                                                                                                                                                                                                                                                                                          | × | ×          | ×      |
|                      |          | PSW.bit                | 3     | 4             |                | PSW.bit ← 0                                                                                                                                                                                                                                                                                                                                                                                                        |   | ^          |        |
|                      |          | laddr16.bit            |       |               |                | (addr16).bit $\leftarrow 0$                                                                                                                                                                                                                                                                                                                                                                                        |   |            |        |
|                      |          | ES:laddr16.bit         | 5     | 3             | _              | (ES, addr16).bit $\leftarrow 0$                                                                                                                                                                                                                                                                                                                                                                                    |   |            |        |
|                      |          | saddr.bit              | 3     | 2             | _              | $(\text{saddr.bit}) \leftarrow 0$                                                                                                                                                                                                                                                                                                                                                                                  |   |            | -      |
|                      |          | sfr.bit                | 3     | 2             |                | sfr.bit ← 0                                                                                                                                                                                                                                                                                                                                                                                                        |   |            |        |
|                      |          | [HL].bit               | 2     | 2             |                | $(HL).bit \leftarrow 0$                                                                                                                                                                                                                                                                                                                                                                                            | _ |            |        |
|                      | 0574     | ES:[HL].bit            | 3     | 3             | —              | (ES, HL).bit $\leftarrow 0$                                                                                                                                                                                                                                                                                                                                                                                        |   |            |        |
|                      | SET1     | CY                     | 2     | 1             |                | CY ← 1                                                                                                                                                                                                                                                                                                                                                                                                             |   |            | 1      |
|                      | CLR1     | CY                     | 2     | 1             |                | CY ← 0                                                                                                                                                                                                                                                                                                                                                                                                             | _ |            | 0      |
|                      | NOT1     | CY                     | 2     | 1             | —              | $CY \leftarrow \overline{CY}$                                                                                                                                                                                                                                                                                                                                                                                      |   |            | ×      |
| Call/return          | CALL     | rp                     | 2     | 3             | _              | $ \begin{aligned} (SP - 2) &\leftarrow (PC + 2)S, (SP - 3) \leftarrow (PC + 2)H, \\ (SP - 4) &\leftarrow (PC + 2)L, PC \leftarrow CS, rp, \\ SP &\leftarrow SP - 4 \end{aligned} $                                                                                                                                                                                                                                 |   |            |        |
|                      |          | \$!addr20              | 3     | 3             | _              | $\begin{array}{l} (SP-2) \leftarrow (PC+3)S,  (SP-3) \leftarrow (PC+3)H, \\ (SP-4) \leftarrow (PC+3)L,  PC \leftarrow PC+3+j disp16, \\ SP \leftarrow SP-4 \end{array}$                                                                                                                                                                                                                                            |   |            |        |
|                      |          | !addr16                | 3     | 3             | —              | $\begin{array}{l} (SP - 2) \leftarrow (PC + 3)S, (SP - 3) \leftarrow (PC + 3)H, \\ (SP - 4) \leftarrow (PC + 3)L, PC \leftarrow 0000, addr16, \\ SP \leftarrow SP - 4 \end{array}$                                                                                                                                                                                                                                 |   |            |        |
|                      |          | ‼addr20                | 4     | 3             | —              | $\begin{array}{l} (SP - 2) \leftarrow (PC + 4)S,  (SP - 3) \leftarrow (PC + 4)H, \\ (SP - 4) \leftarrow (PC + 4)L,  PC \leftarrow addr20, \\ SP \leftarrow SP - 4 \end{array}$                                                                                                                                                                                                                                     |   |            |        |
|                      | CALLT    | [addr5]                | 2     | 5             | _              | $\begin{array}{l} (SP - 2) \leftarrow (PC + 2)S, (SP - 3) \leftarrow (PC + 2)H, \\ (SP - 4) \leftarrow (PC + 2)L, PCS \leftarrow 0000, \\ PCH \leftarrow (0000, addr5 + 1), \\ PCL \leftarrow (0000, addr5), \\ SP \leftarrow SP - 4 \end{array}$                                                                                                                                                                  |   |            |        |
|                      | BRK      | _                      | 2     | 5             | _              | $\begin{array}{l} (\text{SP - 1}) \leftarrow \text{PSW}, (\text{SP - 2}) \leftarrow (\text{PC + 2})\text{s}, \\ (\text{SP - 3}) \leftarrow (\text{PC + 2})\text{H}, (\text{SP - 4}) \leftarrow (\text{PC + 2})\text{L}, \\ \text{PCs} \leftarrow 0000, \\ \text{PCH} \leftarrow (0007\text{FH}), \text{PCL} \leftarrow (0007\text{EH}), \\ \text{SP} \leftarrow \text{SP - 4}, \text{IE} \leftarrow 0 \end{array}$ |   |            |        |
|                      | RET      | _                      | 1     | 6             | —              | $\begin{array}{l} PCL \leftarrow (SP),  PCH \leftarrow (SP+1), \\ PCS \leftarrow (SP+2),  SP \leftarrow SP+4 \end{array}$                                                                                                                                                                                                                                                                                          |   |            |        |
|                      | RETI     | _                      | 2     | 6             | _              | $\begin{array}{l} PCL \leftarrow (SP), PCH \leftarrow (SP+1), \\ PCS \leftarrow (SP+2), PSW \leftarrow (SP+3), \\ SP \leftarrow SP+4 \end{array}$                                                                                                                                                                                                                                                                  | R | R          | R      |

#### Table 25 - 5 Operation List (10/12)



| Instruction         | Mnemonic | Operands              | Bytes | Clo           | ocks   | Clocks                                                                                                                                              |   | Flag |    |
|---------------------|----------|-----------------------|-------|---------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----|
| Group               |          |                       |       | Note 1        | Note 2 |                                                                                                                                                     | Z | AC   | CY |
| Call/return         | RETB     | —                     | 2     | 6             | _      | $\begin{array}{l} PCL \leftarrow (SP),  PCH \leftarrow (SP+1), \\ PCS \leftarrow (SP+2),  PSW \leftarrow (SP+3), \\ SP \leftarrow SP+4 \end{array}$ | R | R    | R  |
| Stack<br>manipulate | PUSH     | PSW                   | 2     | 1             | —      | $(SP - 1) \leftarrow PSW$ , $(SP - 2) \leftarrow 00H$ ,<br>$SP \leftarrow SP - 2$                                                                   |   |      |    |
|                     |          | rp                    | 1     | 1             | —      | $(SP - 1) \leftarrow rpH, (SP - 2) \leftarrow rpL,$<br>$SP \leftarrow SP - 2$                                                                       |   |      |    |
|                     | POP      | PSW                   | 2     | 3             | _      | $PSW \leftarrow (SP + 1),  SP \leftarrow SP + 2$                                                                                                    | R | R    | R  |
|                     |          | rp                    | 1     | 1             | —      | $rp_{L} \leftarrow (SP), rp_{H} \leftarrow (SP + 1), SP \leftarrow SP + 2$                                                                          |   |      |    |
|                     | MOVW     | SP, #word             | 4     | 1             | —      | $SP \leftarrow word$                                                                                                                                |   |      |    |
|                     |          | SP, AX                | 2     | 1             | —      | $SP \leftarrow AX$                                                                                                                                  |   |      |    |
|                     |          | AX, SP                | 2     | 1             | —      | $AX \leftarrow SP$                                                                                                                                  |   |      |    |
|                     |          | HL, SP                | 3     | 1             | _      | HL ← SP                                                                                                                                             |   |      |    |
|                     |          | BC, SP                | 3     | 1             | —      | $BC \leftarrow SP$                                                                                                                                  |   |      |    |
|                     |          | DE, SP                | 3     | 1             | —      | DE ← SP                                                                                                                                             |   |      |    |
|                     | ADDW     | SP, #byte             | 2     | 1             | _      | $SP \leftarrow SP + byte$                                                                                                                           |   |      |    |
|                     | SUBW     | SP, #byte             | 2     | 1             | _      | $SP \leftarrow SP$ - byte                                                                                                                           |   |      |    |
| Unconditio          | BR       | AX                    | 2     | 3             | _      | $PC \leftarrow CS, AX$                                                                                                                              |   |      |    |
| nal branch          |          | \$addr20              | 2     | 3             | —      | PC ← PC + 2 + jdisp8                                                                                                                                |   |      |    |
|                     |          | \$!addr20             | 3     | 3             | _      | PC ← PC + 3 + jdisp16                                                                                                                               |   |      |    |
|                     |          | !addr16               | 3     | 3             | _      | PC ← 0000, addr16                                                                                                                                   |   |      |    |
|                     |          | !!addr20              | 4     | 3             | _      | PC ← addr20                                                                                                                                         |   |      |    |
| Conditional branch  | BC       | \$addr20              | 2     | 2/4<br>Note 5 | —      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 1$                                                                                                         |   |      |    |
|                     | BNC      | \$addr20              | 2     | 2/4<br>Note 5 | _      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 0$                                                                                                         |   |      |    |
|                     | BZ       | \$addr20              | 2     | 2/4<br>Note 5 | —      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 1$                                                                                                          |   |      |    |
|                     | BNZ      | \$addr20              | 2     | 2/4<br>Note 5 | —      | $PC \leftarrow PC + 2 + jdisp8$ if Z = 0                                                                                                            |   |      |    |
|                     | вн       | \$addr20              | 3     | 2/4<br>Note 5 | —      | $PC \leftarrow PC + 3 + jdisp8$ if $(Z \lor CY) = 0$                                                                                                |   |      |    |
|                     | BNH      | \$addr20              | 3     | 2/4<br>Note 5 | —      | $PC \leftarrow PC + 3 + jdisp8$ if $(Z \lor CY) = 1$                                                                                                |   |      |    |
|                     | BT       | saddr.bit, \$addr20   | 4     | 3/5<br>Note 5 | _      | $PC \leftarrow PC + 4 + jdisp8$ if (saddr).bit = 1                                                                                                  |   |      |    |
|                     |          | sfr.bit, \$addr20     | 4     | 3/5<br>Note 5 | _      | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1                                                                                                      |   |      |    |
|                     |          | A.bit, \$addr20       | 3     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1                                                                                                        |   |      |    |
|                     |          | PSW.bit, \$addr20     | 4     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 1                                                                                                      |   |      |    |
|                     |          | [HL].bit, \$addr20    | 3     | 3/5<br>Note 5 | 6/7    | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1                                                                                                     |   |      |    |
|                     |          | ES:[HL].bit, \$addr20 | 4     | 4/6<br>Note 5 | 7/8    | $PC \leftarrow PC + 4 + jdisp8$ if (ES, HL).bit = 1                                                                                                 |   |      |    |

#### Table 25 - 5 Operation List (11/12)



| Instruction        | Mnemonic   | Operands              | Bytes | Clo           | ocks   | Clocks                                                                         |   | Flag |    |
|--------------------|------------|-----------------------|-------|---------------|--------|--------------------------------------------------------------------------------|---|------|----|
| Group              |            |                       |       | Note 1        | Note 2 |                                                                                | Z | AC   | CY |
| Conditional branch | BF         | saddr.bit, \$addr20   | 4     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 4 + jdisp8$ if (saddr).bit = 0                             |   |      |    |
|                    |            | sfr.bit, \$addr20     | 4     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 0                                 |   |      |    |
|                    |            | A.bit, \$addr20       | 3     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 3 + jdisp8 \text{ if A.bit} = 0$                           |   |      |    |
|                    |            | PSW.bit, \$addr20     | 4     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 0                                 |   |      |    |
|                    |            | [HL].bit, \$addr20    | 3     | 3/5<br>Note 5 | 6/7    | $PC \leftarrow PC + 3 + jdisp8 $ if (HL).bit = 0                               |   |      |    |
|                    |            | ES:[HL].bit, \$addr20 | 4     | 4/6<br>Note 5 | 7/8    | PC ← PC + 4 + jdisp8 if (ES, HL).bit = 0                                       |   |      |    |
|                    | BTCLR      | saddr.bit, \$addr20   | 4     | 3/5<br>Note 5 | —      | PC ← PC + 4 + jdisp8 if (saddr).bit = 1<br>then reset (saddr).bit              |   |      |    |
|                    |            | sfr.bit, \$addr20     | 4     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1<br>then reset sfr.bit           |   |      |    |
|                    |            | A.bit, \$addr20       | 3     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1<br>then reset A.bit               |   |      |    |
|                    |            | PSW.bit, \$addr20     | 4     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 1<br>then reset PSW.bit           | × | ×    | ×  |
|                    |            | [HL].bit, \$addr20    | 3     | 3/5<br>Note 5 | —      | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1<br>then reset (HL).bit         |   |      |    |
|                    |            | ES:[HL].bit, \$addr20 | 4     | 4/6<br>Note 5 | —      | $PC \leftarrow PC + 4 + jdisp8$ if (ES, HL).bit = 1<br>then reset (ES, HL).bit |   |      |    |
| Conditional        | SKC        | —                     | 2     | 1             | —      | Next instruction skip if CY = 1                                                |   |      |    |
| skip               | SKNC       | —                     | 2     | 1             | —      | Next instruction skip if CY = 0                                                |   |      |    |
|                    | SKZ        | —                     | 2     | 1             | —      | Next instruction skip if Z = 1                                                 |   |      |    |
|                    | SKNZ       | —                     | 2     | 1             | —      | Next instruction skip if Z = 0                                                 |   |      |    |
|                    | SKH        | —                     | 2     | 1             | —      | Next instruction skip if (Z $\lor$ CY) = 0                                     |   |      |    |
|                    | SKNH       | —                     | 2     | 1             | —      | Next instruction skip if (Z $\lor$ CY) = 1                                     |   |      |    |
| CPU                | SEL Note 6 | RBn                   | 2     | 1             | _      | RBS[1:0] ← n                                                                   |   |      |    |
| control            | NOP        | —                     | 1     | 1             | _      | No Operation                                                                   |   |      |    |
|                    | EI         | —                     | 3     | 4             | _      | IE ← 1 (Enable Interrupt)                                                      |   |      |    |
|                    | DI         | —                     | 3     | 4             | _      | IE ← 0 (Disable Interrupt)                                                     |   | 1    |    |
|                    | HALT       | —                     | 2     | 3             | _      | Set HALT Mode                                                                  |   | 1    | 1  |
|                    | STOP       | —                     | 2     | 3             | —      | Set STOP Mode                                                                  |   | 1    |    |

#### Table 25 - 5 Operation List (12/12)

**Note 1.** Number of CPU clocks (fCLK) when the internal RAM area, SFR area, or extended SFR area is accessed, or when no data is accessed.

**Note 2.** Number of CPU clocks (fCLK) when the code flash memory is accessed, or when the data flash memory is accessed by an 8-bit instruction.

Note 3. Except r = A

**Note 4.** Except rp = AX

Note 5. This indicates the number of clocks "when condition is not met/when condition is met".

**Note 6.** n indicates the number of register banks (n = 0 to 3)

Caution Disable interrupts when executing the DIVHU or DIVWU instruction in an interrupt servicing routine. Alternatively, unless they are executed in the RAM area, note that execution of a DIVHU or DIVWU instruction is possible even with interrupts enabled as long as a NOP instruction is added immediately after the DIVHU or DIVWU instruction in the assembly language source code. The following compilers automatically add a NOP instruction immediately after any DIVHU or DIVWU instruction output during the build process.

- V. 1.71 and later versions of the CA78K0R (Renesas Electronics compiler), for both C and assembly language source code
- Service pack 1.40.3 and later versions of the EWRL78 (IAR compiler), for C language source code
- GNURL78 (KPIT compiler), for C language source code
- **Remark 1.** Number of clock is when program exists in the internal ROM (flash memory) area. If fetching the instruction from the internal RAM area, the number becomes double number plus 3 clocks at a maximum.
- Remark 2. MACR indicates the multiplication and accumulation register (MACRH, MACRL).
- **Remark 3.** cnt indicates the bit shift count.



# **CHAPTER 26 ELECTRICAL SPECIFICATIONS**

For details, refer to R9A02G015 Data Sheet (R19DS0101E).



# **CHAPTER 27 PACKAGE DRAWINGS**

For details, refer to R9A02G015 Data Sheet (R19DS0101E).



## **REVISION HISTORY**

## R9A02G015 User's Manual: Hardware

| Rev. | Date         |      | Description                                                                                                                                                                                                                                                                                        |
|------|--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NEV. | Dale         | Page | Summary                                                                                                                                                                                                                                                                                            |
| 0.10 | Sep 28, 2018 |      | First Draft of the Preliminary User's Manual                                                                                                                                                                                                                                                       |
| 0.20 | Dec 26, 2018 | _    | The following chapters were newly added.<br>• CHAPTER 5 CLOCK GENERATOR<br>• CHAPTER 8 CLOCK OUTPUT/BUZZER OUTPUT CONTROLLER<br>• CHAPTER 11 SERIAL ARRAY UNIT<br>• CHAPTER 12 SERIAL INTERFACE IICA<br>• CHAPTER 13 USB HOST/FUNCTION MODULE (USB)<br>In addition, minor modifications were made. |
| 0.90 | Feb 15, 2019 |      | The following chapters were newly added.<br>• CHAPTER 15 STANDBY FUNCTION<br>• CHAPTER 16 RESET FUNCTION<br>• CHAPTER 19 SAFETY FUNCTIONS<br>• CHAPTER 20 REGULATOR<br>• CHAPTER 21 OPTION BYTE<br>• CHAPTER 22 FLASH MEMORY<br>• CHAPTER 23 ON-CHIP DEBUG FUNCTION                                |
| 1.00 | Mar 29, 2019 |      | First edition issued                                                                                                                                                                                                                                                                               |



## R9A02G015 User's Manual: Hardware

| Publication Date: | Rev.0.10<br>Rev.1.00            | Sep 28, 2018<br>Mar 29, 2019 |
|-------------------|---------------------------------|------------------------------|
| 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.

# R9A02G015

