# RL78/G12 User's Manual: Hardware 16-Bit Single-Chip Microcontrollers All information contained in these materials, including products and product specifications, represents information on the product at the time of publication and is subject to change by Renesas Electronics Corp. without notice. Please review the latest information published by Renesas Electronics Corp. through various means, including the Renesas Electronics Corp. website (http://www.renesas.com). #### Notice - Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information. - Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein. - 3. Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others. - 4. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from such alteration, modification, copy or otherwise misappropriation of Renesas Electronics product. - 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots etc. - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; and safety equipment etc. Renesas Electronics products are neither intended nor authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems, surgical implantations etc.), or may cause serious property damages (nuclear reactor control systems, military equipment etc.). You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application for which it is not intended. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for which the product is not intended by Renesas Electronics. - 6. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges. - 7. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or systems manufactured by you. - 8. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations. - 9. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You should not use Renesas Electronics products or technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. When exporting the Renesas Electronics products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. - 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, who distributes, disposes of, or otherwise places the product with a third party, to notify such third party in advance of the contents and conditions set forth in this document, Renesas Electronics assumes no responsibility for any losses incurred by you or third parties as a result of unauthorized use of Renesas Electronics products. - 11. This document may not be reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics. - 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries. - (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries. - (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics. ## NOTES FOR CMOS DEVICES - (1) VOLTAGE APPLICATION WAVEFORM AT INPUT PIN: Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between VIL (MAX) and VIH (MIN) due to noise, etc., the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between VIL (MAX) and VIH (MIN). - (2) HANDLING OF UNUSED INPUT PINS: Unconnected CMOS device inputs can be cause of malfunction. If an input pin is unconnected, it is possible that an internal input level may be generated due to noise, etc., causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND via a resistor if there is a possibility that it will be an output pin. All handling related to unused pins must be judged separately for each device and according to related specifications governing the device. - (3) PRECAUTION AGAINST ESD: A strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it when it has occurred. Environmental control must be adequate. When it is dry, a humidifier should be used. It is recommended to avoid using insulators that easily build up static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work benches and floors should be grounded. The operator should be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with mounted semiconductor devices. - (4) STATUS BEFORE INITIALIZATION: Power-on does not necessarily define the initial status of a MOS device. Immediately after the power source is turned ON, devices with reset functions have not yet been initialized. Hence, power-on does not guarantee output pin levels, I/O settings or contents of registers. A device is not initialized until the reset signal is received. A reset operation must be executed immediately after power-on for devices with reset functions. - (5) POWER ON/OFF SEQUENCE: In the case of a device that uses different power supplies for the internal operation and external interface, as a rule, switch on the external power supply after switching on the internal power supply. When switching the power supply off, as a rule, switch off the external power supply and then the internal power supply. Use of the reverse power on/off sequences may result in the application of an overvoltage to the internal elements of the device, causing malfunction and degradation of internal elements due to the passage of an abnormal current. The correct power on/off sequence must be judged separately for each device and according to related specifications governing the device. - (6) INPUT OF SIGNAL DURING POWER OFF STATE: Do not input signals or an I/O pull-up power supply while the device is not powered. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements. Input of signals during the power off state must be judged separately for each device and according to related specifications governing the device. ## How to Use This Manual Readers This manual is intended for user engineers who wish to understand the functions of the RL78/G12 and design and develop application systems and programs for these devices. **Purpose** This manual is intended to give users an understanding of the functions described in the **Organization** below. Organization The RL78/G12 manual is separated into two parts: this manual and the software edition (common to the RL78/G12 family). RL78/G12 User's Manual Hardware RL78 family User's Manual Software - Pin functions - · Internal block functions - Interrupts - Other on-chip peripheral functions - · Electrical specifications - CPU functions - Instruction set - Explanation of each instruction **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: - → Read this manual in the order of the **CONTENTS**. The mark "<R>" shows major revised points. The revised points can be easily searched by copying an "<R>" in the PDF file and specifying it in the "Find what:" field. - 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 RL78/G12 Microcontroller instructions: - $\rightarrow$ 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 **Remark**: Supplementary information Numerical representations: Binary $\cdots \times \times \times \times$ or $\times \times \times \times B$ $\begin{array}{ll} \text{Decimal} & \cdots \times \times \times \\ \text{Hexadecimal} & \cdots \times \times \times \text{H} \end{array}$ **Related Documents** The related documents indicated in this publication may include preliminary versions. However, preliminary versions are not marked as such. #### **Documents Related to Devices** | Document Name | Document No. | |-------------------------------------|--------------| | RL78/G12 User's Manual: Hardware | R01UH0200E | | RL78 Family User's Manual: Software | R01US0015E | ## **Documents Related to Flash Memory Programming** | Document Name | Document No. | |----------------------------------------------|--------------| | PG-FP5 Flash Memory Programmer User's Manual | R20UT0008E | 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 MPUs & MCUs RL78 Family | R01CP0003E | | Semiconductor Package Mount Manual | Note | | Quality Grades on NEC Semiconductor Devices | C11531E | | Guide to Prevent Damage for Semiconductor Devices by Electrostatic Discharge (ESD) | C11892E | | Semiconductor Reliability Handbook | R51ZZ0001E | **Note** See the "Semiconductor Package Mount Manual" website (http://www.renesas.com/products/package/manual/index.jsp). 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. Windows, Windows NT and Windows XP are registered trademarks or trademarks of Microsoft Corporation in the United States and/or other countries. PC/AT is a trademark of International Business Machines 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** | CHAPTER 1 OUTLINE | 1 | |-------------------------------------------------------------------------------------|---------| | 1.1 Differences between the R5F102 Products and the R5F103 Products | 1 | | 1.1.1 Data Flash | 1 | | 1.1.2 On-chip oscillator characteristics | 2 | | 1.1.3 Peripheral Functions | 2 | | 1.2 Features | 3 | | 1.3 List of Part Numbers | 6 | | 1.4 Pin Configuration (Top View) | 9 | | 1.4.1 20-pin products | g | | 1.4.2 24-pin products | 10 | | 1.4.3 30-pin products | 11 | | 1.5 Pin Identification | 12 | | 1.6 Block Diagram | 13 | | 1.6.1 20-pin products | 13 | | 1.6.2 24-pin products | 14 | | 1.6.3 30-pin products | 15 | | 1.7 Outline of Functions | 16 | | CHAPTER 2 PIN FUNCTIONS | | | 2.1 Port Functions | | | 2.1.1 20-pin products | | | 2.1.2 24-pin products | | | 2.1.3 30-pin products | | | 2.2 Functions other than port pins | | | 2.2.1 Functions for each product | | | 2.2.2 Description of Functions | | | 2.3 Connection of Unused Pins | | | 2.4 Block Diagrams of Pins | 26 | | CHAPTER 3 CPU ARCHITECTURE | 39 | | 3.1 Memory Space | 39 | | 3.1.1 Internal program memory space | 47 | | 3.1.2 Mirror area | 51 | | 3.1.3 Internal data memory space | 52 | | 3.1.4 Special function register (SFR) area | 54 | | 3.1.5 Extended special function register (2nd SFR: 2nd Special Function Register) a | area 54 | | 3.1.6 Data memory addressing | 55 | | 3.2 Processor Registers | 56 | |--------------------------------------------------------------------------------------|----| | 3.2.1 Control registers | 56 | | 3.2.2 General-purpose registers | 58 | | 3.2.3 ES and CS registers | | | 3.2.4 Special function registers (SFRs) | | | 3.2.5 Extended special function registers (2nd SFRs: 2nd Special Function Registers) | | | 3.3 Instruction Address Addressing | | | 3.3.1 Relative addressing | 71 | | 3.3.2 Immediate addressing | 71 | | 3.3.3 Table indirect addressing | 72 | | 3.3.4 Register direct addressing | | | 3.4 Addressing for Processing Data Addresses | | | 3.4.1 Implied addressing | | | 3.4.2 Register addressing | | | 3.4.3 Direct addressing | | | 3.4.4 Short direct addressing | | | 3.4.5 SFR addressing | | | 3.4.6 Register indirect addressing | | | 3.4.7 Based addressing | | | 3.4.8 Based indexed addressing | | | 3.4.9 Stack addressing | | | CHAPTER 4 PORT FUNCTIONS | | | 4.2 Port Configuration | | | 4.2.1 20, 24-pin products | 86 | | 4.2.1.1 Port 0 | | | 4.2.1.2 Port 1 | 86 | | 4.2.1.3 Port 2 | | | 4.2.1.4 Port 4 | | | 4.2.1.5 Port 6 | | | 4.2.1.7 Port 13 | | | 4.2.2 30-pin products | 87 | | 4.2.2.1 Port 0 | | | 4.2.2.2 Port 1 | 88 | | 4.2.2.3 Port 2 | | | 4.2.2.4 Port 3 | | | 4.2.2.5 Port 5 | | | 4.2.2.6 Port 5 | | | 4.2.2.8 Port 12 | | | 4.2.2.9 Port 13 | | | 4.2.2.10 Port 14 | 89 | | 4.3 Registers Controlling Port Function | 90 | |-----------------------------------------------------------------------------------|-----| | 4.3.1 Port mode registers (PMxx) | 92 | | 4.3.2 Port registers (Pxx) | 93 | | 4.3.3 Pull-up resistor option registers (PUxx) | 95 | | 4.3.4 Port input mode register (PIMx) | 96 | | 4.3.5 Port output mode registers (POMx) | 97 | | 4.3.6 Port mode control registers (PMCxx) | 98 | | 4.3.7 A/D port configuration register (ADPC) | 99 | | 4.3.8 Peripheral I/O redirection register (PIOR) | 99 | | 4.4 Port Function Operations | 101 | | 4.4.1 Writing to I/O port | 101 | | 4.4.2 Reading from I/O port | 101 | | 4.4.3 Operations on I/O port | 101 | | 4.4.4 Handling different potentials (1.8 V, 2.5 V, and 3 V) by using I/O buffers | 102 | | 4.5 Register Settings When Using Alternate Function | 104 | | 4.5.1 Basic concept when using alternate function | 104 | | 4.5.2 Register settings for alternate function whose output function is not used. | 105 | | 4.5.3 Register setting examples for using the port and alternate functions | 106 | | 4.6 Cautions When Using Port Function | 114 | | 4.6.1 Cautions on 1-Bit Manipulation Instruction for Port Register n (Pn) | 114 | | 4.6.2 Notes on specifying the pin settings | 115 | | | | | CHAPTER 5 CLOCK GENERATOR | 116 | | 5.1 Functions of Clock Generator | 116 | | 5.2 Configuration of Clock Generator | 117 | | 5.3 Registers Controlling Clock Generator | 119 | | 5.3.1 Clock operation mode control register (CMC) | 120 | | 5.3.2 System clock control register (CKC) | 121 | | 5.3.3 Clock operation status control register (CSC) | 122 | | 5.3.4 Oscillation stabilization time counter status register (OSTC) | 123 | | 5.3.5 Oscillation stabilization time select register (OSTS) | 125 | | 5.3.6 Peripheral enable register 0 (PER0) | 127 | | 5.3.7 Operation speed mode control register (OSMC) | 128 | | 5.3.8 High-speed on-chip oscillator frequency selection register (HOCODIV) | 129 | | 5.3.9 High-speed on-chip oscillator trimming register (HIOTRM) | 130 | | 5.4 System Clock Oscillator | 131 | | 5.4.1 X1 oscillator | 131 | | 5.4.2 High-speed on-chip oscillator | 134 | | 5.4.3 Low-speed on-chip oscillator | 134 | | 5.5 Clock Generator Operation | 134 | | 5.6 Controlling Clock | 136 | | 5.6.1 Example of setting high-speed on-chip oscillator | 136 | |-----------------------------------------------------------------------------------|-----| | 5.6.2 Example of setting X1 oscillation clock | 137 | | 5.6.3 CPU clock status transition diagram | 138 | | 5.6.4 Condition before changing CPU clock and processing after changing CPU clock | 141 | | 5.6.5 Time required for switchover of CPU clock and main system clock | 142 | | 5.6.6 Conditions before clock oscillation is stopped | 142 | | 5.7 Resonator and Oscillator Constants | 143 | | CHAPTER 6 TIMER ARRAY UNIT | 145 | | 6.1 Functions of Timer Array Unit | 147 | | 6.1.1 Independent channel operation function | 147 | | 6.1.2 Simultaneous channel operation function | 148 | | 6.1.3 8-bit timer operation function (channels 1 and 3 only) | 149 | | 6.2 Configuration of Timer Array Unit | 150 | | 6.2.1 Timer/counter register 0n (TCR0n) | 156 | | 6.2.2 Timer data register 0n (TDR0n) | 158 | | 6.3 Registers Controlling Timer Array Unit | 159 | | 6.3.1 Peripheral enable register 0 (PER0) | 160 | | 6.3.2 Timer clock select register 0 (TPS0) | | | 6.3.3 Timer mode register 0n (TMR0n) | 163 | | 6.3.4 Timer status register 0n (TSR0n) | 168 | | 6.3.5 Timer channel enable status register 0 (TE0) | 169 | | 6.3.6 Timer channel start register 0 (TS0) | | | 6.3.7 Timer channel stop register 0 (TT0) | | | 6.3.8 Timer input select register 0 (TIS0) | 172 | | 6.3.9 Timer output enable register 0 (TOE0) | 173 | | 6.3.10 Timer output register 0 (TO0) | 174 | | 6.3.11 Timer output level register 0 (TOL0) | 175 | | 6.3.12 Timer output mode register 0 (TOM0) | 176 | | 6.3.13 Noise filter enable register 1 (NFEN1) | | | 6.3.14 Registers controlling port functions of pins to be used for timer I/O | 178 | | 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 (Only Channels 1 and 3) | | | 6.5 Operation of Counter | 182 | | 6.5.1 Count clock (fTCLK) | 182 | | 6.5.2 Start timing of counter | 184 | | 6.5.3 Counter Operation | | | 6.6 Channel Output (TO0n pin) Control | 190 | | 6.6.1 TO0n pin output circuit configuration | 190 | | 6.6.2. TOOn Pin Output Setting | 191 | | 6.6.3 Cautions on Channel Output Operation | 192 | |--------------------------------------------------------------------------------------------|-----| | 6.6.4 Collective manipulation of TO0n bit | 196 | | 6.6.5 Timer Interrupt and TO0n Pin Output at Operation Start | 197 | | 6.7 Timer Input (TI0n) Control | 198 | | 6.7.1 TI0n input circuit configuration | 198 | | 6.7.2 Noise filter | 198 | | 6.7.3 Cautions on channel input operation | 199 | | 6.8 Independent Channel Operation Function of Timer Array Unit | 200 | | 6.8.1 Operation as interval timer/square wave output | 200 | | 6.8.2 Operation as external event counter | 205 | | 6.8.3 Operation as frequency divider (channel 0 of 30-pin products only) | 210 | | 6.8.4 Operation as input pulse interval measurement | 214 | | 6.8.5 Operation as input signal high-/low-level width measurement | 219 | | 6.8.6 Operation as delay counter | 223 | | 6.9 Simultaneous Channel Operation Function of Timer Array Unit | 228 | | 6.9.1 Operation as one-shot pulse output function | 228 | | 6.9.2 Operation as PWM function | 235 | | 6.9.3 Operation as multiple PWM output function | 242 | | 6.10 Cautions When Using Timer Array Unit | 249 | | 6.10.1 Cautions When Using Timer output | 249 | | CHAPTER 7 12-BIT INTERVAL TIMER | 250 | | 7.1 Functions of 12-bit Interval Timer | 250 | | 7.2 Configuration of 12-bit Interval Timer | 250 | | 7.3 Registers Controlling 12-bit Interval Timer | 250 | | 7.3.1 Peripheral enable register 0 (PER0) | 251 | | 7.3.2 Operation speed mode control register (OSMC) | 251 | | 7.3.3 Interval timer control register (ITMC) | 252 | | 7.4 12-bit Interval Timer Operation | 253 | | 7.4.1 12-bit interval timer operation timing | 253 | | 7.4.2 Start of count operation and re-enter to HALT/STOP mode after returned from HALT/ST | OP | | mode | 254 | | CHAPTER 8 CLOCK OUTPUT/BUZZER OUTPUT CONTROLLER | 255 | | 8.1 Functions of Clock Output/Buzzer Output Controller | 255 | | 8.2 Configuration of Clock Output/Buzzer Output Controller | | | 8.3 Registers Controlling Clock Output/Buzzer Output Controller | 256 | | 8.3.1 Clock output select register n (CKSn) | 257 | | 0.0.0 Designators controlling part functions of pine to be used for clock or buzzer output | | | 8.3.2 Registers controlling port functions of pins to be used for clock or buzzer output | 258 | | 8.4 Operations of Clock Output/Buzzer Output Controller | | | 8.5 Cautions of Clock Output/Buzzer Output Controller | 259 | |--------------------------------------------------------------------------------|-----| | CHAPTER 9 WATCHDOG TIMER | 260 | | 9.1 Functions of Watchdog Timer | 260 | | 9.2 Configuration of Watchdog Timer | 261 | | 9.3 Register Controlling Watchdog Timer | 262 | | 9.3.1 Watchdog timer enable register (WDTE) | 262 | | 9.4 Operation of Watchdog Timer | 263 | | 9.4.1 Controlling operation of watchdog timer | 263 | | 9.4.2 Setting overflow time of watchdog timer | 264 | | 9.4.3 Setting window open period of watchdog timer | 265 | | 9.4.4 Setting watchdog timer interval interrupt | 266 | | CHAPTER 10 A/D CONVERTER | 267 | | 10.1 Function of A/D Converter | | | 10.2 Configuration of A/D Converter | | | 10.3 Registers Controlling A/D Converter | | | 10.3.1 Peripheral enable register 0 (PER0) | | | 10.3.2 A/D converter mode register 0 (ADM0) | 273 | | 10.3.3 A/D converter mode register 1 (ADM1) | 282 | | 10.3.4 A/D converter mode register 2 (ADM2) | | | 10.3.5 10-bit A/D conversion result register (ADCR) | | | 10.3.6 8-bit A/D conversion result register (ADCRH) | | | 10.3.7 Analog input channel specification register (ADS) | | | 10.3.8 Conversion result comparison upper limit setting register (ADUL) | | | 10.3.9 Conversion result comparison lower limit setting register (ADLL) | 289 | | 10.3.10 A/D test register (ADTES) | | | 10.3.11 Registers controlling port function of analog input pins | | | 10.4 A/D Converter Conversion Operations | 291 | | 10.5 Input Voltage and Conversion Results | | | 10.6 A/D Converter Operation Modes | 294 | | 10.6.1 Software trigger mode (select mode, sequential conversion mode) | 294 | | 10.6.2 Software trigger mode (select mode, one-shot conversion mode) | 295 | | 10.6.3 Software trigger mode (scan mode, sequential conversion mode) | 296 | | 10.6.4 Software trigger mode (scan mode, one-shot conversion mode) | 297 | | 10.6.5 Hardware trigger no-wait mode (select mode, sequential conversion mode) | 298 | | 10.6.6 Hardware trigger no-wait mode (select mode, one-shot conversion mode) | 299 | | 10.6.7 Hardware trigger no-wait mode (scan mode, sequential conversion mode) | 300 | | 10.6.8 Hardware trigger no-wait mode (scan mode, one-shot conversion mode) | 301 | | 10.6.9 Hardware trigger wait mode (select mode, sequential conversion mode) | 302 | | 10.6.10 Hardware trigger wait mode (select mode, one-shot conversion mode) | 303 | | 10.6.11 Hardware trigger wait mode (scan mode, sequential conversion mode) | 304 | |--------------------------------------------------------------------------------------------|-----| | 10.6.12 Hardware trigger wait mode (scan mode, one-shot conversion mode) | 305 | | 10.7 A/D Converter Setup Flowchart | 306 | | 10.7.1 Setting up software trigger mode | 306 | | 10.7.2 Setting up hardware trigger no-wait mode | 307 | | 10.7.3 Setting up hardware trigger wait mode | 308 | | 10.7.4 Setup when temperature sensor output voltage/internal reference voltage is selected | | | (example for software trigger mode and one-shot conversion mode) | 309 | | 10.7.5 Setting up test mode | 310 | | 10.8 SNOOZE mode function | 311 | | 10.9 How to Read A/D Converter Characteristics Table | 315 | | 10.10 Cautions for A/D Converter | 317 | | CHAPTER 11 SERIAL ARRAY UNIT | 321 | | 11.1 Functions of Serial Array Unit | 322 | | 11.1.1 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) | 322 | | 11.1.2 UART (UART0 to UART2) | 323 | | 11.1.3 Simplified I <sup>2</sup> C (IIC00, IIC01, IIC11, IIC20) | 324 | | 11.2 Configuration of Serial Array Unit | 325 | | 11.2.1 Shift register | 329 | | 11.2.2 Lower 8/9 bits of the serial data register mn (SDRmn) | 329 | | 11.3 Registers Controlling Serial Array Unit | 331 | | 11.3.1 Peripheral enable register 0 (PER0) | 331 | | 11.3.2 Serial clock select register m (SPSm) | 333 | | 11.3.3 Serial mode register mn (SMRmn) | 334 | | 11.3.4 Serial communication operation setting register mn (SCRmn) | 335 | | 11.3.5 Serial data register mn (SDRmn) | 338 | | 11.3.6 Serial flag clear trigger register mn (SIRmn) | 340 | | 11.3.7 Serial status register mn (SSRmn) | 341 | | 11.3.8 Serial channel start register m (SSm) | 343 | | 11.3.9 Serial channel stop register m (STm) | 344 | | 11.3.10 Serial channel enable status register m (SEm) | 345 | | 11.3.11 Serial output enable register m (SOEm) | 346 | | 11.3.12 Serial output register m (SOm) | 347 | | 11.3.13 Serial output level register m (SOLm) | 348 | | 11.3.14 Serial standby control register 0 (SSC0) | 350 | | 11.3.15 Noise filter enable register 0 (NFEN0) | 351 | | 11.3.16 Registers controlling port functions of serial input/output pins | 352 | | 11.4 Operation Stop Mode | 353 | | 11.4.1 Stopping the operation by units | 353 | | 11.4.2 Stopping the operation by channels | 354 | | 11.5 Operation of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) Communication | 355 | |------------------------------------------------------------------------------------------|-----| | 11.5.1 Master transmission | 356 | | 11.5.2 Master reception | 365 | | 11.5.3 Master transmission/reception | 373 | | 11.5.4 Slave transmission | 382 | | 11.5.5 Slave reception | 391 | | 11.5.6 Slave transmission/reception | 397 | | 11.5.7 SNOOZE mode function | 406 | | 11.5.8 Calculating transfer clock frequency | 410 | | 11.5.9 Procedure for processing errors that occurred during 3-wire serial I/O | | | (CSI00, CSI01, CSI11, CSI20) communication | 412 | | 11.6 Operation of UART (UART0 to UART2) Communication | 413 | | 11.6.1 UART transmission | 414 | | 11.6.2 UART reception | 424 | | 11.6.3 SNOOZE mode function | 431 | | 11.6.4 Calculating baud rate | 439 | | 11.6.5 Procedure for processing errors that occurred during UART (UART0 to UART2) | | | communication | 443 | | 11.7 Operation of Simplified I <sup>2</sup> C (IIC00, IIC01, IIC11, IIC20) Communication | 444 | | 11.7.1 Address field transmission | 446 | | 11.7.2 Data transmission | 450 | | 11.7.3 Data reception | 453 | | 11.7.4 Stop condition generation | 457 | | 11.7.5 Calculating transfer rate | 458 | | 11.7.6 Procedure for processing errors that occurred during simplified I <sup>2</sup> C | | | (IIC00, IIC01, IIC11, IIC20) communication | 460 | | CHAPTER 12 SERIAL INTERFACE IICA | 462 | | 12.1 Functions of Serial Interface IICA | | | 12.2 Configuration of Serial Interface IICA | | | 12.3 Registers Controlling Serial Interface IICA | | | 12.3.1 Peripheral enable register 0 (PER0) | | | 12.3.2 IICA control register 00 (IICCTL00) | | | 12.3.3 IICA status register 0 (IICS0) | | | 12.3.4 IICA flag register 0 (IICF0) | | | 12.3.5 IICA control register 01 (IICCTL01) | | | 12.3.6 IICA low-level width setting register 0 (IICWL0) | | | 12.3.7 IICA high-level width setting register 0 (IICWH0) | | | 12.3.8 Port mode register 6 (PM6) | | | 12.4 I <sup>2</sup> C Bus Mode Functions | | | 12.4.1 Pin configuration | 481 | | | 12.4.2 Setting transfer clock by using IICWL0 and IICWH0 registers | 40∠ | |------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------| | 12.5 | I <sup>2</sup> C Bus Definitions and Control Methods | 483 | | | 12.5.1 Start conditions | 483 | | | 12.5.2 Addresses | 484 | | | 12.5.3 Transfer direction specification | 484 | | | 12.5.4 Acknowledge (ACK) | 485 | | | 12.5.5 Stop condition | 486 | | | 12.5.6 Wait | 487 | | | 12.5.7 Canceling wait | 489 | | | 12.5.8 Interrupt request (INTIICA0) generation timing and wait control | 490 | | | 12.5.9 Address match detection method | 491 | | | 12.5.10 Error detection | 491 | | | 12.5.11 Extension code | 491 | | | 12.5.12 Arbitration | 492 | | | 12.5.13 Wakeup function | 494 | | | 12.5.14 Communication reservation | 497 | | | 12.5.15 Cautions | 501 | | | 12.5.16 Communication operations | 502 | | | 12.5.17 Timing of I <sup>2</sup> C interrupt request (INTIICA0) occurrence | 510 | | | Timing Charts | | | | | | | CHAPIE | ER 13 MULTIPLIER AND DIVIDER/MULTIPLY-ACCUMULATOR | 546 | | | Functions of Multiplier and Divider/Multiply-Accumulator | | | 13.1 | | 546 | | 13.1 | Functions of Multiplier and Divider/Multiply-Accumulator | 546 | | 13.1 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator | <b>546</b><br><b>546</b><br>548 | | 13.1 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator | | | 13.1<br>13.2 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator | | | 13.1<br>13.2 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator | | | 13.1<br>13.2<br>13.3 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator | | | 13.1<br>13.2<br>13.3 | Functions of Multiplier and Divider/Multiply-Accumulator | | | 13.1<br>13.2<br>13.3 | Functions of Multiplier and Divider/Multiply-Accumulator | | | 13.1<br>13.2<br>13.3 | Functions of Multiplier and Divider/Multiply-Accumulator | | | 13.1<br>13.2<br>13.3 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator 13.2.1 Multiplication/division data register A (MDAH, MDAL). 13.2.2 Multiplication/division data register B (MDBL, MDBH). 13.2.3 Multiplication/division data register C (MDCL, MDCH). Register Controlling Multiplier and Divider/Multiply-Accumulator. 13.3.1 Multiplication/division control register (MDUC). Operations of Multiplier and Divider/Multiply-Accumulator. 13.4.1 Multiplication (unsigned) operation. 13.4.2 Multiplication (signed) operation. | | | 13.1<br>13.2<br>13.3 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator 13.2.1 Multiplication/division data register A (MDAH, MDAL). 13.2.2 Multiplication/division data register B (MDBL, MDBH). 13.2.3 Multiplication/division data register C (MDCL, MDCH) Register Controlling Multiplier and Divider/Multiply-Accumulator 13.3.1 Multiplication/division control register (MDUC) Operations of Multiplier and Divider/Multiply-Accumulator 13.4.1 Multiplication (unsigned) operation. 13.4.2 Multiplication (signed) operation. 13.4.3 Multiply-accumulation (unsigned) operation. | | | 13.1<br>13.2<br>13.3<br>13.4 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator 13.2.1 Multiplication/division data register A (MDAH, MDAL) 13.2.2 Multiplication/division data register B (MDBL, MDBH) 13.2.3 Multiplication/division data register C (MDCL, MDCH) Register Controlling Multiplier and Divider/Multiply-Accumulator 13.3.1 Multiplication/division control register (MDUC) Operations of Multiplier and Divider/Multiply-Accumulator 13.4.1 Multiplication (unsigned) operation 13.4.2 Multiplication (signed) operation 13.4.3 Multiply-accumulation (unsigned) operation 13.4.4 Multiply-accumulation (signed) operation | | | 13.1<br>13.2<br>13.3<br>13.4<br>CHAPTE | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator 13.2.1 Multiplication/division data register A (MDAH, MDAL) 13.2.2 Multiplication/division data register B (MDBL, MDBH) 13.2.3 Multiplication/division data register C (MDCL, MDCH) Register Controlling Multiplier and Divider/Multiply-Accumulator 13.3.1 Multiplication/division control register (MDUC) Operations of Multiplier and Divider/Multiply-Accumulator 13.4.1 Multiplication (unsigned) operation 13.4.2 Multiplication (signed) operation 13.4.3 Multiply-accumulation (unsigned) operation 13.4.4 Multiply-accumulation (signed) operation 13.4.5 Division operation | | | 13.1<br>13.2<br>13.3<br>13.4<br>CHAPTE<br>14.1 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator 13.2.1 Multiplication/division data register A (MDAH, MDAL) 13.2.2 Multiplication/division data register B (MDBL, MDBH) 13.2.3 Multiplication/division data register C (MDCL, MDCH) Register Controlling Multiplier and Divider/Multiply-Accumulator 13.3.1 Multiplication/division control register (MDUC) Operations of Multiplier and Divider/Multiply-Accumulator 13.4.1 Multiplication (unsigned) operation 13.4.2 Multiplication (signed) operation 13.4.3 Multiply-accumulation (unsigned) operation 13.4.4 Multiply-accumulation (signed) operation 13.4.5 Division operation | | | 13.1<br>13.2<br>13.3<br>13.4<br>CHAPTE<br>14.1 | Functions of Multiplier and Divider/Multiply-Accumulator Configuration of Multiplier and Divider/Multiply-Accumulator 13.2.1 Multiplication/division data register A (MDAH, MDAL) 13.2.2 Multiplication/division data register B (MDBL, MDBH) 13.2.3 Multiplication/division data register C (MDCL, MDCH) Register Controlling Multiplier and Divider/Multiply-Accumulator 13.3.1 Multiplication/division control register (MDUC) Operations of Multiplier and Divider/Multiply-Accumulator 13.4.1 Multiplication (unsigned) operation 13.4.2 Multiplication (signed) operation 13.4.3 Multiply-accumulation (unsigned) operation 13.4.4 Multiply-accumulation (signed) operation 13.4.5 Division operation ER 14 DMA CONTROLLER Functions of DMA Controller | | | | 14.2.3 DMA byte count register n (DBCn) | 565 | |--------|------------------------------------------------------------------------------------------|-----| | 14.3 | Registers Controlling DMA Controller | 566 | | | 14.3.1 DMA mode control register n (DMCn) | 566 | | | 14.3.2 DMA operation control register n (DRCn) | 568 | | 14.4 | Operation of DMA Controller | 569 | | | 14.4.1 Operation procedure | 569 | | | 14.4.2 Transfer mode | 570 | | | 14.4.3 Termination of DMA transfer | 570 | | 14.5 | Example of Setting of DMA Controller | 570 | | | 14.5.1 CSI consecutive transmission | 570 | | | 14.5.2 Consecutive capturing of A/D conversion results | 572 | | | 14.5.3 UART consecutive reception + ACK transmission | 573 | | | 14.5.4 Holding DMA transfer pending by DWAITn bit | 574 | | | 14.5.5 Forced termination by software | 575 | | 14.6 | Cautions on Using DMA Controller | 577 | | CHAPTE | ER 15 INTERRUPT FUNCTIONS | 580 | | | Interrupt Function Types | | | | Interrupt Sources and Configuration | | | 15.3 | Registers Controlling Interrupt Functions | | | | 15.3.1 Interrupt request flag registers (IF0L, IF0H, IF1L, IF1H, IF2L, IF2H) | 591 | | | 15.3.2 Interrupt mask flag registers (MK0L, MK0H, MK1L, MK1H, MK2L, MK2H) | 593 | | | 15.3.3 Priority specification flag registers (PR00L, PR00H, PR01L, PR01H, PR02L, | | | | PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) | 595 | | | 15.3.4 External interrupt rising edge enable register (EGP0), external interrupt falling | | | | edge enable register (EGN0) | | | | 15.3.5 Program status word (PSW) | | | 15.4 | Interrupt Servicing Operations | | | | 15.4.1 Maskable interrupt request acknowledgment | | | | 15.4.2 Software interrupt request acknowledgment | | | | 15.4.3 Multiple interrupt servicing | | | | 15.4.4 Interrupt request hold | 607 | | CHAPTE | ER 16 KEY INTERRUPT FUNCTION | 608 | | | Functions of Key Interrupt | | | | Configuration of Key Interrupt | | | 16.3 | Register Controlling Key Interrupt | | | | 16.3.1 Key return control register (KRCTL) | | | | 16.3.2 Key return mode control registers (KRM0, KRM1) | | | | 16.3.3 Key return flag register (KRF) | | | | 16.2.4 Port mode registers 0.4.6 (PMO PM4 PM6) | 613 | | 16.4 Key Interrupt Operation | 614 | |---------------------------------------------------------|-----| | 16.4.1 When not using the key interrupt flag (KRMD = 0) | 614 | | 16.4.2 When using the key interrupt flag (KRMD = 1) | 615 | | CHAPTER 17 STANDBY FUNCTION | 618 | | 17.1 Standby Function | 618 | | 17.2 Registers controlling standby function | 619 | | 17.3 Standby Function Operation | 619 | | 17.3.1 HALT mode | 619 | | 17.3.2 STOP mode | 623 | | 17.3.3 SNOOZE mode | 628 | | CHAPTER 18 RESET FUNCTION | 631 | | 18.1 Timing of Reset Operation | | | 18.2 States of Operation During Reset Periods | 635 | | 18.3 Register for Confirming Reset Source | 637 | | 18.3.1 Reset Control Flag Register (RESF) | 637 | | CHAPTER 19 POWER-ON-RESET CIRCUIT | 640 | | 19.1 Functions of Power-on-reset Circuit | 640 | | 19.2 Configuration of Power-on-reset Circuit | 641 | | 19.3 Operation of Power-on-reset Circuit | 641 | | CHAPTER 20 VOLTAGE DETECTOR | 645 | | 20.1 Functions of Voltage Detector | 645 | | 20.2 Configuration of Voltage Detector | 646 | | 20.3 Registers Controlling Voltage Detector | 646 | | 20.3.1 Voltage detection register (LVIM) | 647 | | 20.3.2 Voltage detection level register (LVIS) | 648 | | 20.4 Operation of Voltage Detector | 651 | | 20.4.1 When used as reset mode | 651 | | 20.4.2 When used as interrupt mode | 653 | | 20.4.3 When used as interrupt and reset mode | 655 | | 20.5 Cautions for Voltage Detector | 661 | | CHAPTER 21 SAFETY FUNCTIONS | 663 | | 21.1 Overview of Safety Functions | 663 | | 21.2 Registers Used by Safety Functions | 664 | | | | | 21.3 Operation of Safety Functions | | | 21.3.1.1 CRC input register (CRCIN) | 665 | |------------------------------------------------------------------------|-------| | 21.3.1.2 CRC data register (CRCD) | 665 | | 21.3.2 RAM parity error detection function | | | 21.3.2.1 RAM parity error control register (RPECTL) | | | 21.3.3 RAM guard function | | | 21.3.3.1 Invalid memory access detection control register (IAWCTL) | | | 21.3.4 SFR guard function | | | 21.3.4.1 Invalid memory access detection control register (IAWCTL) | | | 21.3.5 Invalid memory access detection function | | | 21.3.6 Frequency detection function | | | 21.3.6.1 Timer input select register 0 (TIS0) | | | 21.3.7 A/D test function | | | 21.3.7.1 A/D test register (ADTES) | | | 21.3.7.2 Analog input channel specification register (ADS) | 676 | | CHAPTER 22 REGULATOR | 678 | | 22.1 Overview of Regulators | | | 22.1 Overview of negulators | , 070 | | CHAPTER 23 OPTION BYTE | 679 | | 23.1 Functions of Option Bytes | 679 | | 23.1.1 User option byte (000C0H to 000C2H) | 679 | | 23.1.2 On-chip debug option byte (000C3H) | 680 | | 23.2 Format of User Option Byte | 681 | | 23.3 Format of On-chip Debug Option Byte | 685 | | 23.4 Setting of Option Byte | 686 | | CHAPTER 24 FLASH MEMORY | 687 | | 24.1 Serial Programming Using Flash Memory Programmer | 689 | | 24.1.1 Programming environment | 690 | | 24.1.2 Communication mode | 690 | | 24.2 Serial Programming Using External Device (that Incorporates UART) | 691 | | 24.2.1 Programming environment | 691 | | 24.2.2 Communication mode | 692 | | 24.3 Connection of Pins on Board | 693 | | 24.3.1 P40/TOOL0 pin | 693 | | 24.3.2 RESET pin | 693 | | 24.3.3 Port pins | 694 | | 24.3.4 REGC pins | 694 | | 24.3.5 X1 and X2 pins | 694 | | 24.3.6 Power supply | 694 | | 24.4 Serial Programming Method | 695 | | 24.4.1 Serial programming procedure | 695 | |-------------------------------------------------------------------|------------------| | 24.4.2 Flash memory programming mode | 695 | | 24.4.3 Selecting communication mode | 697 | | 24.4.4 Communication commands | 697 | | 24.5 Processing Time for Each Command When PG-FP5 Is in Use (Refe | erence Value)699 | | 24.6 Self-Programming | 700 | | 24.6.1 Self-programming procedure | 701 | | 24.6.2 Flash shield window function | 702 | | 24.7 Security Settings | 703 | | 24.8 Data Flash | 705 | | 24.8.1 Data flash overview | 705 | | 24.8.2 Register controlling data flash memory | | | 24.8.2.1 Data flash control register (DFLCTL) | | | 24.8.3 Procedure for accessing data flash memory | | | CHAPTER 25 ON-CHIP DEBUG FUNCTION | 707 | | 25.1 Connecting E1 On-chip Debugging Emulator | 707 | | 25.2 On-Chip Debug Security ID | 709 | | 25.3 Securing of User Resources | 709 | | | | | CHAPTER 26 BCD CORRECTION CIRCUIT | 711 | | 26.1 BCD Correction Circuit Function | 711 | | 26.2 Registers Used by BCD Correction Circuit | 711 | | 26.2.1 BCD correction result register (BCDADJ) | 711 | | 26.3 BCD Correction Circuit Operation | 712 | | CHAPTER 27 INSTRUCTION SET | 714 | | 27.1 Conventions Used in Operation List | 715 | | 27.1.1 Operand identifiers and specification methods | 715 | | 27.1.2 Description of operation column | 716 | | 27.1.3 Description of flag operation column | 717 | | 27.1.4 PREFIX instruction | 717 | | 27.2 Operation List | 718 | | CHAPTER 28 ELECTRICAL SPECIFICATIONS (TA = -40 to +85°C) | 735 | | 28.1 Absolute Maximum Ratings | 736 | | 28.2 Oscillator Characteristics | 737 | | 28.2.1 X1 oscillator characteristics | 737 | | 28.2.2 On-chip oscillator characteristics | 737 | | 29.2 DC Characteristics | 720 | | | 28.3.1 Pin characteristics | 738 | |---------|----------------------------------------------------------------------|-----| | | 28.3.2 Supply current characteristics | 742 | | 28.4 | AC Characteristics | 747 | | 28.5 | Peripheral Functions Characteristics | 750 | | | 28.5.1 Serial array unit | 750 | | | 28.5.2 Serial interface IICA | 771 | | 28.6 | Analog Characteristics | 772 | | | 28.6.1 A/D converter characteristics | 772 | | | 28.6.2 Temperature sensor/internal reference voltage characteristics | 776 | | | 28.6.3 POR circuit characteristics | 776 | | | 28.6.4 LVD circuit characteristics | 777 | | | 28.6.5 Power supply voltage rising slope characteristics | 778 | | | RAM Data Retention Characteristics | | | | Flash Memory Programming Characteristics | | | | Dedicated Flash Memory Programmer Communication (UART) | | | 28.1 | 0 Timing of Entry to Flash Memory Programming Modes | 780 | | OLIADTI | | | | CHAPII | ER 29 ELECTRICAL SPECIFICATIONS | 704 | | | (G: INDUSTRIAL APPLICATIONS T <sub>A</sub> = -40 to +105°C) | 781 | | 29.1 | Absolute Maximum Ratings | 782 | | 29.2 | Oscillator Characteristics | 783 | | | 29.2.1 X1 oscillator characteristics | 783 | | | 29.2.2 On-chip oscillator characteristics | 783 | | 29.3 | DC Characteristics | | | | 29.3.1 Pin characteristics | | | | 29.3.2 Supply current characteristics | | | | AC Characteristics | | | 29.5 | Peripheral Functions Characteristics | | | | 29.5.1 Serial array unit | | | | 29.5.2 Serial interface IICA | | | 29.6 | Analog Characteristics | | | | 29.6.1 A/D converter characteristics | | | | 29.6.2 Temperature sensor/internal reference voltage characteristics | | | | 29.6.3 POR circuit characteristics | | | | 29.6.4 LVD circuit characteristics | | | | 29.6.5 Power supply voltage rising slope characteristics | | | | RAM Data Retention Characteristics | | | | Flash Memory Programming Characteristics | | | | Dedicated Flash Memory Programmer Communication (UART) | | | 29.1 | 0 Timing of Entry to Flash Memory Programming Modes | 822 | | CHAPTER 30 PACKAGE DRAWINGS | 823 | |--------------------------------------------|-----| | 30.1 20-pin products | 823 | | 30.2 24-pin products | 824 | | 30.3 30-pin products | 825 | | APPENDIX A REVISION HISTORY | 824 | | A.1 Major Revisions in This Edition | 824 | | A.2 Revision History of Preceding Editions | 833 | RL78/G12 RENESAS MCU R01UH0200EJ0210 Rev.2.10 Mar 25, 2016 ## **CHAPTER 1 OUTLINE** ## 1.1 Differences between the R5F102 Products and the R5F103 Products The following are differences between the R5F102 products and the R5F103 products. - O Whether the data flash memory is mounted or not - O High-speed on-chip oscillator oscillation frequency accuracy - O Number of channels in serial interface - O Whether the DMA function is mounted or not - O Whether a part of the safety functions are mounted or not ## 1.1.1 Data Flash The data flash memory of 2 KB is mounted on the R5F102 products, but not on the R5F103 products. | Product | Data Flash | |-------------------------------|-------------| | R5F102 products | 2KB | | R5F1026A, R5F1027A, R5F102AA, | | | R5F10269, R5F10279, R5F102A9, | | | R5F10268, R5F10278, R5F102A8, | | | R5F10267, R5F10277, R5F102A7, | | | R5F10266 Note | | | R5F103 products | Not mounted | | R5F1036A, R5F1037A, R5F103AA, | | | R5F10369, R5F10379, R5F103A9, | | | R5F10368, R5F10378 R5F103A8, | | | R5F10367, R5F10377, R5F103A7, | | | R5F10366 | | **Note** The RAM in the R5F10266 has capacity as small as 256 bytes. Depending on the customer's program specification, the stack area to execute the data flash library may not be kept and data may not be written to or erased from the data flash memory. **Caution** When the flash memory is rewritten via a user program, the code flash area and RAM area are used because each library is used. When using the library, refer to RL78 Family Flash Self Programming Library Type01 User's Manual and RL78 Family Data Flash Library Type04 User's Manual. ## 1.1.2 On-chip oscillator characteristics (1) High-speed on-chip oscillator oscillation frequency of the R5F102 products | Oscillator | Condition | MIN | MAX | Unit | |------------------------|---------------------------------|------|------|------| | High-speed on-chip | T <sub>A</sub> = -20 to +85 °C | -1.0 | +1.0 | % | | oscillator oscillation | T <sub>A</sub> = -40 to -20 °C | -1.5 | +1.5 | | | frequency accuracy | T <sub>A</sub> = +85 to +105 °C | -2.0 | +2.0 | | (2) High-speed on-chip oscillator oscillation frequency of the R5F103 products | Oscillator | Condition | MIN | MAX | Unit | |------------------------|----------------------------------------------|------|------|------| | High-speed on-chip | $T_A = -40 \text{ to} + 85 ^{\circ}\text{C}$ | -5.0 | +5.0 | % | | oscillator oscillation | | | | | | frequency accuracy | | | | | ## 1.1.3 Peripheral Functions The following are differences in peripheral functions between the R5F102 products and the R5F103 products. | | | R5F102 product | | R5F103 product | | |---------------------------------|------------|----------------|------------|----------------|---------| | RL78/G12 | 20, 24 pin | 30 pin product | 20, 24 pin | 30 pin | | | | | product | | product | product | | Serial interface | UART | 1 channel | 3 channels | 1 channel | | | CSI Simplified I <sup>2</sup> C | | 2 channels | 3 channels | 1 channel | | | | | 2 channels | 3 channels | None | | | DMA function | | 2 channels | | None | | | Safety function CRC operation | | Yes | | None | | | RAM guard<br>SFR guard | | Yes | | None | | | | | Yes | | None | | #### 1.2 Features Ultra-low power consumption technology - V<sub>DD</sub> = single power supply voltage of 1.8 to 5.5 V which can operate at a low voltage - HALT mode - STOP mode - SNOOZE mode #### RL78 CPU core - CISC architecture with 3-stage pipeline - Minimum instruction execution time: Can be changed from high speed (0.04167 $\mu$ s: @ 24 MHz operation with high-speed on-chip oscillator) to ultra-low speed (1 $\mu$ s: @ 1 MHz operation) - Address space: 1 MB - General-purpose registers: (8-bit register × 8) × 4 banks - On-chip RAM: 256 B to 2 KB ## Code flash memory - Code flash memory: 2 to 16 KB - Block size: 1 KB - Prohibition of block erase and rewriting (security function) - On-chip debug function - Self-programming (with flash shield window function) ## Data flash memory Note - Data flash memory: 2 KB - Back ground operation (BGO): Instructions are executed from the program memory while rewriting the data flash memory. - Number of rewrites: 1,000,000 times (TYP.) - Voltage of rewrites: VDD = 1.8 to 5.5 V ## High-speed on-chip oscillator - Select from 24 MHz, 16 MHz, 12 MHz, 8 MHz, 6 MHz, 4 MHz, 3 MHz, 2 MHz, and 1 MHz - High accuracy: $\pm 1.0 \%$ (VDD = 1.8 to 5.5 V, TA = -20 to +85°C) ## Operating ambient temperature - T<sub>A</sub> = -40 to +85°C (A: Consumer applications, D: Industrial applications) - T<sub>A</sub> = -40 to +105°C (G: Industrial applications) Note ## Power management and reset function - On-chip power-on-reset (POR) circuit - On-chip voltage detector (LVD) (Select interrupt and reset from 12 levels) ## DMA (Direct Memory Access) controller Note - 2 channels - Number of clocks during transfer between 8/16-bit SFR and internal RAM: 2 clocks Note Provided in the R5F102 products only. ## Multiplier and divider/multiply-accumulator - 16 bits × 16 bits = 32 bits (Unsigned or signed) - 32 bits × 32 bits = 32 bits (Unsigned) - 16 bits × 16 bits + 32 bits = 32 bits (Unsigned or signed) #### Serial interface CSI : 1 to 3 channels UART : 1 to 3 channels • Simplified I<sup>2</sup>C communication : 0 to 3 channels I<sup>2</sup>C communication : 1 channel #### Timer • 16-bit timer : 4 to 8 channels • 12-bit interval timer : 1 channel Watchdog timer : 1 channel (operable with the dedicated low-speed on-chip oscillator) #### A/D converter - 8/10-bit resolution A/D converter (V<sub>DD</sub> = 1.8 to 5.5 V) - 8 to 11 channels, internal reference voltage (1.45 V), and temperature sensor Note #### I/O port - I/O port: 18 to 26 (N-ch open drain I/O [withstand voltage of 6 V]: 2, - N-ch open drain I/O [VDD withstand voltage]: 4 to 9) - Can be set to N-ch open drain, TTL input buffer, and on-chip pull-up resistor - Different potential interface: Can connect to a 1.8/2.5/3 V device - On-chip key interrupt function - On-chip clock output/buzzer output controller ## Others • On-chip BCD (binary-coded decimal) correction circuit Note Can be selected only in HS (high-speed main) mode. Remark The functions mounted depend on the product. See 1.7 Outline of Functions. O ROM, RAM capacities | Code flash | Data flash | RAM | 20 pins | 24 pins | 30 pins | |------------|------------|--------|-----------------|-----------------|----------| | 16 KB | 2 KB | 2 KB | _ | _ | R5F102AA | | | _ | | _ | _ | R5F103AA | | | 2 KB | 1.5 KB | R5F1026A Note 1 | R5F1027A Note 1 | _ | | | _ | | R5F1036A Note 1 | R5F1037A Note 1 | _ | | 12 KB | 2KB | 1 KB | R5F10269 Note 1 | R5F10279 Note 1 | R5F102A9 | | | _ | | R5F10369 Note 1 | R5F10379 Note 1 | R5F103A9 | | 8 KB | 2 KB | 768 B | R5F10268 Note 1 | R5F10278 Note 1 | R5F102A8 | | | _ | | R5F10368 Note 1 | R5F10378 Note 1 | R5F103A8 | | 4 KB | 2KB | 512 B | R5F10267 | R5F10277 | R5F102A7 | | | _ | | R5F10367 | R5F10377 | R5F103A7 | | 2 KB | 2 KB | 256 B | R5F10266 Note 2 | _ | _ | | | _ | | R5F10366 Note 2 | _ | _ | Notes 1. This is 640 bytes when the self-programming function or data flash function is used. (For details, see CHAPTER 3 CPU ARCHITECTURE.) 2. The self-programming function cannot be used for R5F10266 and R5F10366. **Caution** When the flash memory is rewritten via a user program, the code flash area and RAM area are used because each library is used. When using the library, refer to RL78 Family Flash Self Programming Library Type01 User's Manual and RL78 Family Data Flash Library Type04 User's Manual. ## 1.3 List of Part Numbers Figure 1-1. Part Number, Memory Size, and Package of RL78/G12 - **Notes 1.** For details about the differences between the R5F102 products and the R5F103 products of RL78/G12, see **1.1 Differences between the R5F102 Products and the R5F103 Products**. - 2. Products only for "A: Consumer applications ( $T_A = -40 \text{ to } +85^{\circ}\text{C}$ )" and "D: Industrial applications ( $T_A = -40 \text{ to } +85^{\circ}\text{C}$ )" Table 1-1. List of Ordering Part Numbers Pin Package Data flash Part Number count Application R5F1026AASP#V5, R5F10269ASP#V5, R5F10268ASP#V5, R5F10267ASP#V5, 20 20-pin plastic Mounted < R> pins LSSOP R5F10266ASP#V5 R5F1026AASP#X5, R5F10269ASP#X5, R5F10268ASP#X5, R5F10267ASP#X5, $(4.4 \times 6.5 \text{ mm},$ 0.65 mm pitch) R5F10266ASP#X5 D R5F1026ADSP#V5, R5F10269DSP#V5, R5F10268DSP#V5, R5F10267DSP#V5, R5F10266DSP#V5 R5F1026ADSP#X5, R5F10269DSP#X5, R5F10268DSP#X5, R5F10267DSP#X5, R5F10266DSP#X5 G R5F1026AGSP#V5, R5F10269GSP#V5, R5F10268GSP#V5, R5F10267GSP#V5, R5F10266GSP#V5 R5F1026AGSP#X5, R5F10269GSP#X5, R5F10268GSP#X5, R5F10267GSP#X5, B5F10266GSP#X5 R5F1036AASP#V5, R5F10369ASP#V5, R5F10368ASP#V5, R5F10367ASP#V5, Not mounted R5F10366ASP#V5 R5F1036AASP#X5, R5F10369ASP#X5, R5F10368ASP#X5, R5F10367ASP#X5, R5F10366ASP#X5 D R5F1036ADSP#V5, R5F10369DSP#V5, R5F10368DSP#V5, R5F10367DSP#V5, R5F10366DSP#V5 R5F1036ADSP#X5, R5F10369DSP#X5, R5F10368DSP#X5, R5F10367DSP#X5, R5F10366DSP#X5 24 24-pin plastic Mounted R5F1027AANA#U5, R5F10279ANA#U5, R5F10278ANA#U5, R5F10277ANA#U5 Α <R> **HWQFN** pins R5F1027AANA#W5, R5F10279ANA#W5, R5F10278ANA#W5, $(4 \times 4 \text{ mm}, 0.5)$ R5F10277ANA#W5 mm pitch) D R5F1027ADNA#U5, R5F10279DNA#U5, R5F10278DNA#U5, R5F10277DNA#U5 R5F1027ADNA#W5, R5F10279DNA#W5, R5F10278DNA#W5, R5F10277DNA#W5 G R5F1027AGNA#U5, R5F10279GNA#U5, R5F10278GNA#U5, R5F10277GNA#U5 R5F1027AGNA#W5, R5F10279GNA#W5, R5F10278GNA#W5, R5F10277GNA#W5 Not mounted Α R5F1037AANA#V5, R5F10379ANA#V5, R5F10378ANA#V5, R5F10377ANA#V5 R5F1037AANA#X5, R5F10379ANA#X5, R5F10378ANA#X5, R5F10377ANA#X5 D R5F1037ADNA#V5, R5F10379DNA#V5, R5F10378DNA#V5, R5F10377DNA#V5 R5F1037ADNA#X5, R5F10379DNA#X5, R5F10378DNA#X5, R5F10377DNA#X5 R5F102AAASP#V0, R5F102A9ASP#V0, R5F102A8ASP#V0, R5F102A7ASP#V0 30 30-pin plastic Mounted Α LSSOP R5F102AAASP#X0, R5F102A9ASP#X0, R5F102A8ASP#X0, R5F102A7ASP#X0 pins (7.62 mm D R5F102AADSP#V0, R5F102A9DSP#V0, R5F102A8DSP#V0, R5F102A7DSP#V0 (300), 0.65 mm R5F102AADSP#X0, R5F102A9DSP#X0, R5F102A8DSP#X0, R5F102A7DSP#X0 pitch ) G R5F102AAGSP#V0. R5F102A9GSP#V0. R5F102A8GSP#V0. R5F102A7GSP#V0 R5F102AAGSP#X0, R5F102A9GSP#X0, R5F102A8GSP#X0, R5F102A7GSP#X0 R5F103AAASP#V0, R5F103A9ASP#V0, R5F103A8ASP#V0, R5F103A7ASP#V0 Not mounted Α R5F103AAASP#X0, R5F103A9ASP#X0, R5F103A8ASP#X0, R5F103A7ASP#X0 R5F103AADSP#V0. R5F103A9DSP#V0. R5F103A8DSP#V0. R5F103A7DSP#V0 D R5F103AADSP#X0, R5F103A9DSP#X0, R5F103A8DSP#X0, R5F103A7DSP#X0 Note For fields of application, see Figure 1-1 Part Number, Memory Size, and Package of RL78/G12. **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.4 Pin Configuration (Top View) ## 1.4.1 20-pin products • 20-pin plastic LSSOP (4.4 × 6.5 mm, 0.65 mm pitch) Note Provided only in the R5F102 products. Remarks 1. For pin identification, see 1.5 Pin Identification. 2. Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). See Figure 4-8 Format of Peripheral I/O Redirection Register (PIOR). ## 1.4.2 24-pin products <R> • 24-pin plastic HWQFN (4 × 4 mm, 0.5 mm pitch) Note Provided only in the R5F102 products. Remarks 1. For pin identification, see 1.5 Pin Identification. - 2. Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). See **Figure 4-8 Format of Peripheral I/O Redirection Register (PIOR)**. - 3. It is recommended to connect an exposed die pad to Vss. ## 1.4.3 30-pin products • 30-pin plastic LSSOP (7.62 mm (300), 0.65 mm pitch) Note Provided only in the R5F102 products. **Caution** Connect the REGC pin to Vss via capacitor (0.47 to 1 $\mu$ F). Remarks 1. For pin identification, see 1.5 Pin Identification. 2. Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). See Figure 4-8 Format of Peripheral I/O Redirection Register (PIOR). ## 1.5 Pin Identification ANI0 to ANI3, REGC: Regulator Capacitance ANI16 to ANI22: RESET: Analog input Reset AVREFM: Analog Reference Voltage Minus RxD0 to RxD2: Receive Data AVREFP: SCK00, SCK01, SCK11, Analog reference voltage plus EXCLK: External Clock Input SCK20: Serial Clock Input/Output SCL00, SCL01, (Main System Clock) INTP0 to INTP5 Interrupt Request From Peripheral SCL11, SCL20, SCLA0: Serial Clock Input/Output KR0 to KR9: Key Return SDA00, SDA01, SDA11, P00 to P03: Port 0 SDA20, SDAA0: Serial Data Input/Output P10 to P17: Port 1 SI00, SI01, SI11, SI20: Serial Data Input P20 to P23: Port 2 SO00, SO01, SO11, P30 to P31: Port 3 SO20: Serial Data Output P40 to P42: Port 4 TI00 to TI07: Timer Input P50, P51: Port 5 TO00 to TO07: **Timer Output** P60, P61: Port 6 TOOL0: Data Input/Output for Tool P120 to P122, P125: Port 12 TOOLRxD, TOOLTxD: Data Input/Output for External P137: Port 13 Device P147: Port 14 TxD0 to TxD2: Transmit Data PCLBUZ0, PCLBUZ1: Programmable Clock Output/ VDD: Power supply **Buzzer Output** Vss: Ground X1, X2: Crystal Oscillator (Main System Clock) ## 1.6 Block Diagram ## 1.6.1 20-pin products Note Provided only in the R5F102 products. ## 1.6.2 24-pin products Note Provided only in the R5F102 products. ## 1.6.3 30-pin products Note Provided only in the R5F102 products. **Remark** Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). See **Figure 4-8 Format of Peripheral I/O Redirection Register (PIOR)**. ## 1.7 Outline of Functions This outline describes the function at the time when Peripheral I/O redirection register (PIOR) is set to 00H. (1/2) | ltem | | 20-pin | | 24-pin | | 30-pin | | | |-------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------|----------------------------------|----------|-----------------------------------|--| | | | R5F1026x | R5F1036x | R5F1027x | R5F1037x | R5F102Ax | R5F103Ax | | | Code flash memory | | 2 to 16 KB Note 1 | | | 4 to 1 | 16 KB | | | | Data flash memory | | 2 KB | - | 2 KB | - | 2 KB | _ | | | RAM | | 256 B to | o 1.5 KB | 512 B to | 1.5 KB | 512 B | to 2KB | | | Address | space | | | 11 | МВ | | | | | Main<br>system<br>clock | High-speed system clock | X1 (crystal/ceramic) oscillation, external main system clock input (EXCLK) HS (High-speed main) mode: 1 to 20 MHz (V <sub>DD</sub> = 2.7 to 5.5 V), HS (High-speed main) mode: 1 to 16 MHz (V <sub>DD</sub> = 2.4 to 5.5 V), LS (Low-speed main) mode: 1 to 8 MHz (V <sub>DD</sub> = 1.8 to 5.5 V) | | | | | | | | | High-speed on-chip oscillator clock | HS (High-speed main) mode: 1 to 24 MHz (V <sub>DD</sub> = 2.7 to 5.5 V), HS (High-speed main) mode: 1 to 16 MHz (V <sub>DD</sub> = 2.4 to 5.5 V), LS (Low-speed main) mode: 1 to 8 MHz (V <sub>DD</sub> = 1.8 to 5.5 V) | | | | | | | | Low-spee | ed on-chip oscillator clock | 15 kHz (TYP) | | | | | | | | General-p | ourpose register | (8-bit register × 8) × 4 banks | | | | | | | | Minimum | instruction execution time | 0.04167 μs (High-speed on-chip oscillator clock: f <sub>IH</sub> = 24 MHz operation) | | | | | | | | | | 0.05 $\mu s$ (High-speed system clock: f <sub>MX</sub> = 20 MHz operation) | | | | | | | | Instruction | n set | Data transfer (8/16 bits) | | | | | | | | | | Adder and subtractor/logical operation (8/16 bits) | | | | | | | | | | Multiplication (8 bits × 8 bits) | | | | | | | | | 1 | Rotate, barrel shift, and bit manipulation (set, reset, test, and Boolean operation), etc. | | | | | | | | I/O port | Total | 1 | 8 | 2 | 2 | 2 | .6 | | | | CMOS I/O | (N-ch ( | 2<br>D.D. I/O<br>nd voltage]: 4) | (N-ch C | 6<br>D.D. I/O<br>nd voltage]: 5) | (N-ch ( | t1<br>D.D. I/O<br>ad voltage]: 9) | | | | CMOS input | 4 | 4 | 4 | 4 | ; | 3 | | | | N-ch open-drain I/O<br>(6 V tolerance) | 2 | | | | | | | | Timer | 16-bit timer | 4 channels 8 channels | | | | innels | | | | | Watchdog timer | 1 channel | | | | | | | | | 12-bit Interval timer | 1 channel | | | | | | | | | Timer output | 4 channels<br>(PWM outputs: 3 Note 3) | | | 8 cha<br>(PWM outpu | | | | **Notes 1.** The self-programming function cannot be used in the R5F10266 and R5F10366. - 2. The maximum number of channels when PIOR0 is set to 1. - 3. The number of PWM outputs varies depending on the setting of channels in use (the number of masters and slaves). (See 6.9.3 Operation as multiple PWM output function.) **Caution** When the flash memory is rewritten via a user program, the code flash area and RAM area are used because each library is used. When using the library, refer to RL78 Family Flash Self Programming Library Type01 User's Manual and RL78 Family Data Flash Library Type04 User's Manual. (2/2) | Item | | 20-pin | | 24-pin | | 30-pin | | | |-------------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------|----------|------------|----------|--| | | | R5F1026x | R5F1036x | R5F1027x | R5F1037x | R5F102Ax | R5F103Ax | | | Clock output/buzzer output | | 1 2 | | | | | | | | | | 2.44 kHz to 10 MHz: (Peripheral hardware clock: fmain = 20 MHz operation) | | | | | | | | 8/10-bit resolution A/D converter | | 11 channels | | | | 8 channels | | | | Serial interface | | [R5F1026x (20-pin), R5F1027x (24-pin)] | | | | | | | | | | CSI: 2 channels/Simplified I <sup>2</sup> C: 2 channels/UART: 1 channel | | | | | | | | | | [R5F102Ax (30-pin)] | | | | | | | | | | CSI: 1 channel/Simplified I <sup>2</sup> C: 1 channel/UART: 1 channel | | | | | | | | | | • CSI: 1 channel/Simplified I <sup>2</sup> C: 1 channel/UART: 1 channel | | | | | | | | | | CSI: 1 channel/Simplified I <sup>2</sup> C: 1 channel/UART: 1 channel | | | | | | | | | | [R5F1036x (20-pin), R5F1037x (24-pin)] | | | | | | | | | | CSI: 1 channel/Simplified I <sup>2</sup> C: 0 channel/UART: 1 channel | | | | | | | | | | [R5F103Ax (30-pin)] | | | | | | | | | | CSI: 1 channel/Simplified I <sup>2</sup> C: 0 channel/UART: 1 channel | | | | | | | | | I <sup>2</sup> C bus | 1 channel | | | | | | | | Multiplier and divider/multiply-<br>accumulator | | • 16 bits × 16 bits = 32 bits (unsigned or signed) | | | | | | | | | | • 32 bits × 32 bits = 32 bits (unsigned) | | | | | | | | | | • 16 bits × 16 bits + 32 bits = 32 bits (unsigned or signed) | | | | | | | | DMA controller | | 2 channels | _ | 2 channels | _ | 2 channels | _ | | | Vectored interrupt | Internal | 18 | 16 | 18 | 16 | 26 | 19 | | | sources | External | | 5 | | | 6 | | | | Key interrupt | | 6 10 | | | | - | _ | | | Reset | | Reset by RESET pin Internal reset by watchdog timer Internal reset by power-on-reset Internal reset by voltage detector Internal reset by illegal instruction execution Note Internal reset by RAM parity error Internal reset by illegal-memory access | | | | | | | | Power-on-reset circuit | | <ul><li>Power-on-reset: 1.51 V (TYP)</li><li>Power-down-reset: 1.50 V (TYP)</li></ul> | | | | | | | | Voltage detector | | • Rising edge : 1.88 to 4.06 V (12 stages) | | | | | | | | | | • Falling edge : 1.84 to 3.98 V (12 stages) | | | | | | | | On-chip debug function | | Provided | | | | | | | | Power supply voltage | | V <sub>DD</sub> = 1.8 to 5.5 V | | | | | | | | Operating ambient temperature | | | $T_A = -40$ to +85°C (A: Consumer applications, D: Industrial applications), $T_A = -40$ to +105°C (G: Industrial applications) | | | | | | 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. ### **CHAPTER 2 PIN FUNCTIONS** #### 2.1 Port Functions V<sub>DD</sub> is the I/O buffer power supply for pins. Set in each port I/O, buffer, pull-up resistor is also valid for alternate functions. #### 2.1.1 20-pin products (1/2) | Function<br>Name | Pin<br>Type | I/O | After Reset<br>Release | Alternate Function | Function | |------------------|-------------|-----|------------------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P10 | 8-3-2 | I/O | Analog input port | ANI16/PCLBUZ0/<br>SCK00/<br>SCL00 Note 3 | Port 1. 5-bit I/O port. Input/output can be specified in 1-bit units. | | P11 | | | | ANI17/SI00/RxD0/<br>SDA00 Note 3/<br>TOOLRxD | Use of an on-chip pull-up resistor can be specified by a software setting at input port (in 1-bit units). Input of P10 and P11 can be set to TTL input buffer. | | P12 | 7-3-2 | | | ANI18/SO00/TxD0/<br>TOOLTxD | Output of P10 to P12 can be set to N-ch open-drain output (VD tolerance). | | P13 | 7-3-1 | | | ANI19/TI00/TO00/<br>INTP2 | Can be set to analog input Note 1. | | P14 | | | | ANI20/TI01/TO01/<br>INTP3 | | | P20 | 4-3-1 | I/O | Analog input | ANIO/AVREFP | Port 2. | | P21 | | | port | ANI1/AVREFM | 4-bit I/O port. | | P22 | | | | ANI2 | Input/output can be specified in 1-bit units. Can be set to analog input Note 2. | | P23 | | | | ANI3 | Can be set to analog input . | | P40 | 7-1-1 | I/O | Input port | KR0/TOOL0 | Port 4. | | P41 | 7-3-2 | | Analog input port | ANI22/SO01 Note 3/<br>SDA01 Note 3/TI02/<br>TO02/INTP1 | 3-bit I/O port. Input/output can be specified in 1-bit units. Use of an on-chip pull-up resistor can be specified by a | | P42 | 7-3-1 | | | ANI21/SCK01 Note 3/<br>SCL01 Note 3/TI03/<br>TO03 | software setting at input port (in 1-bit units). Output of P41 can be set to N-ch open-drain output (VDD tolerance). P41 and P42 can be set to analog input Note 1. | | P60 | 12-1-1 | I/O | Input port | KR4/SCLA0/(TxD0) | Port 6 | | P61 | | | | KR5/SDAA0/(RxD0) | 2-bit I/O port. | | | | | | | Input/output can be specified in 1-bit units. | | | | | | | N-ch open-drain output (6-V tolerance). | **Notes 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). - 2. Digital or analog for each pin can be selected with the A/D port configuration register (ADPC). - 3. Provided only in the R5F102 products. <R> (2/2) | Function<br>Name | Pin<br>Type | I/O | After Reset<br>Release | Alternate Function | Function | |------------------|-------------|-------|------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | P121 | 2-2-1 | Input | Input port | KR3/X1/<br>(TI03)/(INTP3) | Port 12 3-bit input port. | | P122 | | | | KR2/X2/EXCLK/<br>(TI02)/(INTP2) | P125 is also used for the input pin for external reset (RESET). To use the pin for external reset, set the PORTSELB bit in the | | P125 | 3-1-1 | | | KR1/SI01/RESET | option byte (000C1H) to 1. For P125, use of an on-chip pull-up resistor can be specified by a software setting. | | P137 | 2-1-2 | Input | Input port | INTP0 | Port 13 1-bit input port | Remark Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). For details, see Figure 4-8 Format of Peripheral I/O Redirection Register (PIOR). # 2.1.2 24-pin products (1/2) | Function<br>Name | Pin<br>Type | I/O | After Reset<br>Release | Alternate Function | Function | |------------------|-------------|-----|------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P00 | 7-1-1 | I/O | Input port | KR6/(SI01) Note 3 | Port 0. | | P01 | 7-1-2 | | | KR7/(SO01) Note 3/<br>(SDA01) Note 3 | 4-bit I/O port. Input/output can be specified in 1-bit units. | | P02 | 7-1-1 | | | KR8/(SCK01) Note 3/<br>(SCL01) Note 3 | Use of an on-chip pull-up resistor can be specified by a software setting at input port (in 1-bit units). Output of P01 can be set to N-ch open-drain output (VDD | | P03 | | | | KR9 | tolerance). | | P10 | 8-3-2 | I/O | Analog input port | ANI16/PCLBUZ0/<br>SCK00/SCL00 Note 3 | Port 1.<br>5-bit I/O port. | | P11 | | | | ANI17/SI00/RxD0/<br>SDA00 Note 3/<br>TOOLRxD | Input/output can be specified in 1-bit units. Use of an on-chip pull-up resistor can be specified by a software setting at input port (in 1-bit units). | | P12 | 7-3-2 | | | ANI18/SO00/TxD0/<br>TOOLTxD | Input of P10 and P11 can be set to TTL input buffer. Output of P10 to P12 can be set to N-ch open-drain output | | P13 | 7-3-1 | | | ANI19/TI00/TO00/<br>INTP2 | (V <sub>DD</sub> tolerance). Can be set to analog input <sup>Note 1</sup> . | | P14 | | | | ANI20/TI01/TO01/<br>INTP3 | | | P20 | 4-3-1 | I/O | Analog input | ANIO/AVREFP | Port 2. | | P21 | | | port | ANI1/AVREFM | 4-bit I/O port. | | P22 | | | | ANI2 | Input/output can be specified in 1-bit units. | | P23 | | | | ANI3 | Can be set to analog input Note 2. | - Notes 1. Digital or analog for each pin can be selected with the port mode control register x (PMCx) (can be set in 1bit unit). - 2. Digital or analog for each pin can be selected with the A/D port configuration register (ADPC). - 3. Provided only in the R5F102 products. (2/2) | Function<br>Name | Pin<br>Type | I/O | After Reset<br>Release | Alternate<br>Function | Function | | |------------------|-------------|-------|------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | P40 | 7-1-1 | I/O | Input port | KR0/TOOL0 | Port 4. | | | P41 | 7-3-2 | | Analog input port | ANI22/SO01 Note 2/<br>SDA01 Note 2/TI02/<br>TO02/INTP1 | 3-bit I/O port. Input/output can be specified in 1-bit units. Use of an on-chip pull-up resistor can be specified by a | | | P42 | 7-3-1 | | | ANI21/SCK01 Note 2/<br>SCL01 Note 2/TI03/<br>TO03 | software setting at input port (in 1-bit units). Output of P41 can be set to N-ch open-drain output (VDD tolerance). P41 and P42 can be set to analog input Note 1. | | | P60 | 12-1-1 | I/O | Input port | KR4/SCLA0/<br>(TxD0) | Port 6.<br>2-bit I/O port. | | | P61 | | | | KR5/SDAA0/<br>(RxD0) | Input/output can be specified in 1-bit units. N-ch open-drain output (6-V tolerance). | | | P121 | 2-1-1 | Input | Input port | KR3/X1/<br>(TI03)/(INTP3) | Port 12. 3-bit input port. | | | P122 | | | | KR2/X2/EXCLK/<br>(TI02)/(INTP2) | P125 is also used for the input pin for external reset (RESET). | | | P125 | 3-1-1 | | | KR1/SI01 Note 2/<br>RESET | To use the pin for external reset, set the PORTSELB bit in the option byte (000C1H) to 1. For P125, use of an on-chip pull-up resistor can be specified by a software setting. | | | P137 | 2-1-2 | Input | Input port | INTP0 | Port 13. 1-bit input port. | | **Notes 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). 2. Provided only in the R5F102 products. # 2.1.3 30-pin products (1/2) | Function<br>Name | Pin<br>Type | I/O | After Reset<br>Release | Alternate Function | Function (112) | |------------------|-------------|-----|------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------| | P00 | 7-3-2 | I/O | Analog input | ANI17/TI00/TxD1 Note 3 | Port 0. | | P01 | 8-3-1 | | port | ANI16/TO00/RxD1 <sup>Note 3</sup> | 2-bit I/O port. | | | | | | | Input/output can be specified in 1-bit units. | | | | | | | Use of an on-chip pull-up resistor can be specified by a software setting at input port (in 1-bit units). | | | | | | | Input of P01 can be set to TTL input buffer. | | | | | | | Output of P00 can be set to N-ch open-drain output (VDD tolerance). | | | | | | | Can be set to analog input Note 1. | | P10 | 8-1-2 | I/O | Input port | SCK00/SCL00 Note 3/ | Port 1. | | | | | | (TI07)/(TO07) | 8-bit I/O port. | | P11 | | | | SI00/RxD0/TOOLRxD/ | Input/output can be specified in 1-bit units. | | | | | | SDA00 Note 3/(TI06)/(TO06) | Input of P10, P11, and P13 to P17 can be set to TTL | | P12 | 7-1-2 | | | SO00/TxD0/TOOLTXD/ | input buffer. | | | | | | (TI05)/(TO05) | Output of P10 to P15 and P17 can be set to N-ch open-<br>drain output (V <sub>DD</sub> tolerance). | | P13 | 8-1-2 | | | TxD2 Note 3/SO20 Note 3/<br>(SDAA0) Note 3/(TI04)/<br>(TO04) | Use of an on-chip pull-up resistor can be specified by a software setting at input port (in 1-bit units). | | P14 | | | | RxD2 <sup>Note 3</sup> /SI20 <sup>Note 3</sup> /<br>SDA20 <sup>Note 3</sup> /(SCLA0) <sup>Note 3</sup><br>/(TI03)/(TO03) | | | P15 | | | | PCLBUZ1/SCK20 Note 3/<br>SCL20 Note 3/(TI02)/(TO02) | | | P16 | 8-1-1 | | | TI01/TO01/INTP5/(RxD0) | | | P17 | 8-1-2 | | | TI02/TO02/(TxD0) | | | P20 | 4-3-1 | I/O | Analog input | ANIO/AVREFP | Port 2. | | P21 | | | port | ANI1/AVREFM | 4-bit I/O port. | | P22 | | | | ANI2 | Input/output can be specified in 1-bit units. | | P23 | | | | ANI3 | Can be set to analog input Note 2. | **Notes 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). - 2. Digital or analog for each pin can be selected with the A/D port configuration register (ADPC). - **3.** Provided only in the R5F102 products. (2/2) | Function<br>Name | Pin<br>Type | I/O | After Reset<br>Release | Alternate Function | Function | |------------------|-------------|-------|------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P30 | 7-1-1 | I/O | Input port | INTP3/SCK11 Note 2/<br>SCL11 Note 2 | Port 3. 2-bit I/O port. | | P31 | | | | TI03/TO03/INTP4/<br>PCLBUZ0 | Input/output can be specified in 1-bit units. Use of an on-chip pull-up resistor can be specified by a software setting at input port (in 1-bit units). | | P40 | 7-1-1 | I/O | Input port | TOOL0 | Port 4. 1-bit I/O port. Input/output can be specified in 1-bit units. Use of an on-chip pull-up resistor can be specified by a software setting at input port . | | P50 | 7-1-2 | I/O | Input port | INTP1/SI11 Note 2/<br>SDA11 Note 2 | Port 5. 2-bit I/O port. | | P51 | 7-1-1 | | | INTP2/SO11 Note 2 | Input/output can be specified in 1-bit units. Use of an on-chip pull-up resistor can be specified by a software setting at input port (in 1-bit units). Output of P50 can be set to N-ch open-drain output (VDD tolerance). | | P60 | 12-1-1 | I/O | Input port | SCLA0 | Port 6. | | P61 | | | | SDAA0 | 2-bit I/O port. Input/output can be specified in 1-bit units. N-ch open-drain output (6V tolerance). | | P120 | 7-3-1 | I/O | Analog input | ANI19 | Port 12. 1-bit I/O port and 2-bit input port. | | P121 | 2-2-1 | Input | Input port | X1 | Only for P120, input/output can be specified. | | P122 | | | | X2/EXCLK | Only for P120, use of an on-chip pull-up resistor can be specified by a software setting. P120 can be set to analog input Note 1. | | P137 | 2-1-2 | Input | Input port | INTP0 | Port 13. Dedicated 1-bit input port. | | P147 | 7-3-1 | I/O | Analog input port | ANI18 | Port 14. 1-bit I/O port. Input/output can be specified in 1-bit units. Use of an on-chip pull-up resistor can be specified by a software setting at input port. Can be set to analog input Note 1. | | RESET | 2-1-1 | Input | - | - | Dedicated input pin for external reset. When external reset is not used, connect this pin to VDD directly or via a resistor. | **Notes 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). 2. Provided only in the R5F102 products. # 2.2 Functions other than port pins # 2.2.1 Functions for each product | Function | 20-pin | 24-pin | 30-pin | |----------|-----------|-----------|-----------| | Name | products | products | products | | ANI0 | √ | √ | √ | | ANI1 | √<br>√ | N N | √<br>√ | | ANI2 | √<br>√ | √<br>√ | √<br>√ | | ANI3 | V | V | 7 | | ANI16 | V | V | 7 | | ANI17 | V | V | 7 | | ANI18 | √<br>√ | √<br>√ | √<br>√ | | ANI19 | √<br>√ | V | √<br>√ | | ANI20 | V | V | _ | | ANI21 | √<br>√ | √<br>√ | _ | | ANI22 | √<br>√ | √<br>√ | _ | | INTP0 | √<br>√ | √<br>√ | <b>√</b> | | INTP1 | \<br>√ | \<br>√ | \<br>√ | | INTP2 | √<br>√ | √<br>√ | √<br>√ | | INTP3 | √ | √ | √ · | | INTP4 | = | _ | √ | | INTP5 | _ | _ | √ | | KR0 | V | V | = | | KR1 | V | V | _ | | KR2 | V | V | = | | KR3 | V | V | _ | | KR4 | V | V | _ | | KR5 | V | V | _ | | KR6 | _ | V | _ | | KR7 | _ | V | _ | | KR8 | _ | $\sqrt{}$ | _ | | KR9 | _ | $\sqrt{}$ | - | | PCLBUZ0 | $\sqrt{}$ | $\sqrt{}$ | √ | | PCLBUZ1 | _ | _ | V | | REGC | - | - | √ | | RESET | V | V | V | | RxD0 | V | V | V | | RxD1 | _ | _ | √Note | | RxD2 | _ | _ | √Note | | TxD0 | V | V | V | | TxD1 | _ | _ | √Note | | TxD2 | _ | _ | √Note | | SCK00 | √ | √ | √ | | SCK01 | √Note | √Note | _ | | SCK11 | _ | _ | √Note | | SCK20 | _ | _ | √Note | | SCLA0 | √ | √ | √ | | SDAA0 | V | V | $\sqrt{}$ | | Function | 20-pin | 24-pin | 30-pin | |----------|----------------------|----------------------|----------------------| | Name | products | products | products | | SCL00 | √Note | √Note | √Note | | SCL01 | √Note | √Note | | | SCL11 | _ | _ | √Note | | SCL20 | = | = | √Note | | SDA00 | $\sqrt{\text{Note}}$ | √Note | √Note | | SDA01 | $\sqrt{\text{Note}}$ | √Note | - | | SDA11 | ı | ı | $\sqrt{\text{Note}}$ | | SDA20 | - | _ | √Note | | SI00 | $\checkmark$ | $\checkmark$ | $\checkmark$ | | SI01 | √Note | $\sqrt{\text{Note}}$ | 1 | | SI11 | 1 | ı | $\sqrt{\text{Note}}$ | | SI20 | - | _ | √Note | | SO00 | V | √ | √ | | SO01 | √Note | √Note | = | | SO11 | _ | _ | √Note | | SO20 | = | = | √Note | | TI00 | <b>√</b> | √ | √ | | TI01 | <b>√</b> | √ | √ | | TI02 | √ | √ | √ | | TI03 | <b>√</b> | √ | √ | | TI04 | _ | _ | (√) | | TI05 | - | = | (√) | | TI06 | - | = | (√) | | TI07 | - | = | (√) | | TO00 | √ | √ | √ | | TO01 | <b>√</b> | √ | √ | | TO02 | <b>√</b> | √ | √ | | TO03 | √ | √ | √ | | TO04 | = | = | (√) | | TO05 | - | = | (√) | | TO06 | _ | - | (√) | | TO07 | - | - | (√) | | X1 | V | V | V | | X2 | V | V | √ | | EXCLK | V | V | √ | | VDD | V | V | √ | | AVREFP | V | $\sqrt{}$ | $\sqrt{}$ | | AVREFM | V | V | √ | | VSS | V | V | √ | | TOOLRxD | √ | √ | √ | | TOOLTxD | V | √ | √ | | TOOL0 | V | √ | √ | | | | | | Note Provided only in the R5F102 products. # 2.2.2 Description of Functions | Function Name | I/O | Functions | |------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------| | ANI0 to ANI3, ANI16 to ANI22 | input | Analog input pins of A/D converter | | | | (see Figure 10-44 Analog Input Pin Connection) | | AVREFP | AV <sub>REFP</sub> input Inputs the A/D converter reference potential (+ side) | | | AVREFM | input | Inputs the A/D converter reference potential (- side) | | INTP0 to INTP5 | input | External interrupt request input | | | | Specified available edge: rising edge, falling edge, or both rising and falling edges | | KR0 to KR9 | input | Key interrupt input | | PCLBUZ0, PCLBUZ1 | output | Clock/buzzer output | | REGC | _ | Connecting regulator output stabilization capacitance for internal operation. Connect this pin to Vss via a capacitor (0.47 to 1 $\mu$ F) | | RESET | input | External reset input for low level active | | | | When the external reset pin is not used, connect this pin directly or via a resistor to VDD. | | RxD0 to RxD2 | input | Serial data input for serial interfaces UART0, UART1, and UART2 | | TxD0 to TxD2 | output | Serial data output for serial interfaces UART0, UART1, and UART2 | | SCK00, SCK01, SCK11, SCK20 | I/O | Serial clock I/O for serial interfaces CSI00, CSI01, CSI11, and CSI20 | | SI00, SI01, SI11, SI20 | input | Serial data input for serial interfaces CSI00, CSI01, CSI11, and CSI20 | | SO00, SO01, SO11, SO20 | output | Serial data output for serial interfaces CSI00, CSI01, CSI11, and CSI20 | | SCLA0 | I/O | Serial clock I/O for serial interface IICA | | SDAA0 | I/O | Serial data I/O for serial interface IICA | | SCL00, SCL01, SCL11, SCL20 | output | Clock output for simplified I <sup>2</sup> C serial interfaces IIC00, IIC01, IIC11, IIC20 | | SDA00, SDA01, SDA11, SDA20 | I/O | Serial data I/O for simplified 1 <sup>2</sup> C serial interfaces IIC00, IIC01, IIC11, IIC20 | | TI00 to TI07 | input | Inputting an external count clock/capture trigger to 16-bit timers 00 to 07 | | TO00 to TO07 | output | Timer output pins of 16-bit timers 00 to 07 | | X1, X2 | - | Connecting a resonator for main system clock | | EXCLK | input | External clock input pin for main system clock | | V <sub>DD</sub> | - | Positive power supply | | Vss | = | Ground potential | | TOOLRXD | input | This UART serial data input pin for an external device connection is used during flash memory programming | | TOOLTxD | output | This UART serial data output pin for an external device connection is used during flash memory programming | | TOOL0 | I/O | Data I/O pin for a flash memory programmer/debugger | **Caution** The following shows the relationship between P40/TOOL0 and the operation mode when reset is released. Table 2-1. Relationship between P40/TOOL0 and the Operation Mode When Reset Is Released | P40/TOOL0 | OL0 Operation mode | | | | |-----------------|-------------------------------|--|--|--| | V <sub>DD</sub> | Normal operation mode | | | | | 0 V | Flash memory programming mode | | | | For details, see 24.4 Serial Programming Method. **Remark** Use bypass capacitors (about 0.1 $\mu$ F) as noise and latch up countermeasures with relatively thick wires at the shortest distance to V<sub>DD</sub> to V<sub>SS</sub> lines. ### 2.3 Connection of Unused Pins Tables 2-2 and 2-3 show the connections of unused pins. The pins mounted depend on the product. Refer to 1.4 Pin Configuration (Top View) and 2.1 Port Functions. Table 2-2. Connection of Unused Pins (20-, 24-pin products) | Pin Name | I/O | Recommended Connection of Unused Pins | | | |-----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | P00 to P03 Note | I/O | Input: Independently connect to VDD or Vss via a resistor. | | | | P10 to P14 | | Output: Leave open. | | | | P20 to P23 | | | | | | P40/TOOL0 | | Input: Leave open or independently connect to VDD via a resistor. | | | | | | Output: Leave open. | | | | P41, P42 | | Input: Independently connect to VDD or Vss via a resistor. | | | | | | Output: Leave open. | | | | P60, P61 | | Input: Independently connect to VDD or Vss via a resistor. | | | | | | Output: Set the port's output latch to 0 and leave the pins open, or set the port's output latch to 1 and independently connect the pins to V <sub>DD</sub> or V <sub>SS</sub> via a resistor. | | | | P121, P122 | input | Independently connect to VDD or Vss via a resistor. | | | | P125/RESET | | PORTSELB = 0: Independently connect to V <sub>DD</sub> or V <sub>SS</sub> via a resistor. | | | | | | PORTSELB = 1: Leave open or connect to V <sub>DD</sub> . | | | | P137 | | Independently connect to VDD or Vss via a resistor. | | | Note Provided only in 24-pin products. Table 2-3. Connection of Unused Pins (30-pin products) | | Pin Name | I/O | Recommended Connection of Unused Pins | | |---|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Р | 00, P01 | I/O | Input: Independently connect to VDD or Vss via a resistor. | | | Р | 10 to P17 | | Output: Leave open. | | | P | 20 to P23 | | | | | P | 30, P31 | | | | | P | 40/TOOL0 | | | | | P | 50, P51 | | | | | Р | 60, P61 | | Input: Independently connect to VDD or VSS via a resistor. | | | | | | Output: Set the port's output latch to 0 and leave the pins open, or set the port's output latch to 1 and independently connect the pins to V <sub>DD</sub> or V <sub>SS</sub> via a resistor. | | | Р | 120 | | Input: Independently connect to VDD or VSS via a resistor. | | | | | | Output: Leave open. | | | Р | 121, P122 | input | Input: Independently connect to VDD or Vss via a resistor. | | | Р | 137 | | | | | Р | 147 | I/O | Input: Independently connect to VDD or VSS via a resistor. | | | | | | Output: Leave open. | | | R | ESET | input | Connect to VDD directly or via a resistor. | | | R | EGC | _ | Connect to Vss via a capacitor (0.47 to 1 µF). | | # 2.4 Block Diagrams of Pins Figures 2-1 to 2-13 show the block diagrams of the pins described in **2.1.1 20-pin products** to **2.1.3 30-pin products**. Figure 2-1. Pin Block Diagram for Pin Type 2-1-1 Figure 2-2. Pin Block Diagram for Pin Type 2-1-2 Remark For alternate functions, see 2.1 Port Functions. Figure 2-3. Pin Block Diagram for Pin Type 2-2-1 <R> PU register (PUmn) RDPORT Alternate function RESET PORTSELB Figure 2-4. Pin Block Diagram for Pin Type 3-1-1 Figure 2-5. Pin Block Diagram for Pin Type 4-3-1 Figure 2-6. Pin Block Diagram for Pin Type 7-1-1 Figure 2-7. Pin Block Diagram for Pin Type 7-1-2 Caution A through current may flow through if the pin is in the intermediate potential, because the input buffer is also turned on when the pin is in N-ch open-drain output mode by port output mode register (POMx). Remarks 1. For alternate functions, see 2.1 Port Functions. Figure 2-8. Pin Block Diagram for Pin Type 7-3-1 Figure 2-9. Pin Block Diagram for Pin Type 7-3-2 2. SAU: Serial array unit Caution A through current may flow through if the pin is in the intermediate potential, because the input buffer is also turned on when the pin is in N-ch open-drain output mode by port output mode register (POMx). Figure 2-10. Pin Block Diagram for Pin Type 8-1-1 2. SAU: Serial array unit <R> Caution Because of TTL input buffer structure, if the port input mode register (PIMx) is set in TTL input buffer, a through current may flow through in the case of high level input. It is recommended to input a low level to prevent a through current. Figure 2-11. Pin Block Diagram for Pin Type 8-1-2 - <R> Caution 1 A through current may flow through if the pin is in the intermediate potential, because the input buffer is also turned on when the pin is in N-ch open-drain output mode by port output mode register (POMx). - 2 Because of TTL input buffer structure, if the port input mode register (PIMx) is set in TTL input buffer, a through current may flow through in the case of high level input. It is recommended to input a low level to prevent a through current. - Remarks 1. For alternate functions, see 2.1 Port Functions. - 2. SAU: Serial array unit Figure 2-12. Pin Block Diagram for Pin Type 8-3-1 <R> Caution Because of TTL input buffer structure, if the port input mode register (PIMx) is set in TTL input buffer, a through current may flow through in the case of high level input. It is recommended to input a low level to prevent a through current. Remarks 1. For alternate functions, see 2.1 Port Functions. Figure 2-13. Pin Block Diagram for Pin Type 8-3-2 - <R> Caution 1 A through current may flow through if the pin is in the intermediate potential, because the input buffer is also turned on when the pin is in N-ch open-drain output mode by port output mode register (POMx). - 2 Because of TTL input buffer structure, if the port input mode register (PIMx) is set in TTL input buffer, a through current may flow through in the case of high level input. It is recommended to input a low level to prevent a through current. - Remarks 1. For alternate functions, see 2.1 Port Functions. - 2. SAU: Serial array unit Figure 2-14. Pin Block Diagram for Pin Type 12-1-1 # <R> Caution A through current may flow through if the pin is in the intermediate potential, because the input buffer is turned on when the pin is in output mode. Remarks 1. For alternate functions, see 2.1 Port Functions. #### **CHAPTER 3 CPU ARCHITECTURE** ### 3.1 Memory Space Products in the RL78/G12 can access a 1-MB memory space. Figures 3-1 to 3-6 show the memory maps. 007FFH **FFFFFH** Special function register (SFR) 256 bytes FFF00H General-purpose FFEFFH register 32 bytes FFEE0H FFEDFH RAM Notes 1, 2 256 bytes FFE00H **FFDFFH** Program area Reserved F1800H F17FFH Data flash memory Note 4 F1000H 2 KB Data memory F0FFFH space Reserved F0800H 000CEH F07FFH Special function register (2nd SFR) 000CDH On-chip debug Note 3 2 KB F0000H security ID setting area **EFFFF** 10 bytes 000C4H 000C3H Option byte area Note 3 000C0H 4 bytes Reserved 000BFH CALLT table area 64 bytes 00080H 0007FH 00800H 007FFH Vector table area Program Code flash memory 128 bytes memory 2 KB space 00000H 00000H Figure 3-1. Memory Map for the R5F10266 and R5F10366 - Notes 1 Allocate the stack used for the data flash library to FFEA2H to FFEDFH and the RAM address used for the data buffer and DMA transfer to FFE00H to FFE1FH when rewriting the data flash memory. For details, refer to RL78 Family Data Flash Library Type04 User's Manual. - 2. Instructions can be executed from the RAM area excluding the general-purpose register area. - 3. Set the option bytes to 000C0H to 000C3H, and the on-chip debug security IDs to 000C4H to 000CDH. - 4. The areas are reserved in the R5F10366. - **Cautions 1.** 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 21.3.2 RAM parity error detection function. - 2. The RAM in the R5F10266 has capacity as small as 256 bytes. Depending on the customer's program specification, the stack area to execute the data flash library may not be kept and data may not be written to or erased from the data flash memory. For details, refer to RL78 Family Data Flash Library Type04 User's Manual. - 3. The self-programming function cannot be used in the R5F10266 and R5F10366 Figure 3-2. Memory Map for the R5F10x67, and R5F10x77, and R5F10xA7 (x = 2 or 3) - Notes 1. Do not allocate the stack area, data buffers for use by the flash library, arguments of library functions, branch destinations in the processing of vectored interrupts, or destinations or sources for DMA transfer to the area from FFE20H to FFEDFH when performing self-programming or rewriting of the data flash memory. - 2. Instructions can be executed from the RAM area excluding the general-purpose register area. - 3. Set the option bytes to 000C0H to 000C3H, and the on-chip debug security IDs to 000C4H to 000CDH. - 4. The areas are reserved in the R5F10367, R5F10377, and R5F103A7. **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 21.3.2 RAM parity error detection function. Figure 3-3. Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x = 2 or 3) - Notes 1. Do not allocate the stack area, data buffers for use by the flash library, arguments of library functions, branch destinations in the processing of vectored interrupts, or destinations or sources for DMA transfer to the area from FFE20H to FFEDFH when performing self-programming or rewriting of the data flash memory. For R5F10x68 and R5F10x78, the RAM area used by the flash library starts at FFC00H. For the RAM areas used by the flash library, see Self RAM list of Flash Self-Programming Library for RL78 Family (R20UT2944). - 2. Instructions can be executed from the RAM area excluding the general-purpose register area. - 3. Set the option bytes to 000C0H to 000C3H, and the on-chip debug security IDs to 000C4H to 000CDH. - 4. The areas are reserved in the R5F10368, R5F10378, and R5103A8. **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 21.3.2 RAM parity error detection function. Figure 3-4. Memory Map for the R5F10x69, R5F10x79, and R5F10xA9 (x = 2 or 3) - <R> Notes 1. Do not allocate the stack area, data buffers for use by the flash library, arguments of library functions, branch destinations in the processing of vectored interrupts, or destinations or sources for DMA transfer to the area from FFE20H to FFEDFH when performing self-programming or rewriting of the data flash memory. For R5F10x69 and R5F10x79, the RAM area used by the flash library starts at FFB00H. For the RAM areas used by the flash library, see Self RAM list of Flash Self-Programming Library for RL78 Family (R20UT2944). - 2. Instructions can be executed from the RAM area excluding the general-purpose register area. - 3. Set the option bytes to 000C0H to 000C3H, and the on-chip debug security IDs to 000C4H to 000CDH. - 4. The areas are reserved in the R5F10369, R5F10379, and R5F103A9. 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 21.3.2 RAM parity error detection. Figure 3-5. Memory Map for the R5F10x6A, R5F10x7A (x = 2 or 3) - Notes 1. Do not allocate the stack area, data buffers for use by the flash library, arguments of library functions, branch destinations in the processing of vectored interrupts, or destinations or sources for DMA transfer to the area from FFE20H to FFEDFH when performing self-programming or rewriting of the data flash memory. For R5F10x6A and R5F10x7A, the RAM area used by the flash library starts at FF900H. For the RAM areas used by the flash library, see Self RAM list of Flash Self-Programming Library for RL78 Family (R20UT2944). - 2. Instructions can be executed from the RAM area excluding the general-purpose register area. - 3. Set the option bytes to 000C0H to 000C3H, and the on-chip debug security IDs to 000C4H to 000CDH. - 4. The areas are reserved in the R5F1036A and R5F1037A. **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 21.3.2 RAM parity error detection function. Figure 3-6. Memory Map for the R5F10xAA (x = 2 or 3) - <R> Notes 1. Do not allocate the stack area, data buffers for use by the flash library, arguments of library functions, branch destinations in the processing of vectored interrupts, or destinations or sources for DMA transfer to the area from FFE20H to FFEDFH when performing self-programming or rewriting of the data flash memory. - 2. Instructions can be executed from the RAM area excluding the general-purpose register area. - 3. Set the option bytes to 000C0H to 000C3H, and the on-chip debug security IDs to 000C4H to 000CDH. - 4. The areas are reserved in the R5F103AA. **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 21.3.2 RAM parity error detection. 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. (For the R5F1026A and R5F1027A) Correspondence between the address values and block numbers in the flash memory are shown below. Table 3-1. Correspondence Between Address Values and Block Numbers in Flash Memory | Address Value | Block Number | product | | |------------------|--------------|----------|--| | 00000H to 003FFH | 00H | R5F10x66 | | | 00400H to 007FFH | 01H | | | | 00800H to 00BFFH | 02H | R5F10x67 | | | 00C00H to 00FFFH | 03H | R5F10x77 | | | 01000H to 013FFH | 04H | R5F10x68 | | | 01400H to 017FFH | 05H | R5F10x78 | | | 01800H to 01BFFH | 06H | | | | 01C00H to 01FFFH | 07H | | | | 02000H to 023FFH | 08H | R5F10x69 | | | 02400H to 027FFH | 09H | R5F10x79 | | | 02800H to 02BFFH | 0AH | | | | 02C00H to 02FFFH | 0BH | | | | 03000H to 033FFH | 0CH | R5F10x6A | | | 03400H to 037FFH | 0DH | R5F10x7A | | | 03800H to 03BFFH | 0EH | R5F10xAA | | | 03C00H to 03FFFH | 0FH | | | (x = 2, 3) ### 3.1.1 Internal program memory space The internal program memory space stores the program and table data. The RL78/G12 products incorporate internal ROM (flash memory), as shown below. **Table 3-2. Internal ROM Capacity** | Part Number | Internal ROM | | |------------------------------|--------------|-----------------------------------| | | Structure | Capacity | | R5F10x66 | Flash memory | 2048 × 8 bits (00000H to 07FFFH) | | R5F10x67, R5F10x77, R5F10xA7 | | 4096 × 8 bits (00000H to 00FFFH) | | R5F10x68, R5F10x78, R5F10xA8 | | 8192 × 8 bits (00000H to 01FFFH) | | R5F10x69, R5F10x79, R5F10xA9 | | 12288 × 8 bits (00000H to 02FFFH) | | R5F10x6A, R5F10x7A, R5F10xAA | | 16384 × 8 bits (00000H to 03FFFH) | (x = 2 or 3) The internal program memory space is divided into the following areas. ### (1) Vector table area The 128-byte area of 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 addresses are assigned to a 64 KB address area of 00000H to 0FFFFH, because the vector code is 2 bytes. Of 16-bit addresses, the lower 8 bits are stored at even addresses and the higher 8 bits are stored at odd addresses. Table 3-3. Vector Table (20-, 24-pin products) <R> | Vector Table Address | Interrupt Source | |----------------------|-----------------------------------------------------------| | 00000H | RESET, POR, LVD, WDT, TRAP, IAW, RPE | | 00004H | INTWDTI | | 00006H | INTLVI | | 00008H | INTP0 | | 0000AH | INTP1 | | 0000CH | INTP2 | | 0000EH | INTP3 | | 00010H | INTDMA0 <sup>Note</sup> | | 00012H | INTDMA1 <sup>Note</sup> | | 00014H | INTST0/INTCSI00/INTIIC00 <sup>Note</sup> | | 00016H | INTSR0/INTCSI01 <sup>Note</sup> /INTIIC01 <sup>Note</sup> | | 00018H | INTSRE0 | | 0001AH | INTTM01H | | 0001CH | INTTM03H | | 0001EH | INTIICA0 | | 00020H | INTTM00 | | 00022H | INTTM01 | | 00024H | INTTM02 | | 00026H | INTTM03 | | 00028H | INTAD | | 0002AH | INTIT | | 0002CH | INTKR | | 0002EH | INTMD | | 00030H | INTFL | | 0007EH | BRK | Note Provided only in the R5F102 products. Table 3-4. Vector Table (30-pin products) <R> | Vector Table Address | Interrupt Source | |----------------------|-----------------------------------------------------------| | 00000H | RESET, POR, LVD, WDT, TRAP, IAW, RPE | | 00004H | INTWDTI | | 00006H | INTLVI | | H80000 | INTP0 | | 0000AH | INTP1 | | 0000CH | INTP2 | | 0000EH | INTP3 | | 00010H | INTP4 | | 00012H | INTP5 | | 00014H | INTST2/INTCSI20 <sup>Note</sup> /INTIIC20 <sup>Note</sup> | | 00016H | INTSR2 <sup>Note</sup> | | 00018H | INTSRE2 <sup>Note</sup> | | 0001AH | INTDMA0 <sup>Note</sup> | | 0001CH | INTDMA1 <sup>Note</sup> | | 0001EH | INTST0/INTCSI00/INTIIC00 <sup>Note</sup> | | 00020H | INTSR0 | | 00022H | INTSRE0/INTTM01H | | 00024H | INTST1 <sup>Note</sup> | | 00026H | INTSR1 Note/INTCSI11 Note/INTIIC11 Note | | 00028H | INTSRE1 <sup>Note</sup> /INTTM03H | | 0002AH | INTIICA0 | | 0002CH | INTTM00 | | 0002EH | INTTM01 | | 00030H | INTTM02 | | 00032H | INTTM03 | | 00034H | INTAD | | 00038H | INTIT | | 00042H | INTTM04 | | 00044H | INTTM05 | | 00046H | INTTM06 | | 00048H | INTTM07 | | 0005EH | INTMD | | 00062H | INTFL | | 0007EH | BRK | **Note** Provided only in the R5F102 products. ### (2) CALLT instruction table area The 64-byte area of 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). ### (3) Option byte area The 4-byte area of 000C0H to 000C3H can be used as an option byte area. For details, see CHAPTER 23 OPTION BYTE. # (4) On-chip debug security ID setting area The 10-byte areas of 000C4H to 000CDH and 010C4H to 010CDH can be used as an on-chip debug security ID setting area. For details, see CHAPTER 25 ON-CHIP DEBUG FUNCTION. #### 3.1.2 Mirror area The RL78/G12 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 SFR, extended SFR, RAM, 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 shows examples. Example R5F1026A and RF5F1027A (Flash memory: 16 KB, RAM: 1.5 KB) The PMC register is described below. #### • Processor mode control register (PMC) This register sets the flash memory space for mirroring to the 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-7. 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 MAA | MAA | Selection of flash memory space for mirroring to the area from F0000H to FFFFFH | | |-----|---------------------------------------------------------------------------------|--| | 0 | 00000H to 0FFFFH is mirrored to F0000H to FFFFFH | | | 1 | Setting prohibited | | Cautions 1. Be sure to clear bit 0 (MAA) of this register to 0 (default value). After setting the PMC register, wait for at least one instruction and access the mirror area. #### 3.1.3 Internal data memory space The RL78/G12 products incorporate the following RAMs. Table 3-5. Internal RAM Capacity | Part Number | Internal RAM | |------------------------------|----------------------------------| | R5F10x66 | 256 × 8 bits (FFE00H to FFEFFH) | | R5F10x67, R5F10x77, R5F10xA7 | 512 × 8 bits (FFD00H to FFEFFH) | | R5F10x68, R5F10x78, R5F10xA8 | 768 × 8 bits (FFC00H to FFEFFH) | | R5F10x69, R5F10x79, R5F10xA9 | 1024 × 8 bits (FFB00H to FFEFFH) | | R5F10x6A, R5F10x7A | 1536 × 8 bits (FF900H to FFEFFH) | | R5F10xAA | 2048 × 8 bits (FF700H to FFEFFH) | (x = 2 or 3) 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 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 a stack memory. - **Cautions 1.** It is prohibited to use the general-purpose register space (FFEE0H to FFEFFH) for fetching instructions or as a stack area. - 2. Do not allocate RAM addresses which are used as a stack area, a data buffer, and a DMA transfer destination/transfer source to the RAM areas of the following products when performing self-programming and rewriting the data flash memory. For details, refer to RL78 Family Flash Self Programming Library Type01 User's Manual and RL78 Family Data Flash Library Type04 User's Manual. R5F10266 : FFE20H to FFEA1H, FFEE0H to FFEFFH (Allocate the stack used for the data flash library to FFEA2H to FFEDFH and the RAM address used for the data buffer and DMA transfer to FFE00H to FFE1FH.) R5F102mn, R5F103mn : FFE20H to FFEFFH m: Pin count (m = 6, 7, A), n: ROM capacitance (n = 7, 8, 9, A) 3. Use of the RAM areas of the following products is prohibited when performing self-programming and rewriting the data flash memory, because these areas are used for each library. (Refer to Figures 3-3 to 3-5 Memory Map) R5F102m8, R5F103m8: FFC00H to FFC89H R5F102m9, R5F103m9: FFB00H to FFC89H R5F102mA, R5F103mA: FF900H to FFC89H m: Pin count (m = 6, 7) ## 3.1.4 Special function register (SFR) area On-chip peripheral hardware special function registers (SFRs) are allocated in the area of FFF00H to FFFFH (see Table 3-6 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 of F0000H to F07FFH (see Table 3-7 in 3.2.5 Extended Special function registers (2nd SFRs: 2nd Special Function Registers)). 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. 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 RL78 microcontroller, based on operability and other considerations. 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-8 shows correspondence between data memory and addressing. For details of each addressing, see 3.4 Addressing for Processing Data Addresses. Figure 3-8. Correspondence Between Data Memory and Addressing **Note** The areas are reserved in the R5F103 products. <R> ## 3.2 Processor Registers The RL78/G12 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 00000H and 00001H to the 16 lower-order bits of the program counter. The four higher-order bits of the program counter are cleared to 0000. Figure 3-9. 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 acknowledgment of a vectored interrupt request 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-10. Format of Program Status Word ## (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 or comparison result is zero or equal, 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) These flags manage 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 (PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) (see **15.3 (3)**) can not be acknowledged. Actual vectored interrupt 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-11. Format of Stack Pointer 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. Each stack operation saves data as shown in Figure 3-12. - **Cautions 1.** Since reset signal generation makes the SP contents undefined, be sure to initialize the SP before using the stack. - 2. It is prohibited to use the general-purpose register space (FFEE0H to FFEFFH) for fetching instructions or as a stack area. - 3. Do not allocate RAM addresses which are used as a stack area, a data buffer, and a DMA transfer destination/transfer source to the RAM areas of the following products when performing self-programming and rewriting the data flash memory. For details, refer to RL78 Family Flash Self Programming Library Type01 User's Manual and RL78 Family Data Flash Library Type04 User's Manual. R5F10266 : FFE20H to FFEA1H, FFEE0H to FFEFFH (Allocate the stack used for the data flash library to FFEA2H to FFEDFH and the RAM address used for the data buffer and DMA transfer to FFE00H to FFE1FH.) R5F102mn, R5F103mn : FFE20H to FFEFFH m: Pin count (m = 6, 7, A), n: ROM capacitance (n = 7, 8, 9, A) 4. Use of the RAM areas of the following products is prohibited when performing self-programming and rewriting the data flash memory, because these areas are used for each library. (Refer to Figures 3-3 to 3-5 Memory Map) R5F102m8, R5F103m8: FFC00H to FFC89H R5F102m9, R5F103m9: FFB00H to FFC89H R5F102mA, R5F103mA: FF900H to FFC89H m: Pin count (m = 6, 7) ### 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 interrupts for each bank. **Caution** It is prohibited to use the general-purpose register space (FFEE0H to FFEFFH) for fetching instructions or as a stack area. Figure 3-12. Configuration of General-Purpose Registers # (a) Function name ## 3.2.3 ES and CS registers The ES register is used for data access and the CS register is used to specify the higher address when a branch instruction is executed. The default value of the ES register after reset is 0FH, and that of the CS register is 00H. Figure 3-13. 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. Figure 3-14 Extension of Data Area Which Can Be Accessed ### 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 FFFFFH 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. Table 3-6 gives a list of the SFRs. The meanings of items in the table are as follows. #### Symbol Symbol indicating 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 Indicates whether the corresponding SFR can be read or written. R/W: Read/write enable R: Read only W: Write only # Manipulable bit units " $\sqrt{}$ " indicates the manipulable bit unit (1, 8, or 16). "-" indicates a bit unit for which manipulation is not possible. # After reset Indicates each register status upon reset signal generation. Caution Do not access addresses to which extended SFRs are not assigned. Remark For extended SFRs (2nd SFRs), see 3.2.5 Extended special function registers (2nd SFRs: 2nd Special Function Registers). Table 3-6. SFR List (1/4) | Address | Special Function Register (SFR) Name | Syı | mbol | R/W | Manip | oulable Bit | Range | After Reset | |---------|---------------------------------------------------|----------------|--------|-------------|-----------|-------------|-----------|-------------| | | | | | | 1-bit | 8-bit | 16-bit | | | FFF00H | Port register 0 | P0 | | R/W | √ | V | - | 00H | | FFF01H | Port register 1 | P1 | | R/W | √ | V | _ | 00H | | FFF02H | Port register 2 | P2 | | R/W | √ | <b>√</b> | - | 00H | | FFF03H | Port register 3 | P3 | | R/W | √ | <b>V</b> | - | 00H | | FFF04H | Port register 4 | P4 | | R/W | √ | √ | - | 00H | | FFF05H | Port register 5 | P5 | | R/W | √ | V | - | 00H | | FFF06H | Port register 6 | P6 | | R/W | √ | V | - | 00H | | FFF0CH | Port register 12 | P12 | | R/W<br>Note | $\sqrt{}$ | <b>V</b> | _ | Undefined | | FFF0DH | Port register 13 | P13 | | R | √ | <b>V</b> | - | Undefined | | FFF0EH | Port register 14 | P14 | | R/W | √ | √ | - | 00H | | FFF10H | Serial data register 00 | TXD0/<br>SIO00 | SDR00 | R/W | | <b>√</b> | √ | 0000H | | FFF11H | | = | 1 | | | - | 1 | | | FFF12H | Serial data register 01 | RXD0/<br>SIO01 | SDR01 | R/W | - | <b>V</b> | √ | 0000H | | FFF13H | | | 1 | | - | - | 1 | | | FFF18H | Timer data register 00 | TDR00 | • | R/W | = | = | √ | 0000H | | FFF19H | | | | | | | | | | FFF1AH | Timer data register 01 | TDR01L | TDR01 | R/W | - | √ | √ | 00H | | FFF1BH | | TDR01H | TDR01H | | _ | <b>V</b> | | 00H | | FFF1EH | 10-bit A/D conversion result register | ADCR | ADCR | | Ī | - | $\sqrt{}$ | 0000H | | FFF1FH | 8-bit A/D conversion result register | ADCRH | | R | | <b>√</b> | _ | 00H | | FFF20H | Port mode register 0 | PM0 | | R/W | √ | <b>V</b> | - | FFH | | FFF21H | Port mode register 1 | PM1 | | R/W | √ | <b>√</b> | - | FFH | | FFF22H | Port mode register 2 | PM2 | | R/W | √ | <b>√</b> | - | FFH | | FFF23H | Port mode register 3 | РМ3 | | R/W | √ | V | - | FFH | | FFF24H | Port mode register 4 | PM4 | | R/W | √ | √ | - | FFH | | FFF25H | Port mode register 5 | PM5 | | R/W | √ | V | - | FFH | | FFF26H | Port mode register 6 | PM6 | | R/W | √ | √ | - | FFH | | FFF2CH | Port mode register 12 | PM12 | | R/W | √ | V | - | FFH | | FFF2EH | Port mode register 14 | PM14 | | R/W | √ | V | - | FFH | | FFF30H | A/D converter mode register 0 | ADM0 | | R/W | √ | √ | - | 00H | | FFF31H | Analog input channel specification register | ADS | | R/W | √ | √ | _ | 00H | | FFF32H | A/D converter mode register 1 | ADM1 | | R/W | √ | √ | - | 00H | | FFF34H | Key return control register | KRCTL | | R/W | √ | √ | | 00H | | FFF35H | Key return flag register | KRF | | R/W | √ | √ | - | 00H | | FFF36H | Key return mode register 1 | KRM1 | | R/W | √ | √ | - | 00H | | FFF37H | Key return mode register 0 | KRM0 | | R/W | √ | √ | - | 00H | | FFF38H | External interrupt rising edge enable register 0 | EGP0 | | R/W | <b>V</b> | √ | | 00H | | FFF39H | External interrupt falling edge enable register 0 | EGN0 | | R/W | <b>V</b> | √ | - | 00H | Note Read only for 30-pin product. Table 3-6. SFR List (2/4) | Address | Special Function Register (SFR) Name | Syr | mbol | R/W | Manipulable Bit Range | | | After Reset | |---------|--------------------------------------------------------|----------------|-------|-----|-----------------------|-------|--------|-------------------------------| | | | | | | 1-bit | 8-bit | 16-bit | | | FFF44H | Serial data register 02 | TXD1/<br>SIO10 | SDR02 | R/W | - | √ | √ | 0000H | | FFF45H | | _ | | | _ | _ | | | | FFF46H | Serial data register 03 | RXD1/<br>SIO11 | SDR03 | R/W | - | √ | √ | 0000H | | FFF47H | | _ | | | _ | _ | | | | FFF48H | Serial data register 10 | TXD2/<br>SIO20 | SDR10 | R/W | = | √ | √ | 0000H | | FFF49H | | = | | | = | = | | | | FFF4AH | Serial data register 11 | RXD2/<br>SIO21 | SDR11 | R/W | - | √ | √ | 0000H | | FFF4BH | | - | | | - | _ | | | | 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 | $\sqrt{}$ | √ | = | 00H | | FFF64H | Timer data register 02 | TDR02 | | R/W | - | _ | √ | 0000H | | FFF65H | | | | | | | | | | 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 | _ | _ | √ | 0000H | | FFF6DH | | | | | | | | | | FFF6EH | Timer data register 07 | TDR07 | | R/W | - | _ | √ | 0000H | | FFF6FH | | | | | | | | | | FFF90H | Interval timer control register | ITMC | | R/W | _ | _ | √ | 0FFFH | | FFF91H | | | | | | | | | | FFFA0H | Clock operation mode control register | CMC | | R/W | _ | √ | _ | 00H | | FFFA1H | Clock operation status control register | CSC | | R/W | √ | √ | _ | C0H | | FFFA2H | Oscillation stabilization time counter status register | OSTC | | R | √ | √ | _ | 00H | | FFFA3H | Oscillation stabilization time select register | OSTS | | R/W | - | √ | _ | 07H | | FFFA4H | System clock control register | CKC | | R/W | $\sqrt{}$ | √ | _ | 00H | | FFFA5H | Clock output select register 0 | CKS0 | | R/W | $\sqrt{}$ | √ | _ | 00H | | FFFA6H | Clock output select register 1 | CKS1 | | R/W | √ | √ | _ | 00H | | FFFA8H | Reset control flag register | RESF | | R | = | √ | _ | Undefined Note 1 | | FFFA9H | Voltage detection register | LVIM | | R/W | √ | √ | _ | 00H Note 1 | | FFFAAH | Voltage detection level register | LVIS | | R/W | $\sqrt{}$ | √ | _ | 00H/01H/81H <sup>Note 1</sup> | | FFFABH | Watchdog timer enable register | WDTE | | R/W | = | √ | _ | 1A/9A Note 2 | | FFFACH | CRC input register | CRCIN | | R/W | - | √ | | 00H | Notes 1. The reset values of the registers vary depending on the reset source as shown below. | Registe | Reset Source | RESET Input | Reset by<br>POR | Reset by Execution of Illegal Instruction | Reset by<br>WDT | Reset by<br>RAM parity<br>error | Reset by<br>illegal-<br>memory<br>access | Reset by<br>LVD | | | | |---------|--------------|-------------|-----------------|-------------------------------------------|-----------------|---------------------------------|------------------------------------------|-----------------|--|--|--| | RESF | TRAP bit | Cleared (0) | | Set (1) | Held | | | Held | | | | | | WDTRF bit | | | Held | Set (1) | Held | | | | | | | | RPERF bit | | | Held | | Set (1) | Held | | | | | | | IAWRF bit | | | Held | | | Set (1) | | | | | | | LVIRF bit | | | Held | | | | Set (1) | | | | | LVIM | LVISEN bit | Cleared (0) | | | | | | Held | | | | | | LVIOMSK bit | Held | | | | | | | | | | | | LVIF bit | | | | | | | | | | | | LVIS | | | | | | | | | | | | 2. The reset value of the WDTE register is determined by the setting of the option byte. Table 3-6. SFR List (3/4) | Address | Special Function Register (SFR) Name | Sy | mbol | R/W | Manip | ulable Bit I | Range | After Reset | |---------|-----------------------------------------|-------|------|-----|--------------|--------------|--------------|-------------| | | | | | | 1-bit | 8-bit | 16-bit | | | FFFB0H | DMA SFR address register 0 | DSA0 | | R/W | 1 | √ | - | 00H | | FFFB1H | DMA SFR address register 1 | DSA1 | | R/W | 1 | √ | - | 00H | | FFFB2H | DMA RAM address register 0 | DRA0L | DRA0 | R/W | 1 | √ | √ | 00H | | FFFB3H | | DRA0H | | R/W | 1 | √ | | 00H | | FFFB4H | DMA RAM address register 1 | DRA1L | DRA1 | R/W | 1 | √ | √ | 00H | | FFFB5H | | DRA1H | | R/W | 1 | √ | | 00H | | FFFB6H | DMA byte count register 0 | DBC0L | DBC0 | R/W | 1 | √ | √ | 00H | | FFFB7H | | DBC0H | | R/W | - | √ | | 00H | | FFFB8H | DMA byte count register 1 | DBC1L | DBC1 | R/W | 1 | √ | √ | 00H | | FFFB9H | | DBC1H | | R/W | 1 | √ | | 00H | | FFFBAH | DMA mode control register 0 | DMC0 | | R/W | √ | √ | - | 00H | | FFFBBH | DMA mode control register 1 | DMC1 | | R/W | $\checkmark$ | √ | - | 00H | | FFFBCH | DMA operation control register 0 | DRC0 | | R/W | √ | √ | - | 00H | | FFFBDH | DMA operation control register 1 | DRC1 | | R/W | $\checkmark$ | √ | - | 00H | | FFFD0H | Interrupt request flag register 2 | IF2L | IF2 | R/W | $\checkmark$ | √ | $\checkmark$ | 00H | | FFFD1H | | IF2H | | R/W | $\checkmark$ | √ | | 00H | | FFFD4H | Interrupt mask flag register 2 | MK2L | MK2 | R/W | $\checkmark$ | √ | $\sqrt{}$ | FFH | | FFFD5H | | MK2H | | R/W | $\checkmark$ | √ | | FFH | | FFFD8H | Priority specification flag register 02 | PR02L | PR02 | R/W | $\checkmark$ | √ | √ | FFH | | FFFD9H | | PR02H | | R/W | √ | √ | | FFH | | FFFDCH | Priority specification flag register 12 | PR12L | PR12 | R/W | √ | √ | √ | FFH | | FFFDDH | | PR12H | | R/W | √ | √ | | FFH | Table 3-6. SFR List (4/4) | Address | Special Function Register (SFR) Name | Syı | mbol | R/W | Manip | ulable Bit | Range | After Reset | |---------|---------------------------------------------|-------|------|-----|----------|------------|-----------|-------------| | | | | | • | 1-bit | 8-bit | 16-bit | | | FFFE0H | Interrupt request flag register 0 | IF0L | IF0 | R/W | √ | √ | <b>V</b> | 00H | | FFFE1H | | IF0H | | R/W | √ | √ | 1 | 00H | | FFFE2H | Interrupt request flag register 1 | IF1L | IF1 | R/W | √ | √ | <b>√</b> | 00H | | FFFE3H | | IF1H | | R/W | √ | √ | | 00H | | FFFE4H | Interrupt mask flag register 0 | MK0L | MK0 | R/W | √ | √ | √ | FFH | | FFFE5H | | MK0H | | R/W | √ | √ | | FFH | | FFFE6H | Interrupt mask flag register 1 | MK1L | MK1 | R/W | √ | √ | √ | FFH | | FFFE7H | | MK1H | | R/W | √ | √ | 1 | FFH | | FFFE8H | Priority specification flag register 00 | PR00L | PR00 | R/W | √ | √ | √ | FFH | | FFFE9H | | PR00H | | R/W | √ | √ | | FFH | | FFFEAH | Priority specification flag register 01 | PR01L | PR01 | R/W | √ | √ | √ | FFH | | FFFEBH | | PR01H | | R/W | √ | √ | | FFH | | FFFECH | Priority specification flag register 10 | PR10L | PR10 | R/W | √ | √ | √ | FFH | | FFFEDH | | PR10H | | R/W | <b>V</b> | √ | | FFH | | FFFEEH | Priority specification flag register 11 | PR11L | PR11 | R/W | √ | √ | √ | FFH | | FFFEFH | | PR11H | | R/W | √ | √ | 1 | FFH | | FFFF0H | Multiplication/division data register A (L) | MDAL | | R/W | _ | _ | √ | 0000H | | FFFF1H | | | | | | | | | | FFFF2H | Multiplication/division data register A (H) | MDAH | | R/W | _ | _ | √ | 0000H | | FFFF3H | | | | | | | | | | FFFF4H | Multiplication/division data register B (H) | MDBH | | R/W | = | = | √ | 0000H | | FFFF5H | | | | | | | | | | FFFF6H | Multiplication/division data register B (L) | MDBL | | R/W | - | _ | $\sqrt{}$ | 0000H | | FFFF7H | | | | | | , | | | | FFFFEH | Processor mode control register | PMC | | R/W | √ | | - | 00H | Remark For extended SFRs (2nd SFRs), see Table 3-7 Extended SFR (2nd SFR) List. ### 3.2.5 Extended special function registers (2nd SFRs: 2nd Special Function Registers) Unlike a general-purpose register, each extended SFR (2nd 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 the symbol reserved by the assembler for the 1-bit manipulation instruction operand (!addr16.bit). This manipulation can also be specified with an address. ## · 8-bit manipulation Describe the symbol reserved 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 reserved by the assembler for the 16-bit manipulation instruction operand (laddr16). When specifying an address, describe an even address. Table 3-7 gives a list of the extended SFRs. The meanings of items in the table are as follows. #### Symbol Symbol indicating 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 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 " $\sqrt{}$ " indicates the manipulable bit unit (1, 8, or 16). "-" indicates a bit unit for which manipulation is not possible. #### After reset 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). Table 3-7. Extended SFR (2nd SFR) List (1/5) | Address | Special Function Register (SFR) Name | Symbol | R/W | Manipulable Bit Range | | | After Reset | |---------|------------------------------------------------------------|---------|-----|-----------------------|--------------|--------|------------------| | | | | | 1-bit | 8-bit | 16-bit | | | F0010H | A/D converter mode register 2 | ADM2 | R/W | $\checkmark$ | $\checkmark$ | - | 00H | | F0011H | Conversion result comparison upper limit setting register | ADUL | R/W | - | √ | _ | FFH | | F0012H | Conversion result comparison lower limit setting register | ADLL | R/W | = | √ | _ | 00H | | F0013H | A/D test register | ADTES | R/W | = | <b>V</b> | _ | 00H | | F0030H | Pull-up resistor option register 0 | PU0 | R/W | V | <b>V</b> | - | 00H | | F0031H | Pull-up resistor option register 1 | PU1 | R/W | V | <b>V</b> | _ | 00H | | F0033H | Pull-up resistor option register 3 | PU3 | R/W | V | <b>√</b> | _ | 00H | | F0034H | Pull-up resistor option register 4 | PU4 | R/W | V | <b>V</b> | _ | 01H | | F0035H | Pull-up resistor option register 5 | PU5 | R/W | V | <b>V</b> | _ | 00H | | F0037H | Pull-up resistor option register 7 | PU7 | R/W | V | <b>V</b> | - | 00H | | F003CH | Pull-up resistor option register 12 | PU12 | R/W | V | <b>V</b> | - | 00H/20H Note 3 | | F003EH | Pull-up resistor option register 14 | PU14 | R/W | V | <b>V</b> | _ | 00H | | F0040H | Port input mode register 0 | PIM0 | R/W | V | <b>√</b> | = | 00H | | F0041H | Port input mode register 1 | PIM1 | R/W | V | <b>√</b> | = | 00H | | F0050H | Port output mode register 0 | POM0 | R/W | V | <b>V</b> | - | 00H | | F0051H | Port output mode register 1 | POM1 | R/W | V | <b>√</b> | = | 00H | | F0054H | Port output mode register 4 | POM4 | R/W | V | <b>V</b> | - | 00H | | F0055H | Port output mode register 5 | POM5 | R/W | V | <b>V</b> | _ | 00H | | F0060H | Port mode control register 0 | PMC0 | R/W | V | <b>V</b> | - | FFH | | F0061H | Port mode control register 1 | PMC1 | R/W | V | <b>V</b> | - | FFH | | F0064H | Port mode control register 4 | PMC4 | R/W | V | <b>V</b> | - | FFH | | F006CH | Port mode control register 12 | PMC12 | R/W | V | <b>√</b> | = | FFH | | F006EH | Port mode control register 14 | PMC14 | R/W | V | <b>√</b> | = | FFH | | F0070H | Noise filter enable register 0 | NFEN0 | R/W | V | <b>√</b> | = | 00H | | F0071H | Noise filter enable register 1 | NFEN1 | R/W | V | <b>√</b> | = | 00H | | F0074H | Timer input select register 0 | TIS0 | R/W | - | <b>√</b> | = | 00H | | F0076H | A/D port configuration register | ADPC | R/W | - | <b>V</b> | - | 00H | | F0077H | Peripheral I/O redirection register | PIOR | R/W | - | <b>√</b> | = | 00H | | F0078H | Invalid memory access detection control register | IAWCTL | R/W | _ | V | _ | 00H | | F0090H | Data flash control register | DFLCTL | R/W | $\sqrt{}$ | √ | - | 00H | | F00A0H | High-speed on-chip oscillator trimming register | HOTRM | R/W | _ | V | _ | Undefined Note 1 | | F00A8H | High-speed on-chip oscillator frequency selecting register | HOCODIV | R/W | _ | 1 | _ | Undefined Note 2 | | F00E0H | Multiplication/division data register C (L) | MDCL | R/W | - | - | √ | 0000H | | F00E2H | Multiplication/division data register C (H) | MDCH | R/W | _ | _ | √ | 0000H | | F00E8H | Multiplication/division control register | MDUC | R/W | $\checkmark$ | | - | 00H | Notes 1. The value after a reset is adjusted at the time of shipment. 3. The value after a reset is 20H in 20- and 24-pin products. <sup>2.</sup> The value after a reset is a value set in FRQSEL2 to FRQSEL0 of the option byte (000C2H). Table 3-7. Extended SFR (2nd SFR) List (2/5) | Address | Special Function Register (SFR) Name | Syr | nbol | R/W | Manip | ulable Bit | Range | After Reset | |---------|----------------------------------------|--------|-------|-----|-------|------------|--------------|-------------| | | | | | | 1-bit | 8-bit | 16-bit | | | F00F0H | Peripheral enable register 0 | PER0 | | R/W | √ | <b>V</b> | - | 00H | | F00F3H | Operation speed mode control register | OSMC | OSMC | | _ | <b>V</b> | _ | 00H | | F00F5H | RAM parity error control register | RPECTL | | R/W | √ | <b>V</b> | _ | 00H | | F00FEH | BCD adjust result register | BCDADJ | | R | _ | <b>V</b> | - | Undefined | | F0100H | Serial status register 00 | SSR00L | SSR00 | R | _ | <b>V</b> | √ | 0000H | | F0101H | | _ | | | _ | _ | 1 | | | F0102H | Serial status register 01 | SSR01L | SSR01 | R | _ | <b>V</b> | <b>√</b> | 0000H | | F0103H | | _ | | | _ | _ | 1 | | | F0104H | Serial status register 02 | SSR02L | SSR02 | R | - | V | √ | 0000H | | F0105H | | _ | | | - | - | | 0000H | | F0106H | Serial status register 03 | SSR03L | SSR03 | R | - | V | √ | 0000H | | F0107H | 1 | _ | İ | | - | - | 1 | 0000H | | F0108H | Serial flag clear trigger register 00 | SIR00L | SIR00 | R/W | = | √ | V | 0000H | | F0109H | | = | | | = | = | 1 | | | F010AH | Serial flag clear trigger register 01 | SIR01L | SIR01 | R/W | = | √ | V | 0000H | | F010BH | | _ | | | - | - | | | | F010CH | Serial flag clear trigger register 02 | SIR02L | SIR02 | R/W | - | √ | √ | 0000H | | F010DH | | _ | | | - | _ | | | | F010EH | Serial flag clear trigger register 03 | SIR03L | SIR03 | R/W | - | <b>V</b> | <b>√</b> | 0000H | | F010FH | | _ | | | - | _ | | | | F0110H | Serial mode register 00 | SMR00 | | R/W | - | - | √ | 0020H | | F0111H | | | | | | | | | | F0112H | Serial mode register 01 | SMR01 | | R/W | = | = | V | 0020H | | F0113H | | | | | | | | | | F0114H | Serial mode register 02 | SMR02 | | R/W | _ | _ | $\checkmark$ | 0020H | | F0115H | | | | | | | | | | F0116H | Serial mode register 03 | SMR03 | | R/W | - | - | $\sqrt{}$ | 0020H | | F0117H | | | | | | | | | | F0118H | Serial communication operation setting | SCR00 | | R/W | = | = | $\sqrt{}$ | 0087H | | F0119H | register 00 | | | | | | | | | F011AH | Serial communication operation setting | SCR01 | | R/W | _ | _ | $\sqrt{}$ | 0087H | | F011BH | register 01 | | | | | | , | | | F011CH | Serial communication operation setting | SCR02 | | R/W | _ | _ | $\sqrt{}$ | 0087H | | F011DH | register 02 | | | | | | | | | F011EH | Serial communication operation setting | SCR03 | | R/W | _ | _ | $\sqrt{}$ | 0087H | | F011FH | register 03 | | | | | | | | Table 3-7. Extended SFR (2nd SFR) List (3/5) | Address | Special Function Register (SFR) Name | Svr | nbol | R/W | Manir | oulable Bit | Range | After Reset | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---------------|-----------|-------------|----------|-------------| | | green and a second control of the con | | | | 1-bit | 8-bit | 16-bit | | | F0120H | Serial channel enable status register 0 | SE0L | SE0 | R | √ | √ | √ | 0000H | | F0121H | Conditional more chable status register s | - | 020 | | | | † ` | 000011 | | F0122H | Serial channel start register 0 | SS0L | SS0 | R/W | √ | <b>√</b> | V | 0000H | | F0123H | - Conditional monature register o | - | 1 | 10,00 | | _ | · | 000011 | | F0124H | Serial channel stop register 0 | ST0L | ST0 | R/W | √ | V | V | 0000H | | F0125H | Contai onarmoi stop register o | - | 0.0 | 10,00 | | | · | 000011 | | F0126H | Serial clock select register 0 | SPS0L | SPS0 | R/W | _ | √ | V | 0000H | | F0127H | Geriai Glock Sciect register o | - | 01 00 | 11/00 | _ | _ | · | 000011 | | F0128H | Serial output register 0 | SO0 | | R/W | _ | | <b>√</b> | 0F0FH | | F0129H | Geriai output register o | 300 | | 1 1/ V V | | _ | <b>'</b> | 01 01 11 | | F012AH | Serial output enable register 0 | SOE0L | SOE0 | R/W | √ | <b>√</b> | <b>√</b> | 0000H | | F012BH | Geriai output eriable register o | JOLUL | JOLU | 1 1/ V V | · · · | · · | 1 | 000011 | | F012BH | Serial output level register 0 | SOL0L | SOL0 | R/W | | | <b>√</b> | 0000H | | F013411 | Serial output level register o | SOLUL | SOLU | Π/ <b>V V</b> | | _ v | - ' | 000011 | | F0138H | Sorial atandhy control register 0 | SSC0L | SSC0 | R/W | | | √ | 0000H | | FU138FI | Serial standby control register 0 | SSCOL | 3300 | H/VV | | | · | 00000 | | E04.4011 | Carial status vanistas 10 | - | CCD40 | Г | _ | | <b>√</b> | 000011 | | F0140H | Serial status register 10 | SSR10L | SSR10 | R | | ٧ | · 1 | 0000H | | F0141H | Operior I also have no existent 44 | - | 00044 | | | - | .1 | 000011 | | F0142H | Serial status register 11 | SSR11L | SSR11 | R | = | √ | √ | 0000H | | F0143H | 0 : 10 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | - | OID40 | D 444 | | - | , | 200011 | | F0148H | Serial flag clear trigger register 10 | SIR10L | SIR10 | R/W | _ | √ | √ | 0000H | | F0149H | | - | 015.1 | | | - | , | | | F014AH | Serial flag clear trigger register 11 | SIR11L | SIR11 | R/W | _ | √ | √ | 0000H | | F014BH | | - | | | | - | , | | | F0150H | Serial mode register 10 | SMR10 | | R/W | | - | √ | 0020H | | F0151H | | | | | | | , | | | F0152H | Serial mode register 11 | SMR11 | | R/W | _ | - | √ | 0020H | | F0153H | | | | | | | , | | | F0158H | Serial communication operation setting | SCR10 | | R/W | _ | - | √ | 0087H | | F0159H | register 10 | | | | | | , | | | F015AH | Serial communication operation setting | SCR11 | | R/W | | = | √ | 0087H | | F015BH | register 11 | | 1 | | | , | , | | | F0160H | Serial channel enable status register 1 | SE1L | SE1 | R | √ | √ | √ | 0000H | | F0161H | | - | | | - | - | , | | | F0162H | Serial channel start register 1 | SS1L | SS1 | R/W | √ | √ | √ | 0000H | | F0163H | | | | | _ | - | , | | | F0164H | Serial channel stop register 1 | ST1L | ST1 | R/W | √ | √ | √ | H0000 | | F0165H | | _ | | | - | | , | | | F0166H | Serial clock select register 1 | SPS1L | SPS1 | R/W | | V | √ | H0000 | | F0167H | | _ | | | - | | | | | F0168H | Serial output register 1 | SO1 | | R/W | | | √ | 0F0FH | | F0169H | | | | | | | | | | F016AH | Serial output enable register 1 | SOE1L | SOE1 | R/W | $\sqrt{}$ | √ | √ | 0000H | | F016BH | | _ | | | - | _ | | | | F0174H | Serial output level register 1 | SOL1L | SOL1 | R/W | _ | √ | √ | 0000H | | F0175H | | = | | | = | = | | | Table 3-7. Extended SFR (2nd SFR) List (4/5) | Address | Special Function Register (SFR) Name | Symbol | R/W | Manip | oulable Bit | Range | After Reset | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------|-------|-------------|-----------|-------------| | | . , , , , , | | | 1-bit | 8-bit | 16-bit | | | F0180H | Timer counter register 00 | TCR00 | R | _ | _ | √ | FFFFH | | F0181H | J | | | | | | | | F0182H | Timer counter register 01 | TCR01 | R | - | - | √ | FFFFH | | F0183H | | | | | | | | | F0184H | Timer counter register 02 | TCR02 | R | 1 | - | √ | FFFFH | | F0185H | | | | | | | | | F0186H | Timer counter register 03 | TCR03 | R | - | = | √ | FFFFH | | F0187H | | | | | | | | | F0188H | Timer counter register 04 | TCR04 | R | _ | - | $\sqrt{}$ | FFFFH | | F0189H | | | | | | | | | F018AH | Timer counter register 05 | TCR05 | R | _ | _ | $\sqrt{}$ | FFFFH | | F018BH | | | | | | , | | | F018CH | Timer counter register 06 | TCR06 | R | _ | _ | $\sqrt{}$ | FFFFH | | F018DH | | | | | | | | | F018EH | Timer counter register 07 | TCR07 | R | _ | - | $\sqrt{}$ | FFFFH | | F018FH | | TMD | 5.00 | | | , | | | F0190H | Timer mode register 00 | TMR00 | R/W | - | _ | √ | 0000H | | F0191H | | TMD04 | 5.047 | | | | 000011 | | F0192H | Timer mode register 01 | TMR01 | R/W | _ | _ | √ | 0000H | | F0193H | Times mede verilates 00 | TMP00 | D/4/ | | | √ V | 000011 | | F0194H<br>F0195H | Timer mode register 02 | TMR02 | R/W | _ | = | V | 0000H | | F0195H | Timer mode register 03 | TMR03 | R/W | | | √ V | 0000H | | F0196H<br>F0197H | Timer mode register os | TIVINUS | I I / VV | _ | = | V | ООООН | | F019711 | Timer mode register 04 | TMR04 | R/W | _ | _ | √ | 0000H | | F0199H | Time mode register of | TWITIO | 1000 | | | ' | 000011 | | F019AH | Timer mode register 05 | TMR05 | R/W | | _ | √ | 0000H | | F019BH | - ···································· | | | | | , | | | F019CH | Timer mode register 06 | TMR06 | R/W | _ | _ | √ | 0000H | | F019DH | Times made register of | 11111100 | 1000 | | | , | 000011 | | F019EH | Timer mode register 07 | TMR07 | R/W | | | <b>√</b> | 0000H | | | Timer mode register 07 | TWITTO | 11/00 | = | _ | , v | 000011 | | F019FH | Time and the second state of | TODON TODON | | | .1 | .1 | 000011 | | 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 | - | $\sqrt{}$ | $\sqrt{}$ | 0000H | | F01A5H | | - | | 1 | _ | | | | F01A6H | Timer status register 03 | TSR03L TSR03 | R | 1 | √ | √ | 0000H | | F01A7H | | | | = | = | | | | F01A8H | Timer status register 04 | TSR04L TSR04 | R | - | V | √ | 0000H | | F01A9H | 1 | _ | | _ | = | 1 | | | F01AAH | Timer status register 05 | TSR05L TSR05 | R | _ | √ | <b>√</b> | 0000H | | F01ABH | Times states regions as | | '' | | <u> </u> | ┪ ` ┃ | 5555.1 | | F01ACH | Timer status register 06 | TSR06L TSR06 | R | _ | | √ | 0000H | | | Timer status register 06 | | n | = | | - · | UUUUT | | F01ADH | | -<br>TODOT! TODOT | + _ | - | - | 1 | 000011 | | F01AEH | Timer status register 07 | TSR07L TSR07 | R | = | √ | √ | H0000 | | F01AFH | | - | | - | - | | | Table 3-7. Extended SFR (2nd SFR) List (5/5) | Address | Special Function Register (SFR) Name | Syr | nbol | R/W | Manip | ulable Bit l | Range | After Reset | |---------|------------------------------------------|----------|------|-----|-----------|--------------|--------------|-------------| | | | | | - | 1-bit | 8-bit | 16-bit | | | F01B0H | Timer channel enable status register 0 | TE0L | TE0 | R | √ | √ | √ | 0000H | | F01B1H | | - | | | - | - | | | | F01B2H | Timer channel start register 0 | TS0L | TS0 | R/W | √ | √ | √ | 0000H | | F01B3H | | - | | | - | - | | | | F01B4H | Timer channel stop register 0 | TT0L | TT0 | R/W | $\sqrt{}$ | √ | $\checkmark$ | 0000H | | F01B5H | | - | | | - | - | | | | F01B6H | Timer clock select register 0 | TPS0 | | R/W | - | - | $\checkmark$ | 0000H | | F01B7H | | | | | | | | | | F01B8H | Timer output register 0 | TO0L | TO0 | R/W | - | √ | √ | 0000H | | F01B9H | | _ | | | - | _ | | | | F01BAH | Timer output enable register 0 | TOE0L | TOE0 | R/W | √ | √ | √ | 0000H | | F01BBH | | _ | | | - | _ | | | | F01BCH | Timer output level register 0 | TOL0L | TOL0 | R/W | - | √ | √ | 0000H | | F01BDH | | - | | | - | - | | | | F01BEH | Timer output mode register 0 | TOM0L | TOM0 | R/W | - | √ | √ | 0000H | | F01BFH | | _ | | | - | _ | | | | F0230H | IICA control register 00 | IICCTL00 | ) | R/W | √ | √ | - | 00H | | F0231H | IICA control register 01 | IICCTL01 | | R/W | √ | √ | - | 00H | | F0232H | IICA low-level width setting register 0 | IICWL0 | | R/W | - | √ | | FFH | | F0233H | IICA high-level width setting register 0 | IICWH0 | | R/W | _ | √ | - | FFH | | F0234H | Slave address register 0 | SVA0 | | R/W | _ | √ | - | 00H | | F02FAH | CRC data register | CRCD | | R/W | _ | _ | √ | 0000H | Remark For SFRs in the SFR area, see Table 3-6 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-15. 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-16. Example of CALL !!addr20/BR !!addr20 Figure 3-17. 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 RL78 microcontrollers, branching is enabled only to the 64 KB space from 00000H to 0FFFFH. Figure 3-18. Outline of Table Indirect Addressing ## 3.3.4 Register direct 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 direct addressing can be applied only to the CALL AX, BC, DE, HL, and BR AX instructions. OP code CS rp PC PCs PCH PCL Figure 3-19. Outline of Register Direct Addressing # 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. Figure 3-20. Outline of Implied Addressing # 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. | Ident | tifier | Description | |-------|--------|------------------------| | r | | X, A, C, B, E, D, L, H | | rp | ) | AX, BC, DE, HL | Figure 3-21. 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: automatically added F of higher 4-bit addresses) | | ES: ADDR16 | Label or 16-bit immediate data (higher 4-bit addresses are specified by the ES register) | Figure 3-22. Example of ADDR16 Figure 3-23. Example of ES:ADDR16 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 or FFE20H to FFF1FH immediate data | | | SADDRP | Label or FFE20H to FFF1FH immediate data (only even address is specifiable.) | | Figure 3-24. Outline of Short Direct Addressing **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. | Identifier | Description | | |------------|----------------------------------------------|--| | SFR | SFR name | | | SFRP | 16-bit-manipulatable SFR name (even address) | | Figure 3-25. 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. | | 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) | | | Figure 3-26. Example of [DE], [HL] Figure 3-27. Example of ES:[DE], ES:[HL] # 3.4.7 Based addressing ## [Function] Based addressing uses the contents of a register pair specified with the instruction word 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. | 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-28. Example of [SP+byte] [HL + byte], [DE + byte] <1> <2> <1> <2> **FFFFFH** Instruction code Target OP-code Target memory <2> Offset array of data <2> byte <1> Address of Other data in an array the array rp(HL/DE) F0000H • Either pair of registers <1> specifies the address where the target array of data starts in the 64-Kbyte area from F0000H to FFFFFH. "byte" <2> specifies an offset within the array to the target location in memory. Memory Figure 3-29. Example of [HL + byte], [DE + byte] Figure 3-30. Example of word[B], word[C] Figure 3-31. Example of word[BC] ES: [HL + byte], ES: [DE + byte] <1> <2> <3> <1> <2> XFFFFH Instruction code <2> <3> Target memory Target OP-code array Offset <3> byte of data <2> Address of Other data in an array rp(HL/DE) the array X0000H X0000H Specifies a 64-Kbyte area ES • The ES register <1> specifies a 64-Kbyte area within the overall 1-Mbyte space as the four higher-order bits, X, of the address range. Memory Either pair of registers <2> specifies the address where the target array of data starts in the 64-Kbyte Figure 3-32. Example of ES:[HL + byte], ES:[DE + byte] Figure 3-33. Example of ES:word[B], ES:word[C] "word" <2> specifies the address where the target array of word-sizeddata starts in the 64-Kbyte area specified in the ES register <1>. area specified in the ES register <1>. target location in memory. "byte" <3> specifies an offset within the array to the Either register <3> specifies an offset within the array to the target location in memory. ES: word [BC] <1> <2> <3> XFFFFH Array of Instruction code Target memory <3> word-sized Offset data OP-code rp(BC) <2 Low Addr. Address of a word within an array X0000H High Addr. X0000H <1> Specifies a 64-Kbyte area ES • The ES register <1> specifies a 64-Kbyte area within the overall 1-Mbyte space as the four higher-order bits, X, of the address range. Figure 3-34. Example of ES:word[BC] "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>. 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. | 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-35 Example of [HL+B], [HL+C] Figure 3-36. Example of ES:[HL+B], ES:[HL+C] - A pair of registers <2> specifies the address where the 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 the target location in memory. ### 3.4.9 Stack addressing # [Function] The stack area is indirectly addressed with the stack pointer (SP) contents. 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. Stack addressing is applied only to the internal RAM area. # [Operand format] | Identifier | Description | | |------------|------------------------------------|--| | - | PUSH AX/BC/DE/HL | | | | POP AX/BC/DE/HL | | | | CALL/CALLT | | | | RET | | | | BRK | | | | RETB (Interrupt request generated) | | | | RETI | | Each stack operation saves or restores data as shown in Figures 3-37 to 3-42. PUSH <1> <2> SP Higher-order byte of rp SP - 1 Instruction code Stack area <3> SP - 2 Lower-order byte of rp OP-code SP r.p F0000H Stack addressing is specified <1>. The higher-order and lower-order bytes of the pair of registers indicated by rp <2> are stored in addresses SP - 1 and SP - 2, respectively. • The value of SP <3> is decreased by two (if rp is the program Memory status word (PSW), the value of the PSW is stored in SP - 1 and Figure 3-37. Example of PUSH rp 0 is stored in SP - 2). POP rp <1> <2> SP+2 SP SP+1 (SP+1) Stack Instruction code area (SP) SP <2> OP-code SP F0000H • Stack addressing is specified <1>. • The contents of addresses SP and SP + 1 are stored in the lower-order and higher-order bytes of the pair of registers indicated by rp <2>, respectively. Memory • The value of SP <3> is increased by two (if rp is the program Figure 3-38. Example of POP Figure 3-39. Example of CALL, CALLT • 00H, the values of 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>. status word (PSW), the content of address SP + 1 is stored in the PSW). • The value of the SP <3> is decreased by 4. • The value of SP <3> is increased by four. RET <1> SP+4 <1> SP+3 (SP+3) Instruction code SP+2 (SP+2) Stack OP-code area (SP+1) SP+1 <3> SP (SP) SP <2> F0000H РС • Stack addressing is specified <1>. • The contents of addresses SP, SP + 1, and SP + 2 are stored in PC bits 7 to 0, 15 to 8, and 19 to 16, respectively <2>. Memory Figure 3-40. Example of RET Figure 3-41. Example of Interrupt, BRK 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-42. Example of RETI, RETB • The value of SP <3> is increased by four. ## **CHAPTER 4 PORT FUNCTIONS** ### 4.1 Port Functions The RL78 microcontrollers are 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. Table 4-1. Port Configuration | Item | Configuration | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Control registers | Port mode registers (PM0 to PM6, PM12, PM14) Port registers (P0 to P06, P12 to P14) Pull-up resistor option registers (PU0, PU1, PU3 to PU5, PU12, PU14) Port input mode register (PIM0, PIM1) Port output mode registers (POM0, POM1, POM4, POM5) Port mode control registers (PMC0, PMC1, PMC4, PMC12, PMC14) A/D port configuration register (ADPC) Peripheral I/O redirection register (PIOR) | | Port | • 20-pin products Total: 18 (CMOS I/O: 12, (N-ch open drain I/O [VDD tolerance]: 4), CMOS input: 4, N-ch open drain I/O [6V tolerance]: 2) | | | • 24-pin products Total: 22 (CMOS I/O: 16, (N-ch open drain I/O [VDD tolerance]: 5), CMOS input: 4, N-ch open drain I/O [6V tolerance]: 2) | | | • 30-pin products Total: 26 (CMOS I/O: 21, (N-ch open drain I/O [VDD tolerance]: 9), CMOS input: 3, N-ch open drain I/O [6V tolerance]: 2) | | Pull-up resistor | <ul> <li>20-pin products</li> <li>24-pin products</li> <li>30-pin products</li> <li>Total: 13</li> <li>Total: 17</li> </ul> | **Caution** Most of the following descriptions in this chapter use the R5F102 products. ## 4.2.1 20, 24-pin products ### 4.2.1.1 Port 0 Port 0 is an I/O port with an output latch (with 24-pin products). Port 0 can be set to the input mode or output mode in 1-bit units by using port mode register 0 (PM0). When the P00 to P03 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 0 (PU0). Output from the P01 pin can be specified as N-ch open-drain output (V<sub>DD</sub> tolerance) in 1-bit units by using port output mode register 0 (POM0). This port can also be used for key return input, serial interface data I/O, and clock I/O. Reset signal generation sets port 0 to input mode. #### 4.2.1.2 Port 1 Port 1 is an I/O port with an output latch. Port 1 can be set to the input mode or output mode in 1-bit units by using port mode register 1 (PM1). When the P10 to P14 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 1 (PU1). Input to the P10 and P11 pins can be specified through a normal input buffer or a TTL input buffer in 1-bit units by using port input mode register 1 (PIM1). Output from the P10 to P12 pins can be specified as N-ch open-drain output (VDD tolerance) in 1-bit units by using port output mode register 1 (POM1). The P10 to P14 pins can be specified for digital I/O or analog input in 1-bit units by using the port mode control register 1 (PMC1). This port can also be used for analog input, clock/buzzer output, serial interface data I/O, clock I/O, transmission/reception of programming UART, timer I/O, and external interrupt request input. Reset signal generation sets port 1 to analog input. ## 4.2.1.3 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 by using port mode register 2 (PM2). This port can also be used for A/D converter analog input and reference voltage input (+ side and - side). To use the P20/ANI0 to P23/ANI3 pins as a digital I/O port, set them in the digital I/O mode by using the A/D port configuration register (ADPC). Use these pins starting from the upper bit. To use the P20/ANI0 to P23/ANI3 pins as an analog input port, set them in the analog input mode by using the A/D port configuration register (ADPC) and in the input mode by using the PM2 register. Use these pins starting from the lower bit. | ADPC Register | PM2 Register | ADS Register | P20/ANI0 to P23/ANI3 Pins | |------------------------|--------------|----------------------|------------------------------------| | Digital I/O selection | Input mode | - | Digital input | | | Output mode | _ | Digital output | | Analog input selection | Input mode | Selects ANI. | Analog input (to be converted) | | | | Does not select ANI. | Analog input (not to be converted) | | | Output mode | Selects ANI. | Setting prohibited | | | | Does not select ANI. | | Table 4-2. Setting Functions of P20/ANI0 to P23/ANI3 Pins Reset signal generation sets all the P20/ANI0 to P23/ANI3 pins to analog input. #### 4.2.1.4 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 by using port mode register 4 (PM4). When the P40 to P42 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 4 (PU4). Output from the P41 pin can be specified as N-ch open-drain output (VDD tolerance) by using port output mode register 4 (POM4). The P41 and P42 pins can be specified for digital I/O or analog input in 1-bit units by using the port mode control register 4 (PMC4). This port can also be used for key return input, data I/O for a flash memory programmer/debugger, analog input, serial interface data I/O, clock I/O, timer I/O, and external interrupt request input. Reset signal generation sets port 4 to input mode (the P41 and P42 pins are analog input). #### 4.2.1.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 by using port mode register 6 (PM6). The output of the P60 and P61 pins is N-ch open-drain output (6-V tolerance). This port can also be used for key return input, serial interface data I/O, and clock I/O. Reset signal generation sets port 6 to input mode. #### 4.2.1.6 Port 12 Port 12 is a 3-bit input-only port. Use of an on-chip pull-up resistor can be specified for the P125 pin by using pull-up resistor option register 12 (PU12) (the on-chip pull-up resistor is valid after the RESET pin (PORTSELB = 1) is selected). This port can also be used for key return input, connecting resonator for main system clock, external clock input for main system clock, and reset input. **Caution** After the power is turned on, P125 functions as RESET input. Even if an internal reset signal is released by power-on-reset (POR), the reset status continues as long as the low level is output to this pin. To use P125/KR1/SI01, select the port function (PORTSELB = 0) by the option byte (000C1H) and clear all reset sources. ## 4.2.1.7 Port 13 Port 13 is a 1-bit input-only port. This port can also be used for external interrupt request input. # 4.2.2 30-pin products #### 4.2.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 by using the port mode register 0 (PM0). When the P00 and P01 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 0 (PU0). Input to the P01 pin can be specified through a normal input buffer or a TTL input buffer by using the port input mode register 0 (PIM0). Output from the P00 pin can be specified as N-ch open-drain output (V<sub>DD</sub> tolerance) in 1-bit units by using the port output mode register 1 (POM1). The P00 and P01 pins can be specified for digital I/O or analog input in 1-bit units by using the port mode control register 1 (PMC1). This port can also be used for timer I/O, analog input of A/D converter, and serial interface data I/O. Reset signal generation sets port 0 to analog input. #### 4.2.2.2 Port 1 Port 1 is an I/O port with an output latch. Port 1 can be set to the input mode or output mode in 1-bit units by using port mode register 1 (PM1). When the P10 to P17 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 1 (PU1). Input to the P10, P11, P13 to P17 pins can be specified through a normal input buffer or a TTL input buffer in 1-bit units by using port input mode register 1 (PIM1). Output from the P10 to P15, P17 pins can be specified as N-ch open-drain output (V<sub>DD</sub> tolerance) in 1-bit units by using port output mode register 1 (POM1). This port can also be used for serial interface data I/O, clock I/O, transmission/reception of programming UART, timer I/O, clock/buzzer output, and external interrupt request input. Reset signal generation sets port 1 to input mode. #### 4.2.2.3 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 by using port mode register 2 (PM2). This port can also be used for A/D converter analog input and reference voltage input (+ side and - side). To use the P20/ANI0 to P23/ANI3 pins as a digital I/O port, set them in the digital I/O mode by using the A/D port configuration register (ADPC). Use these pins starting from the upper bit. To use the P20/ANI0 to P23/ANI3 pins as an analog input port, set them in the analog input mode by using the ADPC register and in the input mode by using the PM2 register. Use these pins starting from the lower bit. | ADPC Register | PM2 Register | ADS Register | P20/ANI0 to P23/ANI3 Pins | |------------------------|--------------|----------------------|------------------------------------| | Digital I/O selection | Input mode | - | Digital input | | | Output mode | _ | Digital output | | Analog input selection | Input mode | Selects ANI. | Analog input (to be converted) | | | | Does not select ANI. | Analog input (not to be converted) | | | Output mode | Selects ANI. | Setting prohibited | | | | Does not select ANI. | | Table 4-3. Setting Functions of P20/ANI0 to P23/ANI3 Pins Reset signal generation sets port 2 to analog input. #### 4.2.2.4 Port 3 Port 3 is an I/O port with an output latch. Port 3 can be set to the input mode or output mode in 1-bit units by using port mode register 3 (PM3). When this port 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 3 (PU3). This port can also be used for external interrupt request input, serial interface data I/O, clock I/O, clock/buzzer output, and timer I/O. Reset signal generation sets port 3 to input mode. #### 4.2.2.5 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 using port mode register 4 (PM4). When this port is used as an input port, use of an on-chip pull-up resistor can be specified 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 mode. #### 4.2.2.6 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 by using port mode register 5 (PM5). When the P50 and P51 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). Output from the P50 pin can be specified as N-ch open-drain output (VDD tolerance) using port output mode register 5 (POM5). This port can also be used for external interrupt request input and serial interface data I/O. Reset signal generation sets port 5 to input mode. ### 4.2.2.7 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 by using port mode register 6 (PM6). The output of the P60 and P61 pins is N-ch open-drain output (6-V tolerance). This port can also be used for serial interface data I/O and clock I/O. Reset signal generation sets port 6 to input mode. #### 4.2.2.8 Port 12 The P120 pin is a 1-bit I/O port with an output latch. Port 12 can be set to the input mode or output mode using port mode register 12 (PM12). When the P120 pin is used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 12 (PU12). The P120 pin can be specified for digital I/O or analog input by using the port mode control register 12 (PMC12). The P121 and P122 pins are 2-bit input-only ports. This port can also be used for A/D converter analog input, connecting resonator for main system clock, and external clock input for main system clock. Reset signal generation sets P120 to analog input, and sets P121 and P122 to input mode. ### 4.2.2.9 Port 13 Port 13 is a 1-bit input-only port. This port can also be used for external interrupt request input. #### 4.2.2.10 Port 14 Port 14 is an I/O port with an output latch. Port 14 can be set to the input mode or output mode using port mode register 14 (PM14). When this port is used as an input port, use of an on-chip pull-up resistor can be specified by pull-up resistor option register 14 (PU14). The P147 pin can be specified for digital I/O or analog input by using the port mode control register 14 (PMC14). This port can also be used for A/D converter analog input. Reset signal generation sets port to analog 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 (PIMx) - Port output mode registers (POMx) - Port mode control registers (PMCxx) - A/D port configuration register (ADPC) - Peripheral I/O redirection register (PIOR) **Caution** Which registers and bits are included depends on the product. For details about registers and bits mounted on each product, see Tables 4-4 and 4-5. Be sure to set bits that are not mounted to their initial values. Table 4-4. PMxx, Pxx, PUxx, PIMx, POMx, and PMCxx Registers and the Bits (20-, 24-pin Products) | Port | | | | Bit r | name | | | |------------------------|---|---------------|--------------|---------------|---------------|---------------|----------------| | Port | | PMxx register | Pxx register | PUxx register | PIMx register | POMx register | PMCxx register | | Port 0 <sup>Note</sup> | 0 | PM00 | P00 | PU00 | - | - | _ | | | 1 | PM01 | P01 | PU01 | - | POM01 | _ | | | 2 | PM02 | P02 | PU02 | - | - | _ | | | 3 | PM03 | P03 | PU03 | | | _ | | Port 1 | 0 | PM10 | P10 | PU10 | PIM10 | POM10 | PMC10 | | | 1 | PM11 | P11 | PU11 | PIM11 | POM11 | PMC11 | | | 2 | PM12 | P12 | PU12 | _ | POM12 | PMC12 | | | 3 | PM13 | P13 | PU13 | _ | _ | PMC13 | | | 4 | PM14 | P14 | PU14 | _ | _ | PMC14 | | Port 2 | 0 | PM20 | P20 | = | = | = | _ | | | 1 | PM21 | P21 | - | _ | _ | _ | | | 2 | PM22 | P22 | _ | _ | _ | _ | | | 3 | PM23 | P23 | - | _ | _ | _ | | Port 4 | 0 | PM40 | P40 | PU40 | _ | _ | _ | | | 1 | PM41 | P41 | PU41 | _ | POM41 | PMC41 | | | 2 | PM42 | P42 | PU42 | _ | _ | PMC42 | | Port 6 | 0 | PM60 | P60 | = | = | = | = | | | 1 | PM61 | P61 | = | = | = | = | | Port 12 | 1 | = | P121 | = | = | = | = | | | 2 | = | P122 | = | = | = | = | | | 5 | = | P125 | PU125 | = | = | = | | Port 13 | 7 | _ | P137 | - | - | _ | _ | Note Provided only in 24-pin products. Table 4-5. PMxx, Pxx, PUxx, PIMx, POMx, PMCxx Registers and the Bits (30-pin Products) | Dort | | Bit name | | | | | | | | | | | |---------|---|---------------|--------------|---------------|---------------|---------------|----------------|--|--|--|--|--| | Port | | PMxx register | Pxx register | PUxx register | PIMx register | POMx register | PMCxx register | | | | | | | Port 0 | 0 | PM00 | P00 | PU00 | - | РОМ00 | PMC00 | | | | | | | | 1 | PM01 | P01 | PU01 | PIM01 | _ | PMC01 | | | | | | | Port 1 | 0 | PM10 | P10 | PU10 | PIM10 | POM10 | - | | | | | | | | 1 | PM11 | P11 | PU11 | PIM11 | POM11 | - | | | | | | | | 2 | PM12 | P12 | PU12 | - | POM12 | - | | | | | | | | 3 | PM13 | P13 | PU13 | PIM13 | POM13 | - | | | | | | | | 4 | PM14 | P14 | PU14 | PIM14 | POM14 | - | | | | | | | | 5 | PM15 | P15 | PU15 | PIM15 | POM15 | - | | | | | | | | 6 | PM16 | P16 | PU16 | PIM16 | - | - | | | | | | | | 7 | PM17 | P17 | PU17 | PIM17 | POM17 | - | | | | | | | Port 2 | 0 | PM20 | P20 | _ | _ | _ | _ | | | | | | | | 1 | PM21 | P21 | _ | _ | _ | _ | | | | | | | | 2 | PM22 | P22 | _ | _ | _ | _ | | | | | | | | 3 | PM23 | P23 | - | | | _ | | | | | | | Port 3 | 0 | PM30 | P30 | PU30 | _ | _ | _ | | | | | | | | 1 | PM31 | P31 | PU31 | _ | _ | _ | | | | | | | Port 4 | 0 | PM40 | P40 | PU40 | _ | _ | _ | | | | | | | Port 5 | 0 | PM50 | P50 | PU50 | _ | POM50 | _ | | | | | | | | 1 | PM51 | P51 | PU51 | | | _ | | | | | | | Port 6 | 0 | PM60 | P60 | _ | _ | _ | _ | | | | | | | | 1 | PM61 | P61 | - | = | = | = | | | | | | | Port 12 | 0 | PM120 | P120 | PU120 | = | = | PMC120 | | | | | | | | 1 | = | P121 | = | = | = | = | | | | | | | | 2 | = | P122 | = | = | = | = | | | | | | | Port 13 | 7 | = | P137 | = | = | = | = | | | | | | | Port 14 | 7 | PM147 | P147 | PU147 | - | = | PMC147 | | | | | | # 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**. Figure 4-1. Format of Port Mode Register | | | | | rigure | 4-1. FOI | mat of PC | ort wode | negister | | | | |---------------------|-----------|-----------|------------|--------------|------------|-------------|------------|-------------|---------------|-------------|---------------| | 20-, 24-pi | n product | S | | | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | PM0 <sup>Note</sup> | 1 | 1 | 1 | 1 | PM03 | PM02 | PM01 | PM00 | FFF20H | FFH | R/W | | | | | l. | | | | I . | I. | _ | | | | PM1 | 1 | 1 | 1 | PM14 | PM13 | PM12 | PM11 | PM10 | FFF21H | FFH | R/W | | | | | - | | | | | | 1 | | | | PM2 | 1 | 1 | 1 | 1 | PM23 | PM22 | PM21 | PM20 | FFF22H | FFH | R/W | | F IVI∠ | _ ' | ' | ' | ' | FIVIZO | FIVIZZ | FIVIZI | FIVIZO | 1112211 | FFII | □/ <b>V V</b> | | | | T | l | Τ | Τ | Γ | l | | l | | | | PM4 | 1 | 1 | 1 | 1 | 1 | PM42 | PM41 | PM40 | FFF24H | FFH | R/W | | | _ | | ı | | | | 1 | 1 | Ī | | | | PM6 | 1 | 1 | 1 | 1 | 1 | 1 | PM61 | PM60 | FFF26H | FFH | R/W | | Note | Provided | only in 2 | 4-pin prod | ducts. | | | | | | | | | | | | | | | | | | | | | | 30-pin pro | ducts | | | | | | | | | | | | 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 | | | L. | | | | | * | | I. | | | | | PM1 | PM17 | PM16 | PM15 | PM14 | PM13 | PM12 | PM11 | PM10 | FFF21H | FFH | R/W | | | | | | | | | | | | | | | PM2 | 4 | 1 | | 1 | PM23 | PM22 | DM01 | PM20 | FFF22H | FFH | DAM | | PIVIZ | 1 | ı | 1 | ı | PIVI23 | PIVIZZ | PM21 | PIVIZU | FFFZZN | ггп | R/W | | | | | | | | | | 1 | | | | | PM3 | 1 | 1 | 1 | 1 | 1 | 1 | PM31 | PM30 | FFF23H | FFH | R/W | | | | | | | | | | | | | | | PM4 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | PM40 | FFF24H | FFH | R/W | | | | | | | | | | | | | | | PM5 | 1 | 1 | 1 | 1 | 1 | 1 | PM51 | PM50 | FFF25H | FFH | R/W | | - | | | | | | | | | | | | | DMC | | 4 | 4 | | 4 | 4 | DMC4 | DMCO | FFFOCLI | FFU | DAM | | PM6 | 1 | 1 | 1 | 1 | 1 | 1 | PM61 | PM60 | FFF26H | FFH | R/W | | | | 1 | | | <u> </u> | | | 1 | | | | | PM12 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | PM120 | FFF2CH | FFH | R/W | | | | | | | | | | | | | | | PM14 | PM147 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | FFF2EH | FFH | R/W | | | | <u>l</u> | | L | <u>.</u> | | | | | | | | | PMmn | | | Pmn | pin I/O mo | de selectio | n (m = 0 t | o 6. 12. 14 | ; n = 0 to 7) | | | | | 0 | Output m | ode (outo | ut buffer or | | | , 31 | -,, 11 | , , | | | | | - | · · | | | '/ | | | | | | | | | 1 | input mod | de (output | buller off) | | | | | | | | # 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 If the input data is read from a port for which analog input of the A/D converter is selected, 0 is always returned rather than the pin level. In addition, if the input data is read from P125 when the $\overline{RESET}$ pin (PORTSELB = 1) is selected, 1 is always read. | Figure 4-2. Format of Port Register | Figure 4-2 | . Format | of Port | Register | |-------------------------------------|------------|----------|---------|----------| |-------------------------------------|------------|----------|---------|----------| | 20-, 24-pi | n produc | ts | | | | | | | | | | |------------|----------|----------|------------|-------------|-----------|------|-----------------|----------|----------------|--------------------|---------------------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | P0 | 0 | 0 | 0 | 0 | P03 | P02 | P01 | P00 | FFF00H | 00H (output latch) | R/W | | P1 | 0 | 0 | 0 | P14 | P13 | P12 | P11 | P10 | FFF01H | 00H (output latch) | R/W | | P2 | 0 | 0 | 0 | 0 | P23 | P22 | P21 | P20 | FFF02H | 00H (output latch) | R/W | | P4 | 0 | 0 | 0 | 0 | 0 | P42 | P41 | P40 | FFF04H | 00H (output latch) | R/W | | P6 | 0 | 0 | 0 | 0 | 0 | 0 | P61 | P60 | FFF06H | 00H (output latch) | R/W | | P12 | 0 | 0 | P125 | 0 | 0 | P122 | P121 | 0 | FFF0CH | Undefined | R | | P13 | P137 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FFF0DH | Undefined | R | | 30-pin pro | ducts | | | | | | | | | | | | 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 | | P1 | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | FFF01H | 00H (output latch) | R/W | | P2 | 0 | 0 | 0 | 0 | P23 | P22 | P21 | P20 | FFF02H | 00H (output latch) | R/W | | P3 | 0 | 0 | 0 | 0 | 0 | 0 | P31 | P30 | FFF03H | 00H (output latch) | R/W | | P4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | P40 | FFF04H | 00H (output latch) | R/W | | P5 | 0 | 0 | 0 | 0 | 0 | 0 | P51 | P50 | FFF05H | 00H (output latch) | R/W | | P6 | 0 | 0 | 0 | 0 | 0 | 0 | P61 | P60 | FFF06H | 00H (output latch) | R/W | | P12 | 0 | 0 | 0 | 0 | 0 | P122 | P121 | P120 | FFF0CH | Undefined | R/W <sup>Note</sup> | | P13 | P137 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FFF0DH | Undefined | R | | P14 | P147 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FFF0EH | 00H (output latch) | R/W | | | Pmn | Oı | utput data | control (in | output mo | de) | | Input da | ta read (in ir | nput mode) | 1 | | | 0 | Output 0 | ) | | | | Input low level | | | | | | | 1 | Output 1 | | | | | Input hig | jh level | | | | m = 0 to 6, 12, 13, 14; n = 0 to 7 Note P121 and P122 are read-only. ## 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 both normal output mode (POMmn = 0) and input mode (PMmn = 1) for the pins for which the use of an on-chip pull-up resistor is 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 and analog setting (PMC = 1, ADPC = 1), regardless of the settings of these registers. These registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation sets PU4 to 01H, PU12 to 20H (20-, 24-pin products), and others to 00H. **Caution** When a port with the PIMn register is input from a different-potential device to the TTL buffer, pull up to the power supply of the different-potential device via an external pull-up resistor by setting PUmn = 0. | | | | Figure | e 4-3. Fo | ormat of | Pull-up F | Resistor | Option R | egister | | | |------------|-----------|-----------|-----------------------|-----------|-------------|-------------|---------------|--------------|-----------------|-------------|--------| | 20-, 24-pi | n product | s | | | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | PU0 | 0 | 0 | 0 | 0 | PU03 | PU02 | PU01 | PU00 | F0030H | 00H | R/W | | | | | | | | | | | | | | | PU1 | 0 | 0 | 0 | PU14 | PU13 | PU12 | PU11 | PU10 | F0031H | 00H | R/W | | | - | T | | | | , | | | | | | | PU4 | 0 | 0 | 0 | 0 | 0 | PU42 | PU41 | PU40 | F0034H | 01H | R/W | | | | | | 1 | 1 | 1 | | | | | | | PU12 | 0 | 0 | PU125 <sup>Note</sup> | 0 | 0 | 0 | 0 | 0 | F003CH | 20H | R/W | | | | | | | | | | | | | | | 30-pin pro | oducts | | | | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | PU0 | 0 | 0 | 0 | 0 | 0 | 0 | PU01 | PU00 | F0030H | 00H | R/W | | | | | 1 1 | | I | ı | ı | | | | | | PU1 | PU17 | PU16 | PU15 | PU14 | PU13 | PU12 | PU11 | PU10 | F0031H | 00H | R/W | | | Г | | 1 1 | | I | I | I | | | | | | PU3 | 0 | 0 | 0 | 0 | 0 | 0 | PU31 | PU30 | F0033H | 00H | R/W | | | _ | | 1 - 1 | | l _ | l _ | | | | | | | PU4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PU40 | F0034H | 01H | R/W | | DUE | | | | | | | DUE | DUES | E000511 | 0011 | D 444 | | PU5 | 0 | 0 | 0 | 0 | 0 | 0 | PU51 | PU50 | F0035H | 00H | R/W | | PU12 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PU120 | F003CH | 00H | DAM | | PU12 | 0 | U | 0 | - 0 | U | U | U | F0120 | FUUSCH | ООП | R/W | | PU14 | PU147 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | F003EH | 00H | R/W | | F014 | F0147 | U | 0 | - 0 | 0 | 0 | 0 | U | 1 003EII | 0011 | Γ1/ VV | | | PUmn | | Pmn | nin on-ch | nin null-un | resistor se | lection (m | = 0 1 3 to | 5, 12, 14; n | = 0 to 7) | | | | 0 | On-chin | pull-up resi | | | 10010101 00 | 10011011 (111 | _ 0, 1, 0 10 | , 0, 12, 11, 11 | - 0 10 1) | | | | 1 | · · | pull-up resi | | | | | | | | | | | <u> </u> | 311 0111p | Pan ap 1001 | | a. | | | | | | | Note PU125 can be selected only when P125/KR1/SI01 (PORTSELB = 0) is selected. If the RESET pin (PORTSELB = 1) is selected, the on-chip pull-up resistor is always valid. # 4.3.4 Port input mode register (PIMx) These registers set an input buffer in 1-bit units. TTL input buffer can be selected during serial communication with an external device of a different potential. This register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. # Figure 4-4. Format of Port Input Mode Register | 20-, 24-pi | n product | S | | | | | | | | | | |------------|-----------|-------|-------|-------|-------|---|-------|-------|---------|-------------|-----| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | PIM1 | 0 | 0 | 0 | 0 | 0 | 0 | PIM11 | PIM10 | F0041H | 00H | R/W | | | | | | | | | | | | | | | 30-pin pro | oducts | | | | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | PIM0 | 0 | 0 | 0 | 0 | 0 | 0 | PIM11 | 0 | F0040H | 00H | R/W | | | | | | | | | | | | | | | PIM1 | PIM17 | PIM16 | PIM15 | PIM14 | PIM13 | 0 | PIM11 | PIM10 | F0041H | 00H | R/W | | | | | | | | | | | | | | | PIMmn | Pmn pin input buffer selection (m = 0, 1; n = 0, 1, 3 to 7) | |-------|-------------------------------------------------------------| | 0 | Normal input buffer | | 1 | TTL input buffer | ## 4.3.5 Port output mode registers (POMx) These registers set the output mode in 1-bit units. N-ch open drain output (VDD tolerance) mode can be selected for the SDAxx pin during serial communication with an external device of a different potential or during simplified I<sup>2</sup>C communication with an external device of the same potential. In addition, the POMx and PUx registers specify whether to use the on-chip pull-up resistor. The POMx 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 (POMmn = 1) is set. Figure 4-5. Format of Port Output Mode Register | 20-, 24-pi | n product | s | | | | | | | | | | |------------|-----------|----------|-------------|--------------|-------------|------------|-------------|---------------|-------------|-------------|-----| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | POM0 | 0 | 0 | 0 | 0 | 0 | 0 | POM01 | 0 | F0050H | 00H | R/W | | | | | | | | | | | | | | | POM1 | 0 | 0 | 0 | 0 | 0 | POM12 | POM11 | POM10 | F0051H | 00H | R/W | | | | | | | | | | | | | | | POM4 | 0 | 0 | 0 | 0 | 0 | 0 | POM41 | 0 | F0054H | 00H | R/W | | | | | | | | | | | | | | | 30-pin pro | ducts | | | | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | POM0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | POM01 | F0050H | 00H | R/W | | i | | | | | | | | | | | | | POM1 | POM17 | 0 | POM15 | POM14 | POM13 | POM12 | POM11 | POM10 | F0051H | 00H | R/W | | | | | | | | | | | | | | | POM5 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | POM50 | F0055H | 00H | R/W | | · | | | | | | | | | | | | | | POMmn | | | Pmn | pin output | t mode sel | ection (m = | = 0, 1, 4, 5; | n = 0 to 7) | | | | | 0 | Normal o | output mod | le | | | | | | | | | | 1 | N-ch ope | en-drain ou | itput (VDD t | olerance) ı | mode | | | | | | # 4.3.6 Port mode control registers (PMCxx) These registers set the digital I/O or analog input 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. Analog input Figure 4-6. Format of Port Mode Control Register | 20-, 24-pi | in product | s | | | | | | | | | | | | |------------|------------|-------------|------------------------------------------------------------------------------|-------|-------|-------|-------|--------|---------|-------------|-----|--|--| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | | | PMC1 | 1 | 1 | 1 | PMC14 | PMC13 | PMC12 | PMC11 | PMC10 | F0061H | FFH | R/W | | | | | | | | | | | | | | | | | | | PMC4 | 1 | 1 | 1 | 1 | 1 | PMC42 | PMC41 | 1 | F0064H | FFH | R/W | | | | | - | | | | | | | | | | | | | | 30-pin pro | oducts | | | | | | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | | | | PMC0 | 1 | 1 | 1 | 1 | 1 | 1 | PMC01 | PMC00 | F0060H | FFH | R/W | | | | | | | | ı | | | ı | , , | | | | | | | PMC12 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | PMC120 | F006CH | FFH | R/W | | | | | | | | T | 1 | 1 | T | 1 | | | | | | | PMC14 | PMC147 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | F006EH | FFH | R/W | | | | | | | | | | | | | | | | | | | | PMCmn | | Pmn pin digital I/O/analog input selection (m = 1, 4, 12, 14; n = 0 to 4, 7) | | | | | | | | | | | | | 0 | Digital I/0 | I/O (alternate function other than analog input) | | | | | | | | | | | - **Cautions 1.** Use the port mode register m (PMm) to select the input mode for the ports that are set to analog input by using the PMCxx register. - 2. Do not use the analog input channel specification register (ADS) to set the pins that will be set to digital I/O by using the PMCxx register. - 3. Be sure to set bits that are not mounted to their initial values. #### 4.3.7 A/D port configuration register (ADPC) This register switches the P20/ANI0 to P23/ANI3 pins to digital I/O of port or analog input of A/D converter. This register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 4-7. Format of A/D Port Configuration Register (ADPC) | ADPC2 | ADPC1 | ADPC0 | Analog input (A)/digital I/O (D) switching | | | | | | | |----------------------|-------|-------|--------------------------------------------|----------|----------|----------|--|--|--| | | | | ANI3/P23 | ANI2/P22 | ANI1/P21 | ANI0/P20 | | | | | 0 | 0 | 0 | Α | Α | Α | А | | | | | 0 | 0 | 1 | D | D | D | D | | | | | 0 | 1 | 0 | D | D | D | А | | | | | 0 | 1 | 1 | D | D | Α | Α | | | | | 1 | 0 | 0 | D | A | Α | А | | | | | Other than the above | | | Setting prohibited | | | | | | | - **Cautions 1.** Use the port mode register 2 (PM2) to select the input mode for the ports that are set to analog input by using the ADPC register. - 2. Do not use the analog input channel specification register (ADS) to set the pins that will be set to digital I/O by using the ADPC register. - 3. To use AVREFP and AVREFM, set ANIO and ANI1 to analog input and set the port mode register to the input mode. #### 4.3.8 Peripheral I/O redirection register (PIOR) This register is used to specify whether to enable or disable the peripheral I/O redirect function. This function is used to switch ports to which alternate functions are assigned. Use the PIOR register to assign a port to the function to redirect and enable the function. In addition, the settings for redirection can be changed only until operation of the function is enabled. The PIOR register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 4-8. Format of Peripheral I/O Redirection Register (PIOR) | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Address | After reset | R/W | |--------|---|---|---|---|------------|-------|-------|-------|---------|-------------|-----| | PIOR | 0 | 0 | 0 | 0 | PIOR3 | PIOR2 | PIOR1 | PIOR0 | F0077H | 00H | R/W | | | | | | | Notes 1, 2 | | | | | | | 20-, 24-pin products | Bit | Alternate function | Setting | g value | |-----------------------------|--------------------|---------|---------| | Dit. | Alternate function | 0 | 1 | | PIOR3 <sup>Notes 1, 2</sup> | SCK01 | P42 | P02 | | | SI01 | P125 | P00 | | | S001 | P41 | P01 | | | SCL01 | P42 | P02 | | | SDA01 | P41 | P01 | | PIOR2 <sup>Note 3</sup> | TI02 | P41 | P122 | | | TI03 | P42 | P121 | | PIOR1 | RxD0 | P11 | P61 | | | TxD0 | P12 | P60 | | PIOR0 | INTP2 | P13 | P122 | | | INTP3 | P14 | P121 | 30-pin products | Bit | Alternate function | Setting value | | | | |-------|-------------------------|---------------|--------------------|--|--| | DIL | Alternate function | 0 | 1 | | | | PIOR3 | - | (fixed) | Setting prohibited | | | | PIOR2 | SCLA0 | P60 | P14 | | | | | SDAA0 | P61 | P13 | | | | PIOR1 | TxD2 Note 1 | P13 | = | | | | | RxD2 Note 1 | P14 | = | | | | | SCL20 Note 1 | P15 | = | | | | | SDA20 Note 1 | P14 | = | | | | | SI20 Note 1 | P14 | = | | | | | SO20 Note 1 | P13 | = | | | | | SCK20 Note 1 | P15 | = | | | | | TxD0 | P12 | P17 | | | | | RxD0 | P11 | P16 | | | | | SCL00 Note 1 | P10 | = | | | | | SDA00 <sup>Note 1</sup> | P11 | = | | | | | SI00 | P11 | = | | | | | S000 | P12 | = | | | | | SCK00 | P10 | = | | | | PIOR0 | TI02/TO02 | P17 | P15 | | | | | TI03/TO03 | P31 | P14 | | | | | TI04/TO04 | - | P13 | | | | | TI05/TO05 | - | P12 | | | | | TI06/TO06 | - | P11 | | | | | TI07/TO07 | | P10 | | | **Notes 1.** Provided only in the R5F102 products. - **2.** Provided only in 24-pin products. - **3.** When the PIOR2 bit is set to 1 in the 20- or 24-pin products, using TO02 and TO03 for timer output is prohibited. **Remark** -: The function cannot be used. #### 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. Therefore, byte data can be written to the ports used for both input and output. 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 potentials (1.8 V, 2.5 V, and 3 V) by using I/O buffers Connection with an external device operating on a different potential (1.8 V, 2.5 V or 3 V) is possible by switching I/O buffers by using the port input mode register (PIMxx) and port output mode register (POMxx). To receive input from an external device with a different potential (1.8 V, 2.5 V or 3 V), set the port input mode registers 0 and 1 (PIM0 and PIM1)<sup>Note</sup> on a bit-by-bit basis to enable switching between normal input (CMOS) and TTL input buffer. To output data to an external device with a different potential (1.8 V, 2.5 V or 3 V), set the port output mode registers 0 and 1 (POM0 and POM1) on a bit-by-bit basis to enable switching between normal output (CMOS) and N-ch open drain (VDD tolerance). The following describes the connection of a serial interface. Note For 20- and 24-pin products, only port 1 can be used. # (1) Setting procedure when using input ports of UART0 to UART2, CSI00 and CSI20 functions for the TTL input buffer | Interface | 20, 24-pin product | 30-pin product <sup>Note</sup> | |-----------|--------------------|--------------------------------| | UART0 | P11 | P11 (P16) | | UART1 | - | P01 | | UART2 | - | P14 | | CSI00 | P10 | P10 | | | P11 | P11 | | CSI20 | - | P14 | | | | P15 | Note The pin in parentheses can be assigned by setting the peripheral I/O redirection register (PIOR). - <1> Use an external register to pull up 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 and PIM1 registers to 1 to switch to the TTL input buffer. For VIH and VIL, see 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 ports of UART0 to UART2, CSI00 and CSI20 functions in the N-ch open drain output mode | Interface | 20, 24-pin product | 30-pin product <sup>Note</sup> | |-----------|--------------------|--------------------------------| | UART0 | P12 | P12 (P17) | | UART1 | - | P00 | | UART2 | - | P13 | | CSI00 | P10 | P10 | | | P12 | P12 | | CSI20 | _ | P15 | | | | P13 | Note The pin in parentheses can be assigned by setting the peripheral I/O redirection register (PIOR). - <1> Use an external register to pull up the output pin to be used to the power supply of the target device (onchip 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 POM1 register 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 output mode by manipulating the PM0 and PM1 registers. 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 ports of IIC00 and IIC20 functions for a different potential (1.8 V, 2.5 V or 3 V) | Interface | 20, 24-pin product | 30-pin product | |-----------|--------------------|----------------| | IIC00 | P10 | P10 | | | P11 | P11 | | IIC20 | - | P14 | | | | P15 | - <1> Use an external register to pull up the input pin to be used to the power supply of the target device (onchip 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 and POM1 registers to 1 to set the N-ch open drain output (VDD tolerance) mode. - <5> Set the corresponding bit of the POM0 and PIM1 registers to 1 to switch to the TTL input buffer. For VIH and VIL, see 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 output mode by manipulating the PM0 and PM1 registers (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 First, for a pin that is also assigned to be used for analog input, use the ADPC register or port mode control register (PMCxx) to specify whether to use the pin for analog input or digital I/O. Figure 4-9 shows the basic configuration of an output circuit for pins used for digital I/O. 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 (such as TAU, clock/buzzer output, or IICA) is connected to the other input pin of the OR gate. When such kind of pins are used for the port function or alternate function, the unused alternate function must not hinder the output of the function to be used. Table 4-6 shows the concept of basic settings for this configuration. Figure 4-9. Basic Configuration of Output Circuit for Pins - Notes 1. If there is no POM register, this signal should be considered to be low level (0). - 2. If there is no alternate function, this signal should be considered to be high level (1). - 3. If there is no alternate function, this signal should be considered to be low level (0). **Remark** m: Port number (m = 0 to 14), n: Bit number (n = 0 to 7) | <b>Table 4-6.</b> | Concept of | Basic Settings | |-------------------|------------|----------------| |-------------------|------------|----------------| | Output Function of Used Pin | Output Function of Unused Alternate Function | | | | | | |------------------------------------|----------------------------------------------|---------------------|------------------------------------|--|--|--| | | Port output function | SAU output function | Output function for other than SAU | | | | | Port output function | - | 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** Because more than one output function other than SAU might be assigned to a single pin, the output of unused alternate functions must be set to low level (0). For details about 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 If the output of an alternate function is not used, specify the settings as described below. If the output of the peripheral function is still the target of the peripheral I/O redirection function, the output can be switched to another pin by setting the peripheral I/O redirection register (PIOR). This allows usage of the port function or other alternate functions assigned to the target pin. #### (1) SOp = 1 and TxDq = 1 (settings when the serial output (SOp/TxDq) of SAU is not used) If 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 the serial output enable register m (SOEm) that corresponds to the unused output to 0 (output disabled) and set the SOmn bit in the serial output register m (SOm) to 1 (high). These settings are the same as the initial state. #### (2) SCKp = 1, SDAr = 1, and SCLr = 1 (settings when channel n in SAU is not used) If SAU is not used, set the bit n (SEmn) in the serial channel enable status register m (SEm) to 0 (operation stopped state), set the bit in the serial output enable register m (SOEm) that corresponds to the unused output to 0 (output disabled), and set the SOmn bit and CKOmn bit in the serial output register m (SOm) to 1 (high). These settings are the same as the initial state. #### (3) TOmn = 0 (settings when the output of channel n in TAU is not used) If the TOmn output of TAU is not used, set the bit in the timer output enable register 0 (TOE0) that corresponds to the unused output to 0 (output disabled) and set the bit in the timer output register 0 (TO0) to 0 (low). These settings are the same as the initial state. #### (4) SDAAn = 0 and SCLAn = 0 (setting when IICA is not used) If IICA is not used, set the IICEn bit in the IICA control register n0 (IICCTLn0) to 0 (operation stopped). This setting is the same as the initial state. #### (5) PCLBUZn = 0 (setting when clock output or buzzer output is not used) If the clock output or buzzer output is not used, set the PCLOEn bit in the clock output selection register n (CKSn) to 0 (output disabled). This setting is the same as the initial state. # 4.5.3 Register setting examples for using the port and alternate functions Table 4-7 shows register setting examples for used port and alternate functions. Set the registers used to control the port function as shown in Table 4-7. See the following remark for legends used in Table 4-7. Remark -: Not applicable x: don't care PIORx: Peripheral I/O redirection register POMxx: Port output mode register PMCxx: Port mode control register PMxx: Port mode register Pxx: Port output latch Functions in parentheses can be assigned via settings in the peripheral I/O redirection register (PIOR). Table 4-7. Setting Examples of Registers and Output Latches When Using Alternate Function (20-, 24-Pin Products) (1/5) | Pin Name | Used Function | | PIORx | POMxx | PMCxx | PMxx | Pxx | x Alternate Function Output | | |-----------------------|---------------------------|---------------------------|-----------|-------|-------|------|-----|-----------------------------|----------------| | | Function Name | I/O | | | | | | SAU | Other than SAU | | P00 <sup>Note 1</sup> | P00 | Input | - | - | - | 1 | × | - | _ | | | | Output | _ | _ | - | 0 | 0/1 | = | = | | | KR6 | Input | = | - | - | 1 | × | - | _ | | | (SI01) <sup>Note 2</sup> | Input | PIOR3 = 1 | _ | _ | 1 | × | - | - | | P01 <sup>Note 1</sup> | P01 | Input | = | × | = | 1 | × | × | = | | | | Output | = | 0 | = | 0 | 0/1 | (SO01)/(SDA01) = 1 | = | | | | N-ch open drain output | - | 1 | _ | 0 | 0/1 | | - | | | KR7 | Input | - | × | _ | 1 | × | × | - | | | (SO01) <sup>Note 2</sup> | Output | PIOR3 = 1 | 0/1 | _ | 0 | 1 | × | - | | | (SDA01) <sup>Note 2</sup> | I/O | PIOR3 = 1 | 1 | _ | 0 | 1 | × | - | | P02 <sup>Note 1</sup> | P02 | Input | - | - | _ | 1 | × | × | - | | | | Output | - | - | _ | 0 | 0/1 | (SCK01)/(SCL01) = 1 | - | | | KR8 | Input | - | - | - | 1 | × | × | = | | | (SCK01) <sup>Note 2</sup> | Input | PIOR3 = 1 | - | _ | 1 | × | × | _ | | | | Output | PIOR3 = 1 | - | - | 0 | 1 | × | = | | | (SCL01) <sup>Note 2</sup> | Output | PIOR3 = 1 | - | _ | 0 | 1 | × | = | | P03 <sup>Note 1</sup> | P03 | Input | = | - | - | 1 | × | = | = | | | | Output | = | _ | - | 0 | 0/1 | = | = | | | KR9 | Input | - | _ | - | 1 | × | _ | _ | | P10 | P10 | Input | = | × | 0 | 1 | × | × | × | | | | Output | - | 0 | 0 | 0 | 0/1 | SCK00/ SCL00 = 1 | PCLBZ0 = 0 | | | | N-ch open<br>drain output | - | 1 | 0 | 0 | 0/1 | | | | | ANI16 | Input | = | × | 1 | 1 | × | × | × | | | PCLBZ0 | Output | = | 0 | 0 | 0 | 0 | SCK00/SCL00 = 1 | × | | | SCK00 | Input | = | × | 0 | 1 | × | × | PCLBZ0 = 0 | | | | Output | = | 0/1 | 0 | 0 | 1 | × | PCLBZ0 = 0 | | | SCL00 <sup>Note 2</sup> | Output | - | 0/1 | 0 | 0 | 1 | × | PCLBZ0 = 0 | Notes 1. Provided only in 24-pin products. Table 4-7. Setting Examples of Registers and Output Latches When Using Alternate Function (20-, 24-Pin Products) (2/5) | Pin Name | Used Fu | unction | PIORx | POMxx | PMCxx | PMxx | PMxx Pxx | Alternate Function Output | | |----------|-----------------------|---------------------------|-----------|-------|-------|------|----------|---------------------------|----------------| | | Function Name | I/O | | | | | | SAU | Other than SAU | | P11 | P11 | Input | - | × | 0 | 1 | × | × | - | | | | Output | - | 0 | 0 | 0 | 0/1 | SDA00 = 1 | _ | | | | N-ch open<br>drain output | - | 1 | 0 | 0 | 0/1 | | | | | ANI17 | Input | - | × | 1 | 1 | × | × | _ | | | SI00 | Input | - | × | 0 | 1 | × | × | _ | | | RxD0 | Input | PIOR1 = 0 | × | 0 | 1 | × | × | - | | | SDA00 <sup>Note</sup> | I/O | _ | 1 | 0 | 0 | 1 | × | - | | P12 | P12 | Input | - | × | 0 | 1 | × | × | _ | | | | Output | - | 0 | 0 | 0 | 0/1 | SO00/TxD0 = 1 | _ | | | | N-ch open<br>drain output | - | 1 | 0 | 0 | 0/1 | | | | | ANI18 | Input | - | × | 1 | 1 | × | × | _ | | | SO00 | Output | - | 0/1 | 0 | 0 | 1 | × | _ | | | TxD0 | Output | PIOR1 = 0 | 0/1 | 0 | 0 | 1 | × | _ | | P13 | P13 | Input | = | = | 0 | 1 | × | × | × | | | | Output | - | _ | 0 | 0 | 0/1 | - | TO00 = 0 | | | ANI19 | Input | - | _ | 1 | 1 | × | - | × | | | TI00 | Input | - | _ | 0 | 1 | × | - | × | | | TO00 | Output | - | _ | 0 | 0 | 0 | - | × | | | INTP2 | Input | PIOR0 = 0 | _ | 0 | 1 | × | - | × | | P14 | P14 | Input | - | - | 0 | 1 | × | | × | | | | Output | - | - | 0 | 0 | 0/1 | | TO01 = 0 | | | ANI20 | Input | - | - | 1 | 1 | × | _ | × | | | TI01 | Input | - | - | 0 | 1 | × | _ | × | | | TO01 | Output | - | - | 0 | 0 | 0 | _ | × | | | INTP3 | Input | PIOR0 = 0 | - | 0 | 1 | × | × | × | Table 4-7. Setting Examples of Registers and Output Latches When Using Alternate Function (20-, 24-Pin Products) (3/5) | Pin Name | Used | Function | ADPC | ADM2 | PMxx | Pxx | |----------|---------------|-------------------|-----------------------|--------------------|------|-----| | | Function Name | I/O | | | | | | P20 | P20 | Input | ADPC = 01H | × | 1 | × | | | | Output | ADPC = 01H | × | 0 | 0/1 | | | ANI0 | Analog input | ADPC = 00H/02H to 04H | 00x0xx0x, 10x0xx0x | 1 | × | | | AVREFP | Reference voltage | ADPC = 00H/02H to 04H | 01x0xx0x | 1 | × | | P21 | | Input | ADPC = 01H/02H | × | 1 | × | | | | Output | ADPC = 01H/02H | × | 0 | 0/1 | | | ANI1 | Analog input | ADPC = 00H/03H/04H | xx00xx0x | 1 | × | | | AVREFM | Reference voltage | ADPC = 00H/03H/04H | xx10xx0x | 1 | × | | P22 | P22 | Input | ADPC = 01H to 03H | × | 1 | × | | | | Output | ADPC = 01H to 03H | × | 0 | 0/1 | | | ANI2 | Analog input | ADPC = 00H/04H | × | 1 | × | | P23 | P23 | Input | ADPC = 01H to 04H | × | 1 | × | | | | Output | ADPC = 01H to 04H | × | 0 | 0/1 | | | AN3 | Analog input | ADPC = 00H | × | 1 | × | Table 4-7. Setting Examples of Registers and Output Latches When Using Alternate Function (20-, 24-Pin Products (4/5) | Pin Name | Used | unction | PIORx | POMxx | PMCxx | PMxx | PMxx Pxx | Alternate Function Output | | |----------|-------------------------|----------------------------------------------|-----------------------------|-------|-------|------|----------|---------------------------|----------------| | | Function Name | I/O | | | | | | SAU | Other than SAU | | P40 | P40 | Input | _ | = | - | 1 | × | - | - | | | | Output | - | - | - | 0 | 0/1 | - | - | | | KR0 | Input | - | - | - | 1 | × | - | - | | P41 | P41 | Input | - | × | 0 | 1 | × | × | × | | | | Output | = | 0 | 0 | 0 | 0/1 | SO01/SDA01 = 1 | TO02 = 0 | | | | N-ch open drain output | _ | 1 | 0 | 0 | 0/1 | | | | | ANI22 | Input | - | × | 1 | 1 | × | × | | | | SO01 <sup>Note 2</sup> | Output | PIOR3 = 0 <sup>Note 1</sup> | 0/1 | 0 | 0 | 1 | × | TO02 = 0 | | | SDA01 <sup>Note 2</sup> | I/O | PIOR3 = 0 <sup>Note 1</sup> | 1 | 0 | 0 | 1 | × | TO02 = 0 | | | TI02 | Input | PIOR2 = 0 | × | 0 | 1 | × | × | × | | | TO02 | Output | = | 0 | 0 | 0 | 0 | SO01/SDA01 = 1 | × | | | INTP1 | Input | = | × | 0 | 1 | × | × | × | | P42 | P42 | Input | = | _ | 0 | 1 | × | × | × | | | | Output | = | _ | 0 | 0 | 0/1 | SCK01/SCL01 = 1 | TO03 = 0 | | | ANI21 | Input | = | _ | 1 | 1 | × | × | × | | | SCK01 <sup>Note 2</sup> | Input | PIOR3 = 0 <sup>Note 1</sup> | _ | 0 | 1 | × | × | × | | | | Output | PIOR3 = 0 <sup>Note 1</sup> | _ | 0 | 0 | 1 | × | TO03 = 0 | | | SCL01 <sup>Note 2</sup> | Output | PIOR3 = 0 <sup>Note 1</sup> | _ | 0 | 0 | 1 | × | TO03 = 0 | | | TI03 | Input | PIOR2 = 0 | _ | 0 | 1 | × | × | × | | | TO03 | Output | = | _ | 0 | 0 | 0 | SCK01/SCL01 = 1 | × | | P60 | P60 | Input | = | _ | _ | 1 | × | × | _ | | | | N-ch open<br>drain output<br>(6-V tolerance) | - | _ | _ | 0 | 0/1 | SCLA0/(TxD0) = 1 | - | | | KR4 | Input | - | _ | _ | 1 | × | × | - | | | SCLA0 | I/O | - | - | - | 0 | 0 | × | = | | | (TxD0) | Output | PIOR1 = 1 | - | - | 0 | 1 | × | = | | P61 | P61 | Input | - | - | - | 1 | × | × | = | | | | N-ch open<br>drain output<br>(6-V tolerance) | - | _ | _ | 0 | 0/1 | SDAA0 = 1 | - | | | KR5 | Input | _ | = | = | 1 | × | × | - | | | SDAA0 | I/O | - | = | = | 0 | 0 | × | - | | | (RxD0) | Input | PIOR1 = 1 | - | - | 1 | × | × | - | Notes 1. Provided only in 24-pin products. Table 4-7. Setting Examples of Registers and Output Latches When Using Alternate Function (20-, 24-Pin Products (5/5) | Pin Name | Pin Name Used Function | | PIORx | | Others | |----------|------------------------|-------|-----------------------------|---|--------------------------| | | Function Name | I/O | | | | | P121 | P121 | Input | | × | EXCLK, OSCSEL = 00/10/11 | | | KR3 | Input | - | × | EXCLK, OSCSEL = 00/10/11 | | | (TI03) | Input | PIOR2 = 1 | × | EXCLK, OSCSEL = 00/10/11 | | | (INTP3) | Input | PIOR0 = 1 | × | EXCLK, OSCSEL = 00/10/11 | | | X1 | - | - | × | EXCLK, OSCSEL = 01 | | P122 | P122 | Input | - | × | EXCLK, OSCSEL = 00/10 | | | KR2 | Input | - | × | EXCLK, OSCSEL = 00/10 | | | (TI02) | Input | PIOR2 = 1 | × | EXCLK, OSCSEL = 00/10 | | | (INTP2) | Input | PIOR0 = 1 | × | EXCLK, OSCSEL = 00/10 | | | X2 | - | - | × | EXCLK, OSCSEL = 01 | | | EXCLK | Input | _ | × | EXCLK, OSCSEL = 11 | | P125 | P125 | Input | - | × | PORTSELB = 0 | | | KR1 | Input | - | × | PORTSELB = 0 | | | SI01 <sup>Note 2</sup> | Input | PIOR3 = 0 <sup>Note 1</sup> | × | PORTSELB = 0 | | | RESET | Input | _ | × | PORTSELB = 1 | | P137 | P137 | Input | | × | <del>-</del> | | | INTP0 | Input | | × | | Notes 1. Provided only in 24-pin products. Table 4-8. Setting Examples of Registers and Output Latches When Using Alternate Function (30-Pin Products) (1/6) | Pin Name | Used F | unction | PIORx | POMxx | PMCxx | PMxx | Pxx | Alternate F | unction Output | |----------|-----------------------|---------------------------|-----------|-------|-------|------|-----|-----------------|--------------------------| | | Function Name | I/O | | | | | | SAU | Other than SAU | | P00 | P00 | Input | - | × | 0 | 1 | × | × | - | | | | Output | _ | 0 | 0 | 0 | 0/1 | TxD1 = 1 | = | | | | N-ch open | _ | 1 | 0 | 0 | 0/1 | 1751 - 1 | | | | | drain output | | ' | | O | 0/1 | | | | | ANI17 | Input | = | × | 1 | 1 | × | × | _ | | | TI00 | | | | | | | | | | | TxD1 <sup>Note</sup> | Input<br>Output | _ | × 0/1 | 0 | 0 | × 1 | × | = | | P01 | P01 | | = | - | 0 | 1 | | × _ | | | FUI | FOI | Input | _ | _ | | | × | _ | × | | | | Output | - | _ | 0 | 0 | 0/1 | = | TO00 = 0 | | | ANI16 | Input | - | _ | 1 | 1 | × | - | × | | | TO00 | Output | - | _ | 0 | 0 | 0 | - | × | | | RxD1 <sup>Note</sup> | Input | - | _ | 0 | 1 | × | - | × | | P10 | P10 | Input | = | × | _ | 1 | × | × | × | | | | Output | = | 0 | = | 0 | 0/1 | SCK00/SCL00 = 1 | (TO07) = 0 | | | | N-ch open | - | 1 | - | 0 | 0/1 | | | | | | drain output | | | | | | | | | | SCK00 | Input | PIOR1 = 0 | × | _ | 1 | × | × | × | | | | Output | PIOR1 = 0 | 0/1 | - | 0 | 1 | × | (TO07) = 0 | | | SCL00 <sup>Note</sup> | Output | PIOR1 = 0 | 0/1 | _ | 0 | 1 | × | (TO07) = 0 | | | (TI07) | Input | PIOR0 = 1 | × | - | 1 | × | × | × | | | (TO07) | Output | PIOR0 = 1 | 0 | - | 0 | 0 | SCK00/SCL00 = 1 | × | | P11 | P11 | Input | - | × | _ | 1 | × | × | × | | | | Output | - | 0 | _ | 0 | 0/1 | SDA00 = 1 | (TO06) = 0 | | | | N-ch open<br>drain output | _ | 1 | - | 0 | 0/1 | | | | | SI00 | Input | PIOR1 = 0 | × | _ | 1 | × | × | × | | | RxD0 | Input | PIOR1 = 0 | × | _ | 1 | × | × | × | | | SDA00 <sup>Note</sup> | I/O | PIOR1 = 0 | 1 | _ | 0 | 1 | × | (TO06) = 0 | | | (TI06) | Input | PIOR0 = 1 | × | _ | 1 | × | × | × | | | (TO06) | Output | PIOR0 = 1 | 0 | _ | 0 | 0 | SDA00 = 1 | × | | P12 | P12 | Input | - | × | - | 1 | × | × | × | | | | Output | - | 0 | - | 0 | 0/1 | SO00/TxD0 = 1 | (TO05) = 0 | | | | N-ch open | - | 1 | _ | 0 | 0/1 | | , , | | | SO00 | drain output<br>Output | PIOR1 = 0 | 0/1 | _ | 0 | 1 | × | (TO05) = 0 | | | TxD0 | Output | PIOR1 = 0 | 0/1 | _ | 0 | 1 | × | (TO05) = 0<br>(TO05) = 0 | | | (TI05) | Input | PIOR0 = 1 | × | _ | 1 | × | × | × | | | (TO05) | Output | PIOR0 = 1 | 0 | _ | 0 | 0 | SO00/TxD0 = 1 | × | | P13 | P13 | Input | - | × | _ | 1 | × | × | × | | 0 | | Output | _ | 0 | _ | 0 | 0/1 | TxD2/SO20 = 1 | (SDAA0)/(TO04) = 0 | | | | N-ch open | _ | 1 | _ | 0 | 0/1 | | (32. 2. 3), (1.001) = 0 | | | | drain output | | | | | ٠,٠ | | | | | TxD2 <sup>Note</sup> | Output | PIOR1 = 0 | 0/1 | _ | 0 | 1 | × | (SDAA0)/(TO04) = 0 | | | SO20 <sup>Note</sup> | Output | PIOR1 = 0 | 0/1 | _ | 0 | 1 | × | (SDAA0)/(TO04) = 0 | | | (SDAA0) | I/O | PIOR2 = 1 | 1 | _ | 0 | 0 | TxD2/SO20 = 1 | (TO04) = 0 | | | (TI04) | Input | PIOR0 = 1 | × | _ | 1 | × | × | × | | | (TO04) | Output | PIOR0 = 1 | 0 | _ | 0 | 0 | TxD2/SO20 = 1 | (SDAA0) = 0 | Table 4-8. Setting Examples of Registers and Output Latches When Using Alternate Function (30-Pin Products) (2/6) | Pin Name | Used Fu | nction | PIORx | POMxx | PMCxx | PMxx | Pxx | Alternate Fu | unction Output | |----------|-----------------------|---------------------------|-----------|-------|-------|------|-----|-----------------|--------------------| | | Function Name | I/O | | | | | | SAU | Other than SAU | | P14 | P14 | Input | = | × | - | 1 | × | | | | | | Output | - | 0 | = | 0 | 0/1 | SDA20 = 1 | (SCLA0)/(TO03) = 0 | | | | N-ch open drain output | - | 1 | = | 0 | 0/1 | | | | | RxD2 <sup>Note</sup> | Input | PIOR1 = 0 | × | - | 1 | × | × | × | | | SI20 <sup>Note</sup> | Input | PIOR1 = 0 | × | - | 1 | × | × | × | | | SDA20 <sup>Note</sup> | I/O | PIOR1 = 0 | 1 | - | 0 | 1 | × | (SCLA0)/(TO03) = 0 | | | (SCLA0) | I/O | PIOR2 = 1 | 1 | - | 0 | 0 | SDA20 = 1 | (TO03) = 0 | | | (TI03) | Input | PIOR0 = 1 | × | - | 1 | × | × | × | | | (TO03) | Output | PIOR0 = 1 | 0 | | 0 | 0 | SDA20 = 1 | (SCLA0) = 0 | | P15 | P15 | Input | - | × | - | 1 | × | × | × | | | | Output | - | 0 | - | 0 | 0/1 | SCK20/SCL20 = 1 | PCLBUZ1/(TO02) = 0 | | | | N-ch open drain output | - | 1 | = | 0 | 0/1 | | | | | PCLBUZ1 | Output | - | 0 | - | 0 | 0 | SCK20/SCL20 = 1 | (TO02) = 0 | | | SCK20 <sup>Note</sup> | Input | PIOR1 = 0 | × | _ | 1 | × | × | × | | | | Output | PIOR1 = 0 | 0/1 | - | 0 | 1 | × | PCLBUZ1/(TO02) = 0 | | | SCL20 <sup>Note</sup> | Output | PIOR1 = 0 | 0/1 | - | 0 | 1 | × | PCLBUZ1/(TO02) = 0 | | | (TI02) | Input | PIOR0 = 1 | × | _ | 1 | × | × | × | | | (TO02) | Output | PIOR0 = 1 | 0 | | 0 | 0 | SCK20/SCL20 = 1 | PCLBUZ1 = 0 | | P16 | P16 | Input | I | _ | | 1 | × | _ | × | | | | Output | I | _ | | 0 | 0/1 | _ | TO01 = 0 | | | TI01 | Input | - | - | - | 1 | × | _ | × | | | TO01 | Output | - | - | - | 0 | 0 | _ | × | | | INTP5 | Input | - | - | - | 1 | × | _ | × | | | (RxD0) | Input | PIOR1 = 1 | - | - | 1 | × | _ | × | | P17 | P15 | Input | - | × | - | 1 | × | × | × | | | | Output | - | 0 | - | 0 | 0/1 | (TxD0) = 1 | TO02 = 0 | | | | N-ch open<br>drain output | - | 1 | _ | 0 | 0/1 | | | | | TI02 | Input | PIOR0 = 0 | × | _ | 1 | × | × | × | | | TO02 | Output | PIOR0 = 0 | 0 | _ | 0 | 0 | (TxD0) = 1 | × | | | (TxD0) | Output | PIOR1 = 1 | 0/1 | = | 0 | 1 | × | TO02 = 0 | Table 4-8. Setting Examples of Registers and Output Latches When Using Alternate Function (30-Pin Products) (3/6) | Pin Name | Used | Function | ADPC | ADM2 | PMxx | Pxx | |----------|---------------|-------------------|-----------------------|--------------------|------|-----| | | Function Name | I/O | | | | | | P20 | P20 | Input | ADPC = 00H/02H to 04H | × | 1 | × | | | | Output | ADPC = 01H | × | 0 | 0/1 | | | ANI0 | Analog input | ADPC = 00H/02H to 04H | 00x0xx0x, 10x0xx0x | 1 | × | | | AVREFP | Reference voltage | ADPC = 00H/02H to 04H | 01x0xx0x | 1 | × | | P21 | P21 | Input | ADPC = 01H/02H | × | 1 | × | | | | Output | ADPC = 01H/02H | × | 0 | 0/1 | | | ANI1 | Analog input | ADPC = 00H/03H/04H | xx00xx0x | 1 | × | | | AVREFM | Reference voltage | ADPC = 00H/03H/04H | xx10xx0x | 1 | × | | P22 | P22 | Input | ADPC = 01H to 03H | × | 1 | × | | | | Output | ADPC = 01H to 03H | × | 0 | 0/1 | | | ANI2 | Analog input | ADPC = 00H/04H | × | 1 | × | | P23 | P23 | Input | ADPC = 01H to 04H | × | 1 | × | | | | Output | ADPC = 01H to 04H | × | 0 | 0/1 | | | AN3 | Analog input | ADPC = 00H | × | 1 | × | Table 4-8. Setting Examples of Registers and Output Latches When Using Alternate Function (30-Pin Products) (4/6) | Pin Name | Used F | unction | PIORx | POMxx | PMCxx | PMxx | Pxx | Alternate Fun | ction Output | |----------|-----------------------|--------------|-----------|-------|-------|------|-----|-----------------|----------------| | | Function Name | I/O | | | | | | SAU | Other than SAU | | P30 | P30 | Input | - | - | - | 1 | × | × | - | | | | Output | - | - | _ | 0 | 0/1 | SCK11/SCL11 = 1 | - | | | INTP3 | Input | - | - | _ | 1 | × | × | - | | | SCK11 <sup>Note</sup> | Input | - | - | - | 1 | × | × | _ | | | | Output | = | = | = | 0 | 1 | × | - | | | SCL11 <sup>Note</sup> | Output | - | - | - | 0 | 1 | × | _ | | P31 | P31 | Input | - | - | _ | 1 | × | - | × | | | | Output | - | - | _ | 0 | 0/1 | - | TO03/PCLBUZ0 | | | | | | | | | | | = 0 | | | TI03 | Input | PIOR0 = 0 | - | - | 1 | × | _ | × | | | TO03 | Output | PIOR0 = 0 | - | - | 0 | 0 | - | PCLBUZ0 = 0 | | | INTP4 | Input | = | = | = | 1 | × | - | × | | | PCLBUZ0 | Output | = | = | - | 0 | 0 | = | TO03 = 0 | | P40 | P40 | Input | = | = | = | 1 | × | - | - | | | | Output | - | - | - | 0 | 0/1 | - | _ | | P50 | P50 | Input | = | х | = | 1 | × | × | - | | | | Output | - | 0 | - | 0 | 0/1 | SDA11 = 1 | - | | | | N-ch open | - | 1 | - | 0 | 0/1 | | | | | | drain output | | | | | | | | | | INTP1 | Input | - | × | _ | 1 | × | × | _ | | | SI11 <sup>Note</sup> | Input | - | × | _ | 1 | × | × | _ | | | SDA11 <sup>Note</sup> | I/O | - | 1 | - | 0 | 1 | × | _ | | P51 | P51 | Input | - | - | _ | 1 | × | × | _ | | | | Output | - | - | - | 0 | 0/1 | SO11 = 1 | - | | | INTP2 | Input | = | = | = | 1 | × | × | = | | | SO11 <sup>Note</sup> | Output | _ | - | _ | 0 | 1 | × | _ | Table 4-8. Setting Examples of Registers and Output Latches When Using Alternate Function (30-Pin Products) (5/6) | Pin Name | Used | Function | PIORx | POMxx | PMCxx | PMxx | Pxx | Alternate Fu | nction Output | |----------|---------------|----------------------------------------------|-----------|-------|-------|------|-----|--------------|----------------| | | Function Name | I/O | | | | | | SAU | Other than SAU | | P60 | P60 | Input | - | I | _ | 1 | × | × | - | | | | N-ch open drain<br>output<br>(6-V tolerance) | _ | l | - | 0 | 0/1 | SCLA0 = 1 | - | | | SCLA0 | I/O | PIOR2 = 0 | Ī | - | 0 | 0 | × | _ | | P61 | P61 | Input | - | 1 | - | 1 | × | × | - | | | | N-ch open drain<br>output<br>(6-V tolerance) | - | - | - | 0 | 0/1 | SDAA0 = 1 | - | | | SDAA0 | I/O | PIOR2 = 0 | = | _ | 0 | 0 | × | _ | | P120 | P120 | Input | - | = | 0 | 1 | × | _ | - | | | | Output | - | - | 0 | 0 | 0/1 | - | - | | | ANI19 | Analog input | - | = | 1 | 1 | × | _ | - | | P137 | P137 | Input | - | - | - | - | × | - | - | | | INTP0 | Input | - | - | - | - | × | - | - | | P147 | P147 | Input | - | I | 0 | 1 | × | I | - | | | | Output | - | 1 | 0 | 0 | 0/1 | I | - | | | ANI18 | Analog input | - | ı | 1 | 1 | × | - | | Table 4-8. Setting Examples of Registers and Output Latches When Using Alternate Function (30-Pin Products) (6/6) | Pin Name | Used F | unction | PIORx | Pxx | Others | |----------|---------------|---------|-------|-----|--------------------------| | | Function Name | I/O | | | | | P121 | P121 | Input | - | × | EXCLK, OSCSEL = 00/10/11 | | | X1 | | | × | EXCLK, OSCSEL = 01 | | P122 | P122 | - | | × | EXCLK, OSCSEL = 00/10 | | | X2 | | | × | EXCLK, OSCSEL = 01 | | | EXCLK | | | × | EXCLK, OSCSEL = 11 | #### 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 P00 is an output port, P01 to P03 are input ports (all pin statuses are high level), and the output latch value of port 0 is 00H, if the output of output port P00 is changed from low level to high level via a 1-bit manipulation instruction, the output latch value of port 0 is 0FH. Explanation: The targets of writing to and reading from the Pn register of a port whose PMmn bit is 1 are the output latch and pin status, respectively. A 1-bit manipulation instruction is executed in the following order in the RL78/G12. - <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 P00, which is an output port, is read, while the pin statuses of P01 to P03, which are input ports, are read. If the pin statuses of P01 to P03 are high level at this time, the read value is 0EH. The value is changed to 0FH by the manipulation in <2>. 0FH is written to the output latch by the manipulation in <3>. Figure 4-10. Bit Manipulation Instruction (P00) 1-bit manipulation instruction for P00 bit - <1> Port register 0 (P0) is read in 8-bit units. - For P00, an output port, the value of the port output latch (0) is read. - For P01 to P03, input ports, the pin status (1) is read. - <2> Set the P00 bit to 1. - <3> Write the results of <2> to the output latch of port register 0 (P0) in 8-bit units. # 4.6.2 Notes on specifying the pin settings For an output pin to which multiple alternate functions are assigned, the output of the unused alternate function must be set to its initial state so as to prevent conflicting outputs. This also applies to the functions assigned by using the peripheral I/O redirection register (PIOR). For details about the alternate output function, 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 to 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 three 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 among $f_{IH} = 24$ , 16, 12, 8, 6, 4, 3, 2, or 1 MHz (TYP.) by using the option byte (000C2H). After a reset release, the CPU always starts operating with this high-speed on-chip oscillator clock. 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-9 Format of High-speed On-chip Oscillator Frequency Select Register (HOCODIV)**. The frequencies that can be specified for the high-speed on-chip oscillator by using the option byte and the high-speed on-chip oscillator frequency select register (HOCODIV) are shown below. | Power Supply Voltage | Oscillation Frequency (MHz) | | | | | | | | | |---------------------------------------|-----------------------------|---|---|-----------|---|---|-----------|----|----| | | 1 | 2 | 3 | 4 | 6 | 8 | 12 | 16 | 24 | | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$ | $\sqrt{}$ | √ | √ | $\sqrt{}$ | √ | √ | $\sqrt{}$ | √ | √ | | $2.4~V \leq V_{DD} \leq 5.5~V$ | $\sqrt{}$ | √ | √ | √ | √ | √ | √ | √ | _ | | $1.8~V \leq V_{DD} \leq 5.5~V$ | $\sqrt{}$ | √ | √ | √ | √ | √ | - | - | _ | **Remark** √: Can be specified, –: Cannot be specified 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 onchip oscillator clock can be selected by setting of the MCM0 bit (bit 4 of the system clock control register (CKC)). However, note that the usable frequency range of the main system clock differs depending on the setting of the power supply voltage (V<sub>DD</sub>). The operating voltage of the flash memory must be set by using the CMODE0 and CMODE1 bits of the option byte (000C2H) (see **CHAPTER 23 OPTION BYTE**). #### (2) Low-speed on-chip oscillator clock (Low-speed on-chip oscillator) This circuit oscillates a clock of f<sub>IL</sub> = 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 <R> • 12-bit Interval timer This clock operates when bit 4 (WDTON) of the option byte (000C0H), bit 4 (WUTMMCK0) of the operation speed 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 LOCO stops if the HALT or STOP instruction is executed. Remark fx: X1 clock oscillation frequency fін: High-speed on-chip oscillator clock frequency fex: External main system clock frequency fıL: Low speed on-chip oscillator clock 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 register 0 (PER0) | | | | | | | | Operation speed mode control register (OSMC) | | | | | | | | High-speed on-chip oscillator frequency selection register (HOCODIV) | | | | | | | | High-speed on-chip oscillator trimming register (HIOTRM) | | | | | | | Oscillators | X1 oscillator | | | | | | | | High-speed on-chip oscillator | | | | | | | | Low-speed on-chip oscillator | | | | | | Figure 5-1. Block Diagram of Clock Generator Serial array unit 1 Note 2 Serial interface IICA Serial array unit 0 Timer array unit A/D converter CPU Normal operation mode Standby controller STOP mode HALT mode Controller System clock control register (CKC) Peripheral enable register 0 (PER0) TAU0 SAUO Clock output/buzzer output MCS MCMO IICA0 EN CPU clock and peripheral hardware clock source selection 12 bits Interval timer ADC Operation speed mode control register (OSMC) TMKA WUTMMCK0 Controller Main system clock source selector Oscillation stabilization time select register (OSTS) high-speed on-chip oscillator trimming register(HIOTRM) Oscillation stabilization time counter status register (OSTC) HIOTRM5 | HIOTRM4 | HIOTRM3 | HIOTRM2 | HIOTRM1 | HIOTRM0 HALT/STOP mode signal MOST MOST MOST MOST MOST MOST MOST 8 9 10 11 13 15 17 Internal bus Option byte (000C0H) - WDTON - WDSTBYON X1 oscillation stabilization time counter Internal bus OSTS2 OSTS1 OSTS0 - STOP mode signal HIOSTOP Clock operation status control register (CSC) Low-speed on-chip oscillator Oscillation (15 kHz (TYP.)) MSTOP Clock operation status control register (CSC) носовіу2 носовіу1 носовіу0 20-, 24-pin products only. High-speed on-chip oscillator frequency selection register (HOCODIV) Oscillation fex Crystal/ceramic Oscillation (24 MHz (TYP.)); Oscillation (16 MHz (TYP.)) Oscillation (12 MHz (TYP.)); 'Oscillation (8 MHz (TYP.)) Oscillation (6 MHz (TYP.)) Oscillation (4 MHz (TYP.)) Oscillation (3 MHz (TYP.)) (Oscillation (2 MHz (TYP.)) High-speed on-chip oscillator High-speed system clock oscillator AMPH EXCLK OSCSEL Sook . Clock operation mode control register (CMC) Oscillation (1 MHz (TYP.)) Option byte (000C2H) FRQSEL0 to FRQSEL3 X1/P121/KR3<sup>Note1</sup> ©— (TI03/INTP03) Note1 ©— X2/EXCLK/ P122/KR2<sup>No61</sup>/ (T102/INTP02)<sup>No61</sup> Notes 1. R01UH0200EJ0210 Rev.2.10 Mar 25, 2016 30-pin products only. તં Remark fx: X1 clock oscillation frequency fін: High-speed on-chip oscillator clock frequency fex: External main system clock frequency fmx: High-speed system clock frequency fmain: Main system clock frequency fclk: CPU/peripheral hardware clock frequency fil: Low-speed on-chip oscillator clock frequency ## 5.3 Registers Controlling Clock Generator The following nine 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 register 0 (PER0) - Operation speed mode control register (OSMC) - High-speed on-chip oscillator frequency selection register (HOCODIV) - High-speed on-chip oscillator trimming register (HIOTRM) **Caution** Which registers and bits are included depends on the product. Be sure to set registers and bits that are not mounted in a product to their initial values. #### 5.3.1 Clock operation mode control register (CMC) This register is used to set the operation mode of the X1/P121 and 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. Figure 5-2. Format of Clock Operation Mode Control Register (CMC) | Address: FFFA0H After reset: 00H | | | R/W | | | | | | |----------------------------------|-------|--------|-----|---|---|---|---|------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CMC | EXCLK | OSCSEL | 0 | 0 | 0 | 0 | 0 | AMPH | | EXCLK | OSCSEL | High-speed system clock pin operation mode | X1/P121/KR3 pin | X2/EXCLK/P122/KR2<br>pin | | | |-------|--------|--------------------------------------------|--------------------------------------|--------------------------|--|--| | 0 | 0 | Input port mode | Input port | | | | | 0 | 1 | X1 oscillation mode | Crystal/ceramic resonator connection | | | | | 1 | 0 | Input port mode | Input port | | | | | 1 | 1 | External clock input mode | Input port | External clock input | | | | AMPH | Control of X1 clock oscillation frequency | |------|-------------------------------------------| | 0 | 1 MHz $\leq$ fx $\leq$ 10 MHz | | 1 | 10 MHz < fx ≤ 20 MHz | # Cautions 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 - 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. - 2. After reset release, set the CMC register before X1 oscillation is started as set by the clock operation status control register (CSC). - 3. Be sure to set the AMPH bit to 1 if the X1 clock oscillation frequency exceeds 10 MHz. - **4.** Specify the setting for the AMPH bit while $f_{IH}$ is selected as $f_{CLK}$ after a reset ends (before $f_{CLK}$ is switched to $f_{MX}$ ). - **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: 00H | | R/W Note | | | | | | | |----------------------------------|---|----------|-----|------|---|---|---|---| | 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 on-chip oscillator clock (fн) | | | | | | | | 1 | High-speed system clock (fmx) | | | | | | | | МСМ0 | Main system clock (fmain) operation control | | | | | | | |------|----------------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | Selects the high-speed on-chip oscillator clock (fin) as the main system clock (fmain) | | | | | | | | 1 | Selects the high-speed system clock (fmx) as the main system clock (fmain) | | | | | | | Note Bit 5 is read-only. Remark fin: High-speed on-chip oscillator clock frequency fmx: High-speed system clock frequency fmain: Main system clock frequency **Caution** Be sure to set bits 7, 6, and 3 to 0 to 0. #### 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 clock, (except the low-speed on-chip oscillator clock). 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) After reset: C0H R/W Address: FFFA1H Symbol <0> CSC **HIOSTOP MSTOP** | MSTOP | High-speed system clock operation control | | | | | | | |-------|-------------------------------------------|------------------------------------------|------------|--|--|--|--| | | X1 oscillation 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 | | | | | | Cautions 1. After reset release, set the clock operation mode control register (CMC) before setting the CSC register. - 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. - 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). - 4. Do not stop the clock selected for the CPU peripheral hardware clock (fclk) with the CSC register. - 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. Table 5-2. Stopping Clock Method | Clock | Condition Before Stopping Clock (Invalidating External Clock Input) | Setting of CSC<br>Register Flags | |-------------------------------------|------------------------------------------------------------------------------------------------------|----------------------------------| | X1 clock External main system clock | CPU and peripheral hardware clocks operate with a high-<br>speed on-chip oscillator clock. (MCS = 0) | MSTOP = 1 | | High-speed on-chip oscillator clock | CPU and peripheral hardware clocks operate with a high-<br>speed system clock.(MCS = 1) | HIOSTOP = 1 | <R> ## 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 → MSTOP = 0) - When the STOP mode is released Figure 5-5. Format of Oscillation Stabilization Time Counter Status Register (OSTC) Address: FFFA2H After reset: 00H Symbol 4 3 2 **OSTC** MOST MOST MOST MOST MOST MOST MOST MOST 8 9 10 15 17 18 11 13 | MOST Oscillation stabilization time status | | | |------|------|------|------|------|------|------|------|---------------------------------------|----------------------|----------------------| | 8 | 9 | 10 | 11 | 13 | 15 | 17 | 18 | | fx = 10 MHz | fx = 20 MHz | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 28/fx max. | 25.6 <i>μ</i> s max. | 12.8 <i>μ</i> s max. | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 28/fx min. | 25.6 <i>μ</i> s min. | 12.8 <i>μ</i> s min. | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 29/fx min. | 51.2 <i>μ</i> s min. | 25.6 <i>μ</i> s min. | | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 2 <sup>10</sup> /fx min. | 102 <i>μ</i> s min. | 51.2 <i>μ</i> s min. | | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 2 <sup>11</sup> /fx min. | 204 <i>μ</i> s min. | 102 <i>μ</i> s min. | | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 2 <sup>13</sup> /fx min. | 819 <i>μ</i> s min. | 409 <i>μ</i> 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. | **Cautions 1.** After the above time has elapsed, the bits are set to 1 in order from the MOST8 bit and remain 1. - 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.) - 3. The X1 clock oscillation stabilization wait time does not include the time until clock oscillation starts ("a" below). Remark fx: X1 clock oscillation frequency #### 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. Figure 5-6. Format of Oscillation Stabilization Time Select Register (OSTS) | Address: FFFA3H After reset: 07H | | R/W | | | | | | | |----------------------------------|---|-----|---|---|---|-------|-------|-------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | OSTS | 0 | 0 | 0 | 0 | 0 | OSTS2 | OSTS1 | OSTS0 | | OSTS2 | OSTS1 | OSTS0 | Oscillation stabilization time selection | | | | | |-------|-------|-------|------------------------------------------|-------------|-----------------|--|--| | | | | | fx = 10 MHz | fx = 20 MHz | | | | 0 | 0 | 0 | 2 <sup>8</sup> /fx | 25.6 μs | 12.8 <i>μ</i> s | | | | 0 | 0 | 1 | 2°/fx | 51.2 μs | 25.6 <i>μ</i> s | | | | 0 | 1 | 0 | 2 <sup>10</sup> /fx | 102 μs | 51.2 <i>μ</i> s | | | | 0 | 1 | 1 | 2 <sup>11</sup> /fx | 204 μs | 102 μs | | | | 1 | 0 | 0 | 2 <sup>13</sup> /fx | 819 µs | 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.1 ms | 6.55 ms | | | | 1 | 1 | 1 | 2 <sup>18</sup> /fx | 26.2 ms | 13.1 ms | | | - **Cautions 1.** To set the STOP mode when the X1 clock is used as the CPU clock, set the OSTS register before executing the STOP instruction. - **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.) 3. The X1 clock oscillation stabilization wait time does not include the time until clock oscillation starts ("a" below). Remark fx: X1 clock oscillation frequency ## 5.3.6 Peripheral enable register 0 (PER0) 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 IICA - · Serial array unit 1 - · Serial array unit 0 - Timer array unit 0 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 5-7. Format of Peripheral Enable Register 0 (PER0) (1/2) Address: F00F0H After reset: 00H Symbol <7> 6 <5> <4> <3> <2> <0> PER0 **TMKAEN ADCEN IICA0EN** SAU1EN SAU0EN TAU0EN | TMKAE | Control of 12-bit interval timer clock supply | |-------|--------------------------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by the 12-bit interval timer cannot be written. • The 12-bit interval timer is in the reset status. | | 1 | Enables clock supply. • SFR used by the 12-bit interval timer can be read and written. | | ADCEN | Control of A/D converter clock supply | |-------|----------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by the A/D converter cannot be written. • The A/D converter is in the reset status. | | 1 | Enables clock supply. • SFR used by the A/D converter can be read and written. | | IICA0EN | Control of serial interface IICA clock supply | |---------|--------------------------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by the serial interface IICA cannot be written. • The serial interface IICA is in the reset status. | | 1 | Enables clock supply. • SFR used by the serial interface IICA can be read and written. | Note 30-pin products only. **Caution** Be sure to set the following bits to 0. 20, 24-pin products: bits 1, 3, 6 30-pin products: bits 1, 6 Figure 5-7. Format of Peripheral Enable Register 0 (PER0) (2/2) Address: F00F0H After reset: 00H Symbol <7> 6 <4> <3> <2> <0> 1 PER0 TMKAEN 0 **ADCEN IICA0EN** SAU1EN SAU0EN 0 TAU0EN | SAU1EN | Control of serial array unit 1 clock supply | |--------|----------------------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by the serial array unit 1 cannot be written. • The serial array unit 1 is in the reset status. | | 1 | Enables clock supply. • SFR used by the serial array unit 1 can be read and written. | | SAU0EN | Control of serial array unit 0 clock supply | |--------|----------------------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by the serial array unit 0 cannot be written. • The serial array unit 0 is in the reset status. | | 1 | Enables clock supply. • SFR used by the serial array unit 0 can be read and written. | | TAU0EN | Control of timer array unit clock supply | |--------|--------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by timer array unit cannot be written. • Timer array unit is in the reset status. | | 1 | Enables clock supply. • SFR used by timer array unit can be read and written. | Note 30-pin products only. Caution Be sure to set the following bits to 0. 20, 24-pin products: bits 1, 3, 6 30-pin products: bits 1, 6 ## 5.3.7 Operation speed mode control register (OSMC) The OSMC register is used to control supply of the operation clock for the 12-bit interval timer. When operating the 12-bit interval timer, set WUTMMCK0 = 1 beforehand and do not set WUTMMCK0 = 0 until the timer is stopped. The OSMC register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 5-8. Format of Operation Speed Mode Control Register (OSMC) | Address: F0 | 00F3H After | reset: 00H | R/W | | | | | | |-------------|-------------|------------|-----|----------|---|---|---|---| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | OSMC | 0 | 0 | 0 | WUTMMCK0 | 0 | 0 | 0 | 0 | | WUTMMCK0 | Supply of operation clock for 12-bit interval timer | |----------|-----------------------------------------------------| | 0 | Stops Clock supply | | 1 | Low-speed on-chip oscillator clock (f⊾) supply | #### 5.3.8 High-speed on-chip oscillator frequency selection register (HOCODIV) This register is used to change the frequency of the high-speed on-chip oscillator set with the option byte (000C2H). The available frequency varies depending on the value of the FRQSEL3 bit 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-9 Format of High-Speed On-Chip Oscillator Frequency Selection Register (HOCODIV) ${\sf Address:}\ {\sf F00A8H} \quad \ \ {\sf After}\ {\sf reset:}\ {\sf the}\ {\sf value}\ {\sf set}\ {\sf by}\ {\sf FRQSEL2}\ {\sf to}\ {\sf FRQSEL0}\ {\sf of}\ {\sf the}\ {\sf option}\ {\sf byte}\ ({\sf 000C2H}) \\ \ \ \ \ {\sf R/W}$ | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|-----------|-----------|-----------| | HOCODIV | 0 | 0 | 0 | 0 | 0 | HOCODIV 2 | HOCODIV 1 | HOCODIV 0 | | HOCODIV 2 | HOCODIV 1 | HOCODIV 0 | High-speed on-chip oscillator clock frequency selection | | | | |------------------|-----------|-----------|---------------------------------------------------------|--------------------|--|--| | | | | FRQSEL3 bit is 0 | FRQSEL3 bit is 1 | | | | 0 | 0 | 0 | 24 MHz | Setting prohibited | | | | 0 | 0 | 1 | 12 MHz | 16 MHz | | | | 0 | 1 | 0 | 6 MHz | 8 MHz | | | | 0 | 1 | 1 | 3 MHz | 4 MHz | | | | 1 | 0 | 0 | Setting prohibited | 2 MHz | | | | 1 | 0 | 1 | Setting prohibited | 1 MHz | | | | Other than above | | | Setting p | prohibited | | | **Cautions 1.** 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 | | r lastr operation mode | range | | | | 1 | 0 | LS (low-speed main)<br>mode | 1 MHz to 8 MHz | 1.8 V to 5.5 V | | | 1 | 1 | HS (high-speed main) | 1 MHz to 16 MHz | 2.4 V to 5.5 V | | | | | mode | 1 MHz to 24 MHz | 2.7 V to 5.5 V | | - 2. Set the HOCODIV register with the high-speed on-chip oscillator clock (fih) selected as the CPU/peripheral hardware clock (fclk). - **3.** After settings are 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 ## 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 V<sub>DD</sub> pin voltage change after accuracy adjustment. When the temperature and V<sub>DD</sub> voltage change, accuracy adjustment must be executed regularly or before the frequency accuracy is required. Figure 5-10. Format of High-Speed On-chip Oscillator Trimming Register (HIOTRM) | Address: F00A0H After reset: undefined Note | | | | V | | | | | |---------------------------------------------|---|---|---------|---------|---------|---------|---------|---------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | HIOTRM | 0 | 0 | HIOTRM5 | HIOTRM4 | HIOTRM3 | HIOTRM2 | HIOTRM1 | HIOTRM0 | | HIOTRM5 | HIOTRM4 | HIOTRM3 | HIOTRM2 | HIOTRM1 | HIOTRM0 | High-speed on-chip oscillator | |---------|---------|---------|---------|---------|---------|-------------------------------| | 0 | 0 | 0 | 0 | 0 | 0 | Minimum speed | | 0 | 0 | 0 | 0 | 0 | 1 | <b>†</b> | | 0 | 0 | 0 | 0 | 1 | 0 | | | 0 | 0 | 0 | 0 | 1 | 1 | | | 0 | 0 | 0 | 1 | 0 | 0 | | | | | • | • | | | | | 1 | 1 | 1 | 1 | 1 | 0 | <b>*</b> | | 1 | 1 | 1 | 1 | 1 | 1 | Maximum speed | Note The value after reset is the value adjusted at shipment. Remarks 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% 2. For the usage example of the HIOTRM register, see the application note for RL78 MCU series High-speed On-chip Oscillator (HOCO) Clock Frequency Correction (R01AN0464). # 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 2.3 Connection of Unused Pins. Figure 5-11 shows an example of the external circuit of the X1 oscillator. Figure 5-11. Example of External Circuit of X1 Oscillator #### (a) Crystal or ceramic oscillation #### (b) External clock **Caution** When using the X1 oscillator, wire as follows in the area enclosed by the broken lines in the Figure 5-11 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. Figure 5-12 shows examples of incorrect resonator connection. Figure 5-12. Examples of Incorrect Resonator Connection (1/2) # (c) The X1 and X2 signal line wires cross. (d) A power supply/GND pattern exists under the X1 and X2 wires. **Note** Do not place a power supply/GND pattern under the wiring section (section indicated by a broken line in the figure) of the X1 and X2 pins and the resonators in a multi-layer board or double-sided board. Do not configure a layout that will cause capacitance elements and affect the oscillation characteristics. Figure 5-12. Examples of Incorrect Resonator Connection (2/2) # (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 RL78/G12. The frequency can be selected from among 24, 16, 12, 8, 6, 4, 3, 2, or 1 MHz by using the option byte (000C2H). 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 RL78/G12. 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 operation speed 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.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 fiн - Low-speed on-chip oscillator clock fill - CPU/peripheral hardware clock fclk The CPU starts operation when the high-speed on-chip oscillator starts outputting after a reset release in the RL78/G12. When the power supply voltage is turned on, the clock generator operation is shown in Figure 5-13. Figure 5-13. 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 detection circuit or an external reset until the voltage reaches the range of operating voltage described in 28.4 AC Characteristics and 29.4 AC Characteristics (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 switch the clock via software. - **Notes 1.** The internal reset processing time includes the oscillation accuracy stabilization time of the high-speed onchip oscillator clock. - 2. When releasing a reset, confirm the oscillation stabilization time for the X1 clock using the oscillation stabilization time counter status register (OSTC). - 3. For the reset processing time, see CHAPTER 19 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 on-chip oscillator clock. The frequency of the high-speed on-chip oscillator can be selected from 24, 16, 12, 8, 6, 4, 3, 2, and 1 MHz by using FRQSEL0 to FRQSEL3 of the option byte (000C2H). The frequency can also be changed by the high-speed on-chip oscillator frequency select register (HOCODIV). [Option byte setting] Address: 000C2H > Option byte (000C2H) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---|---|---------|---------|---------|---------| | CMODE1 | CMODE0 | | | FRQSEL3 | FRQSEL2 | FRQSEL1 | FRQSEL0 | | 0/1 | 0/1 | 1 | 0 | 0/1 | 0/1 | 0/1 | 0/1 | | CMODE1 | CMODE0 | Setting of flash operation mode | | | | | | |------------------|--------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 1 | 0 | LS (low speed main) mode | $V_{DD} = 1.8 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 8 \text{ MHz}$ | | | | | | 1 | 1 | HS (high speed main) mode | $V_{DD} = 2.4 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 16 \text{ MHz}$<br>$V_{DD} = 2.7 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 24 \text{ MHz}$ | | | | | | Other than above | | Setting prohibited | | | | | | | FRQSEL3 | FRQSEL2 | FRQSEL1 | FRQSEL0 | Frequency of the high-speed on-chip oscillator | |---------|-----------|----------|---------|------------------------------------------------| | 0 | 0 | 0 | 0 | 24 MHz | | 1 | 0 | 0 | 1 | 16 MHz | | 0 | 0 | 0 | 1 | 12 MHz | | 1 | 0 | 1 | 0 | 8 MHz | | 0 | 0 | 1 | 0 | 6 MHz | | 1 | 0 | 1 | 1 | 4 MHz | | 0 | 0 | 1 | 1 | 3 MHz | | 1 | 1 | 0 | 0 | 2 MHz | | 1 | 1 | 0 | 1 | 1 MHz | | | Other tha | an above | | Setting prohibited | [High-speed on-chip oscillator frequency selection register (HOCODIV) setting] Address: F00A8H 7 6 5 4 3 2 1 0 HOCODIV 0 0 0 HOCODIV 2 HOCODIV 1 HOCODIV 0 | HOCODIV 2 | HOCODIV 1 | HOCODIV 0 | High-speed on-chip oscillator clock frequency selection | | | | |------------------|-----------|-----------|---------------------------------------------------------|--------------------|--|--| | | | | FRQSEL3 bit is 0 | FRQSEL3 bit is 1 | | | | 0 | 0 | 0 | 24 MHz | Setting prohibited | | | | 0 | 0 | 1 | 12 MHz | 16 MHz | | | | 0 | 1 | 0 | 6 MHz 8 MHz | | | | | 0 | 1 | 1 | 3 MHz | 4 MHz | | | | 1 | 0 | 0 | Setting prohibited | 2 MHz | | | | 1 | 0 | 1 | Setting prohibited 1 MHz | | | | | Other than above | | | Setting prohibited | | | | #### 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 on-chip 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 select 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 fx > 10 MHz, in such cases set (1) the AMPH bit, to operate the X1 oscillator. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|--------|---|---|---|---|---|------| | CMC | EXCLK | OSCSEL | | | | | | AMPH | | CIVIC | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0/1 | <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 | | | | | | OSTS2 | OSTS1 | OSTS0 | | 0515 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 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 | |-----|-------|---|---|---|---|---|---|---------| | CSC | MSTOP | | | | | | | HIOSTOP | | CSC | 0 | 0 | 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 $\mu$ 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 | | | 0310 | 1 | 1 | 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 | |-----|---|---|-----|------|---|---|---|---| | CKC | | | MCS | MCM0 | | | | | | ONO | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Note Set the High-speed on-chip oscillator frequency selection register (HOCODIV) within the operable voltage range of the flash operation mode set in the option byte (000C2H) before and after the frequency change. | Option byte (00 | 00C2H) value | Flash operation mode | Operating frequency | Operating voltage range | | |-----------------|--------------|--------------------------|---------------------|-------------------------|--| | CMODE1 | CMODE0 | r lastr operation mode | range | | | | 1 | 0 | LS (low-speed main) mode | 1 MHz to 8 MHz | 1.8 V to 5.5 V | | | 1 | 1 | HS (high-speed main) | 1 MHz to 16 MHz | 2.4 V to 5.5 V | | | | | mode | 1 MHz to 24 MHz | 2.7 V to 5.5 V | | #### 5.6.3 CPU clock status transition diagram Figure 5-14 shows the CPU clock status transition diagram of this product. Power ON High-speed on-chip oscillator: Woken up X1 oscillation/EXCLK input: Stops (input port mode) V<sub>DD</sub> ≥ Lower limit of the operating voltage range (release from the reset state triggered by the LVD circuit or an external reset) Reset release High-speed on-chip oscillator: Operating X1 oscillation/EXCLK input: Stops (input port mode) (B) CPU: Operating High-speed on-chip oscillator: Operating X1 oscillation/EXCLK input: Selectable by CPL high-speed on-chip oscillator CPU: High-speed High-speed on-chip oscillator: Stops on-chip oscillator => STOP X1 oscillation/EXCLK input: Stops (H)CPU: High-speed High-speed on-chip oscillator: Operating on-chip oscillator => SNOOZE (D) X1 oscillation/EXCLK input: Stops CPU: High-speed on-chip oscillator (C) High-speed on-chip oscillator: Operating X1 oscillation/EXCLK input: Oscillatable CPU: Operating with X1 oscillation or EXCLK input (G) High-speed on-chip oscillator: Selectable by CPU CPU: X1 X1 oscillation/EXCLK input: Operating oscillation/EXCLK (E) input => STOP CPU: Internal high-High-speed on-chip oscillator: Stops X1 oscillation/EXCLK input: Stops speed oscillation => HALT High-speed on-chip oscillator: Oscillatable X1 oscillation/EXCLK input: Operating Figure 5-14. CPU Clock Status Transition Diagram Table 5-3 shows transition of the CPU clock and examples of setting the SFR registers. Table 5-3. CPU Clock Transition and SFR Register Setting Examples (1/3) ## (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 | CI | MC Register <sup>N</sup> | ote1 | OSTS<br>Register | CSC<br>Register | OSTC<br>Register | CKC<br>Register | |----------------------------------------------------------------------------------------------------------|-------|--------------------------|------|------------------|-----------------|---------------------|-----------------| | Status Transition | EXCLK | OSCSEL | AMPH | | MSTOP | | МСМ0 | | $(A) \rightarrow (B) \rightarrow (C)$<br>$(X1 \text{ clock: } 1 \text{ MHz} \le f_X \le 10 \text{ MHz})$ | 0 | 1 | 0 | Note 2 | 0 | Must be checked | 1 | | $(A) \rightarrow (B) \rightarrow (C)$<br>(X1 clock: 10 MHz < fx ≤ 20 MHz) | 0 | 1 | 1 | Note 2 | 0 | Must be checked | 1 | | $(A) \rightarrow (B) \rightarrow (C)$<br>(external main clock) | 1 | 1 | × | Note 2 | 0 | Must not be checked | 1 | - **Notes 1.** The clock operation mode control register (CMC) can be written only once by an 8-bit memory manipulation instruction after reset release. - 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 CHAPTER 28 or 29 ELECTRICAL SPECIFICATIONS). Remarks 1. x: don't care 2. (A) to (H) in Table 5-3 correspond to (A) to (H) in Figure 5-14. #### Table 5-3. CPU Clock Transition and SFR Register Setting Examples (2/3) ## (3) CPU clock changing from high-speed on-chip oscillator clock (B) to high-speed system clock (C) (Setting sequence of SFR registers) CMC Register<sup>Note 1</sup> Setting Flag of SFR Register OSTS CSC **OSTC** Register CKC Register Register Register Status Transition **EXCLK** OSCSEL **AMPH MSTOP** MCM0 $(B) \rightarrow (C)$ 0 0 Note 2 0 Must be checked (X1 clock: 1 MHz $\leq$ fx $\leq$ 10 MHz) $(B) \rightarrow (C)$ 0 1 Note 2 0 Must be checked (X1 clock: 10 MHz < fx $\le$ 20 MHz) $(B) \rightarrow (C)$ 1 1 Note 2 0 Must not be checked 1 (external main clock) > Unnecessary if these registers > Unnecessary if the CPU is operating with are already set the high-speed system clock - Notes 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. - 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 CHAPTER 28 or 29 ELECTRICAL SPECIFICATIONS). ### (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 **CKC** Register Oscillation accuracy stabilization time Status Transition HIOSTOP MCM0 $(C) \rightarrow (B)$ 18 $\mu$ s to 65 $\mu$ s > 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 STOP mode period. - (5) HALT mode (D) set while CPU is operating with high-speed on-chip oscillator clock (B) - HALT mode (E) set while CPU is operating with high-speed system clock (C) | Status Transition | Setting | |-------------------------------------------------------------|----------------------------| | $ \begin{array}{c} (B) \to (D) \\ (C) \to (E) \end{array} $ | Executing HALT instruction | Remarks 1. x: don't care 2. (A) to (H) in Table 5-3 correspond to (A) to (H) in Figure 5-14. ## Table 5-3. CPU Clock Transition and SFR Register Setting Examples (3/3) ## (6) • STOP mode (F) set while CPU is operating with high-speed on-chip oscillator clock (B) • STOP mode (G) set while CPU is operating with high-speed system clock (C) # (7) CPU changing from STOP mode (F) to SNOOZE mode (H) For details about the setting for switching from the STOP mode to the SNOOZE mode, see **10.8 SNOOZE Mode** Function, **11.5.7 SNOOZE mode function** and **11.6.3 SNOOZE mode function**. Remark (A) to (H) in Table 5-3 correspond to (A) to (H) in Figure 5-14. ## 5.6.4 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. Table 5-4. Changing CPU Clock <R> | CPU Clock | | Condition Before Change | Processing After Change | | |--------------------------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--| | Before Change | After Change | Condition Before Change | 1 locessing Alter Change | | | High-speed on-<br>chip oscillator<br>clock | | | The operating current can be reduced by stopping the high-speed on-chip oscillator (HIOSTOP = 1) after | | | External main | | checking that the CPU clock is changed. | | | | X1 clock | High-speed on-<br>chip oscillator<br>clock | Enabling oscillation of high-speed on-chip oscillator • HIOSTOP = 0 • After elapse of oscillation accuracy stabilization time | X1 oscillation can be stopped (MSTOP = 1) after checking that the CPU clock is changed. | | | | External main system clock | Transition not possible | - | | | External main system clock | High-speed on-<br>chip oscillator<br>clock | Oscillation of high-speed on-chip oscillator • HIOSTOP = 0 • After elapse of oscillation accuracy stabilization time | External main system clock input can be disabled (MSTOP = 1) after checking that the CPU clock is changed. | | | | X1 clock | Transition not possible | - | | #### 5.6.5 Time required for switchover of CPU clock and main system clock The main system clock can be switched between the high-speed on-chip oscillator clock and the high-speed system clock by specifying bit 4 (MCM0) of the system clock control register (CKC). 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-5**). 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 is also switched. Set Value Before Switchover Set Value After Switchover MCM<sub>0</sub> MCM0 0 1 $(f_{MAIN} = f_{IH})$ $(f_{MAIN} = f_{MX})$ 0 f<sub>MX</sub>>f<sub>IH</sub> 2 clock $(f_{MAIN} = f_{IH})$ fmx<fiH 2fiн/fmx clock 2fмх/fін clock fмх≥fін $(f_{MAIN} = f_{MX})$ fмx<fін 2 clock Table 5-5. Maximum Number of Clocks Required for fin ↔ fmx Remarks 1. Number of CPU clocks before switchover. 2. Calculate the number of clocks by rounding to the nearest whole number. **Example** When switching the main system clock from the high-speed system clock to the high-speed on-chip oscillator clock (@ oscillation with fin = 8 MHz selected, fmx = 10 MHz) $$2 \text{ fih/fmx} = 2(10/8) = 2.5 \rightarrow 3 \text{ clocks}$$ # 5.6.6 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. <R> Before stopping the clock oscillation, check the conditions before the clock oscillation is stopped. Table 5-6. Conditions Before the Clock Oscillation Is Stopped and Flag Settings | Clock | Conditions Before Clock Oscillation Is Stopped (External Clock Input Disabled) | Flag Settings of SFR | |-------------------------------------|--------------------------------------------------------------------------------|----------------------| | High-speed on-chip oscillator clock | MCS = 1 (The CPU is operating on the high-speed system clock.) | HIOSTOP = 1 | | X1 clock | MCS = 0 | MSTOP = 1 | | External main system clock | (The CPU is operating on the high-speed on-chip oscillator clock.) | | #### 5.7 Resonator and Oscillator Constants The resonators for which the operation is verified and their oscillator constants are shown below. - **Cautions 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. - 2. The oscillation voltage and oscillation frequency only indicate the oscillator characteristic. Use the RL78 microcontroller so that the internal operation conditions are within the specifications of the DC and AC characteristics. Figure 5-15. External Oscillation Circuit Example (X1 Oscillation) As of March, 2013 | i | | | T | | 1 | 1 | | | | S OI Ward | 11, 2013 | |---------|-----------------------------------|-----------|--------------------|------|-----------|------------------------|---------|------------------------------|------------------|---------------------|----------| | | Manufacturer | Resonator | Part Number Note 3 | SMD/ | Frequency | Flash | | Recommended Circuit | | Oscillation Voltage | | | | | | | Lead | (MHz) | operation | Constar | Constants Note 2 (reference) | | Range (V) | | | | | | | | | mode <sup>Note 1</sup> | C1 (pF) | C2 (pF) | Rd ( $k\Omega$ ) | MIN. | MAX. | | | Murata | Ceramic | CSTCC2M00G56-R0 | SMD | 2.0 | LS | (47) | (47) | 0 | 1.8 | 5.5 | | <r></r> | Manufacturing<br>Co., Ltd. Note 4 | resonator | CSTCR4M00G55-R0 | SMD | 4.0 | | (39) | (39) | 0 | | | | | CO., Liu. | | CSTLS4M00G53-B0 | Lead | | | (15) | (15) | 0 | | | | | | | CSTCR4M19G55-R0 | SMD | 4.194 | | (39) | (39) | 0 | | | | | | | CSTLS4M19G53-B0 | Lead | | | (15) | (15) | 0 | | | | | | | CSTCR4M91G53-R0 | SMD | 4.915 | | (15) | (15) | 0 | | | | | | | CSTLS4M91G53-B0 | Lead | | | (15) | (15) | 0 | | | | | | | CSTCR5M00G53-R0 | SMD | 5.0 | | (15) | (15) | 0 | | | | | | | CSTLS5M00G53-B0 | Lead | | | (15) | (15) | 0 | | | | | | | CSTCR6M00G53-R0 | SMD | 6.0 | | (15) | (15) | 0 | | | | | | | CSTLS6M00G53-B0 | Lead | | | (15) | (15) | 0 | | | | | | | CSTCE8M00G52-R0 | SMD | 8.0 | | (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.0 | | (10) | (10) | 0 | | | | | | | CSTLS10M0G53-B0 | Lead | | | (15) | (15) | 0 | | | | | | | CSTCE12M0G52-R0 | SMD | 12.0 | | (10) | (10) | 0 | | | | | | | CSTCE16M0V53-R0 | SMD | 16.0 | | (15) | (15) | 0 | | | | | | | CSTLS16M0X51-B0 | Lead | | | (5) | (5) | 0 | | | | | | | CSTCE20M0V51-R0 | SMD | 20.0 | | (5) | (5) | 0 | 2.7 | 5.5 | | | | | CSTLS20M0X51-B0 | Lead | | | (5) | (5) | 0 | | | Notes 1. Set the flash operation mode by using CMODE1 and CMODE0 bits of the option byte (000C2H). - 2. Values in parentheses in the C1, C2 columns indicate an internal capacitance. - 3. Products supporting 105°C operation have different part numbers. For details, contact Murata Manufacturing Co., Ltd. (http://www.murata.com) - 4. When using this resonator, for details about the matching, contact Murata Manufacturing Co., Ltd. <R> (http://www.murata.com). Remarks 1. Relationship between operation voltage width, operation frequency of CPU and operation mode is as below. HS (High speed main) mode: $2.7 \text{ V} \leq V_{DD} \leq 5.5 \text{ V} @ 1 \text{ MHz to } 24 \text{ MHz}$ $2.4~V \leq V_{DD} \leq 5.5~V @ 1~MHz$ to 16~MHz LS (Low speed main) mode: $1.8~V \leq V_{DD} \leq 5.5~V @ 1~MHz$ to 8~MHz 2. A list of the resonators for which the operation has most recently been verified and their oscillation constants (for reference) is provided on the page for the corresponding product at the Renesas Web site (http://www.renesas.com). <R> ## **CHAPTER 6 TIMER ARRAY UNIT** The number of channels of the timer array unit differs depending on the product. | Channels | 20-, 24-pin | 30-pin | |-----------|--------------|--------------| | | | | | Channel 0 | $\sqrt{}$ | $\checkmark$ | | Channel 1 | $\checkmark$ | $\checkmark$ | | Channel 2 | V | $\checkmark$ | | Channel 3 | V | V | | Channel 4 | - | $\checkmark$ | | Channel 5 | - | $\checkmark$ | | Channel 6 | _ | V | | Channel 7 | _ | V | **Caution** The presence or absence of timer I/O pins depends on the product. For details, see Table 6-2 Timer I/O Pins in the Product. The timer array unit has four/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. Note Provided only in 30-pin products 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> <li>Square wave output (→ refer to 6.8.1)</li> <li>External event counter (→ refer to 6.8.2)</li> <li>Divider<sup>Note</sup> (→ refer to 6.8.3)</li> <li>Input pulse interval measurement (→ refer to 6.8.4)</li> <li>Measurement of high-/low-level width of input signal (→ refer to 6.8.5)</li> <li>Delay counter (→ refer to 6.8.6)</li> </ul> | <ul> <li>One-shot pulse output (→ refer to 6.9.1)</li> <li>PWM output (→ refer to 6.9.2)</li> <li>Multiple PWM output (→ refer to 6.9.3)</li> </ul> | Note Only channel 0 of the 30-pin products. 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 (higher and lower 8-bit timers)/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 (INTTM0n) at fixed intervals. #### (2) Square wave output A toggle operation is performed each time INTTM0n interrupt is generated and a square wave with a duty factor of 50% is output from a timer output pin (TO0n). #### (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 (TI0n) has reached a specific value. # (4) Divider Note A clock input from a timer input pin (TI00) is divided and output from an output pin (TO00). ## (5) Input pulse interval measurement Counting is started by the valid edge of a pulse signal input to a timer input pin (TI0n). 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. Note Only channel 0 of the 30-pin products. #### (6) 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 (TI0n), 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. #### (7) Delay counter Counting is started at the valid edge of the signal input to the timer input pin (TI0n), and an interrupt is generated after any delay period. **Remark** 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 three 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. **Remark** n: Channel number (n = 0 to 7) p, q: Slave channel number (n #### 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 (Only Channels 1 and 3). # 6.2 Configuration of Timer Array Unit Timer array unit includes the following hardware. Table 6-1. Configuration of Timer Array Unit | Item | Configuration | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Timer/counter | Timer/counter register 0n (TCR0n) | | Register | Timer data register 0n (TDR0n) | | Timer input | TI00 to TI07 | | Timer output | TO00 to TO07 pins, output controller | | Control registers | <registers block="" of="" setting="" unit=""> <ul> <li>Peripheral enable register 0 (PER0)</li> <li>Timer clock select register 0 (TPS0)</li> <li>Timer channel enable status register 0 (TE0)</li> <li>Timer channel start register 0 (TS0)</li> <li>Timer channel stop register 0 (TI0)</li> <li>Timer input select register 0 (TIS0)</li> <li>Timer output enable register 0 (TOE0)</li> <li>Timer output register 0 (TO0)</li> <li>Timer output level register 0 (TOL0)</li> <li>Timer output mode register 0 (TOM0)</li> </ul></registers> | | | <registers channel="" each="" of=""> <ul> <li>Timer mode register 0n (TMR0n)</li> <li>Timer status register 0n (TSR0n)</li> <li>Noise filter enable register 1 (NFEN1)</li> <li>Port mode control register (PMCxx)<sup>Note</sup></li> </ul></registers> | | | Port mode register (PMxx) <sup>Note</sup> Port register (Pxx) <sup>Note</sup> | Note The Port mode control register (PMCxx), 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 using the port and alternate functions. **Remark** n: Channel number (n = 0 to 7) Alternate port for timer I/O of the timer array unit channels varies depending on products. Table 6-2. Timer I/O Pins in the Products | Timer array unit channel | 30-pin products | 20, 24-pin products | |--------------------------|-----------------|---------------------| | Channel 0 | TI00/TO00 | TI00/TO00 | | Channel 1 | TI01/TO01 | TI01/TO01 | | Channel 2 | TI02/TO02 | TI02/TO02 | | Channel 3 | TI03/TO03 | TI03/TO03 | | Channel 4 | (TI04/TO04) | × | | Channel 5 | (TI05/TO05) | × | | Channel 6 | (TI06/TO06) | × | | Channel 7 | (TI07/TO07) | × | **Remarks** 1. If a pin is to be used for both timer input and timer output, it can be used only for timer input or timer output. - 2. x: The channel is not available - **3.** Pins in the parentheses indicate an alternate port when the bit 0 (PIOR0) of the peripheral I/O redirection register (PIOR) is set to "1" in 30-pin products. Figures 6-1 to 6-3 show the block diagrams of the timer array unit. Timer clock select register 0 (TPS0) PRS031|PRS030|PRS021|PRS020|PRS013|PRS012|PRS011|PRS010|PRS003|PRS002|PRS001|PRS000 2 4 4 Prescaler fclk/2<sup>1</sup>, fclk/2<sup>4</sup> fclk/2<sup>4</sup>, fclk/2<sup>6</sup> fclk/2° - fclk/2 fclk/2<sup>8</sup>, fclk/2<sup>10</sup> fclk/2<sup>12</sup>, fclk/2<sup>14</sup> Peripheral enable Selector Selector register 0 (PER0) TAU0EN Timer input select register 0 (TIS0) Selector Selector CK03 TIS1 TIS0 CK02 CK01 CK00 **→**⊚ TO00 INTTM00 TI00 @ (Timer interrupt) Channel 0 **►**⊚ TO01 ► INTTM01 Selector INTTM01H Channel 1 TI01 ⊚• **→**© TO02 INTTM02 TI02 (0) Channel 2 **►**⊚ TO03 ► INTTM03 Channel 3 ► INTTM03H TI03 ⊚ Figure 6-1. Entire Configuration of Timer Array Unit (20-, and 24-pin products) Remark fil: Low-speed on-chip oscillator clock frequency Figure 6-2. Entire Configuration of Timer Array Unit (30-pin products) **Remark** Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). Figure 6-3. Internal Block Diagram of Channel of Timer Array Unit # (a) Channel 0, 2, 4, 6 Notes 1. Channels 2, 4, and 6 only **2.** n = 2, 4, 6 only **Remarks 1.** n = 0, 2, 4, or 6 2. Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). # (b) Channel 1 for 20-pin and 24-pin product # (c) Channel 1 for 30-pin product #### (d) Channel 3 ## (e) Channel 5 for 30-Pin product # (f) Channel 7 for 30-Pin product **Remark** Functions in parentheses in the above figure can be assigned via settings in the peripheral I/O redirection register (PIOR). #### 6.2.1 Timer/counter register 0n (TCR0n) The TCR0n 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 MD0n3 to MD0n0 bits of timer mode register 0n (TMR0n) (refer to **6.3.3 Timer mode register 0n (TMR0n)**). Figure 6-4. Format of Timer/Counter Register 0n (TCR0n) Address: F0180H, F0181H (TCR00) to F0186H, F0187H (TCR03) After reset: FFFFH R Remark n: Channel number (n = 0 to 7) The count value can be read by reading timer counter register 0n (TCR0n). The count value is set to FFFFH in the following cases. - When the reset signal is generated - When the TAU0EN 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 0n (TDR0n) even when the TCR0n register is read. The TCR0n register read value differs as follows according to operation mode changes and the operating status. Table 6-3. Timer/counter Register 0n (TCR0n) Read Value in Various Operation Modes | Operation Mode | Count Mode | | Timer/counter register 0n (TCR0n) Read Value <sup>Note</sup> | | | | | |------------------------------|------------|---------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------|--|--| | | | Value if the operation mode was changed after releasing reset | Value if the count operation paused (TT0n = 1) | Value if the operation mode was changed after count operation paused (TT0n = 1) | Value when waiting for a start trigger after one count | | | | Interval timer mode | Count down | FFFFH | Value if stop | Undefined | - | | | | Capture mode | Count up | 0000H | Value if stop | Undefined | - | | | | Event counter mode | Count down | FFFFH | Value if stop | Undefined | - | | | | One-count mode | Count down | FFFFH | Value if stop | Undefined | FFFFH | | | | Capture & one-<br>count mode | Count up | 0000H | Value if stop | Undefined | Capture value of TDR0n register + 1 | | | Note This indicates the value read from the TCR0n register when channel n has stopped operating as a timer (TE0n = 0) and has been enabled to operate as a counter (TS0n = 1). The read value is held in the TCR0n register until the count operation starts. Remark n: Channel number (n = 0 to 7) <R> #### 6.2.2 Timer data register 0n (TDR0n) 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 MD0n3 to MD0n0 bits of timer mode register 0n (TMR0n). The value of the TDR0n register can be changed at any time. This register can be read or written in 16-bit units. In addition, for the TDR01, TDR03 registers, while in the 8-bit timer mode (when the SPLIT01, SPLIT03 bits of timer mode register m1, m3 (TMR01, TMR03) is 1), it is possible to read and write the data in 8-bit units, with TDR01H, TDR03H used as the higher 8 bits, and TDR01L, TDR03L used as the lower 8 bits. Reset signal generation clears this register to 0000H. Figure 6-5. Format of Timer Data Register 0n (TDR0n) (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) Figure 6-6. Format of Timer Data Register 01, 03 (TDR01, TDR03) Address: FFF1AH, FFF1BH (TDR01), FFF66H, FFF67H (TDR03) After reset: 0000H R/W # (i) When timer data register 0n (TDR0n) is used as compare register Counting down is started from the value set to the TDR0n register. When the count value reaches 0000H, an interrupt signal (INTTM0n) is generated. The TDR0n register holds its value until it is rewritten. **Caution** The TDR0n 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 0n (TDR0n) is used as capture register The count value of timer/counter register 0n (TCR0n) is captured to the TDR0n register when the capture trigger is input. A valid edge of the TI0n pin can be selected as the capture trigger. This selection is made by timer mode register 0n (TMR0n). **Remark** n: Channel number (n = 0 to 7) # 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 0 (TPS0) - Timer mode register 0n (TMR0n) - Timer status register 0n (TSR0n) - Timer channel enable status register 0 (TE0) - Timer channel start register 0 (TS0) - Timer channel stop register 0 (TT0) - Timer input select register 0 (TIS0) - Timer output enable register 0 (TOE0) - Timer output register 0 (TO0) - Timer output level register 0 (TOL0) - Timer output mode register 0 (TOM0) - Noise filter enable register 1 (NFEN1) - Port mode control register (PMCxx) - Port mode register (PMxx) - Port register (Pxx) **Remark** n: Channel number (n = 0 to 7) **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 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-7. Format of Peripheral Enable Register 0 (PER0) Address: F00F0H After reset: 00H R/W <7> Symbol <5> <4> <3> <2> <0> 1 PER0 **TMKAEN** 0 **ADCEN** IICA0EN SAU1EN<sup>Note</sup> SAU0EN 0 TAU0EN | TAU0EN | Control of timer array unit clock | |--------|-------------------------------------------------------------------------------------------------------------------------------| | 0 | Stops supply of clock. • SFR used by the timer array unit cannot be written. • The timer array unit is in the reset status. | | 1 | Supplies clock. • SFR used by the timer array unit can be read/written. | Note 30-pin products only. Cautions 1. When setting the timer array unit, be sure to set the following registers first while the TAU0EN bit is set to 1. If TAU0EN = 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 0 (TIS0), input switch control register (ISC), noise filter enable register 1 (NFEN1), port mode registers 0, 1, 3, 4 (PM0, PM1, PM3, PM4), port registers 0, 1, 3, 4 (P0, P1, P3, P4), and Port mode control register 0, 1, 4 (PMC0, PMC1, PMC4)). - Timer clock select register 0 (TPS0) - Timer mode register 0n (TMR0n) - Timer status register 0n (TSR0n) - Timer channel enable status register 0 (TE0) - Timer channel start register 0 (TS0) - Timer channel stop register 0 (TT0) - Timer output enable register 0 (TOE0) - Timer output register 0 (TO0) - Timer output level register 0 (TOL0) - Timer output mode register 0 (TOM0) - 2. Be sure to clear the following bits to 0: - 20-, 24-pin products: Bits 1, 3, and 6 - 30-pin products: Bits 1 and 6 #### 6.3.2 Timer clock select register 0 (TPS0) The TPS0 register is a 16-bit register that is used to select four types of operation clocks (CK00 to CK03) that are commonly supplied to each channel from external prescaler. The TPS0 register is a 16-bit register that is used to select two types or four types of operation clocks (CK00, CK01, CK02, CK03) that are commonly supplied to each channel. CK00 is selected by using bits 3 to 0 of the TPS0 register, and CK01 is selected by using bits 7 to 4 of the TPS0 register. In addition, only for channels 1 and 3, CK02 and CK03 can be also selected. CK02 is selected by using bits 9 and 8 of the TPS0 register, and CK03 is selected by using bits 13 and 12 of the TPS0 register. Rewriting of the TPS0 register during timer operation is possible only in the following cases. If the PRS000 to PRS003 bits can be rewritten (n = 0 to 7): All channels for which CK00 is selected as the operation clock (CKS0n1, CKS0n0 = 0, 0) are stopped (TE0n = 0). If the PRS010 to PRS013 bits can be rewritten (n = 0 to 7): All channels for which CK01 is selected as the operation clock (CKS0n1, CKS0n0 = 0, 1) are stopped (TE0n = 0). If the PRS020 and PRS021 bits can be rewritten (n = 1, 3): All channels for which CK02 is selected as the operation clock (CKS0n1, CKS0n0 = 1, 0) are stopped (TE0n = 0). If the PRS030 and PRS031 bits can be rewritten (n = 1, 3): All channels for which CK03 is selected as the operation clock (CKS0n1, CKS0n0 = 1, 1) are stopped (TE0n = 0). The TPS0 register can be set by a 16-bit memory manipulation instruction. Reset signal generation clears this register to 0000H. Figure 6-8. Format of Timer Clock Select register 0 (TPS0) Address: F01B6H, F01B7H After reset: 0000H R/W Symbol 15 13 12 11 10 9 6 5 3 0 TPS0 0 0 PRS **PRS** 0 0 PRS PRS PRS PRS PRS PRS PRS PRS PRS **PRS** 031 030 021 020 013 012 011 010 003 002 001 000 | PRS | PRS | PRS | PRS | | Selec | ction of oper | ation clock | (CK0k) <sup>Note</sup> (k | = 0, 1) | | |-----|-----|-----|-----|----------------------|----------|---------------|-------------|---------------------------|----------|----------| | 0k3 | 0k2 | 0k1 | 0k0 | | fclk = | fclk = | fclk = | fclk = | fclk= | fclk = | | | | | | | 2 MHz | 4 MHz | 8 MHz | 16 MHz | 20 MHz | 24 MHz | | 0 | 0 | 0 | 0 | fclk | 2 MHz | 4 MHz | 8 MHz | 16 MHz | 20 MHz | 24 MHz | | 0 | 0 | 0 | 1 | fclk/2 | 1 MHz | 2 MHz | 4 MHz | 8 MHz | 10 MHz | 12 MHz | | 0 | 0 | 1 | 0 | fclk/2 <sup>2</sup> | 500 kHz | 1 MHz | 2 MHz | 4 MHz | 5 MHz | 6 MHz | | 0 | 0 | 1 | 1 | fclk/2 <sup>3</sup> | 250 kHz | 500 kHz | 1 MHz | 2 MHz | 2.5 MHz | 3 MHz | | 0 | 1 | 0 | 0 | fc∟ĸ/2⁴ | 125 kHz | 250 kHz | 500 kHz | 1 MHz | 1.25 MHz | 1.5 MHz | | 0 | 1 | 0 | 1 | fc∟ĸ/2⁵ | 62.5 kHz | 125 kHz | 250 kHz | 500 kHz | 625 kHz | 750 kHz | | 0 | 1 | 1 | 0 | fclk/2 <sup>6</sup> | 31.3 kHz | 62.5 kHz | 125 kHz | 250 kHz | 313 kHz | 375 kHz | | 0 | 1 | 1 | 1 | fclk/27 | 15.6 kHz | 31.3 kHz | 62.5 kHz | 125 kHz | 156 kHz | 188 kHz | | 1 | 0 | 0 | 0 | fclk/2 <sup>8</sup> | 7.81 kHz | 15.6 kHz | 31.3 kHz | 62.5 kHz | 78.1 kHz | 93.8 kHz | | 1 | 0 | 0 | 1 | fclk/29 | 3.91 kHz | 7.81 kHz | 15.6 kHz | 31.3 kHz | 39.1 kHz | 46.9 kHz | | 1 | 0 | 1 | 0 | fclk/2 <sup>10</sup> | 1.95 kHz | 3.91 kHz | 7.81 kHz | 15.6 kHz | 19.5 kHz | 23.4 kHz | | 1 | 0 | 1 | 1 | fclk/2 <sup>11</sup> | 977 Hz | 1.95 kHz | 3.91 kHz | 7.81 kHz | 9.77 kHz | 11.7 kHz | | 1 | 1 | 0 | 0 | fclk/2 <sup>12</sup> | 488 Hz | 997 Hz | 1.95 kHz | 3.91 kHz | 4.88 kHz | 5.86 kHz | | 1 | 1 | 0 | 1 | fclk/2 <sup>13</sup> | 244 Hz | 488 Hz | 977 Hz | 1.95 kHz | 2.44 kHz | 2.93 kHz | | 1 | 1 | 1 | 0 | fclk/2 <sup>14</sup> | 122 Hz | 244 Hz | 488 Hz | 977 Hz | 1.22 kHz | 1.46 kHz | | 1 | 1 | 1 | 1 | fclk/2 <sup>15</sup> | 61 Hz | 122 Hz | 244 Hz | 488 Hz | 610 Hz | 732 Hz | | PRS | PRS | | Selection of operation clock (CK02) <sup>Note</sup> | | | | | | | | |-----|-----|---------------------|-----------------------------------------------------|--------------|--------------|---------------|---------------|---------------|--|--| | 021 | 020 | | fclk = 2 MHz | fclk = 4 MHz | fclk = 8 MHz | fclk = 16 MHz | fclk = 20 MHz | fclk = 24 MHz | | | | 0 | 0 | fclk/2 | 1 MHz | 2 MHz | 4 MHz | 8 MHz | 10 MHz | 12 MHz | | | | 0 | 1 | fclk/2 <sup>2</sup> | 500 kHz | 1 MHz | 2 MHz | 4 MHz | 5 MHz | 6 MHz | | | | 1 | 0 | fclk/2 <sup>4</sup> | 125 kHz | 250 kHz | 500 kHz | 1 MHz | 1.25 MHz | 1.5 MHz | | | | 1 | 1 | fclk/2 <sup>6</sup> | 31.3 kHz | 62.5 kHz | 125 kHz | 250 kHz | 313 kHz | 375 kHz | | | | PRS | PRS | | Selection of operation clock (CK03) <sup>Note</sup> | | | | | | | | | |-----|-----|----------------------|-----------------------------------------------------|--------------|--------------|---------------|---------------|---------------|--|--|--| | 031 | 030 | | fclk = 2 MHz | fclk = 4 MHz | fclk = 8 MHz | fclk = 16 MHz | fclk = 20 MHz | fclk = 24 MHz | | | | | 0 | 0 | fclk/2 <sup>8</sup> | 7.81 kHz | 15.6 kHz | 31.3 kHz | 62.5 kHz | 78.1 kHz | 93.8 kHz | | | | | 0 | 1 | fclk/2 <sup>10</sup> | 1.95 kHz | 3.91 kHz | 7.81 kHz | 15.6 kHz | 19.5 kHz | 23.4 kHz | | | | | 1 | 0 | fclk/2 <sup>12</sup> | 488 Hz | 977 Hz | 1.95 kHz | 3.91 kHz | 4.88 kHz | 5.86 kHz | | | | | 1 | 1 | fclk/2 <sup>14</sup> | 122 Hz | 244 Hz | 488 Hz | 977 Hz | 1.22 kHz | 1.46 kHz | | | | **Note** When changing the clock selected for fclk (by changing the system clock control register (CKC) value), stop timer array unit (TT0 = 00FFH). $\sqrt{}$ - **Cautions 1.** Be sure to clear bits 15, 14, 11, 10 to "0". - 2. If $f_{CLK}$ (undivided) is selected as the operation clock (CKmk) and TDRnm is set to 0000H (n = 0 or 1, m = 0 to 7), interrupt requests output from timer array units cannot be used. - Remarks 1. fclk: CPU/peripheral hardware clock frequency - 2. The above selected clock, but a signal which becomes high level for one period of fclκ from its rising edge (m = 2 to 15). For details, see 6.5.1 Count clock (fτclκ). By using channels 1 and 3 in the 8-bit timer mode and specifying CK02 or CK03 as the operation clock, the interval times shown in **Table 6-4** can be achieved by using the interval timer function. Interval time (fclk = 20 MHz) Note Clock 10 *μ*s $100 \mu s$ 1 ms 10 ms $\sqrt{}$ CK02 fclk/2 $\sqrt{}$ fclk/22 $\sqrt{}$ $\sqrt{}$ fclk/24 $\sqrt{}$ fclk/26 $\sqrt{}$ $\sqrt{}$ CK03 fclk/28 fclk/2<sup>10</sup> Table 6-4. Interval Times Available for Operation Clock CKS02 or CKS03 **Note** The margin is within 4 %. fclk/2<sup>12</sup> fclk/214 Remarks 1. fclk: CPU/peripheral hardware clock frequency 2. For details of a signal of fclk/2" selected with the TPSm register, see 6.5.1 Count clock (ftclk). #### 6.3.3 Timer mode register 0n (TMR0n) The TMR0n 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 TMR0n register is prohibited when the register is in operation (when TE0n = 1). However, bits 7 and 6 (CIS0n1, CIS0n0) can be rewritten even while the register is operating with some functions (when TE0n = 1) (for details, see 6.8 Independent Channel Operation Function of Timer Array Unit and 6.9 Simultaneous Channel Operation Function of Timer Array Unit). The TMR0n 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 the bit 11 of TMR0n register. TMR02, TMR04, TMR06: MASTER0n bit (n = 2, 4, 6)TMR01, TMR03: SPLIT0n bit (n = 1, 3) TMR00, TMR05, TMR07: Fixed to 0 CKS 0n1 CKS 0n0 TMR0n (n = 0, 5, 7) MD 0n3 MD 0n2 MD 0n1 MD 0n0 0 0 Address: : F0190H, F0191H (TMR00) to F019EH, F019FH (TMR07) After reset: 0000H Symbol 15 14 13 12 11 10 9 8 7 6 5 3 2 0 TMR0n CKS CKS 0 CCS MAST STS STS STS CIS CIS 0 0 MD MD MD MD 0n1 0n0 ER0n 0n2 0n0 0n1 0n0 0n3 0n2 0n0 0n 0n1 0n1 (n = 2, 4, 6)Symbol 15 12 10 9 5 0 14 13 11 8 7 6 4 3 2 ccs STS STS STS TMR0n **CKS CKS SPLIT** CIS CIS 0 MD MD MD MD 0n0 0n2 0n0 0n0 0n3 0n2 0n1 0n0 0n1 Ωn 0n 0n1 0n1(n = 1, 3)Symbol 0 15 14 13 12 11 10 9 8 6 5 3 2 Figure 6-9. Format of Timer Mode Register 0n (TMR0n) (1/4) | CKS0n1 | CKS0n0 | Selection of operation clock (fmck) of channel n | |--------|--------|------------------------------------------------------------------| | 0 | 0 | Operation clock CK00 set by timer clock select register 0 (TPS0) | | 0 | 1 | Operation clock CK02 set by timer clock select register 0 (TPS0) | | 1 | 0 | Operation clock CK01 set by timer clock select register 0 (TPS0) | | 1 | 1 | Operation clock CK03 set by timer clock select register 0 (TPS0) | STS 0n0 CIS 0n1 CIS 0n0 Operation clock ( $f_{MCK}$ ) is used by the edge detector. A count clock ( $f_{TCLK}$ ) and a sampling clock are generated depending on the setting of the CCS0n bit. The operation clocks CK02 and CK03 can only be selected for channels 1 and 3. 0<sup>Note</sup> STS 0n2 STS 0n1 CCS 0n 0 | CCS0n | Selection of count clock (ftclk) of channel n | | | | | | | | |------------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 0 | Operation clock (fмск) specified by the CKS0n0 and CKS0n1 bits | | | | | | | | | 1 | Valid edge of input signal input from the TI0n pin | | | | | | | | | | In channel 1 for 20-, 24-pin product and channel 5 for 30-pin product, Valid edge of input signal selected by TIS0 | | | | | | | | | Count cloc | Count clock (frclk) is used for the counter, output controller, and interrupt controller. | | | | | | | | Note Bit 11 is a read-only bit and fixed to 0. Writing to this bit is ignored. Cautions 1. Be sure to clear bits 13, 5, and 4 to "0". 2. The timer array unit must be stopped (TT0 = 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 CKS0n0 and CKS0n1 bits (fmck) or the valid edge of the signal input from the TI0n pin is selected as the count clock (ftclk). **Remark** n: Channel number (n = 0 to 7) Figure 6-9. Format of Timer Mode Register 0n (TMR0n) (2/4) | Address: : F0 | Address: : F0190H, F0191H (TMR00) to F019EH, F019FH (TMR07) After reset: 0000H R/W | | | | | | | | | | | | | | | | |---------------|------------------------------------------------------------------------------------|-----|----|-----|-------------------|-----|-----|-----|-----|-----|---|---|-----|-----|-----|-----| | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TMR0n | CKS | CKS | 0 | ccs | MAST | STS | STS | STS | CIS | CIS | 0 | 0 | MD | MD | MD | MD | | (n =2, 4, 6) | 0n1 | 0n0 | | 0n | ER0n | 0n2 | 0n1 | 0n0 | 0n1 | 0n0 | | | 0n3 | 0n2 | 0n1 | 0n0 | | | | | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TMR0n | CKS | CKS | 0 | ccs | SPLIT | STS | STS | STS | CIS | CIS | 0 | 0 | MD | MD | MD | MD | | (n = 1, 3) | 0n1 | 0n0 | | 0n | 0n | 0n2 | 0n1 | 0n0 | 0n1 | 0n0 | | | 0n3 | 0n2 | 0n1 | 0n0 | | | | | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TMR0n | CKS | CKS | 0 | ccs | O <sup>Note</sup> | STS | STS | STS | CIS | CIS | 0 | 0 | MD | MD | MD | MD | | (n = 0, 5, 7) | 0n1 | 0n0 | | 0n | | 0n2 | 0n1 | 0n0 | 0n1 | 0n0 | | | 0n3 | 0n2 | 0n1 | 0n0 | (Bit 11 of TMR0n (n = 2, 4, 6)) | MASTER0n | 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. | Only the 2, 4, 6 channel can be set as a master channel (MASTER0n = 1). Be sure to use channel 0, 5, 7 are fixed to 0 (Regardless of the bit setting, channel 0 operates as master, because it is the highest channel). Clear the MASTER0n bit to 0 for a channel that is used with the independent channel operation function. (Bit 11 of TMR0n (n = 1, 3)) | SPLIT0n | Selection of 8 or 16-bit timer operation for channels 1 and 3 | |---------|----------------------------------------------------------------------------------------------------------------------| | 0 | Operates as 16-bit timer. | | | (Operates in independent channel operation function or as slave channel in simultaneous channel operation function.) | | 1 | Operates as 8-bit timer. | | STS0n2 | STS0n1 | STS0n0 | 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 TI0n pin input is used as both the start trigger and capture trigger. | | | | | | 0 | 1 | 0 | Both the edges of the TI0n pin input are used as a start trigger and a capture trigger. | | | | | | 1 | 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). | | | | | | Other than above | | | Setting prohibited | | | | | Note Bit 11 is a read-only bit and fixed to 0. Writing to this bit is ignored. **Remark** n: Channel number (n = 0 to 7) Figure 6-9. Format of Timer Mode Register 0n (TMR0n) (3/4) | Address: : F0190H, F0191H (TMR00) to F019EH, F019FH (TMR07) After reset: 0000H R/W | | | | | | | | | | | | | | | | | |------------------------------------------------------------------------------------|-----|-----|----|-----|-------------------|-----|-----|-----|-----|-----|---|---|-----|-----|-----|-----| | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TMR0n | CKS | CKS | 0 | ccs | MAST | STS | STS | STS | CIS | CIS | 0 | 0 | MD | MD | MD | MD | | (n = 2, 4, 6) | 0n1 | 0n0 | | 0n | ER0n | 0n2 | 0n1 | 0n0 | 0n1 | 0n0 | | | 0n3 | 0n2 | 0n1 | 0n0 | | | | | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TMR0n | CKS | CKS | 0 | ccs | SPLIT | STS | STS | STS | CIS | CIS | 0 | 0 | MD | MD | MD | MD | | (n = 1, 3) | 0n1 | 0n0 | | 0n | 0n | 0n2 | 0n1 | 0n0 | 0n1 | 0n0 | | | 0n3 | 0n2 | 0n1 | 0n0 | | | | | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TMR0n | CKS | CKS | 0 | ccs | O <sup>Note</sup> | STS | STS | STS | CIS | CIS | 0 | 0 | MD | MD | MD | MD | | (n=0,5,7) | 0n1 | 0n0 | | 0n | | 0n2 | 0n1 | 0n0 | 0n1 | 0n0 | | | 0n3 | 0n2 | 0n1 | 0n0 | | CIS0n1 | CIS0n0 | Selection of TI0n pin input valid edge | |--------|--------|----------------------------------------------------------------------------------------------------------| | 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 | | | | W | If both the edges are specified when the value of the STS0n2 to STS0n0 bits is other than 010B, set the CIS0n1 to CIS0n0 bits to 10B. **Note** Bit 11 is a read-only bit and fixed to 0. Writing to this bit is ignored. **Remark** n: Channel number (n = 0 to 7) Figure 6-9. Format of Timer Mode Register 0n (TMR0n) (4/4) Address: : F0190H, F0191H (TMR00) to F019EH, F019FH (TMR07) After reset: 0000H 5 Symbol 15 14 13 12 11 10 9 8 7 6 3 2 1 0 TMR0n CKS CKS 0 CCS MAST STS STS STS CIS CIS 0 0 MDMD $\mathsf{MD}$ MD ER0n 0n1 0n0 0n 0n2 0n1 0n0 0n1 0n0 0n3 0n2 0n1 0n0 (n = 2, 4, 6)Symbol 15 14 13 12 11 10 9 8 7 6 5 4 3 2 0 CKS CKS ccs SPLIT STS STS STS CIS CIS 0 MD TMR0n MD MD MD0n2 0n1 0n0 0n 0n2 0n1 0n0 0n1 0n0 0n3 0n1 0n0 0n (n = 1, 3)Symbol 15 14 13 12 10 9 8 7 6 5 4 3 2 0 11 1 TMR0n **CKS CKS** CCS 0 STS STS STS CIS CIS 0 0 MD MD MDMDNote 1 0n0 0n1 0n0 0n 0n2 0n1 0n0 0n1 0n0 0n3 0n2 0n1 (n=0,5,7) | MD | MD | MD | Setting of operation mode | Corresponding function | Count operation of TCR | | | | | |--------|-------------------------------------|-------|------------------------------|------------------------------------------------------------------------------------|------------------------|--|--|--|--| | 0n3 | 0n2 | 0n1 | of channel n | | Count operation of TCH | | | | | | 0 | 0 | 0 | Interval timer mode | Interval timer / Square wave output /<br>Divider function / PWM output<br>(master) | Down count | | | | | | 0 | 1 | 0 | Capture mode | Input pulse interval measurement | Up count | | | | | | 0 | 1 | 1 | Event counter mode | External event counter | Down count | | | | | | 1 | 0 | 0 | One-count mode | Delay counter / One-shot pulse output / PWM output (slave) | Down count | | | | | | 1 | 1 | 0 | Capture & one-count mode | Measurement of high-/low-level width of input signal | Up count | | | | | | Other | Other than above Setting prohibited | | | | | | | | | | The op | peration | of MD | On0 bit changes depending or | n the operation of each mode (refer to the | ne table bellow) | | | | | | Operation mode (Value set by the MD0n3 to MD0n1 bits (see table above)) | MD<br>0n0 | Setting of starting counting and interrupt | |-------------------------------------------------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | • Interval timer mode (0, 0, 0) | 0 | Timer interrupt is not generated when counting is started (timer output does not change, either). | | • Capture mode (0, 1, 0) | 1 | Timer interrupt is generated when counting is started (timer output also changes). | | • Event counter mode (0, 1, 1) | 0 | Timer interrupt is not generated when counting is started (timer output does not change, either). | | • One-count mode <sup>Note 2</sup> (1, 0, 0) | 0 | Start trigger is invalid during counting operation. At that time, interrupt is not generated, either. | | | 1 | Start trigger is valid during counting operation <sup>Note 3</sup> . At that time, interrupt is also generated. | | • Capture & one-count mode (1, 1, 0) | 0 | Timer interrupt is not generated when counting is started (timer output does not change, either). Start trigger is invalid during counting operation. At that time interrupt is not generated, either. | | Other than above | | Setting prohibited | Notes 1. Bit 11 is a read-only bit and fixed to 0. Writing to this bit is ignored. - 2. In one-count mode, interrupt output (INTTM0n) when starting a count operation and TO0n output are not controlled. - **3.** If the start trigger (TS0n = 1) is issued during operation, the counter is initialized, and recounting is started (interrupt request is not generated). Remark n: Channel number (n = 0 to 7) ## 6.3.4 Timer status register 0n (TSR0n) The TSR0n register indicates the overflow status of the counter of channel n. The TSR0n register is valid only in the capture mode (MD0n3 to MD0n1 = 010B) and capture & one-count mode (MD0n3 to MD0n1 = 110B). It will not be set in any other mode. See Table 6-4 for the operation of the OVF bit in each operation mode and set/clear conditions. The TSR0n register can be read by a 16-bit memory manipulation instruction. The lower 8 bits of the TSR0n register can be set with an 8-bit memory manipulation instruction with TSR0nL. Reset signal generation clears this register to 0000H. Figure 6-10. Format of Timer Status Register On (TSROn) Address: F01A0H, F01A1H (TSR00) to F01AEH, F01AFH (TSR07) After reset: 0000H 7 6 0 Symbol 15 13 12 9 5 4 3 2 11 10 TSR0n OVF | OVF | Counter overflow status of channel n | | | | | |------|------------------------------------------------------------------------------------------------|--|--|--|--| | 0 | Overflow does not occur. | | | | | | 1 | Overflow occurs. | | | | | | When | When OVF = 1, this flag is cleared (OVF = 0) when the next value is captured without overflow. | | | | | **Remark** 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 | | <ul><li>(Use prohibited)</li></ul> | | | One-count mode | set | | | **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 0 (TE0) The TE0 register is used to enable or stop the timer operation of each channel. Each bit of the TE0 register corresponds to each bit of the timer channel start register 0 (TS0) and the timer channel stop register 0 (TT0). 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 TT0 register is set to 1, the corresponding bit of this register is cleared to 0. The TE0 register can be read by a 16-bit memory manipulation instruction. The lower 8 bits of the TE0 register can be set with a 1-bit or 8-bit memory manipulation instruction with TE0L. Reset signal generation clears this register to 0000H. Figure 6-11. Format of Timer Channel Enable Status register 0 (TE0) | Address: F01B0H, F01B1H After reset: 0000H R | | | | | | | | | | | | | | | | | |----------------------------------------------|-------------------------|-----------------------|---------|--------|---------|--------|------------|---------|------------|----------|---------|-----------|--------|---------|----------|------| | 20- and 24-pi | 20- and 24-pin products | | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TE0 | 0 | 0 | 0 | 0 | TEH03 | 0 | TEH01 | 0 | 0 | 0 | 0 | 0 | TE03 | TE02 | TE01 | TE00 | | | | | | | | | | | | | | | | | | | | 30-pin produc | ts | | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TE0 | 0 | 0 | 0 | 0 | TEH03 | 0 | TEH01 | 0 | TE07 | TE06 | TE05 | TE04 | TE03 | TE02 | TE01 | TE00 | | | | | | | | | | | | | | | | | | | | | TEH03 | | Indicat | ion of | whether | operat | ion of the | e highe | r 8-bit ti | mer is e | enabled | l or stop | ped wh | en chai | nnel 3 i | S | | | | | | | | | | in the | 3-bit tim | er mode | Э | | | | | | | | 0 | Operation is stopped. | | | | | | | | | | | | | | | | TEH01 | Indication of whether operation of the higher 8-bit timer is enabled or stopped when channel 1 is | |-------|---------------------------------------------------------------------------------------------------| | | in the 8-bit timer mode | | 0 | Operation is stopped. | | 1 | Operation is enabled. | | | TE0n | Indication of operation enable/stop status of channel n | | | | |---|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--|--|--| | | 0 | Operation is stopped. | | | | | | 1 | Operation is enabled. | | | | | Γ | This bit displays whether operation of the lower 8-bit timer for TE01. TE03 is enabled or stopped when channel 1, 3 | | | | | This bit displays whether operation of the lower 8-bit timer for TE01, TE03 is enabled or stopped when channel 1, 3 is in the 8-bit timer mode. **Remark** n: Channel number (n = 0 to 7) Operation is enabled. #### 6.3.6 Timer channel start register 0 (TS0) The TS0 register is a trigger register that is used to initialize timer/counter register 0n (TCR0n) 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 0 (TE0) is set to 1. The TS0n, TSH01, TSH03 bits are immediately cleared when operation is enabled (TE0n, TEH01, TEH03 = 1), because they are trigger bits. The TS0 register can be set by a 16-bit memory manipulation instruction. The lower 8 bits of the TS0 register can be set with a 1-bit or 8-bit memory manipulation instruction with TS0L. Reset signal generation clears this register to 0000H. Figure 6-12. Format of Timer Channel Start register 0 (TS0) Address: F01B2H, F01B3H After reset: 0000H R/W 20- and 24-pin products Symbol 15 13 12 11 10 3 0 0 0 0 0 0 0 TSH03 0 TSH01 0 0 0 TS03 TS02 TS01 TS00 TS0 30-pin products 7 0 12 9 6 5 3 2 Symbol 15 14 13 11 10 8 TS0 0 0 0 0 TSH03 0 TSH01 0 TS07 TS06 TS05 TS04 TS03 TS02 TS01 TS00 | TSH03 | Trigger to enable operation (start operation) of the higher 8-bit timer when channel 3 is in the 8-bit timer mode | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | No trigger operation | | 1 | The TEH03 bit is set to 1 and the count operation becomes enabled. The TCR03 register count operation start in the interval timer mode in the count operation enabled state (see Table 6-6). | | TSH01 | Trigger to enable operation (start operation) of the higher 8-bit timer when channel 1 is in the 8-bit timer mode | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | No trigger operation | | 1 | The TEH01 bit is set to 1 and the count operation becomes enabled. The TCR01 register count operation start in the interval timer mode in the count operation enabled state (see Table 6-6). | | TS0n | Operation enable (start) trigger of channel n | |------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | No trigger operation | | 1 | The TE0n bit is set to 1 and the count operation becomes enabled. The TCR0n register count operation start in the count operation enabled state varies depending on each operation mode (see Table 6-6). | | | This bit is the trigger to enable operation (start operation) of the lower 8-bit timer for TS01 and TS03 when channel 1 or 3 is in the 8-bit timer mode. | #### Cautions 1. Be sure to clear undefined bits to "0". 2. When switching from a function that does not use TI0n pin input to one that does, the following wait period is required from when timer mode register 0n (TMR0n) is set until the TS0n (TSH01, TSH03) bit is set to 1. When the TIOn pin noise filter is enabled (TNFEN = 1): Four cycles of the operation clock (fmck) # When the TI0n pin noise filter is disabled (TNFEN = 0): Two cycles of the operation clock ( $f_{MCK}$ ) Remarks 1. When the TS0 register is read, 0 is always read. 2. n: Channel number (n = 0 to 7) #### 6.3.7 Timer channel stop register 0 (TT0) The TT0 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 0 (TE0) is cleared to 0. The TT0n, TTH01, TTH03 bits are immediately cleared when operation is stopped (TE0n, TEH01, TEH03 = 0), because they are trigger bits. The TT0 register can be set by a 16-bit memory manipulation instruction. The lower 8 bits of the TT0 register can be set with a 1-bit or 8-bit memory manipulation instruction with TT0L. Reset signal generation clears this register to 0000H. Figure 6-13. Format of Timer Channel Stop register 0 (TT0) Address: F01B4H, F01B5H After reset: 0000H 20- and 24-pin products Symbol 15 13 12 11 10 9 8 6 5 3 0 0 0 0 0 TTH03 0 TTH01 0 0 0 0 0 TT03 TT02 TT01 TT00 TT0 30-pin products Symbol 0 15 14 13 12 11 10 9 8 6 5 3 TT0 0 0 0 TTH03 0 TTH01 0 TT07 O **TT06** TT05 TT04 TT03 TT02 TT01 TT00 | TTH03 | 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 | TEH03 is cleared to 0 and the count operation is stopped. | | TTH01 | 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 | TEH01 is cleared to 0 and the count operation is stopped. | | TT0n | Operation stop trigger of channel n | |------|--------------------------------------------------------------------------------------------------------------------------------------| | 0 | No trigger operation | | 1 | TE0n is cleared to 0 and the count operation is stopped. | | | This bit is the trigger to stop operation of the lower 8-bit timer for TT01 and TT03 when channel 1 or 3 is in the 8-bit timer mode. | Caution Be sure to clear undefined bits to "0". Remarks 1. When the TT0 register is read, 0 is always read. 2. n: Channel number (n = 0 to 7) # 6.3.8 Timer input select register 0 (TIS0) The TIS0 register is used to select the channel 1 for 20- or 24-pin product, channel 5 for 30-pin product 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-14. Format of Timer Input Select register 0 (TIS0) Address: F0074H After reset: 00H R/W 20- and 24-pin products Symbol 7 6 5 4 3 2 1 0 TISO 0 0 0 0 0 0 TISO1 TISO0 | TIS01 | TIS00 | Selection of timer input used with channel 1 | |-------|-------|----------------------------------------------| | × | 0 | Input signal of timer input pin (TI01) | | 0 | 1 | Low-speed on-chip oscillator clock (fil.) | | 1 | 1 | Setting prohibited | ## 30-pin products <R> | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|---|---|---|------|-------|-------| | TIS0 | 0 | 0 | 0 | 0 | 0 | TIS2 | TIS01 | TIS00 | | TIS2 | TIS01 | TIS00 | Selection of timer input used with channel 5 | |------|-----------------|-------|----------------------------------------------| | 0 | × | × | Input signal of timer input pin (TI05) | | 1 | 0 | 0 | Low-speed on-chip oscillator clock (fiL) | | C | other than abov | e | Setting prohibited | x: don't care Caution At least 1/fmck + 10 ns is necessary as the high-level and low-level widths of the timer input to be selected. Thus, the TIS02 bit cannot be set to 1 when fsuB is selected as fclk (CSS in CKC register = 1). ## 6.3.9 Timer output enable register 0 (TOE0) The TOE0 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 TO0n bit of timer output register 0 (TO0) 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 (TO0n). The TOE0 register can be set by a 16-bit memory manipulation instruction. The lower 8 bits of the TOE0 register can be set with a 1-bit or 8-bit memory manipulation instruction with TOE0L. Reset signal generation clears this register to 0000H. Figure 6-15. Format of Timer Output Enable register 0 (TOE0) Address: F01BAH, F01BBH After reset: 0000H R/W 20- and 24-pin products Symbol TOE TOE TOE TOE TOE0 30-pin products Symbol TOE0 TOE TOE TOE TOE TOE TOE TOE TOE | TOE | Timer output enable/disable of channel n | |-----|---------------------------------------------------------------------------------------------------| | 0n | | | 0 | Disable output of timer. | | | Without reflecting on TO0n bit timer operation, to fixed the output. | | | Writing to the TO0n bit is enabled and the level set in the TO0n bit is output from the TO0n pin. | | 1 | Enable output of timer. | | | Reflected in the TO0n bit timer operation, to generate the output waveform. | | | Writing to the TO0n bit is ignored. | Caution Be sure to clear undefined bits to "0". **Remark** n: Channel number (n = 0 to 7) ## 6.3.10 Timer output register 0 (TO0) The TO0 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 (TO0n) of each channel. The TO0n bit oh this register can be rewritten by software only when timer output is disabled (TOE0n = 0). When timer output is enabled (TOE0n = 1), rewriting this register by software is ignored, and the value is changed only by the timer operation. To use the TO00, TO01, TO02, TO03, (TO04), (TO05), (TO06), or (TO07) pin as a port function pin, set the corresponding TO0n bit to 0. The TO0 register can be set by a 16-bit memory manipulation instruction. The lower 8 bits of the TO0 register can be set with an 8-bit memory manipulation instruction with TO0L. Reset signal generation clears this register to 0000H. Figure 6-16. Format of Timer Output register 0 (TO0) | Address: F01B8H, F01B9H After reset: 0000H | | | | | | | | | | | | | | | | | |--------------------------------------------|---------|-----|----|----|----|----|----|---------|-----------|--------|------|------|------|------|------|------| | 20- and 24-pi | n produ | cts | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TO0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TO03 | TO02 | TO01 | TO00 | | | | | | | | | | | | | | | | | | | | 30-pin produc | ets | | | | | | | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TO0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TO07 | TO06 | TO05 | TO04 | TO03 | TO02 | TO01 | TO00 | | | | | | | | | | | | | | | | | | | | | TO0n | | | | | | Ti | imer ou | tput of c | hannel | n | | | | | | | | | | | | | | | | | | | | | | | | | TO0n | Timer output of channel n | |------|----------------------------| | 0 | Timer output value is "0". | | 1 | Timer output value is "1". | Caution Be sure to clear undefined bits to "0". **Remark** n: Channel number (n = 0 to 7) ## 6.3.11 Timer output level register 0 (TOL0) The TOLO 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 (TOE0n = 1) in the Slave channel output mode (TOM0n = 1). In the master channel output mode (TOM0n = 0), this register setting is invalid. The TOL0 register can be set by a 16-bit memory manipulation instruction. The lower 8 bits of the TOL0 register can be set with an 8-bit memory manipulation instruction with TOL0L. Reset signal generation clears this register to 0000H. Figure 6-17. Format of Timer Output Level register 0 (TOL0) | TOL0n | Control of timer output level of channel n | |-------|--------------------------------------------| | 0 | Positive logic output (active-high) | | 1 | Negative logic output (active-low) | Caution Be sure to clear undefined bits to "0". **Remarks 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. **2.** n: Channel number (n = 1 to 7) #### 6.3.12 Timer output mode register 0 (TOM0) The TOM0 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 (TOE0n = 1). The TOM0 register can be set by a 16-bit memory manipulation instruction. The lower 8 bits of the TOM0 register can be set with an 8-bit memory manipulation instruction with TOM0L. Reset signal generation clears this register to 0000H. Figure 6-18. Format of Timer Output Mode register 0 (TOM0) Address: F01BEH, F01BFH After reset: 0000H 20- and 24-pin products Symbol 12 11 10 3 TOM TOM0 O n 0 0 0 0 0 0 0 0 0 0 TOM TOM 0 03 02 01 30-pin products Symbol TOM0 | O O O O O O O TOM TOM TOM | | | | | | | | | | 10 | | 12 | 13 | | 15 | |---------------------------|--|--|--|---|-----------|--|-----------|---|---|----|---|----|----|---|----| | | | | | Λ | TOM<br>04 | | TOM<br>07 | 0 | 0 | 0 | 0 | 0 | 0 | ) | 0 | | TOM0n | Control of timer output mode of channel n | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Master channel output mode (to produce toggle output by timer interrupt request signal (INTTM0n)) | | 1 | Slave channel output mode (output is set by the timer interrupt request signal (INTTM0n) of the master channel, and reset by the timer interrupt request signal (INTTM0p) of the slave channel) | Caution Be sure to clear undefined bits to "0". Remark n: Channel number n = 1 to 7 (n = 0, 2, 4, or 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 ${\bf 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 registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Noise filter ON Note For details, see 6.5.1 (2) When valid edge of input signal via the Tl0n pin is selected (CCS0n = 1), 6.5.2 Start timing of counter, and 6.7 Timer Input (Tl0n) Control. Figure 6-19. Format of Noise Filter Enable Register 1 (NFEN1) | Address: F00 | 71H After re | set: 00H R/ | W | | | | | | |----------------|--------------|-----------------|---------|------------------|-----------------|------------------|---------|---------| | 20- and 24-pir | n products | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | NFEN1 | 0 | 0 | 0 | 0 | TNFEN03 | TNFEN02 | TNFEN01 | TNFEN00 | | • | | | | | | | | | | 30-pin produc | ts | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | NFEN1 | TNFEN07 | TNFEN06 | TNFEN05 | TNFEN04 | TNFEN03 | TNFEN02 | TNFEN01 | TNFEN00 | | | | | | | | | | | | | TNFEN0n | | Enab | le/disable using | noise filter of | TIOn pin input s | signal | | | | 0 | Noise filter OF | F | | | | | | | | | | | | | | | , | Remark The presence or absence of timer I/O pins of channel 0 to 7 depends on the product. See Table 6-2 Timer I/O Pins in the Products for details. #### 6.3.14 Registers controlling port functions of pins to be used for timer I/O Using port pins for the timer array unit functions requires setting of the registers that control the port functions multiplexed on the target pins (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 using the port and alternate functions. When using the ports that shares the pin with the timer output (such as TI00/TO00/P13) for timer output, set the port mode control register (PMCxx) bit, port mode register (PMxx) bit, and port register (Pxx) bit corresponding to each port to 0. Example: When using P13/TI00/TO00 for timer output in 20-, 24-pin product Set the PMC13 bit of port mode control register 1 to 0. Set the PM00 bit of port mode register 1 to 0. Set the P00 bit of port register 1 to 0. When using the ports (such as TI00/TO00/P13) to be shared with the timer output pin for timer input, set the port mode register (PMxx) bit corresponding to each port to 1. Also set the port mode control register (PMCxx) bit corresponding to each port to 0. At this time, the port register (Pxx) bit may be 0 or 1. Example: When using P13/T000/TI00 for timer input in 20-, 24-pin product Set the PMC13 bit of port mode control register 1 to 0. Set the PM00 bit of port mode register 1 to 1. Set the P00 bit of port register 1 to 0 or 1. ## 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, 6) 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 (Channel 3 to 7) 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 CKS0n0 and CKS0n1 bits (bits 15 and 14 of timer mode register 0n (TMR0n)) of the slave channel that operate in combination with the master channel must be the same value as that of the master channel. - (7) A master channel can transmit INTTM0n (interrupt), start software trigger, and count clock to the lower channels. - (8) A slave channel can use INTTM0n (interrupt), a start software trigger, or the count clock of the master channel as a source clock, but cannot transmit its own INTTM0n (interrupt), start software trigger, or count clock to channels with lower channel numbers. - (9) A master channel cannot use INTTM0n (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 (TS0n) of the channels in combination must be set at the same time. - (11) During the counting operation, a TS0n bit of a master channel or TS0n bits of all channels which are operating simultaneously can be set. It cannot be applied to TS0n bits of slave channels alone. - (12) To stop the channels in combination simultaneously, the channel stop trigger bit (TT0n) of the channels in combination must be set at the same time. - (13) CK02/CK03 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 0n (TMR0n) 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** n: Channel number (n = 0 to 7) # Example #### 6.4.2 Basic rules of 8-bit timer operation function (Only Channels 1 and 3) 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 SPLIT0n bit of timer mode register 0n (TMR0n) 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 INTTM01H/INTTM03H (an interrupt) (which is the same operation performed when MD0n0 is set to 1). - (5) The operation clock of the higher 8 bits is selected according to the CKS0n1 and CKS0n0 bits of the lower-bit TMR0n register. - (6) For the higher 8 bits, the TSH01/TSH03 bit is manipulated to start channel operation and the TTH01/TTH03 bit is manipulated to stop channel operation. The channel status can be checked using the TEH01/TEH03 bit. - (7) The lower 8 bits operate according to the TMR0n register settings. The following three functions support operation of the lower 8 bits: - Interval timer function/Square wave output function - External event counter function - Delay count function - (8) For the lower 8 bits, the TS01/TS03 bit is manipulated to start channel operation and the TT01/TT03 bit is manipulated to stop channel operation. The channel status can be checked using the TE01/TE03 bit. - (9) During 16-bit operation, manipulating the TSH01/TSH03/TTH01/TTH03 bits is invalid. The TS01/TS03/TT01/TT03 bits are manipulated to operate channels 1 and 3. The TEH03 and TEH01 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. **Remark** n: Channel number (n = 1, 3) <R> <R> #### 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 CCS0n bit of timer mode register 0n (TMR0n). - Operation clock (fmck) specified by the CKS0n0 and CKS0n1 bits - Valid edge of input signal input from the TI0n 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 CKS0n0 and CKS0n1 bits is selected (CCS0n = 0) The count clock (ftclk) is between fclk to fclk /2 $^{15}$ by setting of timer clock select register 0 (TPS0). 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 0n (TCR0n) 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. Figure 6-20. Timing of fclk and count clock (ftclk) (When CCS0n = 0) - Remarks 1. A: Rising edge of the count clock - ▲ : Synchronization, increment/decrement of counter - 2. fclk: CPU/peripheral hardware clock #### (2) When valid edge of input signal via the TI0n pin is selected (CCS0n = 1) The count clock (ftclk) becomes the signal that detects valid edge of input signal via the TI0n pin and synchronizes next rising fmck. The count clock (ftclk) is delayed for 1 to 2 period of fmck from the input signal via the TI0n pin (when a noise filter is used, the delay becomes 3 to 4 clock). Counting of timer count register 0n (TCR0n) 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 TI0n pin", as a matter of convenience. Figure 6-21. Timing of fclκ and count clock (fτclκ) (When CCS0n = 1, noise filter unused) - <1> Setting TS0n bit to 1 enables the timer to be started and to become wait state for valid edge of input signal via the TI0n pin. - <2> The rise of input signal via the TIOn pin is sampled by fmck. - <3> The edge is detected by the rising of the sampled signal and the detection signal (count clock) is output. #### Remarks 1. △ : Rising edge of the count clock - ▲ : Synchronization, increment/decrement of counter - 2. fclk: CPU/peripheral hardware clock - fмск: Operation clock of channel n - 3. The waveform of the input signal via TI0n pin of the input pulse interval measurement, the measurement of high/low width of input signal, and the delay counter, the one-shot pulse output are the same as that shown in **Figure 6-21**. # 6.5.2 Start timing of counter Timer count register 0n (TCR0n) becomes enabled to operation by setting of TS0n bit of timer channel start register 0 (TS0). Operations from count operation enabled state to timer count Register 0n (TCR0n) count start is shown in Table 6-6. Table 6-6. Operations from Count Operation Enabled State to Timer count Register 0n (TCR0n) Count Start | Timer operation mode | Operation when TS0n = 1 is set | |--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Interval timer mode | No operation is carried out from start trigger detection (TS0n = 1) until count clock generation. | | | The first count clock loads the value of the TDR0n register to the TCR0n register and the subsequent count clock performs count down operation (see <b>6.5.3 (1)</b> Interval timer mode operation). | | Event counter mode | Writing 1 to the TS0n bit loads the value of the TDR0n register to the TCR0n register. Detection Tl0n input edge, the subsequent count clock performs count down operation. (see 6.5.3 (2) Event counter mode operation). | | Capture mode | No operation is carried out from start trigger (TS0n = 1) detection until count clock generation. | | | The first count clock loads 0000H to the TCR0n register and the subsequent count clock performs count up operation (see 6.5.3 (3) Capture mode operation (input pulse interval measurement)). | | One-count mode | The waiting-for-start-trigger state is entered by writing 1 to the TS0n bit while the timer is stopped (TE0n = 0). No operation is carried out from start trigger detection until count clock generation. The first count clock loads the value of the TDR0n register to the TCR0n register and the subsequent count clock performs count down operation (see 6.5.3 (4) One-count mode operation). | | Capture & one-count mode | The waiting-for-start-trigger state is entered by writing 1 to the TS0n bit while the timer is stopped (TE0n = 0). No operation is carried out from start trigger detection until count clock generation. The first count clock loads 0000H to the TCR0n register and the subsequent count clock performs count up operation (see 6.5.3 (5) Capture & one-count mode operation (high-level width is measured)). | #### 6.5.3 Counter Operation Here, the counter operation in each mode is explained. ## (1) Interval timer mode operation - <1> Operation is enabled (TE0n = 1) by writing 1 to the TS0n bit. Timer count register 0n (TCR0n) holds the initial value until count clock generation. - <2> A start trigger is generated at the first count clock (fmck) after operation is enabled. - <3> When the MD0n0 bit is set to 1, INTTM0n is generated by the start trigger. - <4> By the first count clock after the operation enable, the value of timer data register 0n (TDR0n) is loaded to the TCR0n register and counting starts in the interval timer mode. - <5> When the TCR0n register counts down and its count value is 0000H, INTTM0n is generated in the next count clock (fmck) and the value of timer data register 0n (TDR0n) is loaded to the TCR0n register and counting keeps on. Figure 6-22. Operation Timing (In Interval Timer Mode) **Caution** In the first cycle operation of count clock after writing the TS0n 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 MD0n0 = 1. **Remark** fmck, the start trigger detection signal, and INTTM0n become active between one clock in synchronization with fclk. #### (2) Event counter mode operation - <1> Timer count register 0n (TCR0n) holds its initial value while operation is stopped (TE0n = 0). - <2> Operation is enabled (TE0n = 1) by writing 1 to the TS0n bit. - <3> As soon as 1 has been written to the TS0n bit and 1 has been set to the TE0n bit, the value of timer data register 0n (TDR0n) is loaded to the TCR0n register to start counting. - <4> After that, the TCR0n register value is counted down according to the count clock of the valid edge of the TI0n input. Figure 6-23. Operation Timing (In Event Counter Mode) **Remark** The timing is shown in **Figure 6-23** indicates while the noise filter is not used. By making the noise filter on-state, the edge detection becomes 2 f<sub>MCK</sub> cycles (it sums up to 3 to 4 cycles) later than the normal cycle of TI0n input. The error per one period occurs be the asynchronous between the period of the TIOn input and that of the count clock (fmck). #### (3) Capture mode operation (input pulse interval measurement) - <1> Operation is enabled (TE0n = 1) by writing 1 to the TS0n bit. - <2> Timer count register 0n (TCR0n) 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 TCR0n register and counting starts in the capture mode. (When the MD0n0 bit is set to 1, INTTM0n is generated by the start trigger.) - <4> On detection of the valid edge of the Tl0n input, the value of the TCR0n register is captured to timer data register 0n (TDR0n) and INTTM0n is generated. However, this capture value is nomeaning. The TCR0n register keeps on counting from 0000H. - <5> On next detection of the valid edge of the TI0n input, the value of the TCR0n register is captured to timer data register 0n (TDR0n) and INTTM0n is generated. Figure 6-24. Operation Timing (In Capture Mode: Input Pulse Interval Measurement) Note If a clock has been input to TI0n (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 TS0n 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 MD0n0 = 1. **Remark** The timing is shown in **Figure 6-24** indicates while the noise filter is not used. By making the noise filter on-state, the edge detection becomes 2 fmcκ cycles (it sums up to 3 to 4 cycles) later than the normal cycle of TI0n input. The error per one period occurs be the asynchronous between the period of the TIOn input and that of the count clock (fmck). #### (4) One-count mode operation - <1> Operation is enabled (TE0n = 1) by writing 1 to the TS0n bit. - <2> Timer count register 0n (TCR0n) holds the initial value until start trigger generation. - <3> Rising edge of the TI0n input is detected. - <4> On start trigger detection, the value of timer data register 0n (TDR0n) is loaded to the TCR0n register and count starts. - <5> When the TCR0n register counts down and its count value is 0000H, INTTM0n is generated and the value of the TCR0n register becomes FFFFH and counting stops Figure 6-25. Operation Timing (In One-count Mode) Start trigger input wait status Remark The timing is shown in Figure 6-25 indicates while 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 TI0n input. The error per one period occurs be the asynchronous between the period of the TI0n input and that of the count clock (fmck). #### (5) Capture & one-count mode operation (high-level width is measured) - <1> Operation is enabled (TE0n = 1) by writing 1 to the TS0n bit of timer channel start register 0 (TS0). - <2> Timer count register 0n (TCR0n) holds the initial value until start trigger generation. - <3> Rising edge of the TI0n input is detected. - <4> On start trigger detection, the value of 0000H is loaded to the TCR0n register and count starts. - <5> On detection of the falling edge of the TI0n input, the value of the TCR0n register is captured to timer data register 0n (TDR0n) and INTTM0n is generated. Figure 6-26. Operation Timing (In Capture & One-count Mode: High-level Width Measurement) Remark The timing is shown in Figure 6-28 indicates while 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 TI0n input. The error per one period occurs be the asynchronous between the period of the TI0n input and that of the count clock (fmck). ## 6.6 Channel Output (TO0n pin) Control ## 6.6.1 TO0n pin output circuit configuration Figure 6-27. Output Circuit Configuration The following describes the TO0n pin output circuit. - <1> When TOM0n = 0 (master channel output mode), the set value of timer output level register 0 (TOL0) is ignored and only INTTM0p (slave channel timer interrupt) is transmitted to timer output register 0 (TO0). - <2> When TOM0n = 1 (slave channel output mode), both INTTM0n (master channel timer interrupt) and INTTM0p (slave channel timer interrupt) are transmitted to the TO0 register. At this time, the TOL0 register becomes valid and the signals are controlled as follows: ``` When TOL0n = 0: Positive logic output (INTTM0n \rightarrow set, INTTM0p \rightarrow reset) When TOL0n = 1: Negative logic output (INTTM0n \rightarrow reset, INTTM0p \rightarrow set) ``` When INTTM0n and INTTM0p are simultaneously generated, (0% output of PWM), INTTM0p (reset signal) takes priority, and INTTM0n (set signal) is masked. - <3> While timer output is enabled (TOE0n = 1), INTTM0n (master channel timer interrupt) and INTTM0p (slave channel timer interrupt) are transmitted to the TO0 register. Writing to the TO0 register (TO0n write signal) becomes invalid. - When TOE0n = 1, the TO0n pin output never changes with signals other than interrupt signals. To initialize the TO0n pin output level, it is necessary to set timer operation is stopped (TOE0n = 0) and to write a value to the TO0 register. - <4> While timer output is disabled (TOE0n = 0), writing to the TO0n bit to the target channel (TO0n write signal) becomes valid. When timer output is disabled (TOE0n = 0), neither INTTM0n (master channel timer interrupt) nor INTTM0p (slave channel timer interrupt) is transmitted to the TO0 register. - <5> The TO0 register can always be read, and the TO0n pin output level can be checked. Remark n: Channel number n = 0 to 7 (n = 0, 2, 4, or 6 for master channel) p: Slave channel number n<p≤7 #### 6.6.2 TO0n Pin Output Setting The following figure shows the procedure and status transition of the TO0n output pin from initial setting to timer operation start. Figure 6-28. Status Transition from Timer Output Setting to Operation Start - <1> The operation mode of timer output is set. - TOM0n bit (0: Master channel output mode, 1: Slave channel output mode) - TOL0n 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 0 (TO0). - <3> The timer output operation is enabled by writing 1 to the TOE0n bit (writing to the TO0 register is disabled). - <4> The port is set to digital I/O by port mode control register (PMCxx) (see 6.3.14 Registers controlling port functions of pins to be used for timer I/O). - <5> The port I/O setting is set to output (see 6.3.14 Registers controlling port functions of pins to be used for timer I/O). - <6> The timer operation is enabled (TS0n = 1). **Remark** n: Channel number (n = 0 to 7) Mar 25, 2016 #### 6.6.3 Cautions on Channel Output Operation ## (1) Changing values set in the registers TO0, TOE0, and TOL0 during timer operation Since the timer operations (operations of timer count register 0n (TCR0n) and timer data register 0n (TDR0n)) are independent of the TO0n output circuit and changing the values set in timer output register 0 (TO0), timer output enable register 0 (TOE0), timer output level register 0 (TOL0) does not affect the timer operation, the values can be changed during timer operation. To output an expected waveform from the TO0n pin by timer operation, however, set the TO0, TOE0, TOL0, and TOM0 registers to the values stated in the register setting example of each operation. When the values set to the TOE0 and TOL0 registers (but not the TO0 register) are changed close to the occurrence of the timer interrupt (INTTM0n) of each channel, the waveform output to the TO0n pin might differ, depending on whether the values are changed immediately before or immediately after the timer interrupt (INTTM0n) occurs. **Remark** n: Channel number (n = 0 to 7) ## (2) Default level of TO0n pin and output level after timer operation start The change in the output level of the TO0n pin when timer output register 0 (TO0) is written while timer output is disabled (TOE0n = 0), the initial level is changed, and then timer output is enabled (TOE0n = 1) before port output is enabled, is shown below. #### (a) When operation starts with master channel output mode (TOM0n = 0) setting The setting of timer output level register 0 (TOL0) is invalid when master channel output mode (TOM0n = 0). When the timer operation starts after setting the default level, the toggle signal is generated and the output level of the TO0n pin is reversed. Figure 6-29. TO0n Pin Output Status at Toggle Output (TOM0n = 0) **Remarks** 1. Toggle: Reverse TO0n pin output status 2. n: Channel number (n = 0 to 7) ## (b) When operation starts with slave channel output mode (TOM0p = 1) setting (PWM output)) When slave channel output mode (TOM0p = 1), the active level is determined by timer output level register 0 (TOL0p) setting. Figure 6-30. TOM0p Pin Output Status at PWM Output (TO0p = 1) - **Remarks 1.** Set: The output signal of the TO0p pin changes from inactive level to active level. Reset: The output signal of the TO0p pin changes from active level to inactive level. - 2. p: Channel number (n #### (3) Operation of TO0n pin in slave channel output mode (TOM0n = 1) ## (a) When timer output level register 0 (TOL0) setting has been changed during timer operation When the TOL0 register setting has been changed during timer operation, the setting becomes valid at the generation timing of the TO0n pin change condition. Rewriting the TOL0 register does not change the output level of the TO0n pin. The operation when TOM0n is set to 1 and the value of the TOL0 register is changed while the timer is operating (TE0n = 1) is shown below. Figure 6-31. Operation when TOL0 Register Has Been Changed during Timer Operation **Remarks 1.** Set: The output signal of the TO0p pin changes from inactive level to active level. Reset: The output signal of the TO0p pin changes from active level to inactive level. 2. n: Channel number (n = 0 to 7) #### (b) Set/reset timing To realize 0%/100% output at PWM output, the TO0n pin/TO0n bit set timing at master channel timer interrupt (INTTM0n) 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-32 shows the set/reset operating statuses where the master/slave channels are set as follows. Master channel: TOE0n = 1, TOM0n = 0, TOL0n = 0Slave channel: TOE0p = 1, TOM0p = 1, TOL0p = 0 Figure 6-32. Set/Reset Timing Operating Statuses # (a) Basic operation timing ## (b) Operation timing when 0 % duty Remarks 1. Internal reset signal: TO0n pin reset/toggle signal Internal set signal: TO0n pin set signal 2. n: Channel number (n = 0 to 7) n = 0 to 7 (n = 0, 2, 4, 6 for master channel)p: Slave channel number n #### 6.6.4 Collective manipulation of TO0n bit In timer output register 0 (TO0), the setting bits for all the channels are located in one register in the same way as timer channel start register 0 (TS0). Therefore, the TO0n bit of all the channels can be manipulated collectively. Only the desired bits can also be manipulated by enabling writing only to the TO0n bits (TOE0n = 0) that correspond to the relevant bits of the channel used to perfor0 output (TO0n). Before writing TO0 0 0 0 0 0 0 0 TO07 TO06 TO05 TO04 TO03 TO02 TO01 TO00 0 0 0 0 0 TOE0 0 0 0 0 0 0 0 TOE07 TOE06 TOE05 TOE04 TOE03 TOE02 TOE01 TOE00 0 0 0 1 1 Data to be written 0 0 0 0 0 0 0 0 0 1 0 0 0 1 Φ Φ Φ After writing TO0 0 TO03 TO01 0 0 0 0 0 0 TO07 TO06 **TO05** TO04 TO02 TO00 0 0 0 0 Figure 6-33. Example of TO0n Bit Collective Manipulation Writing is done only to the TO0n bit with TOE0n = 0, and writing to the TO0n bit with TOE0n = 1 is ignored. TO0n (channel output) to which TOE0n = 1 is set is not affected by the write operation. Even if the write operation is done to the TO0n bit, it is ignored and the output change by timer operation is normally done. Figure 6-34. TO0n Pin Statuses by Collective Manipulation of TO0n Bit **Remark** n: Channel number (n = 0 to 7) ## 6.6.5 Timer Interrupt and TO0n Pin Output at Operation Start In the interval timer mode or capture mode, the MD0n0 bit in timer mode register 0n (TMR0n) sets whether or not to generate a timer interrupt at count start. When MD0n0 is set to 1, the count operation start timing can be known by the timer interrupt (INTTM0n) generation. In the other modes, neither timer interrupt at count operation start nor TO0n output is controlled. Figure 6-37 shows operation examples when the interval timer mode (TOE0n = 1, TOM0n = 0) is set. Figure 6-35. Operation examples of timer interrupt at count operation start and TO0n output (a) When MD0n0 is set to 1 #### (b) When MD0n0 is set to 0 When MD0n0 is set to 1, a timer interrupt (INTTM0n) is output at count operation start, and TO0n performs a toggle operation. When MD0n0 is set to 0, a timer interrupt (INTTM0n) is not output at count operation start, and TO0n does not change either. After counting one cycle, INTTM0n is output and TO0n performs a toggle operation. **Remark** n: Channel number (n = 0 to 7) # 6.7 Timer Input (TI0n) Control # 6.7.1 TI0n 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-36. 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-37. Sampling Waveforms through Tl0n Input Pin with Noise Filter Enabled and 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 (CCS0n), 9 (STS0n1), and 8 (STS0n0) in the timer mode register 0n (TMR0n) are all 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 (TS0). ## (2) Noise filter is enabled When bits 12 (CCS0n), 9 (STS0n1), and 8 (STS0n0) in the timer mode register 0n (TMR0n) 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 (TS0). # 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 INTTM0n (timer interrupt) at fixed intervals. The interrupt generation period can be calculated by the following expression. Generation period of INTTM0n (timer interrupt) = Period of count clock × (Set value of TDR0n + 1) # (2) Operation as square wave output TO0n performs a toggle operation as soon as INTTM0n has been generated, and outputs a square wave with a duty factor of 50%. The period and frequency for outputting a square wave from TO0n can be calculated by the following expressions. - Period of square wave output from TO0n = Period of count clock × (Set value of TDR0n + 1) × 2 - Frequency of square wave output from TO0n = Frequency of count clock/{(Set value of TDR0n + 1) × 2} Timer count register 0n (TCR0n) operates as a down counter in the interval timer mode. The TCR0n register loads the value of timer data register 0n (TDR0n) at the first count clock after the channel start trigger bit (TS0n, TSH01, TSH03) of timer channel start register 0 (TS0) is set to 1. If the MD0n0 bit of timer mode register 0n (TMR0n) is 0 at this time, INTTM0n is not output and TO0n is not toggled. If the MD0n0 bit of the TMR0n register is 1, INTTM0n is output and TO0n is toggled. After that, the TCR0n register count down in synchronization with the count clock. When TCR0n = 0000H, INTTM0n is output and TO0n is toggled at the next count clock. At the same time, the TCR0n register loads the value of the TDR0n register again. After that, the same operation is repeated. The TDR0n register can be rewritten at any time. The new value of the TDR0n register becomes valid from the next period. Operation clock Note CK01 Timer counter register 0n (TCR0n) Timer data register 0n (TDR0n) Timer data register 0n (TDR0n) Timer data register 0n (TDR0n) Figure 6-38. Block Diagram of Operation as Interval Timer/Square Wave Output Note When channels 1 and 3, the clock can be selected from CK00 to CK03. Figure 6-39. Example of Basic Timing of Operation as Interval Timer/Square Wave Output (MD0n0 = 1) **Remarks 1.** n: Channel number (n = 0 to 7) 2. TS0n: Bit n of timer channel start register 0 (TS0) TE0n: Bit n of timer channel enable status register 0 (TE0) TCR0n: Timer count register 0n (TCR0n) TDR0n: Timer data register 0n (TDR0n) TO0n: TO0n pin output signal (a) Timer mode register 0n (TMR0n) 10 15 14 13 12 0 TMR0n CKS0n1 CKS0n0 CCS0n M/S No STS0n2 STS0n1 STS0n0 CIS0n1 MD0n3 MD0n0 CIS0n0 MD0n2 MD0n1 1/0 1/0 0 1/0 O O 1/0 0 0 0 0 0 0 0 0 Operation mode of channel n 000B: Interval timer Setting of operation when counting is started 0: Neither generates INTTM0n nor inverts timer output when counting is started. 1: Generates INTTM0n and inverts timer output when counting is started. Selection of TI0n pin input edge 00B: Sets 00B because these are not used. Start trigger selection 000B: Selects only software start. Setting of MASTER0n bit (Channel 2, 4, 6) 0: Independent channel operation. Setting of SPLIT0n bit (Channel 1, 3) 0: 16-bit timer 1: 8-bit timer Count clock selection 0: Selects operation clock (fmck). Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel n. 10B: Selects CK01 as operation clock of channel n. 01B: Selects CK02 as operation clock of channels 1, 3 (This can only be selected channels 1 and 3). 11B: Selects CK03 as operation clock of channels 1, 3 (This can only be selected channels 1 and 3). Figure 6-40. Example of Set Contents of Registers During Operation as Interval Timer/Square Wave Output (1/2) # (b) Timer output register 0 (TO0) TO0 Bit n TO0n 1/0 0: Outputs 0 from TO0n. 1: Outputs 1 from TO0n. # (c) Timer output enable register 0 (TOE0) TOE0 Bit n TOE0n 1/0 0: Stops the TO0n output operation by counting operation. 1: Enables the TO0n output operation by counting operation. Note TMR02, TMR04, TMR06: MASTER0n bit TMR01, TMR03: SPLIT0n bit TMR00, TMR05, TMR07: 0 fixed Figure 6-40. Example of Set Contents of Registers During Operation as Interval Timer/Square Wave Output (2/2) (d) Timer output level register 0 (TOL0) TOL0 Bit n TOL0n 0 0: Cleared to 0 when master channel output mode (TOM0n = 0) (e) Timer output mode register 0 (TOM0) TOM0 Bit n TOM0n 0 0: Sets master channel output mode. Operation is resumed. Figure 6-41. Operation Procedure of Interval Timer/Square Wave Output Function (1/2) | | Software Operation | Hardware Status | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | Sets the TAU0EN 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 0 (TPS0). Determines clock frequencies of CK00 and CK01 (or CK02 and CK03 when using the 8-bit timer mode). | | | Channel<br>default<br>setting | Sets timer mode register 0n (TMR0n) (determines operation mode of channel). Sets interval (period) value to timer data register 0n (TDR0n). | Channel stops operating. (Clock is supplied and some power is consumed.) | | | To use the TO0n output Clears the TOM0n bit of timer output mode register 0 (TOM0) to 0 (master channel output mode). Clears the TOL0n bit to 0. Sets the TO0n bit and determines default level of the | The TO0n pin goes into Hi-Z output state. | | | TO0n output. | The TO0n default setting level is output when the port mode register is in the output mode and the port register is 0. | | | | TO0n does not change because channel stops operating. The TO0n pin outputs the TO0n set level. | | Operation<br>start | (Sets the TOE0n bit to 1 only if using TO0n output and resuming operation.). Sets the TS0n (TSH01, TSH03) bit to 1. The TS0n (TSH01, TSH03) bit automatically returns to 0 because it is a trigger bit. | TE0n (TEH01, TEH03) = 1, and count operation starts. Value of the TDR0n register is loaded to timer count register 0n (TCR0n) at the count clock input. INTTM0n is generated and TO0n performs toggle operation if the MD0n0 bit of the TMR0n register is 1. | | During<br>operation | Set value of the TDR0n register can be changed. The TCR0n register can always be read. The TSR0n register is not used. Set values of the TMR0n register, TOM0n, and TOL0n bits cannot be changed. | Counter (TCR0n) counts down. When count value reaches 0000H, the value of the TDR0n register is loaded to the TCR0n register again and the count operation is continued. By detecting TCR0n = 0000H, INTTM0n is generated and TO0n performs toggle operation. After that, the above operation is repeated. | | Operation stop | The TT0n (TTH01, TTH03) bit is set to 1. The TT0n (TTH01, TTH03) bit automatically returns to 0 because it is a trigger bit. | TE0n (TEH01, TEH03), and count operation stops. The TCR0n register holds count value and stops. The TO0n output is not initialized but holds current status | | | The TOE0n bit is cleared to 0 and value is set to the TO0n bit. $\dashv$ | The TO0n pin outputs the TO0n bit set level. | | TAU<br>stop | To hold the TO0n pin output level Clears the TO0n bit to 0 after the value to be held is set to the port register. When holding the TO0n pin output level is not necessary Setting not required. | The TO0n pin output level is held by port function. | | | The TAU0EN bit of the PER0 register is cleared to 0. | Power-off status All circuits are initialized and SFR of each channel is also initialized. (The TO0n bit is cleared to 0 and the TO0n pin is set to port mode.) | <R> ## 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 TI0n 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 TDR0n + 1 Timer count register 0n (TCR0n) operates as a down counter in the event counter mode. The TCR0n register loads the value of timer data register 0n (TDR0n) by setting any channel start trigger bit (TS0n) of timer channel start register 0 (TS0) to 1. The TCR0n register counts down each time the valid input edge of the TI0n pin has been detected. When TCR0n = 0000H, the TCR0n register loads the value of the TDR0n register again, and outputs INTTM0n. After that, the above operation is repeated. An irregular waveform that depends on external events is output from the TO0n pin. Stop the output by setting the TOE0n bit of timer output enable register 0 (TOE0) to 0. The TDR0n register can be rewritten at any time. The new value of the TDR0n register becomes valid during the next count period. Figure 6-42. Block Diagram of Operation as External Event Counter Figure 6-43. Example of Basic Timing of Operation as External Event Counter **Remarks 1.** n: Channel number (n = 0 to 7) **2.** TS0n: Bit n of timer channel start register 0 (TS0) TE0n: Bit n of timer channel enable status register 0 (TE0) TI0n: TI0n pin input signal TCR0n: Timer count register 0n (TCR0n) TDR0n: Timer data register 0n (TDR0n) Figure 6-44. Example of Set Contents of Registers in External Event Counter Mode (1/2) Figure 6-44. Example of Set Contents of Registers in External Event Counter Mode (2/2) # (d) Timer output level register 0 (TOL0) TOL0 TOLOn 0 0: Cleared to 0 when master channel output mode (TOM0n = 0). # (e) Timer output mode register 0 (TOM0) TOM0 TOM0n 0 0: Sets master channel output mode. Figure 6-45. Operation Procedure When External Event Counter Function Is Used | | | Software Operation | Hardware Status | |-----------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | | Sets the TAU0EN 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 0 (TPS0). Determines clock frequencies of CK00 and CK01 (or CK02 and CK03 when using the 8-bit timer mode). | | | | Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable registers 1 (NFEN1) to 0 (off) or 1 (on). Sets timer mode register 0n (TMR0n) (determines operation mode of channel). Sets number of counts to timer data register 0n (TDR0n). Sets noise filter enable register 1 (NFEN1) Clears the TOE0n bit of timer output enable register 0 (TOE0) to 0. | Channel stops operating. (Clock is supplied and some power is consumed.) | | ned. | Operation<br>start | , | TE0n = 1, and count operation starts. Value of the TDR0n register is loaded to timer count register 0n (TCR0n) and detection of the TI0n pin input edge is awaited. | | Operation is resumed. | During<br>operation | Set value of the TDR0n register can be changed. The TCR0n register can always be read. The TSR0n register is not used. Set values of the TMR0n register, TOM0n, TOL0n, TO0n, and TOE0n bits cannot be changed. | Counter (TCR0n) counts down each time input edge of the TI0n pin has been detected. When count value reaches 0000H, the value of the TDR0n register is loaded to the TCR0n register again, and the count operation is continued. By detecting TCR0n = 0000H, the INTTM0n output is generated. After that, the above operation is repeated. | | | Operation stop | The TT0n bit is set to 1. The TT0n bit automatically returns to 0 because it is a trigger bit. | TE0n = 0, and count operation stops. The TCR0n register holds count value and stops. | | | TAU<br>stop | The TAU0EN bit of the PER0 register is cleared to 0. | Power-off status All circuits are initialized and SFR of each channel is also initialized. | ## 6.8.3 Operation as frequency divider (channel 0 of 30-pin products only) The timer array unit can be used as a frequency divider that divides a clock input to the TI00 pin and outputs the result from the TO00 pin. The divided clock frequency output from TO00 can be calculated by the following expression. - When rising edge/falling edge is selected: - Divided clock frequency = Input clock frequency/ $\{(\text{Set value of TDR00} + 1) \times 2\}$ - When both edges are selected: - Divided clock frequency ≅ Input clock frequency/(Set value of TDR00 + 1) Timer count register 00 (TCR00) operates as a down counter in the interval timer mode. After the channel start trigger bit (TS00) of timer channel start register 0 (TS0) is set to 1, the TCR00 register loads the value of timer data register 00 (TDR00) when the Tl00 valid edge is detected. If the MD000 bit of timer mode register 00 (TMR00) is 0 at this time, INTTM00 is not output and TO00 is not toggled. If the MD000 bit of timer mode register 00 (TMR00) is 1, INTTM00 is output and TO00 is toggled. After that, the TCR00 register counts down at the valid edge of the Tl00 pin. When TCR00 = 0000H, it toggles T000. At the same time, the TCR00 register loads the value of the TDR00 register again, and continues counting. If detection of both the edges of the TI00 pin is selected, the duty factor error of the input clock affects the divided clock period of the TO00 output. The period of the TO00 output clock includes a sampling error of one period of the operation clock. Clock period of TO00 output = Ideal TO00 output clock period ± Operation clock period (error) The TDR00 register can be rewritten at any time. The new value of the TDR00 register becomes valid during the next count period. Figure 6-46. Block Diagram of Operation as Frequency Divider Figure 6-47. Example of Basic Timing of Operation as Frequency Divider (MD000 = 1) **Remark** TS00: Bit n of timer channel start register 0 (TS0) TE00: Bit n of timer channel enable status register 0 (TE0) TI00: TI00 pin input signal TCR00: Timer count register 00 (TCR00) TDR00: Timer data register 00 (TDR00) TO00: TO00 pin output signal (a) Timer mode register 00 (TMR00) 15 14 13 12 0 TMR00 CKS0n1 CCS00 CIS001 CKS0n0 STS002 STS001 STS000 CIS000 MD003 MD002 MD001 MD000 1/0 0 0 1 0 0 0 1/0 1/0 0 0 0 0 1/0 Operation mode of channel 0 000B: Interval timer Setting of operation when counting is started 0: Neither generates INTTM00 nor inverts timer output when counting is started. 1: Generates INTTM00 and inverts timer output when counting is started. Selection of TI00 pin input edge 00B: Detects falling edge. 01B: Detects rising edge. 10B: Detects both edges. 11B: Setting prohibited Start trigger selection 000B: Selects only software start. Count clock selection 1: Selects the TI00 pin input valid edge. Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel 0. 10B: Selects CK01 as operation clock of channel 0. (b) Timer output register 0 (TO0) Bit 0 TO0 0: Outputs 0 from TO00. TO00 1/0 1: Outputs 1 from TO00. Figure 6-48. Example of Set Contents of Registers During Operation as Frequency Divider ## (c) Timer output enable register 0 (TOE0) TOE0 TOE00 1/0 0: Stops the TO00 output operation by counting operation. 1: Enables the TO00 output operation by counting operation. # (d) Timer output level register 0 (TOL0) TOL0 Bit 0 TOL00 0 0: Cleared to 0 when master channel output mode (TOM00 = 0) ## (e) Timer output mode register 0 (TOM0) томо т Bit 0 TOM00 0 0: Sets master channel output mode. Figure 6-49. Operation Procedure When Frequency Divider Function Is Used | | Software Operation | Hardware Status | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | Sets the TAU0EN 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 0 (TPS0). Determines clock frequencies of CK00 and CK01. | | | Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable registers 1 (NFEN1) to 0 (off) or 1 (on). Sets timer mode register 00 (TMR00) (determines operation mode of channel and selects the detection edge). Sets interval (period) value to timer data register 00 (TDR00). | Channel stops operating. (Clock is supplied and some power is consumed.) | | | Clears the TOM00 bit of timer output mode register 0 (TOM0) to 0 (master channel output mode). Clears the TOL0n bit to 0. Sets the TO00 bit and determines default level of the | The TO00 pin goes into Hi-Z output state. | | | TO00 output. Sets the TOE00 bit to 1 and enables operation of TO00.— | The TO00 default setting level is output when the port mode register is in output mode and the port register is 0. TO00 does not change because channel stops operating. The TO00 pin outputs the TO00 set level. | | Operation start | Sets the TOE00 bit to 1 (only when operation is resumed). Sets the TS00 bit to 1. The TS00 bit automatically returns to 0 because it is a trigger bit. | TE00 = 1, and count operation starts. Value of the TDR00 register is loaded to timer count register 00 (TCR00). INTTM0n is generated and TO00 performs toggle operation if the MD00n bit of the TMR00 register is 1. | | During<br>operation | Set value of the TDR00 register can be changed. The TCR00 register can always be read. The TSR00 register is not used. Set values of the TO0 and TOE0 registers can be changed. Set values of the TMR00 register, TOM00, and TOL00 bits cannot be changed. | Counter (TCR00) counts down. When count value reaches 0000H, the value of the TDR00 register is loaded to the TCR00 register again, and the count operation is continued. By detecting TCR00 = 0000H, INTTM00 is generated and TO00 performs toggle operation. After that, the above operation is repeated. | | Operation stop | The TT00 bit is set to 1. The TT00 bit automatically returns to 0 because it is a trigger bit. The TOE00 bit is cleared to 0 and value is set to the TO00 bit. | TE00 = 0, and count operation stops. The TCR00 register holds count value and stops. The TC000 output is not initialized but holds current status. | | TAU<br>stop | To hold the TO00 pin output level Clears the TO00 bit to 0 after the value to be held is | The TO00 pin output level is held by port function. | | | | Power-off status All circuits are initialized and SFR of each channel is also initialized. (The TO00 bit is cleared to 0 and the TO00 pin is set to port mode). | #### 6.8.4 Operation as input pulse interval measurement The count value can be captured at the TI0n valid edge and the interval of the pulse input to TI0n can be measured. In addition, the count value can be captured by using software operation (TS0n = 1) as a capture trigger while the TE0n bit is set to 1. The pulse interval can be calculated by the following expression. TI0n input pulse interval = Period of count clock × ((10000H × TSR0n: OVF) + (Capture value of TDR0n + 1)) **Caution** The TI0n pin input is sampled using the operating clock selected with the CKS0n bit of timer mode register 0n (TMR0n), so an error of up to one operating clock cycle occurs. Timer count register 0n (TCR0n) operates as an up counter in the capture mode. When the channel start trigger bit (TS0n) of timer channel start register 0 (TS0) is set to 1, the TCR0n register counts up from 0000H in synchronization with the count clock. When the TI0n pin input valid edge is detected, the count value of the TCR0n register is transferred (captured) to timer data register 0n (TDR0n) and, at the same time, the TCR0n register is cleared to 0000H, and the INTTM0n is output. If the counter overflows at this time, the OVF bit of timer status register 0n (TSR0n) 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 TDR0n register, the OVF bit of the TSR0n 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 TSR0n 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 STS0n2 to STS0n0 bits of the TMR0n register to 001B to use the valid edges of Tl0n as a start trigger and a capture trigger. selection CK01 Operation clock<sup>Note</sup> Timer counter Interrupt Interrupt signal Clock register 0n (TCR0n) controller (INTTM0n) CKOO TNFEN0n selection Noise Edge TI0n pin filter detection Timer data register 0n (TDR0n) rigger TS0n Figure 6-50. Block Diagram of Operation as Input Pulse Interval Measurement Note When channels 1 and 3, the clock can be selected from CK00, CK01, CK02, and CK03. Figure 6-51. Example of Basic Timing of Operation as Input Pulse Interval Measurement (MD0n0 = 0) **Remarks 1.** n: Channel number (n = 0 to 7) 2. TS0n: Bit n of timer channel start register 0 (TS0) TE0n: Bit n of timer channel enable status register 0 (TE0) TIOn: TIOn pin input signal TCR0n: Timer count register 0n (TCR0n) TDR0n: Timer data register 0n (TDR0n) OVF: Bit 0 of timer status register 0n (TSR0n) (a) Timer mode register 0n (TMR0n) 13 10 0 TMR0n CKS0n1 CKS0n0 CCS0n STS0n2 STS0n1 STS0n0 CIS0n1 CIS0n0 MD0n3 MD0n2 MD0n0 MD0n1 1/0 0 0 0 0 1/0 1/0 1/0 Operation mode of channel n 010B: Capture mode Setting of operation when counting is started 0: Does not generate INTTM0n when counting is started. 1: Generates INTTM0n when counting is started. Selection of TI0n pin input edge 00B: Detects falling edge. 01B: Detects rising edge. 10B: Detects both edges. 11B: Setting prohibited Capture trigger selection 001B: Selects the TI0n pin input valid edge. Setting of MASTER0n bit (Channel 2, 4, 6) 0: Independent channel operation. Setting of SPLIT0n bit (Channel 1, 3) 0: 16-bit timer Count clock selection 0: Selects operation clock (fmck). Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel n. 10B: Selects CK01 as operation clock of channel n. 01B: Selects CK02 as operation clock of channels 1, 3 (This can only be selected channels 1 and 3). 11B: Selects CK03 as operation clock of channels 1, 3 (This can only be selected channels 1 and 3). (b) Timer output register 0 (TO0) Bit n TO0 Figure 6-52. Example of Set Contents of Registers to Measure Input Pulse Interval (1/2) TO0n 0 0: Outputs 0 from TO0n. # (c) Timer output enable register 0 (TOE0) Bit n TOE0 TOE0n 0 0: Stops TO0n output operation by counting operation. Note TMR02, TMR04, TMR06: MASTER0n bit TMR01, TMR03: SPLIT0n bit TMR00, TMR05, TMR07: 0 fixed Figure 6-52. Example of Set Contents of Registers to Measure Input Pulse Interval (2/2) (d) Timer output level register 0 (TOL0) TOL0 Bit n TOL0n 0 0: Cleared to 0 when master channel output mode (TOM0n = 0). (e) Timer output mode register 0 (TOM0) TOM0 TOM0n 0: Sets master channel output mode. Note TMR02, TMR04, TMR06: MASTER0n bit TMR01, TMR03: SPLIT0n bit TMR00, TMR05, TMR07: 0 fixed Figure 6-53. Operation Procedure When Input Pulse Interval Measurement Function Is Used | | | Software Operation | Hardware Status | |-----------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | | Sets the TAU0EN 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 0 (TPS0). Determines clock frequencies of CK00 to CK03. | | | | Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable registers 1 (NFEN1) to 0 (off) or 1 (on). Sets timer mode register 0n (TMR0n) (determines operation mode of channel). | Channel stops operating. (Clock is supplied and some power is consumed.) | | | | Sets Noise filter enable register 1 (NFEN1). | | | | Operation<br>start | Sets TS0n bit to 1. The TS0n bit automatically returns to 0 because it is a trigger bit. | TE0n = 1, and count operation starts. Timer count register 0n (TCR0n) is cleared to 0000H at the count clock input. When the MD0n0 bit of the TMR0n register is 1, INTTM0n is generated. | | Operation is resumed. | During<br>operation | Set values of only the CIS0n1 and CIS0n0 bits of the TMR0n register can be changed. The TDR0n register can always be read. The TCR0n register can always be read. The TSR0n register can always be read. Set values of the TOM0n, TOL0n, TO0n, and TOE0n bits cannot be changed. | Counter (TCR0n) counts up from 0000H. When the valid edge of the Tl0n pin input is detected or the TS0n bit is set to 1, the count value is transferred (captured) to timer data register 0n (TDR0n). At the same time, the TCR0n register is cleared to 0000H, and the INTTM0n signal is generated. If an overflow occurs at this time, the OVF bit of timer status register 0n (TSR0n) is set; if an overflow does not occur, the OVF bit is cleared. After that, the above operation is repeated. | | | Operation stop | The TT0n bit is set to 1. The TT0n bit automatically returns to 0 because it is a trigger bit. | TE0n = 0, and count operation stops. The TCR0n register holds count value and stops. The OVF bit of the TSR0n register is also held. | | | TAU<br>stop | The TAU0EN bit of the PER0 register is cleared to 0. | Power-off status All circuits are initialized and SFR of each channel is also initialized. | ## 6.8.5 Operation as input signal high-/low-level width measurement By starting counting at one edge of the TI0n pin input and capturing the number of counts at another edge, the signal width (high-level width/low-level width) of TI0n can be measured. The signal width of TI0n can be calculated by the following expression. Signal width of TI0n input = Period of count clock × ((10000H × TSR0n: OVF) + (Capture value of TDR0n + 1)) **Caution** The TI0n pin input is sampled using the operating clock selected with the CKS0n bit of timer mode register 0n (TMR0n), so an error equivalent to one operation clock occurs. Timer count register 0n (TCR0n) operates as an up counter in the capture & one-count mode. When the channel start trigger bit (TS0n) of timer channel start register 0 (TS0) is set to 1, the TE0n bit is set to 1 and the Tl0n pin start edge detection wait status is set. When the TI0n pin input start edge (rising edge of the TI0n 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 TI0n pin input when the high-level width is to be measured) is detected later, the count value is transferred to timer data register 0n (TDR0n) and, at the same time, INTTM0n is output. If the counter overflows at this time, the OVF bit of timer status register 0n (TSR0n) is set to 1. If the counter does not overflow, the OVF bit is cleared. The TCR0n register stops at the value "value transferred to the TDR0n register + 1", and the TI0n 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 TDR0n register, the OVF bit of the TSR0n 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 TSR0n 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 TI0n pin is to be measured can be selected by using the CIS0n1 and CIS0n0 bits of the TMR0n register. Because this function is used to measure the signal width of the TI0n pin input, the TS0n bit cannot be set to 1 while the TE0n bit is 1. CISOn1, CISOn0 of TMR0n register = 10B: Low-level width is measured. CIS0n1, CIS0n0 of TMR0n register = 11B: High-level width is measured. selection CK01 Operation clock<sup>Note</sup> CK00 Timer counter Interrupt Interrupt signal Clock register 0n (TCR0n) controller (INTTM0n) TNFEN0n rigger selection Timer data Noise Edge TI0n pin⊙ register 0n (TDR0n) filter detection Figure 6-54. Block Diagram of Operation as Input Signal High-/Low-Level Width Measurement Note For channels 1 and 3, the clock can be selected from CK00, CK01, CK02, and CK03. Figure 6-55. Example of Basic Timing of Operation as Input Signal High-/Low-Level Width Measurement **Remarks 1.** n: Channel number (n = 0 to 7) 2. TS0n: Bit n of timer channel start register 0 (TS0) TE0n: Bit n of timer channel enable status register 0 (TE0) TIOn: TIOn pin input signal TCR0n: Timer count register 0n (TCR0n) TDR0n: Timer data register 0n (TDR0n) OVF: Bit 0 of timer status register 0n (TSR0n) (a) Timer mode register 0n (TMR0n) 15 14 13 12 TMR0n CKS0n1 CKS0n0 CCS0n M/S No STS0n2 STS0n1 STS0n0 CIS0n1 CIS0n0 MD0n3 MD0n2 MD0n1 MD0n0 1/0 0 O 0 O 0 0 1/0 O 0 0 Operation mode of channel n 110B: Capture & one-count Setting of operation when counting is started 0: Does not generate INTTM0n when counting is started. Selection of TI0n pin input edge 10B: Both edges (to measure low-level width) 11B: Both edges (to measure high-level width) Start trigger selection 010B: Selects the TI0n pin input valid edge. Setting of MASTER0n bit (Channel 2, 4, 6) 0: Independent channel operation. Setting of SPLIT0n bit (Channel 1, 3) 0: 16-bit timer Count clock selection 0: Selects operation clock (fmck). Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel n. 10B: Selects CK01 as operation clock of channel n. 01B: Selects CK02 as operation clock of channels 1, 3 (This can only be selected channels 1 and 3). 11B: Selects CK03 as operation clock of channels 1, 3 (This can only be selected channels 1 and 3). (b) Timer output register 0 (TO0) Bit n TO0 TO0n 0: Outputs 0 from TO0n. 0 (c) Timer output enable register 0 (TOE0) Bit n TOE0 0: Stops the TO0n output operation by counting operation. TOE0n 0 (d) Timer output level register 0 (TOL0) Bit n Figure 6-56. Example of Set Contents of Registers to Measure Input Signal High-/Low-Level Width TOLO TOLOn 0: Cleared to 0 when master channel output mode (TOM0n = 0). # (e) Timer output mode register 0 (TOM0) TOM0 Bit n TOM0n 0 0: Sets master channel output mode. Note TMR02, TMR04, TMR06: MASTER0n bit TMR01, TMR03: SPLIT0n bit TMR00, TMR05, TMR07: 0 fixed Remark n: Channel number (n = 0 to 7) Figure 6-57. 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 (Clock supply is stopped and writing to each register is disabled.) | | | Sets the TAU0EN 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 0 (TPS0). Determines clock frequencies of CK00 to CK03. | | | Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable registers 1 (NFEN1) to 0 (off) or 1 (on). Sets timer mode register 0n (TMR0n) (determines operation mode of channel). Sets noise filter enable register 1 (NFEN1) Clears the TOE0n bit to 0 and stops operation of TO0n. | Channel stops operating. (Clock is supplied and some power is consumed.) | | Operation start | Sets the TS0n bit to 1. The TS0n bit automatically returns to 0 because it is a trigger bit. | TE0n = 1, and the TI0n pin start edge detection wait status is set. | | | Detects the TI0n pin input count start valid edge. | Clears timer count register 0n (TCR0n) to 0000H and starts counting up. | | During<br>operation | Set value of the TDR0n register can always be read. The TCR0n register can always be read. The TSR0n register can always be read. Set values of the TMR0n register, TOM0n, TOL0n, TO0n, and TOE0n bits cannot be changed. | When the TI0n pin start edge is detected, the counter (TCR0n) counts up from 0000H. If a capture edge of the TI0n pin is detected, the count value is transferred to timer data register 0n (TDR0n) and INTTM0n is generated. If an overflow occurs at this time, the OVF bit of timer status register 0n (TSR0n) is set; if an overflow does not occur, the OVF bit is cleared. The TCR0n register stops the count operation until the next TI0n pin start edge is detected. | | Operation stop | The TT0n bit is set to 1. The TT0n bit automatically returns to 0 because it is a trigger bit. | TE0n = 0, and count operation stops. The TCR0n register holds count value and stops. The OVF bit of the TSR0n register is also held. | | TAU<br>stop | The TAU0EN bit of the PER0 register is cleared to 0. | Power-off status All circuits are initialized and SFR of each channel is also initialized. | ## 6.8.6 Operation as delay counter It is possible to start counting down when the valid edge of the TI0n pin input is detected (an external event), and then generate INTTM0n (a timer interrupt) after any specified interval. It can also start counting down and generate INTTM0n (timer interrupt) at any interval by setting TS0n to 1 by software during the period of TE0n = 1. The interrupt generation period can be calculated by the following expression. Generation period of INTTM0n (timer interrupt) = Period of count clock × (Set value of TDR0n + 1) Timer count register 0n (TCR0n) operates as a down counter in the one-count mode. When the channel start trigger bit (TS0n, TSHm1, TSHm3) of timer channel start register 0 (TS0) is set to 1, the TE0n, TEHm1, TEHm3 bits are set to 1 and the Tl0n pin input valid edge detection wait status is set. Timer count register 0n (TCR0n) starts operating upon TI0n pin input valid edge detection and loads the value of timer data register 0n (TDR0n). The TCR0n register counts down from the value of the TDR0n register it has loaded, in synchronization with the count clock. When TCR0n = 0000H, it outputs INTTM0n and stops counting until the next TI0n pin input valid edge is detected. The TDR0n register can be rewritten at any time. The new value of the TDR0n register becomes valid from the next period. Clock selection Operation clock<sup>Note</sup> Timer counter register 0n (TCR0n) TS0n selection Interrupt signal Timer data Interrupt register 0n (TDR0n) (INTTM0n) Edge Noise rigger controller TI0n pin ( detection filter TNFEN0n Figure 6-58. Block Diagram of Operation as Delay Counter Note For using channels 1 and 3 in 8-bit timer mode, the clock can be selected from CK00, CK01, CK02, and CK03. Figure 6-59. Example of Basic Timing of Operation as Delay Counter **Remarks 1.** n: Channel number (n = 0 to 7) **2.** TS0n: Bit n of timer channel start register 0 (TS0) TE0n: Bit n of timer channel enable status register 0 (TE0) TIOn: TIOn pin input signal TCR0n: Timer count register 0n (TCR0n) TDR0n: Timer data register 0n (TDR0n) Figure 6-60. Example of Set Contents of Registers to Delay Counter (1/2) TO0 TO0n 0 0: Outputs 0 from TO0n. # (c) Timer output enable register 0 (TOE0) TOE0 Bit n TOE0n 0 0: Stops the TO0n output operation by counting operation. Note TMR02, TMR04, TMR06: MASTER0n bit TMR01, TMR03: SPLIT0n bit TMR00, TMR05, TMR07: 0 fixed Figure 6-60. Example of Set Contents of Registers to Delay Counter (2/2) (d) Timer output level register 0 (TOL0) TOL0 Bit n TOL0n 0 0: Cleared to 0 when master channel output mode (TOM0n = 0). (e) Timer output mode register 0 (TOM0) TOM0 TOM0n 0 0: Sets master channel output mode. Figure 6-61. Operation Procedure When Delay Counter Function Is Used | | Software Operation | Hardware Status | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | Sets the TAU0EN 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 0 (TPS0). Determines clock frequencies of CK00 and CK01 (or CK02 and CK03 when using the 8-bit timer mode). | | | Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable registers 1 (NFEN1) to 0 (off) or 1 (on). Sets timer mode register 0n (TMR0n) (determines operation mode of channel). INTTM0n output delay is set to timer data register 0n (TDR0n). Sets noise filter enable register 1 (NFEN1). | Channel stops operating. (Clock is supplied and some power is consumed.) | | | Clears the TOE0n bit to 0 and stops operation of TO0n. | | | Operation start | The TS0n bit automatically returns to 0 because it is a trigger bit. | TE0n = 1, and the start trigger detection (the valid edge of the TI0n pin input is detected or the TS0n bit is set to 1) wait status is set. | | | The counter starts counting down by the next start trigger detection. | | | | Detects the valid edge of the TI0n pin input. Sets the TS0n bit to 1 by the software. | Value of the TDR0n register is loaded to the timer count register 0n (TCR0n). | | During<br>operation | Set value of the TDR0n register can be changed. The TCR0n register can always be read. The TSR0n register is not used. | The counter (TCR0n) counts down. When the count value of TCR0n reaches 0000H, INTTM0n output is generated, and count operation stops until the next start trigger detection (the valid edge of the Tl0n pin input is detected or the TS0n bit is set to 1). | | Operation stop | The TT0n bit is set to 1. The TT0n bit automatically returns to 0 because it is a trigger bit. | TE0n = 0, and count operation stops. The TCR0n register holds count value and stops. | | TAU<br>stop | The TAU0EN bit of the PER0 register is cleared to 0. | Power-off status All circuits are initialized and SFR of each channel is also initialized. | # 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 TI0n pin. The delay time and pulse width can be calculated by the following expressions. Delay time = {Set value of TDR0n (master) + 2} $\times$ Count clock period Pulse width = {Set value of TDR0p (slave)} $\times$ Count clock period The master channel operates in the one-count mode and counts the delays. Timer count register 0n (TCR0n) of the master channel starts operating upon start trigger detection and loads the value of timer data register 0n (TDR0n). The TCR0n register counts down from the value of the TDR0n register it has loaded, in synchronization with the count clock. When TCR0n = 0000H, it outputs INTTM0n 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 TCR0p register of the slave channel starts operation using INTTM0n of the master channel as a start trigger, and loads the value of the TDR0p register. The TCR0p register counts down from the value of The TDR0p register it has loaded, in synchronization with the count value. When count value = 0000H, it outputs INTTM0p and stops counting until the next start trigger (INTTM0n of the master channel) is detected. The output level of TO0p becomes active one count clock after generation of INTTM0n from the master channel, and inactive when TCR0p = 0000H. Instead of using the TI0n pin input, a one-shot pulse can also be output using the software operation (TS0n = 1) as a start trigger. Caution The timing of loading of timer data register 0n (TDR0n) of the master channel is different from that of the TDR0p register of the slave channel. If the TDR0n and TDR0p registers are rewritten during operation, therefore, an illegal waveform is output. Rewrite the TDR0n register after INTTM0n is generated and the TDR0p register after INTTM0p is generated. **Remark** n: Channel number (n = 0, 2, 4, 6) p: Slave channel number (n \leq 7) Figure 6-62. Block Diagram of Operation as One-Shot Pulse Output Function **Remark** n: Channel number (n = 0, 2, 4, 6) p: Slave channel number (n \leq 7) Figure 6-63. Example of Basic Timing of Operation as One-Shot Pulse Output Function **Remarks 1.** n: Channel number (n = 0, 2, 4, 6) p: Slave channel number (n \leq 7) **2.** TS0n, TS0p: Bit n, p of timer channel start register 0 (TS0) TE0n, TE0p: Bit n, p of timer channel enable status register 0 (TE0) TIOn, TIOp: TIOn and TIOp pins input signal TCR0n, TCR0p: Timer count registers mn, mp (TCR0n, TCR0p) TDR0n, TDR0p: Timer data registers mn, mp (TDR0n, TDR0p) TO0n, TO0p: TO0n and TO0p pins output signal Figure 6-64. Example of Set Contents of Registers When One-Shot Pulse Output Function Is Used (Master Channel) #### (a) Timer mode register 0n (TMR0n) 14 15 13 12 MAS TMR0n CKS0n1 CKS0n0 CCS0n STS0n2 STS0n1 STS0n0 CIS0n1 CIS0n0 MD0n3 MD0n2 MD0n1 MD0n0 TER0r 1/0 0 0 0 1/0 1/0 0 0 0 0 0 0 Operation mode of channel n 100B: One-count mode Start trigger during operation 0: Trigger input is invalid. Selection of TI0n pin input edge 00B: Detects falling edge. 01B: Detects rising edge. 10B: Detects both edges. 11B: Setting prohibited Start trigger selection 001B: Selects the TI0n pin input valid edge. Setting of MASTER0n bit (channels 2, 4, 6) 1: Master channel. Count clock selection 0: Selects operation clock (fmck). -Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channels n. 10B: Selects CK01 as operation clock of channels n. Note TMR02, TMR04, TMR06: MASTER0n = 1 TMR00: Fixed to 0 (b) Timer output register 0 (TO0) Bit n TO0 0: Outputs 0 from TO0n. TO0n 0 # (c) Timer output enable register 0 (TOE0) Bit n TOE0 TOF0n 0: Stops the TO0n output operation by counting operation. 0 # (d) Timer output level register 0 (TOL0) Bit n TOL<sub>0</sub> 0: Cleared to 0 when TOM0n = 0 (master channel output mode). TOL0n 0 ## (e) Timer output mode register 0 (TOM0) Bit n TOM0 0: Sets master channel output mode. TOM0n 0 Note TMR02, TMR04, TMR06: MASTER0n = 1 TMR00: Fixed to 0 **Remark** n: Channel number (n = 0, 2, 4, 6) (a) Timer mode register 0p (TMR0p) 10 15 14 13 12 0 TMR0p CKS0p1 CKS0p0 CCS0p M/S STS0p2 STS0p1 CIS0p1 MD0p3 MD0p2 MD0p0 STS0p0 CIS0p0 MD0p1 1/0 0 0 O 0 0 0 0 0 0 0 0 0 Operation mode of channel p 100B: One-count mode Start trigger during operation 0: Trigger input is invalid. Selection of TI0p pin input edge 00B: Sets 00B because these are not used. Start trigger selection 100B: Selects INTTM0n of master channel. Setting of MASTER0n bit (Channel 2, 4, 6) 0: Independent channel operation. Setting of SPLIT0n bit (Channel 1, 3) 0: 16-bit timer Count clock selection 0: Selects operation clock (fmck). Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel p. Figure 6-65. Example of Set Contents of Registers When One-Shot Pulse Output Function Is Used (Slave Channel) # (b) Timer output register 0 (TO0) TO0 TO0p 0: Outputs 0 from TO0p. 1: Outputs 1 from TO0p. ## (c) Timer output enable register 0 (TOE0) TOE0 Bit p TOE0p 1/0 0: Stops the TO0p output operation by counting operation. 10B: Selects CK01 as operation clock of channel p.\* Make the same setting as master channel. 1: Enables the TO0p output operation by counting operation. # (d) Timer output level register 0 (TOL0) TOL0 Bit p TOL0p 1/0 0: Positive logic output (active-high) 1: Negative logic output (active-low) # (e) Timer output mode register 0 (TOM0) TOM0 Bit p TOM0p 1 1: Sets the slave channel output mode. Note TMR02, TMR04, TMR06: MASTER0n bit TMR01, TMR03: SPLIT0n bit TMR00, TMR05, TMR07: 0 fixed **Remark** n: Master channel number (n = 0, 2, 4, 6) p: Slave channel number (n \leq 7) Figure 6-66. Operation Procedure of One-Shot Pulse Output Function (1/2) | | Software Operation | Hardware Status | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | Sets the TAU0EN bit of peripheral enable registers 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 0 (TPS0). Determines clock frequencies of CK00 and CK01. | | | Channel<br>default<br>setting | Sets the corresponding bit of the noise filter enable registers 1 (NFEN1) to 0 (off) or 1 (on). Sets timer mode register 0n, mp (TMR0n, TMR0p) of two channels to be used (determines operation mode of channels). An output delay is set to timer data register 0n (TDR0n) of the master channel, and a pulse width is set to the TDR0p register of the slave channel. | Channel stops operating. (Clock is supplied and some power is consumed.) | | | Sets the TOE0p bit to 1 and enables operation of TO0p. | The TO0p pin goes into Hi-Z output state. The TO0p default setting level is output when the port mode register is in output mode and the port register is 0. TO0p does not change because channel stops operating. The TO0p pin outputs the TO0p set level. | Remark n: Channel number (n = 0, 2, 4, 6) p: Slave channel number (n \leq 7) Operation is resumed. Figure 6-66. Operation Procedure of One-Shot Pulse Output Function (2/2) | ſ | | Software Operation | Hardware Status | | |---|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | * | Operation<br>start | Sets the TOE0p bit (slave) to 1 (only when operation is resumed). The TS0n (master) and TS0p (slave) bits of timer channel start register 0 (TS0) are set to 1 at the same time. The TS0n and TS0p bits automatically return to 0 because they are trigger bits. | The TE0n and TE0p bits are set to 1 and the master channel enters the start trigger detection (the valid edge of the TI0n pin input is detected or the TS0n bit of the master channel is set to 1) wait status. Counter stops operating. | | | | | Count operation of the master channel is started by start trigger detection of the master channel. • Detects the TI0n pin input valid edge. | Master channel starts counting. | | | | | <ul> <li>Sets the TS0n bit of the master channel to 1 by software<sup>Note</sup>.</li> <li>Note Do not set the TS0n bit of the slave channel to 1.</li> </ul> | | | | | During<br>operation | Set values of only the CIS0n1 and CIS0n0 bits of the TMR0n register can be changed. Set values of the TMR0p, TDR0n, TDR0p registers, TOM0n, TOM0p, TOL0n, and TOL0p bits cannot be changed. The TCR0n and TCR0p registers can always be read. The TSR0n and TSR0p registers are not used. Set values of the TO0 and TOE0 registers of slave channel can be changed. | Master channel loads the value of the TDR0n register to timer count register 0n (TCR0n) by the start trigger detection (the valid edge of the TI0n pin input is detected or the TS0n bit of the master channel is set to 1), and the counter starts counting down. When the count value reaches TCR0n = 0000H, the INTTM0n output is generated, and the counter stops until the next start trigger detection. The slave channel, triggered by INTTM0n of the master channel, loads the value of the TDR0p register to the TCR0p register, and the counter starts counting down. The output level of TO0p becomes active one count clock after generation of INTTM0n from the master channel. It becomes inactive when TCR0p = 0000H, and the counting operation is stopped. After that, the above operation is repeated. | | | • | Operation<br>stop | The TT0n (master) and TT0p (slave) bits are set to 1 at the same time. The TT0n and TT0p bits automatically return to 0 because they are trigger bits. | TE0n, TE0p = 0, and count operation stops. The TCR0n and TCR0p registers hold count value and stop. The TO0p output is not initialized but holds current status. | | | | | The TOE0p bit of slave channel is cleared to 0 and value is set to the TO0p bit. | The TO0p pin outputs the TO0p set level. | | | | TAU<br>stop | To hold the TO0p pin output level Clears the TO0p bit to 0 after the value to be held is set to the port register. When holding the TO0p pin output level is not necessary Setting not required. | The TO0p pin output level is held by port function. | | | | | The TAU0EN bit of the PER0 register is cleared to 0. | Power-off status All circuits are initialized and SFR of each channel is also initialized. (The TO0p bit is cleared to 0 and the TO0p pin is set to port mode.) | | **Remark** n: Channel number (n = 0, 2, 4, 6) #### 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 TDR0n (master) + 1} $\times$ Count clock period Duty factor [%] = {Set value of TDR0p (slave)}/{Set value of TDR0n (master) + 1} × 100 Set value of TDR0p (slave) = 0000H 100% output: Set value of TDR0p (slave) ≥ {Set value of TDR0n (master) + 1} Remark Although the duty factor exceeds 100% if the set value of TDR0p (slave) > (set value of TDR0n (master) + 1), it summarizes to 100% output. The master channel operates in the interval timer mode. If the channel start trigger bit (TS0n) of timer channel start register 0 (TS0) is set to 1, an interrupt (INTTM0n) is output, the value set to timer data register 0n (TDR0n) is loaded to timer count register 0n (TCR0n), and the counter counts down in synchronization with the count clock. When the counter reaches 0000H, INTTM0n is output, the value of the TDR0n register is loaded again to the TCR0n register, and the counter counts down. This operation is repeated until the channel stop trigger bit (TT0n) of timer channel stop register 0 (TT0) 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 (TO0p) cycle. The slave channel operates in one-count mode. By using INTTM0n from the master channel as a start trigger, the TCR0p register loads the value of the TDR0p register and the counter counts down to 0000H. When the counter reaches 0000H, it outputs INTTM0p and waits until the next start trigger (INTTM0n 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 (TO0p) duty. PWM output (TO0p) goes to the active level one clock after the master channel generates INTTM0n and goes to the inactive level when the TCR0p register of the slave channel becomes 0000H. Caution To rewrite both timer data register 0n (TDR0n) of the master channel and the TDR0p register of the slave channel, a write access is necessary two times. The timing at which the values of the TDR0n and TDR0p registers are loaded to the TCR0n and TCR0p registers is upon occurrence of INTTM0n of the master channel. Thus, when rewriting is performed split before and after occurrence of INTTM0n of the master channel, the TO0p pin cannot output the expected waveform. To rewrite both the TDR0n register of the master and the TDR0p register of the slave, therefore, be sure to rewrite both the registers immediately after INTTM0n is generated from the master channel. **Remark** n: Channel number (n = 0, 2, 4, 6) Figure 6-67. Block Diagram of Operation as PWM Function Remark n: Channel number (n = 0, 2, 4, 6) Figure 6-68. Example of Basic Timing of Operation as PWM Function **Remarks 1.** n: Channel number (n = 0, 2, 4, 6) p: Slave channel number (n \leq 7) **2.** TS0n, TS0p: Bit n, p of timer channel start register 0 (TS0) TE0n, TE0p: Bit n, p of timer channel enable status register 0 (TE0) TCR0n, TCR0p: Timer count registers mn, mp (TCR0n, TCR0p) TDR0n, TDR0p: Timer data registers mn, mp (TDR0n, TDR0p) TO0n, TO0p: TO0n and TO0p pins output signal (a) Timer mode register 0n (TMR0n) 2 0 14 10 9 8 6 5 3 15 13 12 MAS TMR0n CKS0n KS0n0 CCS0n STS0n2 STS0n1 STS0n0 CIS0n1 CIS0n0 MD0n3 MD0n2 MD0n1 MD0n0 TER0n 0 1/0 0 0 0 0 0 0 0 0 0 1 1 Operation mode of channel n 000B: Interval timer Setting of operation when counting is started 1: Generates INTTM0n when counting is started. Selection of TI0n pin input edge 00B: Sets 00B because these are not used. Start trigger selection 000B: Selects only software start. Setting of the MASTER0n bit (channels 2, 4, 6) 1: Master channel. Count clock selection 0: Selects operation clock (fmck). Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel n. Figure 6-69. Example of Set Contents of Registers When PWM Function (Master Channel) Is Used # (b) Timer output register 0 (TO0) 0: Outputs 0 from TO0n. # (c) Timer output enable register 0 (TOE0) TOE0 Bit n TOE0n 0 0: Stops the TO0n output operation by counting operation. 10B: Selects CK01 as operation clock of channel n. #### (d) Timer output level register 0 (TOL0) TOL0 Bit n TOL0n 0 0: Cleared to 0 when TOM0n = 0 (master channel output mode). # (e) Timer output mode register 0 (TOM0) TOM0 TOM0n 0 0: Sets master channel output mode. Note TMR02, TMR04, TMR06: MASTER0n = 1 TMR00: Fixed to 0 Remark n: Channel number (n = 0, 2, 4, 6) (a) Timer mode register 0p (TMR0p) 10 15 14 13 12 0 TMR0p CKS0p1 CKS0p0 CCS0p M/S STS0p2 STS0p1 CIS0p1 MD0p3 MD0p0 STS0p0 CIS0p0 MD0p2 MD0p1 1/0 0 0 O 0 0 0 0 0 0 0 0 1 Operation mode of channel p 100B: One-count mode Start trigger during operation 1: Trigger input is valid. Selection of TI0p pin input edge 00B: Sets 00B because these are not used. Start trigger selection 100B: Selects INTTM0n of master channel. Setting of MASTER0n bit (channels 2, 4, 6) 0: Slave channel Setting of SPLIT0p bit (channels 1, 3) 0: 16-bit timer Count clock selection 0: Selects operation clock (fmck). Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel p. 10B: Selects CK01 as operation clock of channel p. \* Make the same setting as master channel. (b) Timer output register 0 (TO0) Bit p TO0 TO0p 0: Outputs 0 from TO0p. 1/0 1: Outputs 1 from TO0p. (c) Timer output enable register 0 (TOE0) Bit p TOE0 TOE0p 0: Stops the TO0p output operation by counting operation. 1/0 1: Enables the TO0p output operation by counting operation. Figure 6-70. Example of Set Contents of Registers When PWM Function (Slave Channel) Is Used #### (d) Timer output level register 0 (TOL0) Bit p TOL0 TOL0p 1/0 0: Positive logic output (active-high) 1: Negative logic output (active-low) # (e) Timer output mode register 0 (TOM0) Bit p TOM<sub>0</sub> TOM0p 1: Sets the slave channel output mode. Note TMR02, TMR04, TMR06: MASTER0n = 1 TMR01, TMR03: SPLIT0p bit TMR05, TMR07: 0 fixed **Remark** n: Channel number (n = 0, 2, 4, 6) Figure 6-71. Operation Procedure When PWM Function Is Used (1/2) | | Software Operation | Hardware Status | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------| | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | Sets the TAU0EN bit of peripheral enable register 0 (PER0) to 1. | Power-on status. Each channel stops operating. | | | (FENO) to 1. | (Clock supply is started and writing to each register is enabled.) | | | Sets timer clock select register 0 (TPS0). Determines clock frequencies of CK00 and CK01. | | | Channel<br>default<br>setting | Sets timer mode registers mn, mp (TMR0n, TMR0p) of two channels to be used (determines operation mode of channels). An interval (period) value is set to timer data register 0n (TDR0n) of the master channel, and a duty factor is set to the TDR0p register of the slave channel. | Channel stops operating. (Clock is supplied and some power is consumed.) | | | Sets slave channel. The TOM0p bit of timer output mode register 0 (TOM0) is set to 1 (slave channel output mode). Sets the TOL0p bit. Sets the TO0p bit and determines default level of the | The TO0p pin goes into Hi-Z output state. | | | TO0p output. | The TO0p default setting level is output when the port mode register is in output mode and the port register is 0. | | | · · · · · · · · · · · · · · · · · · · | TO0p does not change because channel stops operating. The TO0p pin outputs the TO0p set level. | - Remark n: Channel number (n = 0, 2, 4, 6) - p: Slave channel number (n \leq 7) Operation is resume Figure 6-71. Operation Procedure When PWM Function Is Used (2/2) | | Software Operation | Hardware Status | | | |---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Operation<br>start | Sets the TOE0p bit (slave) to 1 (only when operation is resumed). The TS0n (master) and TS0p (slave) bits of timer channel start register 0 (TS0) are set to 1 at the same time. The TS0n and TS0p bits automatically return to 0 because they are trigger bits. | TE0n = 1, TE0p = 1 ➤ When the master channel starts counting, INTTM0n is generated. Triggered by this interrupt, the slave channel also starts counting. | | | | During<br>operation | Set values of the TMR0n and TMR0p registers, TOM0n, TOM0p, TOL0n, and TOL0p bits cannot be changed. Set values of the TDR0n and TDR0p registers can be changed after INTTM0n of the master channel is generated. The TCR0n and TCR0p registers can always be read. The TSR0n and TSR0p registers are not used. | The counter of the master channel loads the TDR0n register value to timer count register 0n (TCR0n), and counts down. When the count value reaches TCR0n = 0000H, INTTM0n output is generated. At the same time, the value of the TDR0n register is loaded to the TCR0n register, and the counter starts counting down again. At the slave channel, the value of the TDR0p register is loaded to the TCR0p register, triggered by INTTM0n of the master channel, and the counter starts counting down. The output level of TO0p becomes active one count clock after generation of the INTTM0n output from the master channel. It becomes inactive when TCR0p = 0000H, and the counting operation is stopped. | | | | Operation<br>stop | The TT0n and TT0p bits automatically return to 0 because they are trigger bits. The TOE0p bit of slave channel is cleared to 0 and value | TE0n, TE0p = 0, and count operation stops. The TCR0n and TCR0p registers hold count value and stop. The TO0p output is not initialized but holds current status. | | | | TAU<br>stop | is set to the TO0p bit. To hold the TO0p pin output level Clears the TO0p bit to 0 after the value to be held is set to the port register. When holding the TO0p pin output level is not necessary Setting not required. | The TO0p pin outputs the TO0p set level. The TO0p pin output level is held by port function. | | | | | The TAU0EN bit of the PER0 register is cleared to 0. | Power-off status All circuits are initialized and SFR of each channel is also initialized. (The TO0p bit is cleared to 0 and the TO0p pin is set to port mode.) | | | **Remark** n: Channel number (n = 0, 2, 4, 6) #### 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 TDR0n (master) + 1} × Count clock period Duty factor 1 [%] = {Set value of TDR0p (slave 1)}/{Set value of TDR0n (master) + 1} × 100 Duty factor 2 [%] = {Set value of TDR0q (slave 2)}/{Set value of TDR0n (master) + 1} × 100 ``` Remark Although the duty factor exceeds 100% if the set value of TDR0p (slave 1) > {set value of TDR0n (master) + 1} or if the {set value of TDR0q (slave 2)} > {set value of TDR0n (master) + 1}, it is summarized into 100% output. Timer count register 0n (TCR0n) of the master channel operates in the interval timer mode and counts the periods. The TCR0p register of the slave channel 1 operates in one-count mode, counts the duty factor, and outputs a PWM waveform from the TO0p pin. The TCR0p register loads the value of timer data register 0p (TDR0p), using INTTM0n of the master channel as a start trigger, and starts counting down. When TCR0p = 0000H, TCR0p outputs INTTM0p and stops counting until the next start trigger (INTTM0n of the master channel) has been input. The output level of TO0p becomes active one count clock after generation of INTTM0n from the master channel, and inactive when TCR0p = 0000H. In the same way as the TCR0p register of the slave channel 1, the TCR0q register of the slave channel 2 operates in one-count mode, counts the duty factor, and outputs a PWM waveform from the TO0g pin. The TCR0g register loads the value of the TDR0q register, using INTTM0n of the master channel as a start trigger, and starts counting down. When TCR0q = 0000H, the TCR0q register outputs INTTM0q and stops counting until the next start trigger (INTTM0n of the master channel) has been input. The output level of TO0g becomes active one count clock after generation of INTTM0n from the master channel, and inactive when TCR0q = 0000H. When channel 0 is used as the master channel as above, up to seven types of PWM signals can be output at the same time. Caution To rewrite both timer data register 0n (TDR0n) of the master channel and the TDR0p register of the slave channel 1, write access is necessary at least twice. Since the values of the TDR0n and TDR0p registers are loaded to the TCR0n and TCR0p registers after INTTM0n is generated from the master channel, if rewriting is performed separately before and after generation of INTTM0n from the master channel, the TO0p pin cannot output the expected waveform. To rewrite both the TDR0n register of the master and the TDR0p register of the slave, be sure to rewrite both the registers immediately after INTTM0n is generated from the master channel (This applies also to the TDR0g register of the slave channel 2). **Remark** n: Channel number (n = 0, 2, 4) p: Slave channel number 1, q: Slave channel number 2 n (Where p and q are consecutive integers greater than n) Master channel (interval timer mode) selection CK01 Operation clock Timer counter Clock register 0n (TCR0n) CKOO rigger selection Timer data Interrupt Interrupt signal TS0n register 0n (TDR0n) controller (INTTMOn) Slave channel 1 (one-count mode) selection CK01 Operation clock Timer counter Output Clock ·O TO0p pin CK00 register 0p (TCR0p) controller rigger selection Timer data Interrupt Interrupt signal register 0p (TDR0p) controller (INTTM0p) Slave channel 2 (one-count mode) selection CK01 Operation clock Timer counter Output -⊚TO0q pin Clock register 0q (TCR0q) CK00 controller selection Timer data Interrupt Interrupt signal register 0q (TDR0q) **Trigger**: controller (INTTM0q) Figure 6-72. Block Diagram of Operation as Multiple PWM Output Function (output two types of PWMs) Remark n: Channel number (n = 0, 2, 4) p: Slave channel number 1, q: Slave channel number 2 n (Where p and q are consecutive integers greater than n) Figure 6-73. Example of Basic Timing of Operation as Multiple PWM Output Function (Output two types of PWMs) (1/2) Remarks 1. n: Channel number (n = 0, 2, 4) p: Slave channel number 1, q: Slave channel number 2 n (Where p and q are consecutive integers greater than n) **2.** TS0n, TS0p, TS0q: Bit n, p, q of timer channel start register 0 (TS0) TE0n, TE0p, TE0q: Bit n, p, q of timer channel enable status register 0 (TE0) TCR0n, TCR0p, TCR0q: Timer count registers mn, mp, mq (TCR0n, TCR0p, TCR0q) TDR0n, TDR0p, TDR0q: Timer data registers mn, mp, mq (TDR0n, TDR0p, TDR0q) TO0n, TO0p, TO0q: TO0n, TO0p, and TO0q pins output signal Figure 6-74. Example of Set Contents of Registers When Multiple PWM Output Function (Master Channel) Is Used # (b) Timer output register 0 (TO0) TO0 TO0n 0 0: Outputs 0 from TO0n. #### (c) Timer output enable register 0 (TOE0) TOE0 Bit n TOE0n 0 0: Stops the TO0n output operation by counting operation. ### (d) Timer output level register 0 (TOL0) TOL0 Bit n TOLon 0 0: Cleared to 0 when TOM0n = 0 (master channel output mode). #### (e) Timer output mode register 0 (TOM0) TOM0 Bit n TOM0n 0 0: Sets master channel output mode. Note TMR02, TMR04, TMR06: MASTER0n = 1 TMR00: Fixed to 0 **Remark** n: Channel number (n = 0, 2, 4) (a) Timer mode register 0p, mq (TMR0p, TMR0q) 15 14 13 12 10 6 0 TMR0p CKS0p1 CKS0p0 CCS0p M/S STS0p2 STS0p1 STS0p0 CIS0p1 CIS0p0 MD0p3 MD0p2 MD0p1 MD0p0 1/0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 15 14 13 12 10 9 8 7 6 5 4 3 2 0 11 TMR0q STS0q2 STS0q1 CKS0a1 CKS0a0 CCS0c M/S STS0a0 CIS0a1 CIS0q0 MD0q3 MD0a2 MD0q1 MD0q0 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 TI0p and TI0q pins input edge 00B: Sets 00B because these are not used. Start trigger selection 100B: Selects INTTM0n of master channel. Setting of MASTERmn bit (Channel 2, 4, 6) 0: Independent channel operation. Setting of SPLITmn bit (Channel 1, 3) 0: 16-bit timer Count clock selection 0: Selects operation clock (fmck). Operation clock (fmck) selection 00B: Selects CK00 as operation clock of channel p, q. Figure 6-75. Example of Set Contents of Registers When Multiple PWM Output Function (Slave Channel) Is Used (output two types of PWMs) #### (b) Timer output register 0 (TO0) TO0 Bit q Bit p TO0q TO0p 1/0 1/0 0: Outputs 0 from TO0p or TO0q. 10B: Selects CK01 as operation clock of channel p, q. \* Make the same setting as master channel. 1: Outputs 1 from TO0p or TO0q. # (c) Timer output enable register 0 (TOE0) TOE0 TOE | Bit q | Bit p | |-------|-------| | TOE0q | TOE0p | | 1/0 | 1/0 | - 0: Stops the TO0p or TO0q output operation by counting operation. - 1: Enables the TO0p or TO0q output operation by counting operation. # (d) Timer output level register 0 (TOL0) TOL0 | Bit q | Bit p | |-------|-------| | TOL0q | TOL0p | | 1/0 | 1/0 | - 0: Positive logic output (active-high) - 1: Negative logic output (active-low) # (e) Timer output mode register 0 (TOM0) ТОМО | Bit q | Bit p | |-------|-------| | TOM0q | ТОМ0р | | 1 | 1 | 1: Sets the slave channel output mode. Note TMR02, TMR04, TMR06: MASTER0n bit TMR01, TMR03: SPLIT0n bit TMR05. TMR07: 0 fixed **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0, 2, 4) p: Slave channel number 1, q: Slave channel number 2 n (Where p and q are consecutive integers greater than n) Figure 6-76. Operation Procedure When Multiple PWM Output Function Is Used (1/2) | | Software Operation | Hardware Status | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------| | TAU<br>default<br>setting | | Power-off status (Clock supply is stopped and writing to each register is disabled.) | | | Sets the TAU0EN 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 0 (TPS0). Determines clock frequencies of CK00 and CK01. | | | Channel<br>default<br>setting | Sets timer mode registers mn, mp, 0q (TMR0n, TMR0p, TMR0q) of each channel to be used (determines operation mode of channels). An interval (period) value is set to timer data register 0n (TDR0n) of the master channel, and a duty factor is set to the TDR0p and TDR0q registers of the slave channels. | Channel stops operating. (Clock is supplied and some power is consumed.) | | | Sets slave channels. The TOM0p and TOM0q bits of timer output mode register 0 (TOM0) are set to 1 (slave channel output mode). Sets the TOL0p and TOL0q bits. Sets the TO0p and TO0q bits and determines default level of the TO0p and TO0q outputs. | The TO0p and TO0q pins go into Hi-Z output state. The TO0p and TO0q default setting levels are output when | | | | the port mode register is in output mode and the port register is 0. | | | Sets the TOE0p and TOE0q bits to 1 and enables operation of TO0p and TO0q. | TO0p and TO0q do not change because channels stop operating. | | | Clears the port register and port mode register to 0. | The TO0p and TO0q pins output the TO0p and TO0q set levels. | - **Remark** n: Channel number (n = 0, 2, 4) - p: Slave channel number 1, q: Slave channel number 2 n (Where p and q are a consecutive integer greater than n) Figure 6-77. Operation Procedure When Multiple PWM Output Function Is Used (2/2) | | | Software Operation | Hardware Status | | | |-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | Operation<br>start | (Sets the TOE0p and TOE0q (slave) bits to 1 only when resuming operation.) The TS0n bit (master), and TS0p and TS0q (slave) bits of timer channel start register 0 (TS0) are set to 1 at the same time. The TS0n, TS0p, and TS0q bits automatically return to 0 because they are trigger bits. | TE0n = 1, TE0p, TE0q = 1 When the master channel starts counting, INTTM0n is generated. Triggered by this interrupt, the slave channel also starts counting. | | | | Operation is resumed. | During operation Set values of the TMR0n, TMR0p, TMR0q registers TOM0n, TOM0p, TOM0q, TOL0n, TOL0p, and TOL bits cannot be changed. Set values of the TDR0n, TDR0p, and TDR0q regist can be changed after INTTM0n of the master chanred generated. The TCR0n, TCR0p, and TCR0q registers can alwaread. The TSR0n, TSR0p, and TSR0q registers are not under the total content of conte | | The counter of the master channel loads the TDR0n register value to timer count register 0n (TCR0n) and counts down. When the count value reaches TCR0n = 0000H, INTTM0n output is generated. At the same time, the value of the TDR0n register is loaded to the TCR0n register, and the counter starts counting down again. At the slave channel 1, the values of the TDR0p register are transferred to the TCR0p register, triggered by INTTM0n of the master channel, and the counter starts counting down. The output levels of TO0p become active one count clock after generation of the INTTM0n output from the master channel. It becomes inactive when TCR0p = 0000H, and the counting operation is stopped. At the slave channel 2, the values of the TDR0q register are transferred to TCR0q register, triggered by INTTM0n of the master channel, and the counter starts counting down. The output levels of TO0q become active one count clock after generation of the INTTM0n output from the master channel. It becomes inactive when TCR0q = 0000H, and the counting operation is stopped. After that, the above operation is repeated. | | | | | Operation<br>stop | The TT0n bit (master), TT0p, and TT0q (slave) bits are set to 1 at the same time. The TT0n, TT0p, and TT0q bits automatically return to 0 because they are trigger bits. | TE0n, TE0p, TE0q = 0, and count operation stops. The TCR0n, TCR0p, and TCR0q registers hold count value and stop. The TO0p and TO0q output are not initialized but hold current status. | | | | | | The TOE0p and TOE0q bits of slave channels are cleared to 0 and value is set to the TO0p and TO0q bits. → | The TO0p and TO0q pins output the TO0p and TO0q set levels. | | | | | TAU<br>stop | To hold the TO0p and TO0q pin output levels Clears the TO0p and TO0q bits to 0 after the value to be held is set to the port register. When holding the TO0p and TO0q pin output levels are not necessary Setting not required | The TO0p and TO0q pin output levels are held by port function. | | | | | | | Power-off status All circuits are initialized and SFR of each channel is also initialized. (The TO0p and TO0q bits are cleared to 0 and the TO0p and TO0q pins are set to port mode.) | | | **Remark** n: Channel number (n = 0, 2, 4) p: Slave channel number 1, q: Slave channel number 2 n (Where p and q are a consecutive integer greater than n) # 6.10 Cautions When Using Timer Array Unit # 6.10.1 Cautions When Using Timer output Pins may be assigned multiplexed timer output and other alternate functions. If you intend to use a timer output in such a case, set the outputs from all other multiplexed pin functions to their initial values. 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. Table 7-1. Configuration of 12-bit Interval Timer | Item | Configuration | | |-------------------------------------------------------|----------------------------------------|--| | Counter | 12-bit counter | | | Control registers Peripheral enable register 0 (PER0) | | | | Operation speed mode control register (OSMC) | | | | | Interval timer control register (ITMC) | | Figure 7-1. Block Diagram 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 0 (PER0) - Operation speed mode control register (OSMC) - Interval timer control register (ITMC) #### 7.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 the hardware that is not used is also stopped so as to decrease the power consumption and noise. When using the 12-bit interval timer, be sure to set bit 7 (TMKAEN) to 1 at first. 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 7-2. Format of Peripheral Enable Register 0 (PER0) | TMKAEN | Control of clock supply for 12-bit interval timer | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0 | Stops clock supply. SFR used by the 12-bit interval timer cannot be written. The 12-bit interval timer is in the reset status. | | | | | 1 | Enables clock supply. • SFR used by the 12-bit interval timer can be read and written. | | | | Note Provided only in 30-pin products. - Cautions 1. When using the 12-bit interval timer, be sure to first set the TMKAEN bit to 1 after starting supply of the low-speed on-chip oscillator clock (WUTMMCK0 = 1) and then set the interval timer control register (ITMC). If TMKAEN bit = 0, writing to the registers controlling the 12-bit interval timer is ignored, and, even if the register is read, only the default value is read (except the operation speed mode control register (OSMC)). - 2. Be sure to clear the following bits to 0. 20- or 24-pin products: Bits 1, 3, and 6 30-pin products: Bits 1 and 6 #### 7.3.2 Operation speed mode control register (OSMC) The WUTMMCK0 bit can be used to control supply of the 12-bit interval timer operation clock. The OSMC register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 7-3. Format of Operation Speed 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 | Supply of operation clock for 12-bit interval timer | | |----------|-----------------------------------------------------|--| | 0 | Clock supply stop. | | | 1 | Low-speed on-chip oscillator clock (fill) supply | | #### 7.3.3 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-4. Format of Interval Timer Control Register (ITMC) | Address: FFF90H After reset: 0FFFH | | 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) | | | 1 | Count operation started | | | Specification of the 12-bit interval timer compare value | |----------------------------------------------------------------------------------| | These bits generate an interrupt at the fixed cycle (count clock cycles x (ITCMP | | setting + 1)). | | | | | | | | | Example interrupt cycles when 001H or FFFH is specified for ITCMP11 to ITCMP0 - ITCMP11 to ITCMP0 = 001H, count clock: when $f_{IL}$ = 15 kHz 1/15 [kHz] $\times$ (1 + 1) $\div$ 0.1333 [ms] = 133.3 [ $\mu$ s] - ITCMP11 to ITCMP0 = FFFH, count clock: when $f_{IL}$ = 15 kHz 1/15 [kHz] × (4095 + 1) ÷ 273 [ms] - **Cautions 1.** When RINTE bit is changed from 0 to 1, set WUTMMCK0 bit of OSMC register to 1 before the change so that the operation clock is established. - 2. Before changing the RINTE bit from 1 to 0, use the interrupt mask flag register to disable the INTIT interrupt servicing. When operation starts (0 to 1) again, clear the TMKAIF flag, and then enable the interrupt servicing. - 3. The value read from the RINTE bit is applied one count clock cycle after setting the RINTE bit. - **4.** 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. - 5. 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 shown in Figure 7-5. Figure 7-5. 12-bit Interval Timer Operation Timing (ITCMP11 to ITCMP0 = 0FFH, count clock: $f_{1L}$ = 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-6). - 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-6). Figure 7-6. Procedure of entering to HALT or STOP mode after setting RINTE to 1 #### CHAPTER 8 CLOCK OUTPUT/BUZZER OUTPUT CONTROLLER The number of output pins of the clock output and buzzer output controllers differs, depending on the product. | Output pin | 20- and 24-pin | 30-pin | |------------|----------------|--------| | PCLBUZ0 | V | V | | PCLBUZ1 | - | V | **Caution** Most of the following descriptions in this chapter use the 30-pin as an example. # 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. One pin can be used to output a clock or buzzer sound. The PCLBUZn 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, 1 Figure 8-1. Block Diagram of Clock Output/Buzzer Output Controller Note For output frequencies available from PCLBUZ0 and PCLBUZ1, refer to 28.4 or 29.4 AC Characteristics. PCLBUZ1 output function is available only in 30-pin products. # 8.2 Configuration of Clock Output/Buzzer Output Controller The clock output/buzzer output controller includes the following hardware. Table 8-1. Configuration of Clock Output/Buzzer Output Controller | Item | Configuration | | | | |-------------------|---------------------------------------|--|--|--| | Control registers | Clock output select register n (CKSn) | | | | | | Port mode register 1, 3 (PM1, PM3) | | | | | | Port register 1, 3 (P1, P3) | | | | # 8.3 Registers Controlling Clock Output/Buzzer Output Controller The following registers are used to control the clock output/buzzer output controller. - Clock output select register n (CKSn) - Port mode register 1, 3 (PM1, PM3) - Port register 1, 3 (P1, P3) # 8.3.1 Clock output select register n (CKSn) These registers set output enable/disable for clock output or for the buzzer frequency output pin (PCLBUZn), and set the output clock. Select the clock to be output from the PCLBUZn 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. Figure 8-2. Format of Clock Output Select Register n (CKSn) Address: FFFA5H (CKS0), FFFA6 (CKS1) Note 1 After reset: 00H R/W Symbol <7> 6 5 4 3 2 1 0 CKSn PCLOEn 0 0 0 CCSn2 CCSn1 CCSn0 | PCLOEn | PCLBUZn pin output enable/disable specification | |--------|-------------------------------------------------| | 0 | Output disable (default) | | 1 | Output enable | | CCSn2 | CCSn1 | CCSn0 | PCLBUZn pin output clock selection | | | | | | |-------|-------|-------|------------------------------------|-------------|--------------------------|--------------------------|--------------------------------------|--------------------------------------| | | | | | fmain (MHz) | | | | | | | | | | 5 | 10 | 16 | 20 | 24 | | 0 | 0 | 0 | fmain | 5 MHz | 10 MHz <sup>Note 2</sup> | 16 MHz <sup>Note 2</sup> | Setting prohibited <sup>Note 2</sup> | Setting prohibited <sup>Note 2</sup> | | 0 | 0 | 1 | fmain/2 | 2.5 MHz | 5 MHz | 8 MHz <sup>Note 2</sup> | 10 MHz Note 2 | 12 MHz Note 2 | | 0 | 1 | 0 | fmain/2 <sup>2</sup> | 1.25 MHz | 2.5 MHz | 4 MHz | 5 MHz | 6 MHz | | 0 | 1 | 1 | fmain/2 <sup>3</sup> | 625 kHz | 1.25 MHz | 2 MHz | 2.5 MHz | 3 MHz | | 1 | 0 | 0 | fmain/2 <sup>4</sup> | 313 kHz | 625 kHz | 1 MHz | 1.25 MHz | 1.5 MHz | | 1 | 0 | 1 | fmain/2 <sup>11</sup> | 2.44 kHz | 4.88 kHz | 7.81 kHz | 9.77 kHz | 11.7 kHz | | 1 | 1 | 0 | fmain/2 <sup>12</sup> | 1.22 kHz | 2.44 kHz | 3.91 kHz | 4.88 kHz | 5.86 kHz | | 1 | 1 | 1 | fmain/2 <sup>13</sup> | 610 Hz | 1.22 kHz | 1.95 kHz | 2.44 kHz | 2.93 kHz | Notes 1. 30-pin products only. 2. Use the output clock within a range of 16 MHz. For detail, refer to 28.4 or 29.4 AC characteristics. **Cautions 1.** Change the output clock after disabling clock output (PCLOEn = 0). **2.** To shift to STOP mode, set PCLOEn = 0 before executing the STOP instruction. **Remarks 1.** n = 0, 1 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 (P10/PCLBUZ0 (20- and 24-pin products), P15/PCLBUZ1, P31/PCLBUZ0 (30-pin products)) for clock or buzzer output, requires setting the corresponding bits in the port mode register (PMxx) and port register (Pxx) to 0. Example: When P15/PCLBUZ1 is to be used for clock or buzzer output Set the PM15 bit of port mode register 1 to 0. Set the P15 bit of port register 1 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). The PCLBUZ1 pin outputs a clock/buzzer selected by the clock output select register 1 (CKS1). #### 8.4.1 Operation as output pin The PCLBUZn pin is output as the following procedure. - <1> Set 0 in the bit of the port mode register (PMxx) and port register (Px) which correspond to the port which has a pin used as the PCLBUZn pin. - <2> Select the output frequency with bits 0 to 2 (CCSn0 to CCSn2) of the clock output select register (CKSn) of the PCLBUZn pin (output in disabled). - <3> Set bit 7 (PCLOEn) of the CKSn register to 1 to enable clock/buzzer output. - Remarks 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. - **2.** n = 0 or 1 Figure 8-3. Timing of Outputting Clock from PCLBUZn Pin # 8.5 Cautions of Clock Output/Buzzer Output Controller If STOP mode is entered within 1.5 clock cycles output from the PCLBUZn pin after the output is disabled (PCLOEn = 0), the PCLBUZn 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 18 RESET FUNCTION**. When 75%+1/2f<sub>IL</sub> 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. Table 9-2. Setting of Option Bytes and Watchdog Timer | 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 23 OPTION BYTE. Figure 9-1. Block Diagram of Watchdog Timer 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: I | FFFABH | After reset: 9A | AH/1AH <sup>Note</sup> | 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 | - **Cautions 1.** If a value other than "ACH" is written to the WDTE register, an internal reset signal is generated. - **2.** If a 1-bit memory manipulation instruction is executed for the WDTE register, an internal reset signal is generated. - **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 23**). | 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 23). - 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 23). - 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 - **Cautions 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. - 2. After "ACH" is written to the WDTE register, an error of up to 2 clocks (f<sub>IL</sub>) may occur before the watchdog timer is cleared. - 3. The watchdog timer can be cleared immediately before the count value overflows. (Cautions 4 is listed on the next page.) **Cautions 4.** The operation of the watchdog timer in the HALT, STOP, and SNOOZE 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. Table 9-3. Setting of Overflow Time of Watchdog Timer | WDCS2 | WDCS1 | WDCS0 | Overflow Time of Watchdog Timer | |-------|-------|-------|-----------------------------------------------| | | | | (fiL = 17.25 kHz (MAX.)) | | 0 | 0 | 0 | 2 <sup>6</sup> /fi∟ (3.71 ms) | | 0 | 0 | 1 | 2 <sup>7</sup> /fı∟ (7.42 ms) | | 0 | 1 | 0 | 2 <sup>8</sup> /fı∟ (14.84 ms) | | 0 | 1 | 1 | 2 <sup>9</sup> /fı∟ (29.68 ms) | | 1 | 0 | 0 | 2 <sup>11</sup> /fi∟ (118.72 ms) | | 1 | 0 | 1 | 2 <sup>13</sup> /f <sub>IL</sub> (474.89 ms) | | 1 | 1 | 0 | 2 <sup>14</sup> /f <sub>IL</sub> (949.79 ms) | | 1 | 1 | 1 | 2 <sup>16</sup> /f <sub>IL</sub> (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. Table 9-4. Setting Window Open Period of Watchdog Timer | WINDOW1 | WINDOW0 | Window Open Period of Watchdog Timer | |---------|---------|--------------------------------------| | 0 | 0 | Setting prohibited | | 0 | 1 | 50% | | 1 | 0 | 75% | | 1 | 1 | 100% | Caution 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^{9}/f_{IL}$ , 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^{9}/f_{IL}$ (MAX.) = $2^{9}/17.25$ kHz (MAX.) = 29.68 ms - Window close time: 0 to $2^9/f_{IL}$ (MIN.) × (1 - 0.5) = 0 to $2^9/12.75$ kHz × 0.5 = 0 to 20.08 ms - Window open time: $2^9/f_{1L}$ (MIN.) × (1 – 0.5) to $2^9/f_{1L}$ (MAX.) = $2^9/12.75$ kHz × 0.5 to $2^9/17.25$ kHz = 20.08 to 29.68 ms #### 9.4.4 Setting watchdog timer interval interrupt Depending on the setting of bit 7 (WDTINT) of an option byte (000C0H), an interval interrupt (INTWDTI) can be generated when 75% + 1/2 f<sub>L</sub> of the overflow time is reached. Table 9-5. Setting of Watchdog Timer Interval Interrupt | WDTINT | Use of Watchdog Timer Interval Interrupt | | |--------|---------------------------------------------------------------------------------|--| | 0 | Interval interrupt is used. | | | 1 | Interval interrupt is generated when 75% + 1/2 fı∟ 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 differs depending on the product. | | 20- and 24-pin | 30-pin | |-----------------------|-------------------------------|--------------------------------| | Analog input channels | 11 ch | 8 ch | | | (ANI0 to ANI3, ANI6 to ANI22) | (ANI0 to ANI3, ANI16 to ANI19) | #### 10.1 Function of A/D Converter The A/D converter converts analog input signals into digital values, and is configured to control analog inputs, including up to 11 channels of A/D converter analog inputs (ANI0 to ANI3 and ANI16 to ANI22). 10-bit or 8-bit resolution can be selected by using 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 ANI3 and ANI16 to ANI22 (ANI0 to ANI3 and ANI16 to ANI19 for 30-pin products). 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 system is off and in the conversion standby state, and conversion is then started automatically after the A/D power supply stabilization wait time passes. Select hardware trigger wait mode when using the SNOOZE mode function. | | Channel | Select mode | A/D conversion is performed on the analog input of one channel. | | selection mode | Scan mode | A/D conversion is performed on the analog input of four channels in order. ANI0 to ANI3 can be selected as analog input. | | Conversion | One-shot conversion mode | A/D conversion is performed on the selected channel once. | | operation mode | Sequential conversion mode | A/D conversion is sequentially performed on the selected channels until it is stopped by software. | | Operation | Normal 1 or normal 2 mode | Conversion is done in the operation voltage range of 2.7 V $\leq$ VDD $\leq$ 5.5 V. | | voltage mode | Low-voltage 1 or low-voltage 2 mode | Conversion is done in the operation voltage range of 1.8 V $\leq$ VDD $\leq$ 5.5 V. | | | | Select this mode for conversion at a low voltage. Because the operation voltage is low, it is internally boosted during conversion. | | Sapling time selection | Sampling clock cycles: 7 fab | The sampling time in normal 1 or low-voltage 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 a longer sampling time is required. | | | Sampling clock cycles: 5 fab | The sampling time in normal 2 or low-voltage 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). | Note Provided only in 20- or 24-pin products. # 10.2 Configuration of A/D Converter The A/D converter includes the following hardware. #### (1) ANI0 to ANI3 and ANI16 to ANI22 pins These are the analog input pins of the 11 channels of the A/D converter (for 30-pin products, these are analog input pins of the 8 channels of ANI0 to ANI3 and ANI16 to ANI19 pins). 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. **Remark** AV<sub>REF</sub>: The + side reference voltage of the A/D converter. This can be selected from AV<sub>REFP</sub>, the internal reference voltage (1.45 V), and V<sub>DD</sub>. # (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. #### (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 the A/D converter mode register 2 (ADM2) to 0 and 1, respectively. The analog signals input to ANI3 to ANI10 and ANI16 to ANI22 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) - A/D port configuration register (ADPC) - Port mode control registers 0, 1, 4, 12, 14 (PMC0, PMC1, PMC4, PMC12, PMC14) - Port mode registers 0, 1, 2, 4, 12, 14 (PM0, PM1, PM2, PM4, PM12, PM14) #### 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: 00H R/W <7> Symbol <5> <4> <3> <2> <0> 1 PER0 **TMKAEN** 0 **ADCEN** IICA0EN SAU1EN<sup>Note</sup> SAU0EN 0 TAU0EN | ADCEN | Control of clock supply to the A/D converter | |-------|----------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by the A/D converter cannot be written. • The A/D converter is in the reset status. | | 1 | Enables clock supply. • SFR used by the A/D converter can be read/written. | Note 30-pin products only. - Cautions 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, 1, 2, 4, 12, and 14 (PM0, PM1, PM2, PM4, PM12, and PM14), port mode control registers 0, 1, 4, 12, and 14 (PMC0, PMC1, PMC4, PMC12, and PMC14), and A/D port configuration register (ADPC)). - · 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). - 2. Be sure to clear the following bits to 0. 20- or 24-pin products: Bits 1, 3, and 6 30-pin products: Bits 1 and 6 #### 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: | 00H R/W | | | | | | |----------|--------|--------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------| | Symbol | <7> | 6 | 5 | 4 | 3 | 2 | 1 | <0> | | ADM0 | ADCS | ADMD | FR2 <sup>Note 1</sup> | FR1 <sup>Note 1</sup> | FR0 <sup>Note 1</sup> | LV1 <sup>Note 1</sup> | LV0 <sup>Note 1</sup> | ADCE | | ADCS | A/D conversion operation control | |------|-------------------------------------------------------------------------------------| | 0 | Stops conversion operation | | | [When read] | | | Conversion stopped/standby status | | 1 | Enables conversion operation | | | [When read] | | | While in the software trigger mode: Conversion operation status | | | While in the hardware trigger wait mode: A/D power supply stabilization wait status | | | + conversion operation status | | ADMD | Specification of the A/D conversion channel selection mode | |------|------------------------------------------------------------| | 0 | Select mode | | 1 | Scan mode | | ADCE | A/D voltage comparator operation control <sup>Note 2</sup> | |------|------------------------------------------------------------| | 0 | Stops A/D voltage comparator operation | | 1 | Enables A/D voltage comparator operation | - Notes 1. For details of the FR2 to FR0, LV1, LV0 bits, and A/D conversion, see **Table 10-3 A/D**Conversion Time Selection. - 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 $\mu$ s from the start of operation for the operation to stabilize. Therefore, when the ADCS bit is set to 1 after 1 $\mu$ 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. - **Cautions 1.** Change the ADMD, FR2 to FR0, LV1 and LV0 bits while conversion is stopped (ADCS = 0, ADCE = 0). - 2. The setting combination of the ADCS bit to 1 and the ADCE bit to 0 is prohibited. - 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 10.7 A/D Converter Setup Flowchart. Table 10-1. Settings of ADCS and ADCE Bits | 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-2. Setting and Clearing Conditions for ADCS Bit | | A/D Conversio | n Mode | Set Conditions | Clear Conditions | | | |-----------------------------|---------------|----------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------|--|--| | Software trigger | Select mode | Sequential conversion mode | When 1 is written to ADCS | 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 A/D conversion ends.</li> </ul> | | | | | Scan mode | Sequential conversion mode | | When 0 is written to ADCS | | | | | | One-shot conversion mode | | When 0 is written to ADCS The bit is automatically cleared to 0 when conversion ends on the specified four channels. | | | | Hardware<br>trigger no-wait | Select mode | Sequential conversion mode | | When 0 is written to ADCS | | | | 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<br>trigger wait | Select mode | Sequential conversion mode | When a hardware trigger | When 0 is written to ADCS | | | | mode | | One-shot conversion mode | is input | When 0 is written to ADCS The bit is automatically cleared to 0 when A/D conversion ends. | | | | | Scan mode | Sequential conversion mode | | When 0 is written to ADCS | | | | | | One-shot conversion mode | | When 0 is written to ADCS The bit is automatically cleared to 0 when conversion ends on the specified four channels. | | | Figure 10-4. Timing Chart When A/D Voltage Comparator Is Used - **Notes 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 $\mu$ s or longer to stabilize the internal circuit. - 2. In starting conversion, the longer will take up to following time | | ADM0 | | Conversion | Conversion Start Time ( | (Number of fclk Clock) | |-----|------|-----|-------------|---------------------------------------------------------|----------------------------| | FR2 | FR1 | FR0 | Clock (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 | | 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. - **Cautions 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. - 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. - **3.** Only rewrite the value of the ADCE bit when ADCS = 0 (while in the conversion stopped/conversion standby status). - 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 + 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 ### Table 10-3. A/D Conversion Time Selection (1/4) # (1) When there is no A/D power supply stabilization wait time Normal mode 1 or 2 (software trigger mode/hardware trigger no-wait mode) | A/ | D Cor | nverte | er Mo | de | Mode | Conversion | Number of | Conversion | | Conv | ersion Tim | e at 10-Bit F | Resolution | | |-----|----------------------------|-----------------|-------|-----|-------------|-------------|------------------------|-----------------|--------------------|--------------------|--------------------|--------------------|-------------------|--------------------| | R | legiste | er 0 ( <i>F</i> | ADMC | )) | | Clock (fad) | Conversion Clock Note | Time | | | 2.7 V ≤ | ≤ VDD ≤ 5.5 \ | / | | | FR2 | FR1 | FR0 | LV1 | LV0 | | | Clock | | fclk=<br>1 MHz | fclk=<br>2 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 | 19 fad<br>(number of | 1216/fськ | Setting prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 76 <i>μ</i> s | 50.67 μs | | 0 | 0 | 1 | | | | fcьк/32 | sampling | 608/fclk | | | | 76 <i>μ</i> s | 38 <i>μ</i> s | 25.33 <i>μ</i> s | | 0 | 1 | 0 | | | | fclk/16 | clock: 7 fad) | 304/fclk | | | 76 <i>μ</i> s | 38 <i>μ</i> s | 19 <i>μ</i> s | 12.67 <i>μ</i> s | | 0 | 1 | 1 | | | | fclk/8 | | 152/fclk | | 76 <i>μ</i> s | 38 <i>μ</i> s | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 6.33 <i>μ</i> s | | 1 | 0 | 0 | | | | fclk/6 | | 114/fclk | | 57 <i>μ</i> s | 28.5 <i>μ</i> s | 14.25 <i>μ</i> s | 7.125 <i>μ</i> s | 4.75 <i>μ</i> s | | 1 | 0 | 1 | | | | fclk/5 | | 95/fclk | 95 μs | 47.5 μs | 23.75 μs | 11.875 <i>μ</i> s | 5.938 μs | 3.96 <i>μ</i> s | | 1 | 1 | 0 | | | | fclk/4 | | 76/fclk | 76 <i>μ</i> s | 38 μs | 19 <i>μ</i> s | 9.5 μs | 4.75 μs | 3.17 <i>μ</i> s | | 1 | 1 | 1 | | | | fclk/2 | | <b>38/f</b> cLK | 38 μs | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 4.75 <i>μ</i> s | 2.375 µs | Setting prohibited | | 0 | 0 | 0 | 0 | 1 | Normal<br>2 | fclk/64 | 17 fab<br>(number of | 1088/fcLK | Setting prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 68 <i>μ</i> s | 45.33 μs | | 0 | 0 | 1 | | | | fclk/32 | sampling | 544/fclk | | | | 68 μs | 34 <i>μ</i> s | 22.67 μs | | 0 | 1 | 0 | | | | fclk/16 | clock: 5 fad) | 272/fclk | | | 68 μs | 34 μs | 17 <i>μ</i> s | 11.33 <i>μ</i> s | | 0 | 1 | 1 | | | | fclk/8 | | 136/fclk | | 68 μs | 34 <i>μ</i> s | 17 <i>μ</i> s | 8.5 <i>μ</i> s | 5.67 <i>μ</i> s | | 1 | 0 | 0 | | | | fclk/6 | | 102/fclk | | 51 <i>μ</i> s | 25.5 <i>μ</i> s | 12.75 <i>μ</i> s | 6.375 μs | 4.25 <i>μ</i> s | | 1 | 0 | 1 | | | | fclk/5 | <u> </u> | 85/fclk | 85 <i>μ</i> s | 42.5 μs | 21.25 µs | 10.625 <i>μ</i> s | 5.3125 <i>μ</i> s | 3.54 <i>μ</i> s | | 1 | 1 | 0 | | | | fclk/4 | | 68/fclk | 68 μs | 34 <i>μ</i> s | 17 <i>μ</i> s | 8.5 <i>μ</i> s | 4.25 <i>μ</i> s | 2.83 µs | | 1 | 1 | 1 | | | | fcLk/2 | | 34/fськ | 34 μs | 17 <i>μ</i> s | 8.5 μs | 4.25 μs | 2.125 μs | Setting prohibited | | | Other than the above – – – | | | | | | | | | rohibited | | | | | **Note** 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 (f<sub>AD</sub>). **Cautions 1.** The A/D conversion time must be within the range of conversion times (tconv) described in 28.6.1 A/D converter characteristics or 29.6.1 A/D converter characteristics. - 2. When rewriting the FR2 to FR0, LV1, and LV0 bits to other than the current data, stop A/D conversion once (ADCS = 0, ADCE = 0) beforehand. - **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. ### Table 10-3. A/D Conversion Time Selection (2/4) # (2) When there is no A/D power supply stabilization wait time Low-voltage mode 1 or 2(software trigger mode/hardware trigger no-wait mode) | A/ | D Coi | nverte | er Mo | de | Mode | Conversion | Number of | Conversion | | Conv | ersion Tim | e at 10-Bit R | Resolution | | |-----|-------------------|--------|-------|------|----------------|-------------|----------------------|-----------------|--------------------|--------------------|--------------------|--------------------|------------------|--------------------| | R | Register 0 (ADM0) | | | | | Clock (fab) | Conversion | Time | | 1.8 V ≤ \ | VDD ≤ 5.5 \ | V | Note 1 | Note 2 | | FR2 | FR1 | FR0 | LV1 | LV0 | | | Clock Note 3 | | fclk= | fclk = 2 MHz | fcLk =<br>4 MHz | fcLk =<br>8 MHz | fclk=<br>16 MHz | fcLK = 24 MHz | | 0 | 0 | 0 | 1 | 0 | Low<br>voltage | fclk/64 | 19 fad<br>(number of | 1216/fськ | Setting prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 76 <i>μ</i> s | 50.67 μs | | 0 | 0 | 1 | | | 1 | fclk/32 | sampling | 608/fclk | | | | 76 <i>μ</i> s | 38 <i>μ</i> s | 25.33 <i>μ</i> s | | 0 | 1 | 0 | | | | fclk/16 | clock : 7 fab) | 304/fclk | | | 76 <i>μ</i> s | 38 <i>μ</i> s | 19 <i>μ</i> s | 12.67 <i>μ</i> s | | 0 | 1 | 1 | | | | fclk/8 | | 152/fclk | | 76 <i>μ</i> s | 38 μs | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 6.33 <i>μ</i> s | | 1 | 0 | 0 | | | | fclk/6 | | 114/fclk | | 57 <i>μ</i> s | 28.5 <i>μ</i> s | 14.25 µs | 7.125 <i>µ</i> s | 4.75 <i>μ</i> s | | 1 | 0 | 1 | | | | fclk/5 | | 95/fськ | 95 μs | 47.5 μs | 23.75 μs | 11.875 <i>μ</i> s | 5.938 μs | 3.96 <i>μ</i> s | | 1 | 1 | 0 | | | | fclk/4 | | 76/fcLK | 76 <i>μ</i> s | 38 <i>μ</i> s | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 4.75 μs | 3.17 <i>μ</i> s | | 1 | 1 | 1 | | | | fclk/2 | | 38/fськ | 38 <i>μ</i> s | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 4.75 <i>μ</i> s | 2.375 µs | Setting prohibited | | 0 | 0 | 0 | 1 | 1 | Low<br>voltage | fcьк/64 | 17 fad<br>(number of | 1088/fcLK | Setting prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 68 μs | 45.33 μs | | 0 | 0 | 1 | | | 2 | fclk/32 | sampling | 544/fclk | | | | 68 <i>μ</i> s | 34 <i>μ</i> s | 22.667 μs | | 0 | 1 | 0 | | | | fclk/16 | clock : 5 fad) | 272/fclk | | | 68 μs | 34 <i>μ</i> s | 17 <i>μ</i> s | 11.333 μs | | 0 | 1 | 1 | | | | fclk/8 | | 136/fськ | | 68 μs | 34 <i>μ</i> s | 17 <i>μ</i> s | 8.5 <i>μ</i> s | 5.667 μs | | 1 | 0 | 0 | | | | fclk/6 | | 102/fclk | | 51 <i>μ</i> s | 25.5 <i>μ</i> s | 12.75 µs | 6.375 <i>μ</i> s | 4.25 <i>μ</i> s | | 1 | 0 | 1 | | | | fclk/5 | | <b>85/f</b> ськ | 85 <i>μ</i> s | 42.5 μs | 21.25 μs | 10.625 μs | 5.313 <i>μ</i> s | 3.542 <i>μ</i> s | | 1 | 1 | 0 | | | | fclk/4 | | 68/fclk | 68 <i>μ</i> s | 34 <i>μ</i> s | 17 <i>μ</i> s | 8.5 μs | 4.25 <i>μ</i> s | 2.833 μs | | 1 | 1 | 1 | | | | fclk/2 | | <b>34/f</b> cLK | 34 <i>μ</i> s | 17 <i>μ</i> s | 8.5 μs | 4.25 µs | 2.125 <i>µ</i> s | Setting prohibited | | | Oth | er tha | n the | abov | е | = | = | - | Setting p | rohibited | | | | | **Notes 1.** $2.4 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}$ - **2.** $2.7 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}$ - **3.** 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 (f<sub>AD</sub>). - **Cautions 1.** The A/D conversion time must be within the range of conversion times (tconv) described in 28.6.1 A/D converter characteristics or 29.6.1 A/D converter characteristics. - 2. When rewriting the FR2 to FR0, LV1, and LV0 bits to other than the current data, stop A/D conversion once (ADCS = 0, ADCE = 0) beforehand. - **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. #### Table 10-3. A/D Conversion Time Selection (3/4) # (3) When there is A/D power supply stabilization wait time Normal mode 1 or 2 (hardware trigger wait mode Note1) | A/ | | | | | Mode | Conversion | Number of | | A/D Power | A/D Po | wer Supply | Stabilization | n Wait Time | + Conversi | on Time | |-----|----------------------|-----|-----|-----|------------------|------------|---------------------------------------|-----------------------------|-------------------------------------------|-----------------------|--------------------|--------------------|--------------------|-------------------|--------------------| | R | (fap) | | | | onversion Supply | | $2.7~V \leq V_{DD} \leq 5.5~V$ | | | | | | | | | | FR2 | FR1 | FR0 | LV1 | LV0 | | (fad) | Supply<br>Stabilization<br>Wait Clock | tabilization \ /ait Clock ( | Stabilization Wait Time + Conversion Time | fcLk =<br>1 MHz | fclk=<br>2 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<br>prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 108 <i>μ</i> s | 72 <i>μ</i> s | | 0 | 0 | 1 | | | | fclk/32 | | | 864/fclk | | | | 108 <i>μ</i> s | 54 <i>μ</i> s | 36 <i>μ</i> s | | 0 | 1 | 0 | | | | fcLк/16 | | clock : 7 fad) | 432/fcLK | | | 108 <i>μ</i> s | 54 <i>μ</i> s | 27 <i>μ</i> s | 18 <i>μ</i> s | | 0 | 1 | 1 | | | | fclk/8 | | | 216/fcьк | | 108 <i>μ</i> s | 54 <i>μ</i> s | 27 <i>μ</i> s | 13.5 <i>μ</i> s | 9 <i>μ</i> s | | 1 | 0 | 0 | | | | fclk/6 | | | 162/fcLK | | 81 <i>μ</i> s | 40.5 <i>μ</i> s | 20.25 <i>μ</i> s | 10.125 <i>μ</i> s | 6.75 <i>μ</i> s | | 1 | 0 | 1 | | | | fclk/5 | | | 135/fськ | 135 <i>μ</i> s | 67.5 <i>μ</i> s | 33.75 <i>μ</i> s | 16.875 <i>μ</i> s | 8.438 <i>μ</i> s | 5.625 <i>μ</i> s | | 1 | 1 | 0 | | | | fclk/4 | | | 108/fclk | 108 <i>μ</i> s | 54 <i>μ</i> s | 27 <i>μ</i> s | 13.5 <i>μ</i> s | 6.75 <i>μ</i> s | 4.5 <i>μ</i> s | | 1 | 1 | 1 | | | | fclk/2 | | | <b>54/f</b> ськ | 54 <i>μ</i> s | 27 <i>μ</i> s | 13.5 <i>μ</i> s | 6.75 <i>μ</i> s | 3.375 <i>μ</i> s | Setting prohibited | | 0 | 0 | 0 | 0 | 1 | Normal<br>2 | fclk/64 | | 17 fad<br>(number of | 1600/fcLK | Setting prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 100 <i>μ</i> s | 66.67 <i>μ</i> s | | 0 | 0 | 1 | | | | fclk/32 | | sampling | 800/fclk | | | | 100 <i>μ</i> s | 50 <i>μ</i> s | 33.33 <i>μ</i> s | | 0 | 1 | 0 | | | | fclk/16 | | clock : 5 | 400/fcLK | | | 100 <i>μ</i> s | 50 <i>μ</i> s | 25 <i>μ</i> s | 16.67 <i>μ</i> s | | 0 | 1 | 1 | | | | fclk/8 | | fAD) | 200/fcLK | | 100 <i>μ</i> s | 50 <i>μ</i> s | 25 <i>μ</i> s | 12.5 <i>μ</i> s | 8.33 <i>µ</i> s | | 1 | 0 | 0 | | | | fclk/6 | | | 150/fcLK | | 75 <i>μ</i> s | 37.5 <i>μ</i> s | 18.75 <i>μ</i> s | 9.375 <i>μ</i> s | 6.25 <i>μ</i> s | | 1 | 0 | 1 | | | | fclk/5 | | | 125/fclк | 125 <i>μ</i> s | 62.5 <i>μ</i> s | 31.25 <i>μ</i> s | 15.625 <i>μ</i> s | 7.8125 <i>μ</i> s | 5.21 <i>μ</i> s | | 1 | 1 | 0 | | | | fclk/4 | | | 100/fcLK | 100 <i>μ</i> s | 50 <i>μ</i> s | 25 <i>μ</i> s | 12.5 <i>μ</i> s | 6.25 <i>μ</i> s | 4.17 <i>μ</i> s | | 1 | 1 | 1 | | | | fclk/2 | | | 50/fcLK | 50 <i>μ</i> s | 25 <i>μ</i> s | 12.5 <i>μ</i> s | 6.25 <i>μ</i> s | 3.125 <i>µ</i> s | Setting prohibited | | | Other than the above | | | | | - | = | = | = | Setting pro | hibited | | | | | - **Notes 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 10-3 (1/4)**). - 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). - **Cautions 1.** The A/D conversion time must be within the range of conversion times (tconv) indicated in 28.6.1 A/D converter characteristics. Note that the conversion time (tconv) does not include the A/D power supply stabilization wait time. - 2. When rewriting the FR2 to FR0, LV1, and LV0 bits to other than the current data, stop A/D conversion once (ADCS = 0, ADCE = 0) beforehand. - **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. - **4.** While in the hardware trigger wait mode, the conversion time includes the A/D power supply stabilization wait time after the hardware trigger is detected. #### Table 10-3. A/D Conversion Time Selection (4/4) # (4) When there is A/D power supply stabilization wait time Low-voltage mode 1 or 2 (hardware trigger wait mode Note 1) | | A/D Converter Mode Mode Register 0 (ADM0) | | | | | | | Number of | A/D Power | A/D Po | wer Suppl | y Stabilizati | on Wait Tim | e + Convers | ion Time | |-----|-------------------------------------------|--------|--------|-----|----------------|----------------|-----------------------------|------------------------------------------|----------------------------------------------------|--------------------|--------------------|--------------------|--------------------|------------------|--------------------| | R | legiste | er 0 ( | ADM | 0) | | Clock<br>(fad) | A/D Power<br>Supply | A/D Power Conversion Supply Clock Note 4 | | | 1.8 V ≤ 1 | $V_{DD} \le 5.5 V$ | | Note 2 | Note 3 | | FR2 | FR1 | FR0 | LV1 | LV0 | | (IAD) | Stabilization<br>Wait Clock | | Stabilization<br>Wait Time +<br>Conversion<br>Time | fcLK=<br>1 MHz | fcLK = 2 MHz | fcLK =<br>4 MHz | fclk=<br>8 MHz | fclk =<br>16 MHz | fcLK =<br>24 MHz | | 0 | 0 | 0 | 1 | 0 | Low<br>voltage | fclk/64 | 2 fad | 19 fad<br>(number of | 1344/fськ | Setting prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 84 <i>μ</i> s | 56 <i>μ</i> s | | 0 | 0 | 1 | | | 1 | fclk/32 | | sampling | 672/fclk | | | | 84 <i>μ</i> s | 42 μs | 28 <i>μ</i> s | | 0 | 1 | 0 | | | | fcьк/16 | | clock :7 | 336/fclk | | | 84 <i>μ</i> s | 42 μs | 21 μs | 14 <i>μ</i> s | | 0 | 1 | 1 | | | | fclk/8 | | fAD) | 168/fclk | | 84 <i>μ</i> s | 42 <i>μ</i> s | 21 <i>μ</i> s | 10.5 <i>μ</i> s | 7 <i>μ</i> s | | 1 | 0 | 0 | | | | fclk/6 | | | <b>126/f</b> ськ | | 63 <i>μ</i> s | 31.25 <i>μ</i> s | 15.75 <i>μ</i> s | 7.875 <i>μ</i> s | 5.25 μs | | 1 | 0 | 1 | | | | fclk/5 | | | 105/fclk | 105 <i>μ</i> s | 52.5 <i>μ</i> s | 26.25 μs | 13.125 <i>µ</i> s | 6.563 <i>μ</i> s | 4.38 μs | | 1 | 1 | 0 | | | | fclk/4 | | | 84/fclk | 84 <i>μ</i> s | 42 <i>μ</i> s | 21 <i>μ</i> s | 10.5 <i>μ</i> s | 5.25 μs | 3.5 μs | | 1 | 1 | 1 | | | | fclk/2 | | | 42/fcLK | 42 <i>μ</i> s | 21 <i>μ</i> s | 10.5 <i>μ</i> s | 5.25 μs | 2.625 μs | Setting prohibited | | 0 | 0 | 0 | 1 | 1 | Low<br>voltage | fclk/64 | | 17 fAD<br>(number of | 1216/fclк | Setting prohibited | Setting prohibited | Setting prohibited | Setting prohibited | 76 <i>µ</i> s | 50.67 μs | | 0 | 0 | 1 | | | 2 | fclk/32 | | sampling | 608/fclk | | | | 76 <i>μ</i> s | 38 <i>μ</i> s | 25.33 <i>μ</i> s | | 0 | 1 | 0 | | | | fclk/16 | | clock :5 | 304/fclk | | | 76 <i>μ</i> s | 38 μs | 19 <i>μ</i> s | 12.67 <i>μ</i> s | | 0 | 1 | 1 | | | | fclk/8 | | fAD) | <b>152/f</b> ськ | | 76 <i>μ</i> s | 38 <i>μ</i> s | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 6.33 μs | | 1 | 0 | 0 | | | | fclk/6 | | | 114/fськ | | 57 <i>μ</i> s | 28.5 <i>μ</i> s | 14.25 <i>μ</i> s | 7.125 <i>μ</i> s | 4.75 <i>μ</i> s | | 1 | 0 | 1 | | | | fclk/5 | | | 95/fclk | 95 <i>μ</i> s | 47.5 <i>μ</i> s | 23.75 μs | 11.875 <i>μ</i> s | 5.938 <i>μ</i> s | 3.96 <i>μ</i> s | | 1 | 1 | 0 | | | | fclk/4 | | | <b>76/f</b> ськ | 76 <i>μ</i> s | 38 <i>μ</i> s | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 4.75 <i>μ</i> s | 3.17 <i>μ</i> s | | 1 | 1 | 1 | | | | fclk/2 | | | 38/fськ | 38 <i>μ</i> s | 19 <i>μ</i> s | 9.5 <i>μ</i> s | 4.75 <i>μ</i> s | 2.375 μs | Setting prohibited | | | Oth | er tha | an the | abo | ve | = | = | = | = | Setting p | rohibited | | | | | - **Notes 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 10-3 (2/4)**). - **2.** $2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}.$ - 3. $2.7 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}.$ - **4.** 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). - Cautions 1. The A/D conversion time must be within the range of conversion times (tconv) described in 28.6.1 A/D converter characteristics. Note that the conversion time (tconv) does not include the A/D power supply stabilization wait time. - 2. When rewriting the FR2 to FR0, LV1 and LV0 bits to other than the current data, stop A/D conversion once conversion (ADCS = 0, ADCE = 0) beforehand. - **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. - **4.** While in the hardware trigger wait mode, the conversion time includes the A/D power supply stabilization wait time after the hardware trigger is detected. Conversion time ADCS Sampling timing INTAD Conversion Sampling Successive conversion Sampling Successive conversion Conversion time Conversion start time 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: 00H | R/W | | | | | | |-----------------|--------|------------------|-------|---|---|---|--------|--------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADM1 | ADTMD1 | ADTMD0 | ADCSM | 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 | Count completion of timer channel 01 or capture completion interrupt signal (INTTM01) | | | | | | | 1 | 1 | 12-bit interval timer interrupt signal (INTIT) | | | | | | | Other than above | | Setting prohibited | | | | | | Cautions 1. Only rewrite the value of the ADM1 register while conversion is stopped (ADCS = 0, ADCE = 0). 2. To complete A/D conversion, specify at least the following values 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 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 folk cycles after the first INTIT is input. Remarks 1. x: don't care #### 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 of 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: 00H R/W Symbol 6 5 4 <3> <2> <0> ADM2 ADREFP1 ADREFP0 **ADREFM** 0 **ADRCK AWC** 0 **ADTYP** | ADREFP1 | ADREFP0 | Selection of the + side reference voltage of the A/D converter | | | | |---------|---------|----------------------------------------------------------------|--|--|--| | 0 | 0 | Supplied from VDD | | | | | 0 | 1 | Supplied from P20/AV <sub>REFP</sub> /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. After wait of (5), start A/D conversion When ADREFP1 and ADREFP0 are set to 1 and 0, respectively, A/D conversion cannot be performed on the temperature sensor output voltage and internal reference voltage (1.45 V). Be sure to perform A/D conversion while ADISS = 0. | ĺ | ADREFM | Selection of the – side reference voltage of the A/D converter | |---|--------|----------------------------------------------------------------| | ĺ | 0 | Supplied from Vss | | ĺ | 1 | Supplied from P21/AVREFM/ANI1 | Note This setting can be used only in HS (high-speed main) mode. Cautions 1. Only rewrite the value of the ADM2 register while conversion is stopped (ADCS = 0, ADCE = 0). - 2. Do not set the ADREFP1 bit to 1 when shifting to STOP mode. If the internal reference voltage (ADREFP1, ADREFP0 = 1, 0) is selected, the A/D converter reference voltage current (IADREF) indicated in 28.3.2 or 29.3.2 Supply current characteristics will be added. - **3.** When using AV<sub>REFP</sub> and AV<sub>REFM</sub>, specify ANI0 and ANI1 as the analog input channels and specify input mode by using the port mode register. Figure 10-7. Format of A/D Converter Mode Register 2 (ADM2) (2/2) Address: F0010H After reset: 00H Symbol 6 5 <2> <0> <3> 1 ADM2 ADREFP1 ADREFP0 **ADREFM** ADRCK **AWC** 0 ADTYP | ADRCK | Checking the upper limit and lower limit conversion result values | | | | | | | |----------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | The interrupt signal (INTAD) is output when the ADLL register ≤ the ADCR register ≤ the ADUL register (AREA1). | | | | | | | | 1 | The interrupt signal (INTAD) is output when the ADCR register < the ADLL register (AREA2) or the ADUL register < the ADCR register (AREA3). | | | | | | | | Figure 10-8 sh | Figure 10-8 shows the generation range of the interrupt signal (INTAD) for AREA 1 to AREA 3. | | | | | | | | | AWC | Specification 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 be specified only 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. - Using the SNOOZE mode function in the software trigger mode or hardware trigger no-wait mode is prohibited. - Using the SNOOZE mode function in the sequential conversion mode is prohibited. - Even when using the SNOOZE mode, be sure to set the AWC bit to 0 in the normal operation and change it to 1 just before shifting to the STOP mode. Also, be sure to change the AWC bit to 0 after returning from the STOP mode to normal operation. 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. | ADTYP | Selection of the A/D conversion resolution | |-------|--------------------------------------------| | 0 | 10-bit resolution | | 1 | 8-bit resolution | Note Refer to "Transition time from STOP mode to SNOOZE mode" in 17.3.3 SNOOZE mode. **Caution** Only rewrite the value of the ADM2 register while conversion is stopped (ADCS = 0, ADCE = 0). Figure 10-8. ADRCK Bit Interrupt Signal Generation Range **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<sup>Note</sup>. The ADCR register can be read by a 16-bit memory manipulation instruction. Address: FFF1FH, FFF1EH After reset: 0000H 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 ADUL/ADLL registers; see Figure 10-8), the result is not stored. Figure 10-9. Format of 10-bit A/D Conversion Result Register (ADCR) - **Cautions 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 (bits 7 and 6 of the ADCR register). - 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 of the ADCR register. #### 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 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 ADUL/ADLL registers; see Figure 10-8), the result is not stored. Figure 10-10. Format of 8-bit A/D Conversion Result Register (ADCRH) | Address: FFF1FH | | After reset: | 00H R | | | | | | |-----------------|---|--------------|-------|---|---|---|---|---| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCRH | | | | | | | | | Caution When writing to the A/D converter mode register 0 (ADM0), analog input channel specification register (ADS), and A/D port configuration register (ADPC), the contents of the ADCRH register may become undefined. Read the conversion result following conversion completion before writing to the ADM0, ADS, and ADPC registers. 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-11. Format of Analog Input Channel Specification Register (ADS) | Address: FFF31H | | After reset: 00H | 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) (20- or 24-pin products) | ADISS | ADS4 | ADS3 | ADS2 | ADS1 | ADS0 | Analog input 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 | 1 | 0 | 0 | 0 | 0 | ANI16 | P10/ANI16 pin | | 0 | 1 | 0 | 0 | 0 | 1 | ANI17 | P11/ANI17 pin | | 0 | 1 | 0 | 0 | 1 | 0 | ANI18 | P12/ANI18 pin | | 0 | 1 | 0 | 0 | 1 | 1 | ANI19 | P13/ANI19 pin | | 0 | 1 | 0 | 1 | 0 | 0 | ANI20 | P14/ANI20 pin | | 0 | 1 | 0 | 1 | 0 | 1 | ANI21 | P42/ANI21 pin | | 0 | 1 | 0 | 1 | 1 | 0 | ANI22 | P41/ANI22 pin | | 1 | 0 | 0 | 0 | 0 | 0 | - | Temperature sensor output | | 1 | 0 | 0 | 0 | 0 | 1 | = | Internal reference voltage output (1.45 V) Note | | | | Other than | the above | | | Setting prohib | ited | Note This setting can be used only in HS (high-speed main) mode. O Select mode (ADMD = 0) (30-pin products) | ADISS | ADS4 | ADS3 | ADS2 | ADS1 | ADS0 | Analog input 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 | 1 | 0 | 0 | 0 | 0 | ANI16 | P01/ANI16 pin | | | 0 | 1 | 0 | 0 | 0 | 1 | ANI17 | P00/ANI17 pin | | | 0 | 1 | 0 | 0 | 1 | 0 | ANI18 | P147/ANI18 pin | | | 0 | 1 | 0 | 0 | 1 | 1 | ANI19 | P120/ANI19 pin | | | 1 | 0 | 0 | 0 | 0 | 0 | _ | Temperature sensor output | | | 1 | 0 | 0 | 0 | 0 | 1 | = | Internal reference voltage output (1.45 V) Note | | | Other than the above | | | | | Setting prohibited | | | | Note This setting can be used only in HS (high-speed main) mode. O Scan mode (ADMD = 1) | ADS4 | ADS3 | ADS2 | ADS1 | ADS0 | Analog input channel | | | | | |----------------------|------|------|------|------|----------------------|--------------------|--------|--------|--| | | | | | | Scan 0 | Scan 1 | Scan 2 | Scan 3 | | | 0 | 0 | 0 | 0 | 0 | ANI0 | ANI1 | ANI2 | ANI3 | | | 0 | 0 | 0 | 0 | 1 | ANI1 | ANI2 | ANI3 | - | | | 0 | 0 | 0 | 1 | 0 | ANI2 | ANI3 | - | - | | | 0 | 0 | 0 | 1 | 1 | ANI3 | - | _ | - | | | Other than the above | | | | | | Setting prohibited | | | | **Remark** –: Ignore the conversion result because it is undefined. #### Cautions 1. Be sure to clear bits 5 and 6 to 0. - 2. Set a channel to be set the analog input by ADPC and PMCx registers in the input mode by using port mode registers 0, 1, 2, 4, 12, or 14 (PM0, PM1, PM2, PM4 PM12, PM14). - **3.** Do not set the pin that is set by the A/D port configuration register (ADPC) as digital I/O by the ADS register. - **4.** Do not set the pin that is set by port mode control registers 0, 1, 4, 12, 14 (PMC0, PMC1, PMC4, PMC12, PMC14) as digital I/O by the ADS register. - **5.** Only rewrite the value of the ADISS bit while A/D conversion comparator operation is stopped(ADCS = 0, ADCE = 0) - **6.** If using AV<sub>REFP</sub> as the + side reference voltage of the A/D converter, do not select ANI0 as an A/D conversion channel. - 7. If using AVREFM as the side reference voltage of the A/D converter, do not select ANI1 as an A/D conversion channel. - 8. If the ADISS bit is set to 1, the internal reference voltage (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 details about the setting flow, see 10.7.4 Setup when temperature sensor output voltage/internal reference voltage is selected. - 9. Do not set the ADISS bit to 1 when shifting to the STOP mode or HALT mode. If the ADISS bit is set to 1, the A/D converter reference voltage current (IADREF) indicated in 28.3.2 or 29.3.2 Supply current characteristics will be added. #### 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. Figure 10-12. Format of Conversion Result Comparison Upper Limit Setting Register (ADUL) | Address: F0011H After reset: FFH 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-13. Format of Conversion Result Comparison Lower Limit Setting Register (ADLL) - Cautions 1. When 10-bit resolution A/D conversion is selected, the higher 8 bits of the 10-bit A/D conversion result register (ADCR) are compared with the value in the ADUL and ADLL registers. - 2.Only rewrite the values of the ADUL and ADLL registers while conversion is stopped (ADCS = 0, ADCE = 0). - 3. The value of the ADUL register 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 or - side reference voltage of the A/D converter, an analog input channel (ANIxx), the temperature sensor output voltage, and the internal reference voltage (1.45 V) as the target for A/D conversion. For details, see **21.3.7 A/D test function**. When using this register to test the A/D 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 is set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 10-14. Format of A/D Test Register (ADTES) Address: F0013H After reset: 00H R/W Symbol 7 6 5 4 3 2 1 0 ADTES 0 0 0 0 0 ADTES1 ADTES0 | ADTES1 | ADTES0 | A/D conversion target | |----------------------|--------|----------------------------------------------------------------------------------------------| | 0 | 0 | ANIxx/temperature sensor output voltage Note/internal reference voltage (1.45 V) | | | | (This is specified using the analog input channel specification register (ADS).) | | 1 | 0 | The - side reference voltage (selected by the ADREFM bit of the ADM2 register) | | 1 | 1 | The + side reference voltage (selected by the ADREFP1 and ADREFP0 bits of the ADM2 register) | | Other than the above | | Setting prohibited | **Note** The temperature sensor output voltage and internal reference voltage (1.45 V) can be selected only in HS (high-speed main) mode. #### 10.3.11 Registers controlling port function of analog input pins Set up the port mode registers (PMxx), port mode control registers (PMCxx), and A/D port configuration register (ADPC), which are used for controlling the functions of the ports shared with the analog input pins of the A/D converter. For details, see 4.3.1 Port mode registers (PMxx), 4.3.6 Port mode control registers (PMCxx), and 4.3.7 A/D port configuration register. When using the ANI0 to ANI3 pins for analog input of the A/D converter, set the port mode register (PMxx) bit corresponding to each port to 1, and specify analog input by using the A/D port configuration register (ADPC). When using the ANI16 to ANI22 pins for analog input of the A/D converter, set the port mode register (PMxx) bit and the port mode control register (PMCxx) bit 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 Note 1. At the same time, the A/D conversion end interrupt request (INTAD) can also be generated Note 1. - <8> Repeat steps <1> to <7>, until the ADCS bit is cleared to 0 Note 2. To stop the A/D converter, clear the ADCS bit to 0. - **Notes 1.** If the A/D conversion result is outside the A/D conversion result range specified by the ADRCK bit and the ADUL and ADLL registers (see **Figure 10-8**), the A/D conversion result interrupt request signal is not generated and no A/D conversion results are stored in the ADCR and ADCRH registers. - 2. 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. - Remarks 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 - 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 VDD. Figure 10-15. 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. If the analog input channel specification register (ADS) is overwritten during A/D conversion operation, the current conversion is interrupted, and A/D conversion of the analog input specified by the ADS register is performed. 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 ANI3, ANI16 to ANI22) 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 $$\left(\frac{V_{AIN}}{AV_{REF}} \times 1024 + 0.5\right)$$ ADCR = SAR × 64 or $$\big(\frac{ADCR}{64} - 0.5\big) \times \frac{AV_{REF}}{1024} \leq V_{AIN} < \big(\frac{ADCR}{64} + 0.5\big) \times \frac{AV_{REF}}{1024}$$ where, INT(): Function which returns integer part of value in parentheses Analog input voltage VAIN: AVREF: AVREF pin voltage ADCR: A/D conversion result register (ADCR) value SAR: Successive approximation register Figure 10-16 shows the relationship between the analog input voltage and the A/D conversion result. Figure 10-16. Relationship Between Analog Input Voltage and A/D Conversion Result A/D conversion result Input voltage/AV<sub>REF</sub> 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-17. Example of Software Trigger Mode (Select Mode, Sequential Conversion Mode) Operation Timing #### 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-18. Example of Software Trigger Mode (Select Mode, One-Shot Conversion Mode) Operation Timing #### 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. <1> ADCE is set to 1. ADCE is cleared to 0.<8> ADCS is cleared <7> ADCE ADCS is overwritten <2>ADCS is set to 1 while in the A hardware trigger is <6> The trigge with 1 during A/D to 0 during A/D generated (and ignored). The trigger conversion standby status. conversion operation conversion operation. owledge ADCS <5> ADS is rewritten during A/D conversion operation ANIO to ANI3 ANI1 to ANI3 ADS Conversion is interrupted and re <3> Conversion is interrupted and restarts <3> A/D Stop Data: Stop Data ( Data 0 (ANI0) Data 1 (ANI1) Data 0 (ANI0) Data 0 Data 1 (ANIO) (ANI1) Data 1 (ANI1) Data 1 (ANI1) conversion (ANI1) (ANI2) (ANI3) (ANI1 (ANI2 (ANI3 (ANI2 (ANI3) status ADCR Data 0 (ANI0) Data 2 (ANI2) Data 1 (ANI1) Data 0 (ANIO) ADCRE INTAD The interrupt is generated four times. The interrupt is generated four times Figure 10-19. Example of Software Trigger Mode (Scan Mode, Sequential Conversion Mode) Operation Timing The interrupt is generated four times #### 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-20. 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 power down 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-21. 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 power down 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-22. 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 power down 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-23. 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 power down 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 (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-25. 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 ADMO 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-26. 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-27. 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-28. 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-29. 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 and ADCRH registers. <R> ### 10.7.2 Setting up hardware trigger no-wait mode Figure 10-30. Setting up Hardware Trigger No-Wait Mode Start of setup PER0 register setting The ADCEN bit of the PER0 register is set (1), and supplying the clock starts. The ports are set to analog input. ADPC and PMCx register ANI0 to ANI14 pins: Set using the ADPC register settings ANI16 to ANI26 pins: Set using the PMCx register PM register setting The ports are set to the input mode. ADM0 register FR2 to FR0, LV1, and LV0 bits: These are used to specify the A/D conversion time. ADMD bit: Select mode/scan mode ADM1 register ADTMD1 and ADTMD0 bits: These are used to specify the hardware trigger no-wait ADSCM bit: Sequential conversion mode/one-shot conversion mode ADM2 register ADM0 register setting ADREFP1, ADREFP0, and ADREFM bits: These are used to select the reference ADM1 register setting voltage. · ADM2 register setting ADRCK bit: This is used to select the range for the A/D conversion result comparison value generated by the interrupt signal from AREA1, AREA3, and · ADUL/ADLL register setting ARFA2. · ADS register setting ADTYP bit: 8-bit/10-bit resolution (The order of the settings is irrelevant.) ADUL/ADLL register These are used to specify the upper limit and lower limit A/D conversion result comparison values. ADS register ADS4 to ADS0 bits: These are used to select the analog input channels. The reference voltage stabilization wait time count A is required if the values of the ADREFP1 Reference voltage and ADREFP0 bits are changed. stabilization wait time count A If the values of ADREFP1 and ADREFP0 are changed to 1 and 0, respectively: A = 5 $\mu$ s A wait is not required if the values of ADREFP1 and ADREFP0 are change to 0 and 0 or 0 and 1, respectively. ADCE bit setting The ADCE bit of the ADM0 register is set (1), and the system enters the A/D conversion standby status. Reference voltage The software counts the reference voltage stabilization wait time count B (1 $\mu$ s). stabilization wait time count B After counting up to the reference voltage stabilization wait time count B ends, the ADCS bit of ADCS bit setting the ADM0 register is set (1), and the system enters the hardware trigger standby status. Hardware trigger standby status Start of A/D conversion by generating a hardware trigger The A/D conversion operations are performed. End of A/D conversion The A/D conversion end interrupt (INTAD) is generated. Note Storage of conversion results in The conversion results are stored in the ADCR and ADCRH registers. the ADCR and ADCRH registers **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 and ADCRH registers. <R> ### 10.7.3 Setting up hardware trigger wait mode Figure 10-31. 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 and ADCRH registers. # 10.7.4 Setup when temperature sensor output voltage/internal reference voltage is selected (example for software trigger mode and one-shot conversion mode) Figure 10-32. Setup when Temperature Sensor Output Voltage/Internal Reference Voltage is Selected <R> 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 and ADCRH registers. Caution This setting can be used only in HS (high-speed main) mode. ### 10.7.5 Setting up test mode Figure 10-33. Setting up Test 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 and ADCRH registers. **Caution** For details about how to test the A/D converter, see 21.3.7 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 function, 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 SNOOZE mode can only be specified when the high-speed on-chip oscillator clock is selected for fclk. Figure 10-34. 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 Note 2). Just before switching to the STOP mode, bit 2 (AWC) of the A/D converter mode register 2 (ADM2) is set to 1. After the initial settings are specified, bit 0 (ADCE) of the 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>. - Notes 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. - 2. Be sure to set the ADM1 register to E2H or E3H. Remarks 1. The hardware trigger is INTIT. 2. Specify the hardware trigger by using the A/D Converter Mode Register 1 (ADM1) ### (1) If an interrupt request 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 After A/D conversion ends and the A/D conversion end interrupt request signal (INTAD) is generated, 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 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-35. Operation Example When Interrupt Request Is Generated After A/D Conversion Ends (While in Scan Mode) ### (2) If no interrupt request 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 ARDCK 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 on-chip 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-36. Operation Example When No Interrupt Request Is Generated After A/D Conversion Ends (While in Scan Mode) <R> Figure 10-37. Flowchart for Setting Up SNOOZE Mode Notes 1. If the A/D conversion end interrupt request signal (INTAD) is not generated due to the setting of the ADRCK bit and ADUL/ADLL register, conversion results are 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 is performed again in the SNOOZE mode. 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^{10} = 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. Figure 10-38. Overall Error Figure 10-39. Quantization Error # (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......011 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-40. Zero-Scale Error Figure 10-41. Full-Scale Error Figure 10-42. Integral Linearity Error Figure 10-43. Differential Linearity 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 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 ANI3 and ANI16 to ANI22 pins <R> Observe the rated range of the ANI0 to ANI3 and ANI16 to ANI22 pins input voltage. If a voltage exceeding VDD and AVREFP or below Vss and AVREFM (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 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 Internal reference voltage (1.45 V) can be used 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 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), or A/D port configuration register (ADPC) write upon the end of conversion - The ADM0, ADS, or ADPC 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, ANIO to ANI3, and ANI16 to ANI22 pins. - <1> Connect a capacitor with a low equivalent resistance and a good frequency response (capacitance of about 0.01 $\mu$ F) via the shortest possible run of relatively thick wiring 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-44. Analog Input Pin Connection ## (5) Analog input (ANIn) pins - <1> The analog input pins (ANI0 to ANI3) are also used as input port pins (P20 to P23). When A/D conversion is performed with any of the ANI0 to ANI3 pins selected, do not change output value to alternate port P20 to P23 while conversion is in progress; otherwise the conversion resolution may be degraded. - <2> If a pin adjacent to a pin that is being A/D converted is used as a digital I/O port pin, the A/D conversion result might differ from the expected value due to a coupling noise. Be sure to prevent a pulse with sharp transitions such as a digital signal from being input or output during 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, we recommend using the converter with analog input sources that have output impedances no greater than 1 k $\Omega$ . If a source has a higher output impedance, lengthen the sampling time or connect a capacitor (with a value of about 100 $\mu$ F) to the ANI0 to ANI3 and ANI16 to ANI22 pins (see **Figure 10-44**). The voltage which is charged in the sampling capacitor become undefined when the ADCS bit is set to 0 or conversion is restarted during conversion operations. Accordingly, the state of conversion is undefined when charging starts in the next round of conversion after the ADCS bit is set to 0 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-45. 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 $\mu$ 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 the A/D converter mode register 0 (ADM0), analog input channel specification register (ADS), A/D port configuration register (ADPC), or port mode control register (PMCx), the contents of the ADCR and ADCRH registers may become undefined. Read the conversion result following conversion completion before writing to the ADM0, ADS, ADPC, or PMCx 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-46. Internal Equivalent Circuit of ANIn Pin Table 10-4. Resistance and Capacitance Values of Equivalent Circuit (Reference Values) | AVREFP, VDD | ANIn Pins | R1 [kΩ] | C1 [pF | C2 [pF] | |---------------------------------------------------------------|----------------|---------|--------|---------| | $3.6~V \leq V_{\text{DD}} \leq 5.5~V$ | ANI0 to ANI3 | 14 | 8 | 2.5 | | | ANI16 to ANI22 | 18 | | 7.0 | | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 3.6~\textrm{V}$ | ANI0 to ANI3 | 39 | | 2.5 | | | ANI16 to ANI22 | 53 | | 7.0 | | $1.8~V \leq V_{DD} < 2.7~V$ | ANI0 to ANI3 | 231 | | 2.5 | | | ANI16 to ANI22 | 321 | | 7.0 | Remark The resistance and capacitance values shown in Table 10-6 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** Serial array unit 0 has two serial channels in 20- and 24-pinproducts and four serial channels in 30-pin products, and serial array unit 1 mounted 30-pin products, has two serial channels. Each channel can achieve 3-wire serial (CSI), UART, and simplified I<sup>2</sup>C communication. Function assignment of each channel supported by the RL78/G12 is as shown below. ### 20- or 24-pin products | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C | | |------|---------|-----------------------|--------------|-------------------------------------|--| | 0 | 0 | CSI00 | UART0 | IIC00 <sup>Note</sup> | | | | 1 | CSI01 <sup>Note</sup> | | IIC01 <sup>Note</sup> | | # 30-pin products | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C | |------|---------|-----------------------|-----------------------|-------------------------------------| | 0 | 0 | CSI00 | UART0 | IIC00 <sup>Note</sup> | | | 1 | - | | - | | | 2 | - | UART1 <sup>Note</sup> | - | | | 3 | CSI11 <sup>Note</sup> | | IIC11 Note | | 1 | 0 | CSI20 <sup>Note</sup> | UART2 <sup>Note</sup> | IIC20 <sup>Note</sup> | | | 1 | - | | - | Note Provided in the R5F102 products only. A single channel cannot be used under multiple communication methods. When a different communication method is to be configured, use another channel. When using CSI00, CSI20, IIC00, IIC20, UART0, UART1, or UART2, communication between devices with different voltages (1.8, 2.5, or 3 V) is possible, except when the serial I/O for UART0 of a 20- or 24-pin product is assigned to P6 by the setting of the I/O redirection register (PIOR1 = 1). For details about the settings, see **4.4.4 Handling different** potentials (1.8 V, 2.5 V, and 3 V) by using I/O buffers. ## 11.1 Functions of Serial Array Unit Each serial interface supported by the RL78/G12 has the following features. ## 11.1.1 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) 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, CSI11, CSI20) 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<sup>Note</sup> 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 In addition, CSI00 (channel 0 of unit 0) supports the SNOOZE mode. When SCK00 pin input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. Only CSI00, which supports asynchronous receive operations, can be specified. Note Use the clocks within a range satisfying the SCK cycle time (tkcy) characteristics. For details, see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C). # 11.1.2 UART (UART0 to UART2) 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 to UART2) Communication. ## [Data transmission/reception] - Data length of 7, 8, or 9 bits<sup>Note</sup> - · 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 Note Only UART0 can be specified for the 9-bit data length. In addition, UART0 reception (channel 1 of unit 0) supports the SNOOZE mode. When RxD0 pin input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. ## 11.1.3 Simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) 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, IIC11, IIC20) 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, 0 is written to the SOEmn bit of the serial output enable register m (SOEm) and serial communication data output is stopped, disabling ACK output. See the processing flow in **11.7.3 (2)** for details. Remarks 1. To use a fully functional I2C bus, see CHAPTER 12 SERIAL INTERFACE IICA. 2. m: Unit number, n: Channel number (mn = 00, 01, 03, 10) # 11.2 Configuration of Serial Array Unit The serial array unit includes the following hardware. Table 11-1. Configuration of Serial Array Unit | Item | Configuration | |--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Shift register | 8 or 9 bits <sup>Note 1</sup> | | Buffer register | Lower 8 or 9 bits of serial data register mn (SDRmn) <sup>Notes 1, 2</sup> | | Serial clock I/O | SCK00, SCK01, SCK11, and SCK20 pins (for 3-wire serial I/O), SCL00, SCL01, SCL11, and SCL20 pins (for simplified I <sup>2</sup> C) | | Serial data input | SI00, SI01, SI11, and SI20 pins (for 3-wire serial I/O), RxD0, RxD1, and RxD2 pins (for UART) | | Serial data output | SO00, SO01, SO11, and SO20 pins (for 3-wire serial I/O), TxD0, TxD1, and TxD2 pins (for UART) | | Serial data I/O | SDA00, SDA01, SDA11 and SDA20 pins (for simplified I <sup>2</sup> C) | | Control registers | <registers block="" of="" setting="" unit=""> <ul> <li>Peripheral enable register 0 (PER0)</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 (STm)</li> <li>Serial output enable register m (SOEm)</li> <li>Serial output register m (SOm)</li> <li>Serial output level register m (SOLm)</li> <li>Serial standby control register m (SSCm)</li> <li>Noise filter enable register 0 (NFEN0)</li> </ul></registers> | | | <registers channel="" each="" of=""> <ul> <li>Serial data register mn (SDRmn)</li> <li>Serial mode register mn (SMRmn)</li> <li>Serial communication operation setting register mn (SCRmn)</li> <li>Serial status register mn (SSRmn)</li> <li>Serial flag clear trigger register mn (SIRmn)</li> </ul> Port input mode register 0, 1 (PIM0, PIM1) <ul> <li>Port output mode registers 1, 4, 5 (POM1, POM4, POM5)</li> <li>Port mode control registers 0, 1, 4 (PMC0, PMC1, PMC4)</li> <li>Port mode registers 0, 1, 3 to 6 (PM0, PM1, PM3 to PM6)</li> <li>Port register 0, 1, 3 to 6 (P0, P1, P3 to P6)</li> </ul></registers> | **Notes 1.** The number of bits used as shift register or buffer register varies depending on the unit or channel. mn = 00, 01: lower 9 bits, mn = 02, 03, 10, 11: lower 8 bits - 2. The lower 8 bits of serial data register mn (SDRmn) can be read or written as the following SFR, depending on the communication mode. - During CSIp communication: SIOp (CSIp data register) - During UARTq reception: RXDq (UART0 receive data register) During UARTq transmission: TXDq (UART0 transmit data register) - During IICr communication: SIOr (IICr data register) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), q: UART number (q = 0 to 2), r: IIC number (r = 00, 01, 11, 20) Figure 11-1 or 11-2 shows the block diagram of the serial array unit 0. Noise filter enable register 0 (NFEN0) 0 CKO03 CKO02 CKO01 CKO00 0 0 0 SO03 SO02 SO01 SO00 SNFEN SNFEN 10 00 Serial channel enable status register 0 (SE0) Peripheral enable register 0 (PER0) Serial standby control register 0 (SSC0) Serial clock select register 0 (SPS0) register 0 (SE0 Serial channel start register 0 (SS0) Serial channel stopregister 0 (ST0) PRS PRS PRS PRS PRS PRS PRS PRS PRS 013 012 011 010 003 002 001 000 SAU0EN SS02 SS01 SS03 SS00 SSEC0 SWC0 ST02 ST01 ST03 ST00 Serial output enable register 0 (SOE0) SOE03 SOE02 SOE01 SOE00 Serial output level register 0 (SOL0) SOL02 0 SOL00 Selector Serial data register 00 (SDR00) Channel 0 (Buffer register block) (Clock division setting block) Clock controller PM11 or PM12 Output Serial data output pin (when CSI00: SO00) (when IIC00: SDA00) (when UART0: TxD0) Interrupt controller Serial transfer end interrupt (when CSI00: INTCSI00) (when IIC00: INTIIC00) (when UART0: INTST0) Outputlatch (P10) Mode selection CSI00 or IIC00 or UART0 (for transmission) Serial flag clear trigger register 00 (SIR00) PM10 PECT OVCT Serial data input pin (when CSI00: SI00) (when IIC00: SDA00) (when UART0: RxD0) CKS00 CCS00 STS00 MD002 MD001 Commu TXE RXE DAP CKP EOC PTC PTC DIR SLC SLC DLS 00 00 00 00 00 001 000 00 00 001 000 001 000 001 TSF 00 Serial communication operation setting register 00(SCR00) Serial data output pin (when CSI01: SO01) (when IIC01: SDA01) Channel 1 ommunication controlle Serial transfer end interrupt (when CSI01: INTCSI01) (when IIC01: INTIIC01) (when UART0: INTSR0) Mode selection CSI01 or IIC01 or UART0 (for reception) Edge/level detection Error controller Serial data input pin (when CSI01: SI01) (when IIC01: SDA01) Serial transfer error interru (INTSRE0) Figure 11-1. Block Diagram of Serial Array Unit 0 (20- or 24-pin products) Figure 11-2. Block Diagram of Serial Array Unit 0 (30-pin products) Figure 11-3 shows the block diagram of the serial array unit 0. Figure 11-3. Block Diagram of Serial Array Unit 1 (30-pin products) The serial array unit 1 is available only in the 30-pin R5F102 products. ### 11.2.1 Shift register This is an 8-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<sup>Note 1</sup>. 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 to 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 | | | | | | | | | | ## 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 1</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 length of data stored in the lower 8/9 bits of this register is as follows, depending on the setting of bits 0 and 1 (DLSmn0, DLS0m1) 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 SDR00 and SDR01 registers) Note 1 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 in 8-bit units as the following SFR, depending on the communication mode<sup>Note 2</sup>. - During CSIp communication: SIOp (CSIp data register) - During UARTq reception: RXDq (UARTq receive data register) - During UARTq transmission: TXDq (UARTq transmit data register) - During IICr communication: SIOr (IICr data register) Reset signal generation clears the SDRmn register to 0000H. Notes 1. Only UART0 can be specified for the 9-bit data length. 2. When operation is stopped (SEmn = 0), do not rewrite SDRmn[7:0] by an 8-bit memory manipulation instruction (SDRmn[15:9] are all cleared to 0). Remarks 1. After data is received, "0" is applied to some bits of bits 0 to 8 to make up the specified data length. 2. m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), q: UART number (q = 0 to 2), r: IIC number (r = 00, 01, 11, 20) <R> Figure 11-4. Format of Serial Data Register mn (SDRmn) (mn = 00, 01) Address: FFF10H, FFF11H (SDR00), FFF12H, FFF13H (SDR01) After reset: 0000H R/W Remark For the function of the higher 7 bits of the SDRmn register, see 11.3 Registers Controlling Serial Array Unit. Figure 11-5. Format of Serial Data Register mn (SDRmn) (mn = 02, 03, 10, 11) Address: FFF44H, FFF45H (SDR02), FFF46H, FFF47H (SDR03) After reset: 0000H FFF48H, FFF49H (SDR10), FFF4AH, FFF4BH (SDR11) FFF45H (SDR02) FFF44H (SDR02) 15 7 6 14 13 12 11 10 9 8 5 4 3 SDR0n Shift register Caution Be sure to clear bit 8 to "0". 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) - Serial clock select register m (SPSm) - Serial mode register mn (SMRmn) - Serial communication operation setting register mn (SCRmn) - Serial data register mn (SDRmm) - 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 registers 0, 1 (PIM0, PIM1) - Port output mode registers 0, 1, 4, 5 (POM0, POM1, POM4, POM5) - Port mode control registers 0, 1, 4 (PMC0, PMC1, PMC4) - Port mode registers 0, 1, 3 to 6 (PM0, PM1, PM3 to PM6) - Port registers 0, 1, 3 to 6 (P0, P1, P3 to P6) **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) # 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. When serial array unit 1 is used, be sure to set bit 3 (SAU1EN) 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-6. Format of Peripheral Enable Register 0 (PER0) Address: F00F0H After reset: 00H R/W Symbol <7> 6 <5> <4> <3> <2> 1 <0> PER0 **TMKAEN** 0 SAU1EN<sup>Note</sup> 0 **ADCEN IICA0EN** SAU0EN TAU0EN | SAU1EN | Control of serial array unit 1 clock supply | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply (fixed as "0" in 20- or 24-pin products). • SFR used by serial array unit 1 cannot be written. • Serial array unit 1 is in the reset status. | | 1 | Enables clock supply. • SFR used by serial array unit 1 can be read/written. | | SAU0EN | Control of serial array unit 0 clock supply | |--------|--------------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. • SFR used by serial array unit 0 cannot be written. • Serial array unit 0 is in the reset status. | | 1 | Enables clock supply. • SFR used by serial array unit 0 can be read/written. | Note 30-pin products only. Cautions 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, control registers of serial array unit m become default values and writing to them is ignored (except for the noise filter enable register 0 (NFEN0), port input mode registers 0, 1 (PIM0, PIM1), port output mode registers 0, 1, 4, 5 (POM0, POM1, POM4, POM5), port mode control registers 0, 1, 4 (PMC0, PMC1, PMC4), port mode registers 0, 1, 3 to 6 (PM0, PM1, PM3 to PM6), and port registers 0, 1, 3 to 6 (P0, P1, P3 to P6)). - 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) - 2. Be sure to clear the following bits to 0. 20, 24-pin products: bits 1, 3, 6 30-pin products: bits 1, 6 ### 11.3.2 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. Figure 11-7. Format of Serial Clock Select Register m (SPSm) Address: F0126H, F0127H (SPS0), F0166H, F0167H (SPS1) After reset: 0000H R/W 7 6 5 0 Symbol 12 4 3 2 15 14 13 11 0 PRS **PRS PRS PRS** PRS **PRS PRS** PRS SPSm 0 0 0 0 0 0 m03 m01 m00 m13 m12 m11 m10 m02 | PRS | PRS | PRS | PRS | | Section of operation clock (CKmk) <sup>Note</sup> | | | | | | |-----|-----|-----|-----|----------------------|---------------------------------------------------|----------|----------|----------|----------|----------| | mk3 | mk2 | mk1 | mk0 | | fclk= | fclk= | fclk= | fclk= | fclk= | fcьк = | | | | | | | 2 MHz | 4 MHz | 8 MHz | 16 MHz | 20 MHz | 24 MHz | | 0 | 0 | 0 | 0 | fclk | 2 MHz | 4 MHz | 8 MHz | 16 MHz | 20 MHz | 24 MHz | | 0 | 0 | 0 | 1 | fclk/2 | 1 MHz | 2 MHz | 4 MHz | 8 MHz | 10 MHz | 12 MHz | | 0 | 0 | 1 | 0 | fclk/2 <sup>2</sup> | 500 kHz | 1 MHz | 2 MHz | 4 MHz | 5 MHz | 6 MHz | | 0 | 0 | 1 | 1 | fclk/23 | 250 kHz | 500 kHz | 1 MHz | 2 MHz | 2.5 MHz | 3 MHz | | 0 | 1 | 0 | 0 | fclk/2 <sup>4</sup> | 125 kHz | 250 kHz | 500 kHz | 1 MHz | 1.25 MHz | 1.5 MHz | | 0 | 1 | 0 | 1 | fc∟к/2⁵ | 62.5 kHz | 125 kHz | 250 kHz | 500 kHz | 625 kHz | 750 kHz | | 0 | 1 | 1 | 0 | fclk/2 <sup>6</sup> | 31.3 kHz | 62.5 kHz | 125 kHz | 250 kHz | 313 kHz | 375 kHz | | 0 | 1 | 1 | 1 | fclk/27 | 15.6 kHz | 31.3 kHz | 62.5 kHz | 125 kHz | 156 kHz | 188 kHz | | 1 | 0 | 0 | 0 | fclk/28 | 7.81 kHz | 15.6 kHz | 31.3 kHz | 62.5 kHz | 78.1 kHz | 93.8 kHz | | 1 | 0 | 0 | 1 | fclk/29 | 3.91 kHz | 7.81 kHz | 15.6 kHz | 31.3 kHz | 39.1 kHz | 46.9 kHz | | 1 | 0 | 1 | 0 | fclk/2 <sup>10</sup> | 1.95 kHz | 3.91 kHz | 7.81 kHz | 15.6 kHz | 19.5 kHz | 23.4 kHz | | 1 | 0 | 1 | 1 | fcьк/2 <sup>11</sup> | 977 Hz | 1.95 kHz | 3.91 kHz | 7.81 kHz | 9.77 kHz | 11.7 kHz | | 1 | 1 | 0 | 0 | fcLK/2 <sup>12</sup> | 488 Hz | 977 Hz | 1.95 kHz | 3.91 kHz | 4.88 kHz | 5.86 kHz | | 1 | 1 | 0 | 1 | fclk/2 <sup>13</sup> | 244 Hz | 488 Hz | 977 Hz | 1.95 kHz | 2.44 kHz | 2.93 kHz | | 1 | 1 | 1 | 0 | fclk/2 <sup>14</sup> | 122 Hz | 244 Hz | 488 Hz | 977 Hz | 1.22 kHz | 1.46 kHz | | 1 | 1 | 1 | 1 | fclk/2 <sup>15</sup> | 61 Hz | 122 Hz | 244 Hz | 488 Hz | 610 Hz | 732 Hz | **Note** When changing the clock selected for fclk while the serial array unit (SAU) is operating (by changing the system clock control register (CKC) value), do so after having stopped (serial channel stop register m (STm) = 000FH) the operation of SAU. Caution Be sure to clear bits 15 to 8 to "0". Remarks 1. fclk: CPU/peripheral hardware clock frequency **2.** m: Unit number (m = 0, 1) k = 0, 1 ### 11.3.3 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-8. Format of Serial Mode Register mn (SMRmn) (1/2) Address: F0110H, F0111H (SMR00), F0116H, F0117H (SMR03) After reset: 0020H R/W F0150H, F0151H (SMR10), F0152H, F0153H (SMR11) Symbol SMRmn | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|----|----|----|----|---|--------------------|---|---------------------|---|---|---|-----|-----|-----| | CKS | ccs | 0 | 0 | 0 | 0 | 0 | STS | 0 | SIS | 1 | 0 | 0 | MD | MD | MD | | mn | mn | | | | | | mn <sup>Note</sup> | | mn0 <sup>Note</sup> | | | | mn2 | mn1 | mn0 | | CKSmn | Selection of operation clock (fmck) of channel n | | | | | |-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 0 | Operation clock CK00 set by the SPSm register | | | | | | Operation clock CK01 set by the SPSm register | | | | | | | Operation clo | Operation clock (f <sub>MCK</sub> ) is used by the edge detector. In addition, depending on the setting of the CCSmn bit and the | | | | | Operation clock (fmck) is used by the edge detector. In addition, depending on the setting of the CCSmn bit and the higher 7 bits of the SDRmn register, a transfer clock (ftclk) is generated. | CCSmn | Selection of transfer clock (ftclk) of channel n | |-------|-----------------------------------------------------------------| | 0 | Divided operation clock fmck specified by the CKSmn bit | | 1 | Clock input fsck from the SCKp pin (slave transfer in CSI mode) | Transfer clock $f_{TCLK}$ is used for the shift register, communication controller, output controller, interrupt controller, and error controller. When CCSmn = 0, the division ratio of operation clock ( $f_{MCK}$ ) is set by the higher 7 bits of the SDRmn register. | STSmn <sup>Note</sup> | Selection of start trigger source | | | | | |--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|--|--|--| | 0 | Only software trigger is valid (selected for CSI, UART transmission, and simplified I <sup>2</sup> C). | | | | | | 1 | Valid edge of the RxDq pin (selected for UART reception) | | | | | | Transfer is started when the above source is satisfied after 1 is set to the SSm register. | | | | | | Note Provided in the SMR01, SMR03, and SMR11 registers 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, SMR02, SMR10, or SMR12 register) to "0". Be sure to set bit 5 to "1". (Remark is listed on the next page.) Figure 11-8. Format of Serial Mode Register mn (SMRmn) (2/2) Address: F0110H, F0111H (SMR00) to F0116H, F0117H (SMR03), After reset: 0020H R/W F0150H, F0151H (SMR10), F0152H, F0153H (SMR11) Symbol SMRmn | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|----|----|----|----|---|--------------------|---|---------------------|---|---|---|-----|-----|-----| | CKS | ccs | 0 | 0 | 0 | 0 | 0 | STS | 0 | SIS | 1 | 0 | 0 | MD | MD | MD | | mn | mn | | | | | | mn <sup>Note</sup> | | mn0 <sup>Note</sup> | | | | mn2 | mn1 | mn0 | | SISmn0 <sup>Note</sup> | Controls inversion of level of receive data of channel n in UART mode | |------------------------|---------------------------------------------------------------------------------------------------| | 0 | Falling edge is detected as the start bit. The input communication data is captured as is. | | 1 | Rising edge is detected as the start bit. The input communication data is inverted and captured. | | MDmn2 | MDmn1 | Setting of operation mode of channel n | |-------|-------|----------------------------------------| | 0 | 0 | CSI mode | | 0 | 1 | UART mode | | 1 | 0 | Simplified I <sup>2</sup> C mode | | 1 | 1 | Setting prohibited | | MDmn0 | Selection of interrupt source of channel n | | | | | | | | | | | |---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 0 | ransfer end interrupt | | | | | | | | | | | | 1 | Buffer empty interrupt | | | | | | | | | | | | | (Occurs 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 Provided in the SMR01, SMR03, and SMR11 registers 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, SMR02, SMR10, or SMR12 register) to "0". Be sure to set bit 5 to "1". **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), q: UART number (q = 0 to 2), r: IIC number (r = 00, 01, 11, 20) # 11.3.4 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. Figure 11-9. Format of Serial Communication Operation Setting Register mn (SCRmn) (1/2) Address: F0118H, F0119H (SCR00) to F011EH, F011FH (SCR03) After reset: 0087H R/W F0158H, F0159H (SCR10), F015AH, F015BH (SCR11) Symbol SCRmn | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|-----|----|-----|-----|-----|-----|---|----------------------|-----|---|---|----------------------|-----| | TXE | RXE | DAP | CKP | 0 | EOC | PTC | PTC | DIR | 0 | SLCm | SLC | 0 | 1 | DLSm | DLS | | mn | mn | mn | mn | | mn | mn1 | mn0 | mn | | n1 <sup>Note 1</sup> | mn0 | | | n1 <sup>Note 2</sup> | mn0 | | TXEmn | RXEmn | Setting of operation mode of channel n | |-------|-------|----------------------------------------| | 0 | 0 | Disable communication. | | 0 | 1 | Reception only | | 1 | 0 | Transmission only | | 1 | 1 | Transmission/reception | | EOCmn | Mask control of error interrupt signal (INTSREx (x = 0 to 3)) | | | | | | | | | | |-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 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 EOCmn = 0 in the CSI mode, simplified I <sup>2</sup> C mode, and during UART transmission <sup>Note 3</sup> . | | | | | | | | | | | - Notes 1. Provided in the SCR00, SCR02, and SCR10 registers only. - 2. Provided in the SCR00 and SCR01 registers only. Others are fixed to 1. - 3. If EOCmn is not cleared for CSImn, 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, SCR03, or SCR11 register to 0). Be sure to set bit 2 to "1". (Remark is listed on the next page.) Figure 11-9. Format of Serial Communication Operation Setting Register mn (SCRmn) (2/2) Address: F0118H, F0119H (SCR00), F011EH, F011FH (SCR03) After reset: 0087H R/W F0158H, F0159H (SCR10), F015AH, F015BH (SCR11) Symbol **SCRmn** | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|-----|----|-----|-----|-----|-----|---|----------------------|-----|---|---|----------------------|-----| | TXE | RXE | DAP | CKP | 0 | EOC | PTC | PTC | DIR | 0 | SLCm | SLC | 0 | 1 | DLSm | DLS | | mn | mn | mn | mn | | mn | mn1 | mn0 | mn | | n1 <sup>Note 1</sup> | mn0 | | | n1 <sup>Note 2</sup> | mn0 | | PTCmn1 | PTCmn0 | Setting of parity bit in UART mode | | | | | | | | | | |--------------------------------------------------------------------------------------------|--------|--------------------------------------|-------------------------|--|--|--|--|--|--|--|--| | | | Transmission | Reception | | | | | | | | | | 0 | 0 | Does not output the parity bit. | Receives without parity | | | | | | | | | | 0 | 1 | Outputs 0 parity <sup>Note 3</sup> . | No parity judgment | | | | | | | | | | 1 | 0 | Outputs even parity. | Judged as even parity. | | | | | | | | | | 1 | 1 | Outputs odd parity. | Judges as odd parity. | | | | | | | | | | Be sure to set PTCmn1, PTCmn0 = 0, 0 in the CSI mode and simplified I <sup>2</sup> C mode. | | | | | | | | | | | | DIRmn 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^2C$ mode. | SLCmn1 <sup>Note 1</sup> | SLCmn0 | Setting of stop bit in UART mode | | | | | | | | | |--------------------------|--------|-------------------------------------------------|--|--|--|--|--|--|--|--| | 0 | 0 | No stop bit | | | | | | | | | | 0 | 1 | op bit length = 1 bit | | | | | | | | | | 1 | 0 | Stop bit length = 2 bits (mn = 00, 02, 10 only) | | | | | | | | | | 1 | 1 | Setting prohibited | | | | | | | | | When the transfer end interrupt is selected, the interrupt is generated when all stop bits have been completely transferred. Set the stop bit length to 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 the stop bit length to 1 bit (SLCmn1, SLCmn0 = 0, 1) or 2 bits (SLCmn1, SLCmn0 = 1, 0) during UART transmission. | DLSmn1 <sup>Note 2</sup> | DLSmn0 | Setting of data length in CSI and UART modes | | | | | | | | | | |--------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 0 | 1 | 9-bit data length (stored in bits 0 to 8 of the SDR00 and SDR01 registers) (settable in UART0 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 tha | an above | Setting prohibited | | | | | | | | | | | Be sure to se | Be sure to set DLSmn1, DLSmn0 = 1, 1 in the simplified I <sup>2</sup> C mode. | | | | | | | | | | | - Notes 1. Provided in the SCR00, SCR02, and SCR10 registers only. - 2. Provided in the SCR00 and SCR01 registers only. Others are fixed to 1. - 3. 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, SCR03, or SCR11 register to 0). Be sure to set bit 2 to "1". **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20) ### 11.3.5 Serial data register mn (SDRmn) The SDRmn register is the transmit/receive data register of channel n (16 bits). Bits 8 to 0 (lower 9 bits) of SDR00 and SDR01 or bits 7 to 0 (lower 8 bits) of SDR02, SDR03, SDR10, and SDR11 function 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 operating clock divided by the division ratios specified by bits 15 to 9 (higher 7 bits) of the SDRmn register is used as the transfer clock. If the CCSmn bit of SMRmn is set to 1, set bits 15 to 9 (higher 7 bits) of SDR00, SDR01, SDR10, and SDR11 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 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. Figure 11-10. Format of Serial Data Register mn (SDRmn) Address: FFF10H, FFF11H (SDR00), FFF12H, FFF13H (SDR01) After reset: 0000H R/W FFF11H (SDR00) FFF10H (SDR00) Symbol 15 14 13 12 11 10 9 6 **SDRmn** Address: FFF44H, FFF45H (SDR02), FFF46H, FFF47H (SDR03) After reset: 0000H R/W FFF48H, FFF49H (SDR10), FFF4AH, FFF4BH (SDR11) FFF45H (SDR02) FFF44H (SDR02) Symbol SDRmn SDRmn[15:9] Transfer clock setting by dividing the operating clock (fMCK) 0 0 0 0 **fмск/2** 0 0 0 0 0 0 **fмск/4** 1 0 0 0 0 0 0 fмск/6 1 0 0 0 0 0 1 1 fмск/8 1 1 1 1 1 1 0 fmck/254 fmck/256 1 1 1 1 (Cautions and Remarks are listed on the next page.) - Cautions 1. Be sure to clear bit 8 of SDR02, SDR03, SDR10, and SDR11 registers to 0. - **2.** Setting SDRmn[15:9] = (0000000B, 0000001B) is prohibited when UART is used. - **3.** Setting SDRmn[15:9] = 0000000B is prohibited when simplified I<sup>2</sup>C is used. Set SDRmn[15:9] to 0000001B or greater. - **4.** When operation is stopped (SEmn = 0), do not rewrite SDRmn[7:0] by an 8-bit memory manipulation instruction (SDRmn[15:9] are all cleared to 0). - Remarks 1. For the function of the lower 8/9 bits of the SDRmn register, see 11.2 Configuration of Serial Array Unit. - 2. m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) ### 11.3.6 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 (SSRmn) 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. Figure 11-11. Format of Serial Flag Clear Trigger Register mn (SIRmn) Address: F0108H, F0109H (SIR00), F010EH, F010FH (SIR03), After reset: 0000H R/W F0148H, F0149H (SIR10), F014AH, F014BH (SIR11) Symbol SIRmn | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | / | ь | 5 | 4 | 3 | 2 | ı | U | |----|----|----|----|----|----|---|---|---|---|---|---|---|--------------------|------|------| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FECT | PECT | OVCT | | | | | | | | | | | | | | | mn <sup>Note</sup> | mn | mn | | FECTmn <sup>Note</sup> | Clear trigger of framing error of channel n | |------------------------|--------------------------------------------------| | 0 | Not cleared | | 1 | Clears the FEFmn bit of the SSRmn register to 0. | | PECTmn | Clear trigger of parity error flag of channel n | |--------|--------------------------------------------------| | 0 | Not cleared | | 1 | Clears the PEFmn bit of the SSRmn register to 0. | | OVCTmn | Clear trigger of overrun error flag of channel n | |--------|--------------------------------------------------| | 0 | Not cleared | | 1 | Clears the OVFmn bit of the SSRmn register to 0. | Note Provided in the SIR01, SIR03, SIR11 registers only. Caution Be sure to clear bits 15 to 3 (or bits 15 to 2 for the SIR00, SIR02, or SIR10 register) to "0". **Remarks 1.** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) 2. When the SIRmn register is read, 0000H is always read. ### 11.3.7 Serial status register mn (SSRmn) The SSRmn register indicates the communication status and error occurrence status of channel n. The errors indicated by this register are framing errors, parity errors, and overrun errors. The SSRmn register can be read by a 16-bit memory manipulation instruction. The lower 8 bits of the SSRmn register can be read with an 8-bit memory manipulation instruction as 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 F0106H, F0107H (SSR03) After reset: 0000H R F0140H, F0141H (SSR10), F0142H, F0143H (SSR11) Symbol SSRmn | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|-----|-----|---|---|--------------------|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TSF | BFF | 0 | 0 | FEF | PEF | OVF | | | | | | | | | | | mn | mn | | | mn <sup>Note</sup> | mn | mn | | TSFmn | Communication status indication flag of channel n | | | | | |-------|---------------------------------------------------|--|--|--|--| | 0 | Communication is stopped or suspended. | | | | | | 1 | Communication is in progress. | | | | | #### <Clear conditions> - 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. | BFFmn | 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 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 Provided in the SSR01, SSR03, SSR11 registers only. **Caution** When the CSI is performing reception operations in the SNOOZE mode (SWC0 = 1), the BFF01 flag will not change. **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) Figure 11-12. Format of Serial Status Register mn (SSRmn) (2/2) Address: F0100H, F0101H (SSR00) to F0106H, F0107H (SSR03) After reset: 0000H R F0140H, F0141H (SSR10), F0142H, F0143H (SSR11) Symbol SSRmn | _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|---|---|---|-----------|-----------|---|---|---------------------------|-----------|-----------| | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TSF<br>mn | BFF<br>mn | 0 | 0 | FEF<br>mn <sup>Note</sup> | PEF<br>mn | OVF<br>mn | | FEFmn <sup>Note</sup> | Framing error detection flag of channel n | |-----------------------|-------------------------------------------| | 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. | PEFmn | Parity / ACK error detection flag of channel n | |-------|-----------------------------------------------------------------------------------------------------------------------| | 0 | No error occurs. | | 1 | Parity error occurs (during UART reception) or ACK is not detected (during simplified I <sup>2</sup> C transmission). | #### <Clear condition> • 1 is written to the PECTmn bit of the SIRmn register. #### <Set condition> - The parity of the transmit data and the parity bit do not match when UART reception ends (parity error). - No ACK signal is returned from the slave channel at the ACK reception timing during simplified I<sup>2</sup>C transmission (ACK is not detected). | OVFmn | Overrun error detection flag of channel n | |-------|-------------------------------------------| | 0 | No error occurs. | | 1 | An error occurs | #### <Clear condition> • 1 is written to the OVCTmn bit of the SIRmn register. #### <Set condition> - 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 each communication mode). - Transmit data is not ready for slave transmission or transmission and reception in CSI mode. Note Provided in the SSR01, SSR03, SSR11 registers only. - **Cautions 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. - 2. When the CSI is performing reception operations in the SNOOZE mode (SWC0 = 1), the OVF01 flag will not change. **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) #### 11.3.8 Serial channel start register m (SSm) The SSm register is a trigger register that is used to enable communication/count for each channel. When 1 is written to 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 a 1-bit or 8-bit memory manipulation instruction with SSmL. Reset signal generation clears the SSm register to 0000H. Figure 11-13. Format of Serial Channel Start Register m (SSm) | Address: F01 | 22H, F0 | 123H ( | SS0) | After re | eset: 00 | 00H | 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 | SS03<br>Note 1 | SS02<br>Note 1 | SS01 | SS00 | | Address: F01 | 62H, F0<br>15 | )163H (; | SS1)<br>13 | After re | eset: 00<br>11 | 00H<br>10 | R/W<br>9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | • | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 0 | , | 0 | 3 | 4 | <u> </u> | | , I | <u> </u> | | SS1 <sup>Note 1</sup> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SS11 | SS10 | | | | | | | | | | | | | | | | | | | | SSmn | Operation start trigger of channel n | |------|------------------------------------------------------------------------------------| | 0 | No trigger operation | | 1 | Sets the SEmn bit to 1 and enters the communication wait status <sup>Note2</sup> . | #### Notes 1. 30-pin product only. 2. If set the SSmn = 1 to during a communication operation, will wait status to stop the communication. At this time, holding status value of control register and shift register, SCKmn and SOmn pins, and FEFmn, PEFmn, OVFmn flags. # **Cautions 1.** Be sure to clear bits 15 to 2 of the SS0 register for 20- or 24-pin products, bits 15 to 4 of the SS0 register for 30-pin products, and bits 15 to 2 of the SS1 register to "0". **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 fmcκ clocks have elapsed. **Remarks 1.** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) 2. When the SSm register is read, 0000H is always read. #### 11.3.9 Serial channel stop register m (STm) The STm register is a trigger register that is used to enable stopping communication/count for each channel. When 1 is written to 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 is set 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 as STmL. Reset signal generation clears the STm register to 0000H. Figure 11-14. Format of Serial Channel Stop Register m (STm) | Address: F01 | 24H, F0 | )125H ( | ST0) | After re | eset: 00 | 00H | R/W | | | | | | | | | | |-----------------------|---------|---------|------|----------|----------|-----|-----|---|---|---|---|---|----------------|----------------|------|------| | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ST0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ST03<br>Note 1 | ST02<br>Note 1 | ST01 | ST00 | | Address: F01 | 64H, F0 | )165H ( | ST1) | After re | eset: 00 | 00H | R/W | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ST1 <sup>Note 1</sup> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ST11 | ST10 | | | | | | | | | | | | | | | | | | | | | STmn | Operation stop trigger of channel n | |---|------|---------------------------------------------------------------------------------| | | 0 | No trigger operation | | ĺ | 1 | Clears the SEmn bit to 0 and stops the communication operation <sup>Note2</sup> | Notes 1. 30-pin product only. **2.** While holding the value of the control register and shift register, and the status of the, SCKmn, SOmn pins, FEFmn, PEFmn, OVFmn flag. **Caution** Be sure to clear bits 15 to 2 of the ST0 register for 20- or 24-pin products, bits 15 to 4 of the ST0 register for 30-pin products, and bits 15 to 2 of the ST1 register to "0". **Remarks 1.** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) 2. When the STm register is read, 0000H is always read. #### 11.3.10 Serial channel enable status register m (SEm) The SEm register indicates whether the data transmission/reception operation of each channel is enabled or disabled. When 1 is written to a bit of serial channel start register m (SSm), the corresponding bit of this register is set to 1. When 1 is written to a bit of serial channel stop register m (STm), the corresponding bit of this register is cleared to 0. If the operation of channel n is enabled, the value of the CKOmn bit (serial clock output of channel n) of serial output register m (SOm) cannot be rewritten by software, and a value is output from the serial clock pin according to the communication operation. If the operation of channel n is disabled, the value of the CKOmn bit of the SOm register can be set by software and its value is output 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 as SEmL. Reset signal generation clears the SEm register to 0000H. Figure 11-15. Format of Serial Channel Enable Status Register m (SEm) | Address: F012 | 20H, F0 | 121H ( | SE0) | After re | eset: 00 | 00H | 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 | SE03 | SE02<br>Note | SE01 | SE00 | | Address: F010 | 60H, F0 | )161H ( | SE1) | After re | eset: 00 | 00H | R | | | | | | | | | | | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SE1 <sup>Note 1</sup> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SE11 | SE11 | | SEmn | Indication of operation enable/disable status of channel n | |------|------------------------------------------------------------| | 0 | Operation is disabled (stopped) | | 1 | Operation is enabled. | Note 30-pin product only. **Caution** Be sure to clear bits 15 to 2 of the SE0 register for 20- or 24-pin products, bits 15 to 4 of the SE0 register for 30-pin products, and bits 15 to 2 of the SE1 register to "0". **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) #### 11.3.11 Serial output enable register m (SOEm) The SOEm register is used to enable or disable output of the serial communication operation of each channel. If serial output is enabled for channel n, the value of the SOmn bit of serial output register m (SOm) cannot be rewritten by software, and a value is output from the serial data output pin according to the communication operation. If serial output is disabled for channel n, the SOmn bit value of the SOm register can be set by software, and its value is output from the serial data output pin. In this way, any waveform, such as that of a start condition/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 as SOEmL. Reset signal generation clears the SOEm register to 0000H. Figure 11-16. Format of Serial Output Enable Register m (SOEm) | Address: F01 | 2AH, F( | )12BH( | SOE0) | After | reset: C | H0000 | 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 | SOE0<br>3 <sup>Note 1</sup> | SOE0<br>2 <sup>Note 1</sup> | SOE0<br>1 <sup>Note 2</sup> | SOE<br>00 | | | | | | | | | | | | | | | | | | | | Address: F01 | 6AH, F0 | )16BH( | SOE1) | After | reset: C | 0000Н | R/W | | | | | | | | | | | Address: F01<br>Symbol | 6AH, F0 | )16BH( | SOE1)<br>13 | After<br>12 | reset: C | 0000H<br>10 | R/W<br>9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | • | , | | | | | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0<br>SOE<br>10 | | SOEmn | Serial output enable/disable of channel n | |-------|----------------------------------------------------| | 0 | Disables output by serial communication operation. | | 1 | Enables output by serial communication operation. | Notes 1. 30-pin product only. 2. 20-, 24-pin product only. **Caution** Be sure to clear bits 15 to 2 of the SOE register for 20- or 24-pin products, bits 15 to 4, and 1 of the SOE0 register for 30-pin products, and bits 15 to 1 of the SOE1 register to "0". **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) <R> <R> <R> #### 11.3.12 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 the pin for serial interface as a port function pin, set the corresponding 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 0F0FH. Figure 11-17. Format of Serial Output Register m (SOm) After reset: 0F0FH R/W Address: F0128H, F0129H(SO0) 0 Symbol 12 9 8 5 3 15 13 11 10 6 2 14 SO<sub>0</sub> CKO CKO CKO 0 0 0 SO SO SO 0 0 0 0 0 SO 01<sup>Note 2</sup> 03<sup>Note</sup> 02<sup>Note</sup> 00 03 01 00 Address: F0168H, F0169H(SO1) After reset: 0F0FH 12 Symbol 15 14 13 11 10 9 8 6 5 3 2 0 SO1 Note 1 0 0 0 0 1 CKO CKO 0 0 0 0 1 1 1 SO 1 02 10 10 | CKOmn | Serial clock output of channel n | |-------|-----------------------------------| | 0 | Serial clock output value is "0". | | 1 | Serial clock output value is "1". | | SOmn | Serial data output of channel n | | | | | | | |------|----------------------------------|--|--|--|--|--|--| | 0 | Serial data output value is "0". | | | | | | | | 1 | Serial data output value is "1". | | | | | | | Notes 1. 30-pin product only. 2. The register value becomes 0303H after a reset for the 20 to 24-pin products. **Caution** Be sure to clear bits 15 to 12, and 7 to 4 of the SOm register to "0". Be sure to set bits 11 to 9, and 3 to 1 of the SO1 register to "1". **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) R01UH0200EJ0210 Rev.2.10 #### 11.3.13 Serial output level register m (SOLm) The SOLm register 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 to corresponding bit in the CSI mode and simplified $I^2C$ 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 during operation (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 as SOLmL. Reset signal generation clears the SOLm register to 0000H. Figure 11-18. Format of Serial Output Level Register m (SOLm) | Address: F01 | 34H, F0 | )135H ( | SOL0) | After | reset: C | H0000 | R/W | | | | | | | | | | |----------------------|---------------|---------------|-------------|-------|----------|-------------|----------|---|---|---|---|---|---|---------------------------|---|-----------| | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SOL0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SOL<br>02 <sup>Note</sup> | 0 | SOL<br>00 | | Address: F01 | 74H, F0<br>15 | )175H (<br>14 | SOL1)<br>13 | After | reset: 0 | 0000H<br>10 | R/W<br>9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SOL1 <sup>Note</sup> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SOL<br>10 | | | | | | | | | | | | | | | | | | | | SOLmn | Selects inversion of the level of the transmit data of channel n in UART mode | | | | | | | |-------|-------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | Communication data is output as is. | | | | | | | | 1 | Communication data is inverted and output. | | | | | | | Note 30-pin product only. **Caution** Be sure to clear bits 15 to 1 of the SOL0 register for 20- or 24-pin products, bits 15 to 3, and 1 of the SOL0 register for 30-pin products, and bits 15 to 1 of the SOL1 register to "0". (Remark is listed on the next page.) Figure 11-19 shows examples in which the level of transmit data is reversed during UART transmission. Figure 11-19. Examples of Reverse Transmit Data ## (a) Non-reverse Output (SOLmn = 0) # (b) Reverse Output (SOLmn = 1) **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 0, 2) #### 11.3.14 Serial standby control register 0 (SSC0) 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 SSC0 register can be set by a 16-bit memory manipulation instruction. The lower 8 bits of the SSC0 register can be set with an 8-bit memory manipulation instruction as SSC0L. Reset signal generation clears the SSC0 register to 0000H. Caution The maximum transfer rate in the SNOOZE mode is as follows. When using CSI00: Up to 1 MbpsWhen using UART0: 4800 bps only Figure 11-20. Format of Serial Standby Control Register 0 (SSC0) Address: F0138H, F0139H After reset: 0000H R/W Symbol 15 13 12 10 SSEC SWC SSCm 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | SSEC0 | Selection of whether to enable or disable the generation of communication error interrupts in the SNOOZE | | | | | | | | |-------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | mode | | | | | | | | | 0 | Enable the generation of error interrupts (INTSRE0). | | | | | | | | | 1 | 1 Stop the generation of error interrupts (INTSRE0). | | | | | | | | | 1 | · · · · · · · · · · · · · · · · · · · | | | | | | | | - The SSEC0 bit can be set to 1 or 0 only when both the SWC0 and EOC01 bits are set to 1 during UART reception in the SNOOZE mode. In other cases, clear the SSEC0 bit to 0. - Setting SSEC0, SWC0 = 1, 0 is prohibited. | SWC0 | Setting 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 SWC0 bit to 0 in normal operation and change it to 1 just before shifting to STOP mode. - Also, be sure to change the SWC0 bit to 0 after returning from STOP mode to normal operation. Figure 11-21. Interrupt in UART Reception Operation in SNOOZE Mode | EOC01 Bit | SSEC0 Bit | Reception Ended Successfully | Reception Ended in an Error | |-----------|-----------|------------------------------|-----------------------------| | 0 | 0 | INTSR0 is generated. | INTSR0 is generated. | | 0 | 1 | INTSR0 is generated. | INTSR0 is generated. | | 1 | 0 | INTSR0 is generated. | INTSRE0 is generated. | | 1 | 1 | INTSR0 is generated. | No interrupt is generated. | ## 11.3.15 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 disabled, only synchronization is performed with the operation clock (fmck) of the target channel. 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-22. Format of Noise Filter Enable Register 0 (NFEN0) | Address: F00 | 70H After re | eset: 00H | R/W | | | | | | |--------------|--------------|-----------|-----|-------------------------|---|-------------------------|---|---------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | NFEN0 | 0 | 0 | 0 | SNFEN20 <sup>Note</sup> | 0 | SNFEN10 <sup>Note</sup> | 0 | SNFEN00 | | SNFEN20 | Use of noise filter of RxD2 pin | | | | | | |---------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 0 | pise filter OFF | | | | | | | 1 | Noise filter ON | | | | | | | | Set the SNFEN20 bit to 1 to use the RxD2 pin. Clear the SNFEN20 bit to 0 to use other than the RxD2 pin. | | | | | | | SNFEN10 | Use of noise filter of RxD1 pin | | | | | | | |---------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | loise filter OFF | | | | | | | | 1 | Noise filter ON | | | | | | | | | Set the SNFEN10 bit to 1 to use the RxD1 pin. Clear the SNFEN10 bit to 0 to use the other than RxD1 pin. | | | | | | | | SNFEN00 | Use of noise filter of RxD0 pin | | | | | | |----------------------------------------------------------------------------------------------------------|---------------------------------|--|--|--|--|--| | 0 | Noise filter OFF | | | | | | | 1 | Noise filter ON | | | | | | | Set the SNFEN00 bit to 1 to use the RxD0 pin. Clear the SNFEN00 bit to 0 to use the other than RxD0 pin. | | | | | | | Note 30-pin product only. Caution Be sure to clear bits 7 to 1 for 20- or 24-pin products, and bits 7 to 5, 3, and 1 for 30-pin products to "0". #### 11.3.16 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), port output mode register (POMxx), and port mode control register (PMCxx)). For details, see 4.3.1 Port mode registers (PMxx), 4.3.2 Port registers (Pxx), 4.3.4 Port input mode registers (PIMxx), 4.3.5 Port output mode registers (POMxx), and 4.3.6 Port mode control registers (PMCxx). Specifically, using a port pin with a multiplexed serial data or serial clock output function (e.g. P10/ANI16/PCLBUZ0/SCK00/SCL00) for serial data or serial clock output, requires setting the corresponding bits in the port mode control register (PMCxx) and port mode register (PMxx) to 0, and the corresponding bits in the port register (Pxx) to 1. When using the port pin in N-ch open-drain output (Vpb 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 potentials (1.8 V, 2.5 V, and 3 V) by using I/O buffers. Example: When P10/ANI16/PCLBUZ0/SCK00/SCL00 for 20 or 24-pin products is to be used for serial clock output: Set the PMC10 bit of port mode control register 1 to 0. Set the PM10 bit of port mode register 1 to 0. Set the P10 bit of port register 1 to 1. Specifically, using a port pin with a multiplexed serial data or serial clock input function (e.g. P10/ANI16/PCLBUZ0/SCK00/ SCL00) for serial data or serial clock input, requires setting the corresponding bit in the port mode register (PMxx) to 1, and the corresponding bit in the port mode control register (PMCxx) to 0. 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 potentials (1.8 V, 2.5 V, and 3 V) by using I/O buffers**. Example: When P10/ANI16/PCLBUZ0/SCK00/SCL00 for 20 or 24-pin products is to be used for serial clock input: Set the PMC10 bit of port mode control register 1 to 0. Set the PM10 bit of port mode register 1 to 0. Set the P10 bit of port register 1 to 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. To stop the operation of serial array unit 1, set bit 3 (SAU1EN) to 0. Figure 11-23. Peripheral Enable Register 0 (PER0) Setting When Stopping Operation by Units (a) Peripheral enable register 0 (PER0) ... Set only the bit of SAUm to be stopped to 0. 7 6 5 4 3 2 1 0 PER0 TMKAEN ADCEN IICA0EN SAU1EN<sup>Note</sup> SAU0EN TAU0EN 0 0/1 0/1 0 Control of SAUm input clock 0: Stops supply of input clock 1: Supplies input clock Note Provided only in 30-pin products. **Cautions 1.** If SAUmEN = 0, writing to a control register of serial array unit m is ignored, and, even if the register is read, only the default value is read Note that this does not apply to the following registers. - Noise filter enable register 0 (NFEN0) - Port input mode register 0, 1 (PIM0, PIM1) - Port output mode registers 0, 1, 4, 5 (POM0, POM1, POM4, POM5) - Port mode registers 0, 1, 3 to 6 (PM0, PM1, PM3 to PM6) - Port registers 0, 1, 3 to 6 (P0, P1, P3 to P6) - Port mode control registers 0, 1, 4 (PMC0, PMC1, PMC4) - 2. Be sure to clear the following bits to 0. 20, 24-pin products: bits 1, 3, 6 30-pin products: bits 1, 6 **Remark** : Setting disabled (fixed by hardware) x: Bits not used with serial array units (depending on the settings of other peripheral functions) 0/1: Set to 0 or 1 depending on the usage of the user. #### 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-24. Each Register Setting When Stopping 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. <sup>\*</sup> Because the STmn bit is a trigger bit, it is cleared immediately when SEmn = 0. (b) Serial Channel Enable Status Register m (SEm) ... This register indicates whether data transmission/reception operation of each channel is enabled or stopped. <sup>\*</sup> The SEm register is a read-only status register. Operation is stopped by using the STm register. For a channel whose operation is disabled, the value of the CKOmn bit of the SOm register can be set by software. (c) Serial output enable register m (SOEm) ... This register is a register that is used to enable or stop output of the serial communication operation of each channel. <sup>\*</sup> For channel n whose serial output is stopped, the SOmn bit value of the SOm register can be set by software. (d) Serial output register m (SOm) ...This register is a buffer register for serial output of each channel. $<sup>^{\</sup>star}$ When using pins corresponding to each channel as port function pins, set the corresponding CKOmn, SOmn bits to "1". **Notes 1.** Provided in the serial array unit 0 of 30-pin products only. 2. 20-, 24-pin products only. **Remarks 1.** m: Unit number (m = 0, 1) n: Channel number (n = 0 to 3) 2. : Setting disabled (fixed by hardware), 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, CSI11, CSI20) 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: Max. fmck/6 [Interrupt function] Transfer end interrupt/buffer empty interrupt [Error detection flag] Overrun error In addition, CSI00 (channel 0 of unit 0) supports the SNOOZE mode. When SCK00 pin input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. Note Use the clocks within a range satisfying the SCK cycle time (tkcy) characteristics. For details, see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C). The channels supporting 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) are channels 0, 1, 3 of SAU0 and channel 0 of SAU1. 20- or 24-pin products | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C | | | |------|---------|-----------------------|--------------|-------------------------------------|--|--| | 0 | | CSI00 | UART0 | IIC00 <sup>Note</sup> | | | | U | 1 | CSI01 <sup>Note</sup> | | IIC01 <sup>Note</sup> | | | 30-pin products | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C | |------|---------|-----------------------|-----------------------|-------------------------------------| | 0 | 0 | CSI00 | UART0 | IIC00 | | | 1 | - | J OAITIO | - | | | 2 | = | UART1 <sup>Note</sup> | = | | | 3 | CSI11 <sup>Note</sup> | UARTI | IIC11 <sup>Note</sup> | | 1 | 0 | CSI20 <sup>Note</sup> | UART2 <sup>Note</sup> | IIC20 <sup>Note</sup> | | | 1 | _ | UARI2 | _ | Note Provided in the R5F102 products only. 3-wire serial I/O (CSI00, CSI01, CIS10, CIS20) performs the following seven types of communication operations. - Master transmission (See 11.5.1.) - Master reception (See 11.5.2.) - Master transmission/reception (See 11.5.3.) - Slave transmission (See 11.5.4.) - Slave reception (See 11.5.5.) - Slave transmission/reception (See 11.5.6.) - SNOOZE mode function (for CSI00 only) (See 11.5.7.) ## 11.5.1 Master transmission Master transmission is that the RL78 microcontroller outputs a transfer clock and transmits data to another device. | 3-Wire Serial I/O | CSI00 | CSI01 | CSI11 | CSI20 | | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------|-------------------|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | Pins used | SCK00, SO00 | SCK01, SO01 | SCK11, SO11 | SCK20, SO20 | | | Interrupt | INTCSI00 | INTCSI01 | INTCSI11 | INTCSI20 | | | | Transfer end interrupt (in single-transfer mode) or buffer empty interrupt (in continuous tr mode) can be selected. | | | | | | Error detection flag | None | | | | | | Transfer data<br>length | 7 or 8 bits | | | | | | Transfer rate <sup>Note</sup> | Max. fcLk/2 [Hz] (CSI00 only), fcLk/4 [Hz] | | | | | | | Min. fcLk/ $(2 \times 2^{15} \times 128)$ [Hz] fcLk: System clock frequency | | | | | | Data phase | Selectable by the DAPmn bit of the SCRmn register • DAPmn = 0: Data output starts at the start of the operation of the serial clock. | | | | | | Clask phase | DAPmn = 1: Data output starts half a clock before the start of the serial clock operation. Output black to the OKP we bit of the OCPP we stirt to the START of the serial clock operation. | | | | | | Clock phase | Selectable by the CKPmn bit of the SCR0n register • CKPmn = 0: Non-reverse (data output at the falling edge and data input at the rising edge of SCK) • CKPmn = 1: Reverse (data output at the rising edge and data input at the falling edge of SCK) | | | | | | Data direction | MSB or LSB first | | | | | Note Use this operation within a range that satisfies the conditions above and the peripheral function characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10 #### (1) Register setting Figure 11-25. Example of Contents of Registers for Master Transmission of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) Notes 1. Provided in the serial array unit 0 of 30-pin products. 2. 20-, 24-pin products only. **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10, p: CSI number (p = 00, 01, 11, 20) - - 0/1: Set to 0 or 1 depending on the usage of the user. ## (2) Operation procedure Figure 11-26. Initial Setting Procedure for Master Transmission Figure 11-27. Procedure for Stopping 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. The master transmission is stopped. Go to the next processing. Figure 11-28. 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) Figure 11-29. Timing Chart of Master Transmission (in Single-Transmission Mode) (Type 1: DAPmn = 0, CKPmn = 0) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10, p: CSI number (p = 00, 01, 11, 20) Figure 11-30. Flowchart of Master Transmission (in Single-Transmission Mode) #### (4) Processing flow (in continuous transmission mode) Figure 11-31. Timing Chart of Master Transmission (in Continuous Transmission Mode) (Type 1: DAPmn = 0, CKPmn = 0) **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, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Figure 11-32. Flowchart of Master Transmission (in Continuous Transmission Mode) Remark <1> to <6> in the figure correspond to <1> to <6> in Figure 11-31 Timing Chart of Master Transmission (in Continuous Transmission Mode). ## 11.5.2 Master reception Master reception is that the RL78 microcontroller outputs a transfer clock and receives data from other device. | 3-Wire Serial I/O | CSI00 | CSI01 | CSI11 | CSI20 | | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------|-------------------|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | Pins used | SCK00, SI00 | SCK01, SI01 | SCK11, SI11 | SCK20, SI20 | | | Interrupt | INTCSI00 | INTCSI01 | INTCSI11 | INTCSI20 | | | | Transfer end interrupt (in single-transfer mode) or buffer empty interrupt (in continuous transfer mode) can be selected. | | | | | | Error detection flag | Overrun error detection flag (OVFmn) only | | | | | | Transfer data length | 7 or 8 bits | | | | | | Transfer rate <sup>Note</sup> | Max. fclk/2 [Hz] (CSI00 only), fclk/4 [Hz] | | | | | | | Min. fcLk/ $(2 \times 2^{15} \times 128)$ [Hz] fcLk: System clock frequency | | | | | | Data phase | ta phase Selectable by the DAPmn bit of the SCRmn register | | | | | | • DAPmn = 0: Data input starts at the start of the operation of the serial clock. | | | | | | | | DAPmn = 1: Data input starts half a clock before the start of the serial clock operation. | | | | | | Clock phase Selectable by the CKPmn bit of the SCRmn register | | | | | | | | • CKPmn = 0: Non-inv | | | | | | | CKPmn = 1: Inverted | <u>t</u> | | | | | 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 CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00 to 03, 10 to 13 #### (1) Register setting Figure 11-33. Example of Contents of Registers for Master Reception of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) **Notes 1.** Provided in the serial array unit 0 of 30-pin products. 2. 20-, 24-pin products only. **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10, 2. ☐: Setting is fixed in the CSI master transmission mode, ☐: 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: Set to 0 or 1 depending on the usage of the user #### (2) Operation procedure Figure 11-34. Initial Setting Procedure for Master Reception Figure 11-35. Procedure for Stopping Master Reception Figure 11-36. 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) Figure 11-37. Timing Chart of Master Reception (in Single-Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10, Figure 11-38. Flowchart of Master Reception (in Single-Reception Mode) ## (4) Processing flow (in continuous reception mode) Figure 11-39. Timing Chart of Master Reception (in Continuous Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0) **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. - Remarks 1. <1> to <8> in the figure correspond to <1> to <8> in Figure 11-40 Flowchart of Master Reception (in Continuous Reception Mode). - 2. m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Figure 11-40. Flowchart of Master Reception (in Continuous Reception Mode) Remark <1> to <8> in the figure correspond to <1> to <8> in Figure 11-39 Timing Chart of Master Reception (in Continuous Reception Mode). ## 11.5.3 Master transmission/reception Master transmission/reception is that the RL78 microcontroller outputs a transfer clock and transmits/receives data to/from other device. | 3-Wire Serial I/O | CSI00 | CSI01 | CSI11 | CSI20 | | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------|-------------------|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | Pins used | SCK00, SI00, SO00 | SCK01, SI01, SO01 | SCK11, SI11, SO11 | SCK20, SI20, SO20 | | | Interrupt | INTCSI00 | INTCSI01 | INTCSI11 | INTCSI20 | | | | Transfer end interrupt (in single-transfer mode) or buffer empty interrupt (in continuous transfer mode) can be selected. | | | | | | Error detection flag | Overrun error detection flag (OVFmn) only | | | | | | Transfer data length | 7 or 8 bits | | | | | | Transfer rate <sup>Note</sup> | Max. fclk/2 [Hz] (CSl00 only), fclk/4 [Hz] Min. fclk/(2 × 2 <sup>15</sup> × 128) [Hz] fclk: System clock frequency | | | | | | Data phase | Selectable by the DAPmn bit of the SCRmn register • DAPmn = 0: Data I/O starts at the start of the operation of the serial clock. • DAPmn = 1: Data I/O starts half a clock before the start of the serial clock operation. | | | | | | Clock phase | Selectable by the CKPmn bit of the SCRmn register • CKPmn = 0: Non-inversion • CKPmn = 1: Inverted | | | | | | 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 CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). **Remarks** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00 to 03, 10 to 13 #### (1) Register setting Figure 11-41. Example of Contents of Registers for Master Transmission/Reception of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) (1/2) Notes 1. Provided in the serial array unit 0 of 30-pin products. 2. 20-, 24-pin products only. **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 - 2. \(\subseteq\): Setting is fixed in the CSI master transmission/reception mode - : Setting disabled (set to the initial value) - x: 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-42. Initial Setting Procedure for Master Transmission/Reception Starting setting to stop If there is any data being transferred, wait for No their completion. (Selective) TSFmn = 0? (If there is an urgent must stop, do not wait) Yes Write 1 to the STmn bit of the target channel. (Essential) Writing the STm register (SEmn = 0: to operation stop status) Set the SOEmn bit to 0 and stop the output of (Essential) Changing setting of the SOEm registe the target channel. The levels of the serial clock (CKOmn) and (Selective) Changing setting of the SOm register serial data (SOmn) on the target channel can be changed if necessitated by an emergency. Reset the serial array unit by stopping the (Selective) Setting the PER0 register clock supply to it. The master transmission is stopped. Stop setting is completed Go to the next processing. Figure 11-43. Procedure for Stopping Master Transmission/Reception Figure 11-44. Procedure for Resuming Master Transmission/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-transmission/reception mode) Figure 11-45. Timing Chart of Master Transmission/Reception (in Single-Transmission/Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Starting CSI communication For the initial setting, refer to Figure 11-42. SAU default setting (Select transfer end interrupt) Setting storage data and number of data for transmission/reception data Setting (Storage area, Transmission data pointer, Reception data pointer, Number transmission/reception data of communication data and Communication end flag are optionally set on Main routine the internal RAM by the software) Clear interrupt request flag (XXIF), reset interrupt mask (XXMK) and **Enables interrupt** set interrupt enable (EI) Read transmit data from storage area and write Writing transmit data to SIOp (=SDRmn[7:0]) it to SIOp. Update transmit data pointer. Writing to SIOp makes SOp and SCKp signals out (communication starts) Wait for transmission/reception completes When transfer end interrupt is generated, it moves to interrupt processing routine. Transfer end interrupt Interrupt processing routine Read receive data then writes to storage area, update Read receive data to SIOp receive data pointer (=SDRmn[7:0]) RETI No Transmission/reception If there are the next data, it continues completed? Yes Main routine Disable interrupt (MASK) Write STmn bit to 1 End of communication Figure 11-46. Flowchart of Master Transmission/Reception (in Single-Transmission/Reception Mode) ## (4) Processing flow (in continuous transmission/reception mode) Figure 11-47. Timing Chart of Master Transmission/Reception (in Continuous Transmission/Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0) - **Notes 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. - **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. - Remarks 1. <1> to <8> in the figure correspond to <1> to <8> in Figure 11-48 Flowchart of Master Transmission/Reception (in Continuous Transmission/Reception Mode). - **2.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10, p: CSI number (p = 00, 01, 11, 20) Starting setting For the initial setting, refer to Figure 11-42. SAU default setting (Select buffer empty interrupt) Setting storage data and number of data for transmission/reception Setting ransmission/reception data (Storage area, Transmission data pointer, Reception data, Number of communication data and Communication end flag are optionally set on the internal RAM by the software) Clear interrupt request flag (XXIF), reset interrupt mask (XXMK) and Enables interrupt set interrupt enable (EI) Writing dummy data to Read transmit data from storage area and write it to SIOp. Update transmit data pointer. SIOp (=SDRmn[7:0]) Writing to SIOp makes SOp and SCKp signals out (communication starts) Wait for transmission/reception completes When transmission/reception interrupt is <3> <6> generated, it moves to interrupt processing routine Buffer empty/transfer end interrupt No BFFmn = 1? Yes Except for initial interrupt, read data received then write them to storage area, and update receive Reading reception data to <4> data pointer SIOp (=SDRmn[7:0]) <7> Interrupt processing routine Subtract -1 from number of transmit data If transmit data is left (number of communication da is equal or grater than 2), read them from storage area then write into SIOp, and update transmit data Number of communication data? If it's waiting for the last data to receive (number of communication data is equal to 1), change interrupt ≥2 timing to communication end Writing transmit data to Clear MDmn0 bit to 0 SIOp (=SDRmn[7:0]) RETI No Number of communication data = 0? Yes Write MDmn0 bit to 1 Continuing Communication? No Disable interrupt (MASK) <8> Write STmn bit to 1 End of communication Figure 11-48. 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-47 Timing Chart of Master Transmission/Reception (in Continuous Transmission/Reception Mode). # 11.5.4 Slave transmission Slave transmission is that the RL78 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 | CSI11 | CSI20 | | | |-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------------|-------------------|--|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | | Pins used | SCK00, SO00 | SCK00, SO00 SCK01, SO01 SCK11, SO11 SCK20 | | | | | | Interrupt | INTCSI00 | INTCSI01 | INTCSI11 | INTCSI20 | | | | | Transfer end interrupt (in single-transfer mode) or buffer empty interrupt (in continuous transfer mode) can be selected. | | | | | | | Error detection flag | Overrun error detection flag (OVFmn) only | | | | | | | Transfer data<br>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 • DAPmn = 0: Data output starts at 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 | Selectable by the CKPmn bit of the SCRmn register CKPmn = 0: Non-inversion CKPmn = 1: Inverted | | | | | | | Data direction | MSB or LSB first | | | | | | - **Notes 1.** Because the external serial clock input to the SCK00, SCK01, SCK11, and SCK20 pins is sampled internally and used, the fastest transfer rate is fmck/6 [Hz]. - Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). Remarks 1. fmck: Operation clock frequency of target channel fsck: Serial clock frequency 2. m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10 #### (1) Register setting Figure 11-49. Example of Contents of Registers for Slave Transmission of 3-Wire Serial I/O (CSI00, CSI01, CSI20) Notes 1. Provided in the serial array unit 0 of 30-pin products. 2. 20-, 24-pin products only. **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 2. ☐: Setting is fixed in the CSI master transmission mode, ☐: Setting disabled (set to the initial value) x: 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-50. Initial Setting Procedure for Slave Transmission Figure 11-51. 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 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. The master transmission is stopped. Go to the next processing. Figure 11-52. 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) Figure 11-53. Timing Chart of Slave Transmission (in Single-Transmission Mode) (Type 1: DAPmn = 0, CKPmn = 0) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Figure 11-54. Flowchart of Slave Transmission (in Single-Transmission Mode) ## (4) Processing flow (in continuous transmission mode) Figure 11-55. Timing Chart of Slave Transmission (in Continuous Transmission Mode) (Type 1: DAPmn = 0, CKPmn = 0) **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, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Figure 11-56. Flowchart of Slave Transmission (in Continuous Transmission Mode) Remark <1> to <6> in the figure correspond to <1> to <6> in Figure 11-55 Timing Chart of Slave Transmission (in Continuous Transmission Mode). ## 11.5.5 Slave reception Slave reception is that the RL78 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 | CSI11 | CSI20 | | | |----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------------------|-----------------------|--|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | | Pins used | SCK00, SI00 | SCK01, SI01 | SCK11, SI11 | SCK20, SI20 | | | | Interrupt | INTCSI00 | INTCSI01 | INTCSI11 | INTCSI20 | | | | | Transfer end interrupt mode) can be selected | ` | or buffer empty interrupt (i | n continuous transfer | | | | Error detection flag | Overrun error detection flag (OVFmn) only | | | | | | | Transfer data length | 7 or 8 bits | | | | | | | Transfer rate | Max. fmck/6 [Hz] <sup>Notes 1, 2</sup> . | | | | | | | Data phase | Selectable by the DAPmn bit of the SCRmn register • DAPmn = 0: Data output starts at 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 | Selectable by the CKPmn bit of the SCRmn register • CKPmn = 0: Non-inversion • CKPmn = 1: Inverted | | | | | | | Data direction | MSB or LSB first | | | | | | - **Notes 1.** Because the external serial clock input to the SCK00, SCK01, SCK11, and SCK20 pins is sampled internally and used, the fastest transfer rate is fmck/6 [Hz]. - 2. Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: Ta = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: Ta = -40 to +105°C)). - $\textbf{Remarks 1.} \ \, \textbf{fmck:} \ \ \, \textbf{Operation clock frequency of target channel}$ fsck: Serial clock frequency **2.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10 #### (1) Register setting Figure 11-57. Example of Contents of Registers for Slave Reception of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) - **Notes 1.** Provided in the serial array unit 0 of 30-pin products. - 2. 20-, 24-pin products only. **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 2. : Setting is fixed in the CSI master transmission mode, : 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: Set to 0 or 1 depending on the usage of the user ## (2) Operation procedure Figure 11-58. Initial Setting Procedure for Slave Reception Figure 11-59. Procedure for Stopping Slave Reception Figure 11-60. 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-61. Timing Chart of Slave Reception (in Single-Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Figure 11-62. Flowchart of Slave Reception (in Single-Reception Mode) ## 11.5.6 Slave transmission/reception Slave transmission/reception is that the RL78 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 | CSI11 | CSI20 | | | |----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|----------------------------|---------------------|--|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | | Pins used | SCK00, SI00, SO00 | SCK01, SI01, SO01 | SCK11, SI11, SO11 | SCK20, SI20, SO20 | | | | Interrupt | INTCSI00 | INTCSI00 INTCSI01 INTCSI11 | | | | | | | Transfer end interrupt (i mode) can be selected. | in single-transfer mode) or | buffer empty interrupt (in | continuous transfer | | | | Error detection flag | Overrun error detection flag (OVFmn) only | | | | | | | Transfer data length | 7 or 8 bits | | | | | | | Transfer rate | Max. fмcк/6 [Hz] <sup>Notes 1, 2</sup> | | | | | | | Data phase | Selectable by the DAPmn bit of the SCRmn register • DAPmn = 0: Data output starts at 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 | Selectable by the CKPmn bit of the SCRmn register • CKPmn = 0: Non-inversion • CKPmn = 1: Inverted | | | | | | | Data direction | MSB or LSB first | | | | | | - Notes 1. Because the external serial clock input to the SCK00, SCK01, SCK11, SCK20 pins is sampled internally and used, the fastest transfer rate is fмcκ/6 [Hz]. - Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). Remarks 1. fmck: Operation clock frequency of target channel fsck: Serial clock frequency **2.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10 # (1) Register setting Figure 11-63. Example of Contents of Registers for Slave Transmission/Reception of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) Notes 1. Provided in the serial array unit 0 of 30-pin products only. 2. 20-, 24-pin products only. Caution Be sure to set transmit data to the SIOp register before the clock from the master is started. **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 2. ☐: Setting is fixed in the CSI master transmission mode, ☐: Setting disabled (set to the initial value) x: 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-64. 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-65. Procedure for Stopping Slave 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. The master transmission is stopped. Go to the next processing. Figure 11-66. Procedure for Resuming Slave Transmission/Reception Cautions 1. Be sure to set transmit data to the SIOp register before the clock from the master is started. 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) Figure 11-67. Timing Chart of Slave Transmission/Reception (in Single-Transmission/Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Starting CSI communication For the initial setting, refer to Figure 11-65 SAU default setting (Select Transfer end interrupt) Setting storage area and number of data for transmission/reception data Setting (Storage area, Transmission/reception data pointer, Number of transmission/reception data communication data and Communication end flag are optionally set on the internal RAM by the software) Clear interrupt request flag (XXIF), reset interrupt mask (XXMK) **Enables interrupt** and set interrupt enable (EI). Read transmit data from storage area and write it to Writing transmit data to SIOp. Update transmit data pointer. SIOp (=SDRmn[7:0]) Start communication when master start providing the clock Wait for transmission/reception completes When transfer end interrupt is generated, it moves to interrupt processing routine nterrupt processing routine Transfer end interrupt Read receive data and write it to storage area. Reading receive data to SIOp (=SDRmn[7:0]) Update receive data pointer. **RETI** Transmission/reception completed? Yes Update the number of communication data and confirm Transmission/reception if next transmission/reception data is available next data? No Disable interrupt (MASK) Write STmn bit to 1 End of communication Figure 11-68. Flowchart of Slave Transmission/Reception (in Single-Transmission/Reception Mode) **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) Figure 11-69. Timing Chart of Slave Transmission/Reception (in Continuous Transmission/Reception Mode) (Type 1: DAPmn = 0, CKPmn = 0) - **Notes 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. - 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. - Remarks 1. <1> to <8> in the figure correspond to <1> to <8> in Figure 11-70 Flowchart of Slave Transmission/Reception (in Continuous Transmission/Reception Mode). - 2. m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), p: CSI number (p = 00, 01, 11, 20), mn = 00, 01, 03, 10 Starting setting For the initial setting, refer to Figure 11-64 SAU default setting (Select buffer empty interrupt) Setting storage area and number of data for transmission/reception data Setting (Transmission/reception data pointer, and Number of communication transmission/reception data data are optionally set on the internal RAM by the software) Main routine Clear interrupt request flag (XXIF), reset interrupt mask (XXMK) Enables interrupt and set interrupt enable (EI) Start communication when master start providing the clock Wait for transmission completes <3> <6> When buffer empty/transfer end is generated, moves to interrupt processing routine Buffer empty/transfer end interrupt No BFFmn = 1? Yes Other than the first interrupt, read reception data then Read receive data to SIOp <4> writes to storage area, update receive data pointer (=SDRmn[7:0]) Interrupt processing routine Subtract -1 from number of transmit data If transmit data is remained (number of communication data $\geq 2$ ), Number of read it from storage area, write it to SIOp, and then, update communication data? storage pointer. If transmit is completed (number of communication data = 1), ≥ 2 change to transfer end interrupt. Clear MDmn0 bit to 0 Writing transmit data to SIOp (=SDRmn[7:0]) RETI Number of communication data = 0? Write MDmn0 bit to 1 Communication continued? No Disable interrupt (MASK) Write STmn bit to 1 <8> End of communication Figure 11-70. 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-69 Timing Chart of Slave Transmission/Reception (in Continuous Transmission/Reception Mode). <R> #### 11.5.7 SNOOZE mode function The SNOOZE mode makes the CSI perform reception operations upon SCK00 pin input detection while in the STOP mode. Normally the CSI stops communication in the STOP mode. However, using the SNOOZE mode enables the CSI to perform reception operations without CPU operation upon detection of the SCK00 pin input. Only CSI00 can be set to the SNOOZE mode. When using the CSI in SNOOZE mode, make the following setting before switching to the STOP mode (see Figure 11-72 Flowchart of SNOOZE Mode Operation (once startup) and Figure 11-74 Flowchart of SNOOZE Mode Operation (continuous startup)). - When using the SNOOZE mode function, set the SWC0 bit of serial standby control register 0 (SSC0) to 1 just before switching to the STOP mode. After the initial setting has been completed, set the SS00 bit of serial channel start register 0 (SS0) 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. After a transition to the STOP mode, the CSI starts reception operations upon detection of an edge of the SCK00 pin. - Cautions 1. The SNOOZE mode can only be specified when the high-speed on-chip oscillator clock is selected for fclk. - 2. The maximum transfer rate when using CSI00 in the SNOOZE mode is 1 Mbps. ## (1) SNOOZE mode operation (once startup) Figure 11-71. Timing Chart of SNOOZE Mode Operation (once startup) (Type 1: DAP00 = 0, CKP00 = 0) Note Only read received data while SWC0 = 1 and before the next valid edge of the SCK00 pin input is detected. Cautions 1. Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the ST00 bit to 1 (clear the SE00 bit, and stop the operation).And after completion the receive operation, also clearing SWC0 bit to 0 (SNOOZE mode release). 2. When SWC0 = 1, the BFF01 and OVF01 flags will not change. Remark <1> to <11> in the figure correspond to <1> to <11> in Figure 11-72 Flowchart of SNOOZE Mode Operation (once startup). Figure 11-72. Flowchart of SNOOZE Mode Operation (once startup) Remark <1> to <11> in the figure correspond to <1> to <11> in Figure 11-71 Timing Chart of SNOOZE Mode Operation (once startup). ## (2) SNOOZE mode operation (continuous startup) Figure 11-73. Timing Chart of SNOOZE Mode Operation (continuous startup) (Type 1: DAP00 = 0, CKP00 = 0) - Note Only read received data while SWC0 = 1 and before the next valid edge of the SCK00 pin input is detected. - Cautions 1. Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the ST00 bit to 1 (clear the SE00 bit, and stop the operation). And after completion the receive operation, also clearing SWC0 bit to 0 (SNOOZE release). - 2. When SWC0 = 1, the BFF01 and OVF01 flags will not change. Remark <1> to <10> in the figure correspond to <1> to <10> in Figure 11-74 Flowchart of SNOOZE Mode Operation (continuous startup). Figure 11-74. Flowchart of SNOOZE Mode Operation (continuous startup) Remark <1> to <10> in the figure correspond to <1> to <10> in Figure 11-73 Timing Chart of SNOOZE Mode Operation (continuous startup). # 11.5.8 Calculating transfer clock frequency The transfer clock frequency for 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) communication can be calculated by the following expressions. (1) Master (Transfer clock frequency) = {Operation clock (fмcκ) 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 11111111B) 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). Table 11-2. Selection of Operation Clock For 3-Wire Serial I/O | | SMRmn<br>Register | SPS0 Register | | | | | r | | 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 | | fcLK = 20 MHz | | | 0 | Χ | Χ | Χ | Х | 0 | 0 | 0 | 0 | fclk | 20 MHz | | | | Χ | Χ | Х | Х | 0 | 0 | 0 | 1 | fclk/2 | 10 MHz | | | | Χ | Χ | Х | Х | 0 | 0 | 1 | 0 | fclk/2 <sup>2</sup> | 5 MHz | | | | Х | Х | Х | Х | 0 | 0 | 1 | 1 | fclk/2 <sup>3</sup> | 2.5 MHz | | | | Х | Х | Х | Х | 0 | 1 | 0 | 0 | fclk/2 <sup>4</sup> | 1.25 MHz | | <r></r> | | Χ | Χ | Χ | Х | 0 | 1 | 0 | 1 | fclk/2 <sup>5</sup> | 625 MHz | | | | Χ | Χ | Χ | Х | 0 | 1 | 1 | 0 | fclk/2 <sup>6</sup> | 312.5 kHz | | | | Χ | Χ | Χ | Х | 0 | 1 | 1 | 1 | fclk/2 <sup>7</sup> | 156.2 kHz | | | | Χ | Χ | Χ | Χ | 1 | 0 | 0 | 0 | fclk/2 <sup>8</sup> | 78.1 kHz | | | | Χ | Χ | Χ | Х | 1 | 0 | 0 | 1 | fclk/29 | 39.1 kHz | | | | Χ | Χ | Χ | Х | 1 | 0 | 1 | 0 | fclk/2 <sup>10</sup> | 19.5kHz | | | | Χ | Χ | Χ | Χ | 1 | 0 | 1 | 1 | fclk/2 <sup>11</sup> | 9.77 kHz | | | | Χ | Χ | Χ | Х | 1 | 1 | 0 | 0 | fclk/2 <sup>12</sup> | 4.88 kHz | | | | Χ | Χ | Χ | Х | 1 | 1 | 0 | 1 | fclk/2 <sup>13</sup> | 2.44 kHz | | | | Χ | Χ | Χ | Χ | 1 | 1 | 1 | 0 | fclk/2 <sup>14</sup> | 1.22 kHz | | | | Χ | Χ | Χ | Χ | 1 | 1 | 1 | 1 | fclk/2 <sup>15</sup> | 610 Hz | | | 1 | 0 | 0 | 0 | 0 | Χ | Χ | Χ | Χ | fclk | 20 MHz | | | | 0 | 0 | 0 | 1 | Χ | Χ | Χ | Χ | fclk/2 | 10 MHz | | | | 0 | 0 | 1 | 0 | Χ | Χ | Χ | Χ | fclk/2 <sup>2</sup> | 5 MHz | | | | 0 | 0 | 1 | 1 | Х | Χ | Χ | Χ | fclk/2 <sup>3</sup> | 2.5 MHz | | | | 0 | 1 | 0 | 0 | Χ | Χ | Χ | Χ | fclk/2 <sup>4</sup> | 1.25 MHz | | <r></r> | | 0 | 1 | 0 | 1 | Χ | Χ | Χ | Χ | fclk/2⁵ | 625 MHz | | | | 0 | 1 | 1 | 0 | Χ | Χ | Χ | Χ | fclk/2 <sup>6</sup> | 312.5 kHz | | | | 0 | 1 | 1 | 1 | Χ | Χ | Χ | Χ | fclk/2 <sup>7</sup> | 156.2 kHz | | | | 1 | 0 | 0 | 0 | Χ | Χ | Χ | Χ | fclk/2 <sup>8</sup> | 78.1 kHz | | | | 1 | 0 | 0 | 1 | Χ | Χ | Χ | Χ | fclk/29 | 39.1 kHz | | | | 1 | 0 | 1 | 0 | Χ | Χ | Χ | Χ | fclk/2 <sup>10</sup> | 19.5 kHz | | | | 1 | 0 | 1 | 1 | Χ | Χ | Χ | Χ | fclk/2 <sup>11</sup> | 9.77 kHz | | | | 1 | 1 | 0 | 0 | Χ | Χ | Х | Χ | fclk/2 <sup>12</sup> | 4.88 kHz | | | | 1 | 1 | 0 | 1 | Х | Χ | Х | Χ | fclk/2 <sup>13</sup> | 2.44 kHz | | | | 1 | 1 | 1 | 0 | Χ | Χ | Χ | Χ | fclk/2 <sup>14</sup> | 1.22 kHz | | | | 1 | 1 | 1 | 1 | Χ | Х | Х | Χ | fclk/2 <sup>15</sup> | 610 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). Remarks 1. X: don't care **2.** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10 # 11.5.9 Procedure for processing errors that occurred during 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) communication The procedure for processing errors that occurred during 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) communication is described in Figure 11-75. Figure 11-75. Processing Procedure in Case of Overrun Error | Software Manipulation | Hardware Status | Remark | | |------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--| | Reads serial data register mn (SDRmn).—I | 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 register mn (SIRmn). | Error flag is cleared. | Error can be cleared only during reading, by writing the value read from the SSRmn register to the SIRmn register without modification. | | **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00, 01, 03, 10 # 11.6 Operation of UART (UART0 to UART2) 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 consists 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 asynchronous UART communication can be performed by using a channel dedicated to transmission (an even-numbered channel) and a channel dedicated to reception (an odd-numbered channel). ## [Data transmission/reception] - Data length of 7, 8, or 9 bits<sup>Note 1</sup> - · Select the MSB/LSB first - · Level setting of transmit/receive data and select of reverse (selecting whether to reverse the level) - · Parity bit appending and parity check functions - · Stop bit appending and stop bit check functions #### [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 UART0 is compatible with SNOOZE mode. When RxD0 pin input is detected while in the STOP mode, the SNOOZE mode makes data reception that does not require the CPU possible. Note 1. Only UART0 can be specified for the 9-bit data length. 20- or 24-pin products | Unit | Channel | Channel Used as CSI Used as UART | | Used as Simplified I <sup>2</sup> C | |------|---------|----------------------------------|-------|-------------------------------------| | 0 | 0 | CSI00 | UART0 | IIC00 <sup>Note 2</sup> | | | 1 | CSI01 <sup>Note 2</sup> | | IIC01 <sup>Note 2</sup> | 30-pin products | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C | |------|---------|-------------------------|-------------------------|-------------------------------------| | 0 | 0 | CSI00 | UART0 | IIC00 <sup>Note 2</sup> | | | 1 | - | | _ | | | 2 | - | UART1 <sup>Note 2</sup> | - | | | 3 | CSI11 <sup>Note 2</sup> | | IIC11 <sup>Note 2</sup> | | 1 | 0 | CSI20 <sup>Note 2</sup> | UART2 <sup>Note 2</sup> | IIC20 <sup>Note 2</sup> | | | 1 | - | | - | Note 2. Provided in the R5F102 products only. 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 CSI01. At this time, however, channel 2, 3, or other channels of the same unit can be used for a function other than UART0, such as CSI10, UART1, and IIC10. (Caution is listed on the next page.) **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 two types of communication operations. - UART transmission (See 11.6.1.) - UART reception (See 11.6.2.) #### 11.6.1 UART transmission UART transmission is an operation to transmit data from the RL78 microcontroller to another device asynchronously (start-stop synchronization). Of the two channels used for UART, the even-numbered channel is used for UART transmission. | UART | UART0 | UART1 | UART2 | | | | | |---------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------|--|--|--|--| | Target channel | Channel 0 of SAU0 | Channel 2 of SAU0 | Channel 0 of SAU1 | | | | | | Pins used | TxD0 | TxD1 | TxD2 | | | | | | Interrupt | INTST0 | INTST1 | INTST2 | | | | | | | Transfer end interrupt (in single mode) can be selected. | -transfer mode) or buffer empty in | terrupt (in continuous transfer | | | | | | Error detection flag | None | | | | | | | | Transfer data length | 7, 8, or 9 bits <sup>Note 1</sup> | | | | | | | | Transfer rate <sup>Note 2</sup> | Max. fмcк/6 [bps] (SDRmn[15:9] | ] = 2 or greater), Min. fcLk/ $(2 \times 2^{15})$ | × 128) [bps] <sup>Note</sup> | | | | | | Data phase | Non-inverted output (default: hi<br>Inverted output (default: low lev | • , | | | | | | | Parity bit | The following selectable No parity bit Appending 0 parity Appending even parity Appending odd parity | <ul> <li>No parity bit</li> <li>Appending 0 parity</li> <li>Appending even parity</li> </ul> | | | | | | | Stop bit | The following selectable • Appending 1 bit • Appending 2 bits | | | | | | | | Data direction | MSB or LSB first | | | | | | | Notes 1. Only UART0 can be specified for the 9-bit data length. Use this operation within a range that satisfies the conditions above and the peripheral function characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). Remarks 1. fmck: Operation clock frequency of target channel fclk: System clock frequency **2.** m: Unit number (m = 0, 1) n: Channel number (n = 0, 2), mn = 00, 02, 10 #### (1) Register setting Figure 11-76. Example of Contents of Registers for UART Transmission (UART0 to UART2) (1/2) #### (a) Serial mode register mn (SMRmn) 9 8 6 5 3 2 0 **SMRmn** /IDmn( CKSm CCSm MDmr /IDmn2 0/1 0 0 0 0 0 0 0 0 0 0 0 0 0/1 Operation clock (fmck) of channel n Interrupt source of channel n 0: Prescaler output clock CK00 set by the SPS0 register 0: Transfer end interrupt 1: Prescaler output clock CK01 set by the SPS0 register 1: Buffer empty interrupt (b) Serial communication operation setting register mn (SCRmn) 0 DLSmn1 SCRmn RXEmr DAPmi TCmn PTCmn( DIRmr SLCmn1 SLCmn( DLSmn 1 0 0 0 0 0 0/1 0/1 0/1 0 0/1 0/1 0 0/1 0/1 Setting of stop bit Setting of parity bit 01B: Appending 1 bit 00B: No parity 10B: Appending 2 bits 01B: Appending 0 parity Selection of data transfer sequence 10B: Appending Even parity 0: Inputs/outputs data with MSB first 11B: Appending Odd parity 1: Inputs/outputs data with LSB first. (c) Serial data register mn (SDRmn) (lower 8 bits: TXDq) 15 14 13 12 11 10 8 6 5 3 2 0 **SDRmn** Baud rate setting Transmit data setting 0 TXDq (d) Serial output level register m (SOLm) ... Sets only the bits of the target channel. 15 14 13 12 11 10 8 0 SOLm2 SOLm SOLmo Notes 1. Provided only in SCR00 register (UART0) only. For SCR02 and SCR10 registers, this bit is fixed to 1. 0 When performs 9-bit communication (by setting the DLS001 and DLS000 bits of the SMR00 register to 1), bits 0 to 8 of the SDR00 register are used as the transmission data specification area. 9-bit communication is available only in UART0. 0 0 0 0: Non-inverted transmission1: Inverted transmission 0 0 0/1 0 0/1 3. Provided only in 30-pin product serial array unit 0. 0 0 0 **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0, 2), q: UART number (q = 0 to 2), mn = 00, 02, 10 2. : Setting is fixed in the CSI master transmission mode, : Setting disabled (set to the initial value) 0/1: Set to 0 or 1 depending on the usage of the user 0 n 0 0 Figure 11-76. Example of Contents of Registers for UART Transmission (UART0 to UART2) (2/2) (e) Serial output register m (SOm) ... Sets only the bits of the target channel. (f) Serial output enable register m (SOEm) ... 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 | |------|----|----|----|----|----|----|---|---|---|---|---|---|----------------|--------|-------|-------| | SOEm | | | | | | | | | | | | | SOE03<br>Note1 | Note 1 | SOE01 | SOEm0 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | × | 0/1 | × | 0/1 | (g) 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 | | | | | | | | | | | | | SS03<br>Note1 | SS02<br>Note1 | SSm1 | SSm0 | l | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | × | 0/1 | × | 0/1 | l | Notes 1. Provided only in 30-pin product serial array unit 0. 2. Before transmission is started, be sure to set to 1 when the SOL00 bit of the target channel is set to 0, and set to 0 when the SOL00 bit of the target channel is set to 1. The value varies depending on the communication data during communication operation. **Remarks 1.** m: Unit number (m = 0, 1), n: Channel number (n = 0, 2), mn = 00, 02, 10 x: 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-77. Initial Setting Procedure for UART Transmission Figure 11-78. Procedure for Stopping UART Transmission Figure 11-79. 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) Figure 11-80. Timing Chart of UART Transmission (in Single-Transmission Mode) **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0, 2), q: UART number (q = 0 to 2), mn = 00, 02, 10 Figure 11-81. Flowchart of UART Transmission (in Single-Transmission Mode) ## (4) Processing flow (in continuous transmission mode) Figure 11-82. 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 (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, 1), n: Channel number (n = 0, 2), q: UART number (q = 0 to 2), mn = 00, 02, 10 Figure 11-83. Flowchart of UART Transmission (in Continuous Transmission Mode) Remark <1> to <6> in the figure correspond to <1> to <6> in Figure 11-82 Timing Chart of UART Transmission (in Continuous Transmission Mode). ## 11.6.2 UART reception UART reception is an operation wherein the RL78 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 | UART1 | UART2 | | | | |---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------|--|--|--| | Target channel | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 1 of SAU1 | | | | | Pins used | RxD0 | RxD1 | RxD2 | | | | | Interrupt | INTSR0 | INTSR1 | INTSR2 | | | | | | Transfer end interrupt only (set | ting the buffer empty interrupt is p | rohibited) | | | | | Error interrupt | INTSRE0 | INTSRE1 | INTSRE2 | | | | | Error detection flag | Framing error detection flag (I Parity error detection flag (PE Overrun error detection flag (I | Fmn) | | | | | | Transfer data length | 7, 8 or 9 bits <sup>Note 1</sup> | | | | | | | Transfer rate <sup>Note 2</sup> | Max. fмcк/6 [bps] (SDRmn [15:9 | $[0] = 2 \text{ or more}$ ), Min. fclk/ $(2 \times 2^{15} \times 10^{15})$ | 128) [bps] <sup>Note</sup> | | | | | Data phase | Non-inverted output (default: hi<br>Inverted output (default: low lev | , | | | | | | Parity bit | The following selectable No parity bit (no parity check) No parity specified (0 parity) Appending even parity Appending odd parity | | | | | | | Stop Bit | Appending 1 bit | | | | | | | Data direction | MSB or LSB first | | | | | | Notes 1. Only UART0 can be specified for the 9-bit data length. 2. Use this operation within a range that satisfies the conditions above and the peripheral characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). Remarks 1. fmck: Operation clock frequency of target channel fclk: System clock frequency **2.** m: Unit number (m = 0, 1) n: Channel number (n = 1, 3), mn = 01, 03, 11 #### (1) Register setting Figure 11-84. Example of Contents of Registers for UART Reception (UART0 to UART2) (1/2) - Notes 1. Provided only in SCR01 register (UART0) only. For SCR03 and SCR11 registers, this bit is fixed to 1. - 2. When UART performs 9-bit communication, bits 0 to 8 of the SDR01 register are used as the transmission data specification area. 9-bit communication is available only in UARTO. For the UART reception, be sure to set the SMRmr register of channel r to UART transmission mode that is to be paired with channel n. **Remarks 1.** m: Unit number (m = 0, 1) n: Channel number (n = 1, 3), mn = 01, 03, 11r: Channel number (r = n - 1) q: UART number (q = 0 to 2) > 2. 🔲 : Setting is fixed in the UART master transmission mode, 🔲 : Setting disabled (set to the initial value) 0/1: Set to 0 or 1 depending on the usage of the user Figure 11-84. Example of Contents of Registers for UART Reception (UART0 to UART2) (2/2) (e) Serial output register m (SOm) ... The register that not used in this mode. (f) Serial output enable register m (SOEm) ... The register that not used in this mode. (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 | | | | | | | | | | | | | SS03<br>Note | SS02<br>Note | SSm1 | SSm0 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0/1 | × | 0/1 | × | Note Provided only in 30-pin product serial array unit 0. **Remarks 1.** m: Unit number (m = 0, 1) **2.** Setting disabled (set to the initial value) $\times$ : 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-85. Initial Setting Procedure for UART Reception Caution After setting the RXEmn bit of SCRmn register to 1, be sure to set SSmn to 0 after 4 or more folk clocks have elapsed. Figure 11-86. Procedure for Stopping UART Reception Figure 11-87. Procedure for Resuming UART Reception Caution After setting the RXEmn bit of SCRmn register to 1, be sure to set SSmn to 0 after 4 or more fmck clocks have elapsed. **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 Figure 11-88. UART Reception Timing Chart **Remark** m: Unit number (m = 0, 1) n: Channel number (n = 1, 3), mn = 01, 03, 11 r: Channel number (r = n - 1) q: UART number (q = 0 to 2) Figure 11-89. Flowchart of UART Reception #### 11.6.3 SNOOZE mode function SNOOZE mode makes UART operate reception by RxD0 pin input detection while 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 UART0 can be set to the SNOOZE mode. When using UART0 in the SNOOZE mode, make the following settings before entering the STOP mode. (See **Figure 11-92 Flowchart of SNOOZE Mode Operation (EOC01 = 0, SSEC0 = 0/1 or EOC01 = 1, SSEC0 = 0)** and **Figure 11-94 Flowchart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 1).**) - 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 SPS0 register and bits 15 to 9 of the SDR01 register with reference to Table 11-3. - Set the EOC01 and SSEC0 bits. This is for enabling or stopping generation of an error interrupt (INTSRE0) when a communication error occurs. - Set the SWC0 bit of serial standby control register 0 (SSC0) to 1 just before switching to the STOP mode. After the initial setting has completed, set the SS01 bit of serial channel start register 0 (SS0) to 1. - A UART0 starts reception in SNOOZE mode on detecting input of the start bit on the RxD0 pin following a transition of the CPU to the STOP mode. - Cautions 1. The SNOOZE mode can only be used when the high-speed on-chip oscillator clock (fin) is selected for fc. k. - 2. The transfer rate in the SNOOZE mode is only 4800 bps. - 3. When SWC0 = 1, UART0 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 SWC0 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 SWC0 bit is returned to 0 - **4.** If a parity error, framing error, or overrun error occurs while the SSEC0 bit is set to 1, the PEF01, FEF01, or OVF01 flag is not set and an error interrupt (INTSRE0) is not generated. Therefore, when the setting of SSEC0 = 1 is made, clear the PEF01, FEF01, or OVF01 flag before setting the SWC0 bit to 1 and read the value in bits 7 to 0 (RxD0 register) of the SDR01 register. - 5. The CPU shifts from the STOP mode to the SNOOZE mode on detecting the valid edge of the RxD0 signal. Note, however, that transfer through the UART channel may not start and the CPU may remain in the SNOOZE mode if an input pulse on the RxD0 pin is too short to be detected as a start bit. In such cases, data may not be received correctly, and this may lead to a framing error or parity error in the next UART transfer. <R> <R> Table 11-3. Baud Rate Setting for UART Reception in SNOOZE Mode | | | Baud Rate for UART Reception in SNOOZE Mode | | | | | | | | | |-----------------------------------------|------------------------|---------------------------------------------|------------------------------|------------------------------|--|--|--|--|--|--| | | | Baud Rat | e of 4800 bps | | | | | | | | | High-speed On-chip<br>Oscillator (fн) | Operation Clock (fмск) | SDRmn[15:9] | Maximum<br>Permissible Value | Minimum Permissible<br>Value | | | | | | | | $24~\text{MHz} \pm 1.0\%^{\text{Note}}$ | fclk/2 <sup>5</sup> | 79 | 1.60% | -2.18% | | | | | | | | 16 MHz ± 1.0% Note | fclk/2 <sup>4</sup> | 105 | 2.27% | -1.53% | | | | | | | | 12 MHz ± 1.0% Note | fclk/2 <sup>4</sup> | 79 | 1.60% | -2.19% | | | | | | | | 8 MHz ± 1.0% <sup>Note</sup> | fclk/2 <sup>3</sup> | 105 | 2.27% | -1.53% | | | | | | | | 6 MHz ± 1.0% Note | fclk/2 <sup>3</sup> | 79 | 1.60% | -2.19% | | | | | | | | 4 MHz ± 1.0% Note | fclk/2 <sup>2</sup> | 105 | 2.27% | -1.53% | | | | | | | | 3 MHz ± 1.0% Note | fclk/2² | 79 | 1.60% | -2.19% | | | | | | | | 2 MHz ± 1.0% Note | fcLk/2 | 105 | 2.27% | -1.54% | | | | | | | | 1 MHz ± 1.0% <sup>Note</sup> | fclk | 105 | 2.27% | -1.57% | | | | | | | **Note** When the accuracy of the clock frequency of the high-speed on-chip oscillator is $\pm 1.5\%$ or $\pm 2.0\%$ , the permissible range becomes smaller as shown below. - In the case of fin $\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 $f_{\text{IH}} \pm 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. <R> ## (1) SNOOZE mode operation (EOC01 = 0, SSEC0 = 0/1) Because of the setting of EOC01 = 0, even though a communication error occurs, an error interrupt (INTSRE0) is not generated, regardless of the setting of the SSEC0 bit. A transfer end interrupt (INTSR0) will be generated. Normal operation STOP mode SNOOZE mode Normal operation CPU operation status <3> <12> SS01 <10> ST01 SE01 <2> 1 SWC0 <11> EOC01 SSEC0 Clock request signal (internal signal) Receive data 2 Receive data 1 SDR01 <9>▲ Read ST Receive data 1 X P / SP Receive data 2 (P/SF RxD0 pin Shift Shift operation Shift operation register 01 INTSR0 <7> Data reception Data reception INTSRE0 L TSF01 <8> <5><6> Figure 11-90. Timing Chart of SNOOZE Mode Operation (EOC01 = 0, SSEC0 = 0/1) **Note** Read the received data when SWC0 = 1. Caution Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, be sure to set the ST00 bit to 1 (clear the SE00 bit to stop the operation). And after completion the receive operation, also clearing SWC0 bit to 0 (SNOOZE mode release). Remark <1> to <12> in the figure correspond to <1> to <12> in Figure 11-92 Flowchart of SNOOZE Mode Operation (EOC01 = 0, SSEC0 = 0/1 or EOC01 = 1, SSEC0 = 0). ## (2) SNOOZE mode operation (EOC01 = 1, SSEC0 = 0: Error interrupt (INTSRE0) generation is enabled) Because EOC01 = 0 and SSEC0 = 0, an error interrupt (INTSRE0) is generated when a communication error occurs. <R> CPU operation status Normal operation STOP mode SNOOZE mode Normal operation <12> I SS01 ST01 <10> SE01 SWC0 <11> EOC01 SSEC0 Clock request signal (internal signal) Receive data 2 SDR01 Receive data 1 <9>▲ Read<sup>Note</sup> RxD0 pin ST/ X P /SP Receive data 2 Receive data 1 P/SF Shift register 01 Shift operation Shift operation INTSR0 Data reception Data reception INTSRE0 TSF01 <5> <6> <8> Figure 11-91. Timing Chart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 0) <R> **Note** Read the received data when SWCm = 1. Caution Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, be sure to set the ST01 bit to 1 (clear the SE01 bit to stop the operation). And after completion of the receive operation, also clearing SWC0 bit to 0 (SNOOZE mode release). Remark <1> to <12> in the figure correspond to <1> to <12> in Figure 11-92 Flowchart of SNOOZE Mode Setting start <R> No Does TSF01 = 0 on all channels? Yes The operation of all channels is also stopped to switch to the Does TSF01 = 0 on all STOP mode. channels? Normal operation Channel 1 is specified for UART reception SAU default setting (change to the UART reception baud rate in SNOOZE mode (SPS0 register and bits 15 to 9 in SDR01 register)). Setting SSC0 register SNOOZE mode setting (SWC0 = 1)Writing 1 to the SS01 bit Communication wait status → SE01 = 1 Clear interrupt request flag (XXIF), reset interrupt mask (XXMK) Enable interrupt and set interrupt enable (EI = 1). SNOOZE mode STOP mode fclk supplied to the SAU is stopped. Entered the STOP mode The valid edge of the RxD0 pin <5> detected (Entered the SNOOZE mode) Input of the start bit on the RxD0 pin <6> detected (UART receive operation) Transfer end interrupt (INTSR0) or error <8> interrupt (INTSRE0) generated? INTSRE0 INTSR0 Reading receive data from the <9> Reading receive data from the The mode switches from SNOOZE to SDR00[7:0] bits (RXD0 register) SDR00[7:0] bits (RXD0 register) normal operation. (8 bits) or the SDR00[8:0] (9 bits) (8 bits) or the SDR00[8:0] (9 bits) Writing 1 to the ST01 bit Writing 1 to the ST01 bit To operation stop status (SE01 = 0) <10> Normal operation Writing 0 to the SWC0 bit <11> Writing 0 to the SWC0 bit Clear SNOOZE mode setting Error processing Set the SPS0 register and bits 15 to 9 in the Change to the UART Change to the UART reception baud rate in reception baud rate in SDR01 register. normal operation normal operation Writing 1 to the SS01 bit Writing 1 to the SS01 bit <12> To communication wait status (SE01 = 1) Normal operation Normal operation Figure 11-92. Flowchart of SNOOZE Mode Operation (EOC01 = 0, SSEC0 = 0/1 or EOC01 = 1, SSEC0 = 0) Remark <1> to <11> in the figure correspond to <1> to <11> in Figure 11-90 Timing Chart of SNOOZE Mode Operation (EOC01 = 0, SSEC0 = 0/1) and Figure 11-91 Timing Chart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 0). #### (3) SNOOZE mode operation (EOC01 = 1, SSEC0 = 1: Error interrupt (INTSRE0) generation is stopped) Because EOC01 = 1 and SSEC0 = 1, an error interrupt (INTSRE0) is not generated when a communication error occurs. Figure 11-93. Timing Chart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 1: Error interrupt (INTSRE0) generation is stopped) **Note** Read the received data when SWC0 = 1. - Cautions 1. Before switching to the SNOOZE mode or after reception operation in the SNOOZE mode finishes, set the ST01 bit to 1 (clear the SE01 bit and stop the operation). After the receive operation completes, also clear the SWC0 bit to 0 (SNOOZE mode release). - 2. If a parity error, framing error, or overrun error occurs while the SSEC0 bit is set to 1, the PEF01, FEF01, or OVF01 flag is not set and an error interrupt (INTSRE0) is not generated. Therefore, when the setting of SSEC0 = 1 is made, clear the PEF01, FEF01, or OVF01 flag before setting the SWC0 bit to 1 and read the value in SDR01[7:0] (RxD0 register) (8 bits) or SDR01[8:0] (9 bits). Remark <1> to <11> in the figure correspond to <1> to <11> in Figure 11-94 Flowchart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 1). Figure 11-94. Flowchart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 1) Caution If a parity error, framing error, or overrun error occurs while the SSEC0 bit is set to 1, the PEF01, FEF01, or OVF01 flag is not set and an error interrupt (INTSRE0) is not generated. Therefore, when the setting of SSEC0 = 1 is made, clear the PEF01, FEF01, or OVF01 flag before setting the SWC0 bit to 1 and read the value in SDR01[7:0] (RxD0 register) (8 bits) or SDR01[8:0] (9 bits). Remark <1> to <11> in the figure correspond to <1> to <11> in Figure 11-93 Timing Chart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 1: Error interrupt (INTSRE0) generation is stopped). ## 11.6.4 Calculating baud rate ## (1) Baud rate calculation expression The baud rate for UART (UART0 to UART2) communication can be calculated by the following expressions. (Baud rate) = {Operation clock (fmck) frequency of target channel} ÷ (SDR0n[15:9] + 1) ÷ 2 [bps] Caution Setting serial data register mn (SDRmn) SDRmn[15:9] = (0000000B, 0000001B) is prohibited. - **Remarks 1.** When UART is used, the value of SDRmn[15:9] is the value of bits 15 to 9 of the SDRmn register (0000010B, 1111111B) and therefore is 2 to 127. - 2. m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00 to 03, 10, 11 The operation clock (fmck) is determined by serial clock select register m (SPSm) and bit 15 (CKSmn) of serial mode register mn (SMRmn). Table 11-4. Selection of Operation Clock For UART | | SMRmn<br>Register | | | 5 | SPSm F | Registe | r | | | Operation | on Clock (fMCK) <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 | | fclk = 20 MHz | | | 0 | Х | Х | Х | Х | 0 | 0 | 0 | 0 | fclk | 20 MHz | | | | Х | Х | Χ | Χ | 0 | 0 | 0 | 1 | fclk/2 | 10 MHz | | | | Х | Х | Х | Х | 0 | 0 | 1 | 0 | fclk/2 <sup>2</sup> | 5 MHz | | | | Х | Χ | Χ | Χ | 0 | 0 | 1 | 1 | fclk/2 <sup>3</sup> | 2.5 MHz | | | | Х | Х | Χ | Χ | 0 | 1 | 0 | 0 | fclk/2 <sup>4</sup> | 1.25 MHz | | <r></r> | | Х | Х | Χ | Χ | 0 | 1 | 0 | 1 | fc∟κ/2⁵ | 625 MHz | | \1\1> | | Х | Χ | Х | Х | 0 | 1 | 1 | 0 | fclk/2 <sup>6</sup> | 312.5 kHz | | | | Х | Х | Χ | Χ | 0 | 1 | 1 | 1 | fclk/2 <sup>7</sup> | 156.2 kHz | | | | Х | Х | Х | Х | 1 | 0 | 0 | 0 | fclk/2 <sup>8</sup> | 78.1 kHz | | | | Х | Х | Х | Х | 1 | 0 | 0 | 1 | fclk/2 <sup>9</sup> | 39.1 kHz | | | | Х | Χ | Х | Х | 1 | 0 | 1 | 0 | fclk/2 <sup>10</sup> | 19.5 kHz | | | | Х | Χ | Χ | Χ | 1 | 0 | 1 | 1 | fclk/2 <sup>11</sup> | 9.77 kHz | | | | Х | Χ | Χ | Χ | 1 | 1 | 0 | 0 | fclk/2 <sup>12</sup> | 4.88 kHz | | | | Х | Χ | Х | Х | 1 | 1 | 0 | 1 | fcLk/2 <sup>13</sup> | 2.44 kHz | | | | Х | Χ | Х | Х | 1 | 1 | 1 | 0 | fcLK/2 <sup>14</sup> | 1.22 kHz | | | | Х | Χ | Х | Х | 1 | 1 | 1 | 1 | fclk/2 <sup>15</sup> | 610 Hz | | | 1 | 0 | 0 | 0 | 0 | Χ | Χ | Х | Χ | fclk | 20 MHz | | | | 0 | 0 | 0 | 1 | Х | Х | Х | Х | fclk/2 | 10 MHz | | | | 0 | 0 | 1 | 0 | Х | Х | Х | Х | fclk/2 <sup>2</sup> | 5 MHz | | | | 0 | 0 | 1 | 1 | Х | Х | Х | Х | fclk/2 <sup>3</sup> | 2.5 MHz | | | | 0 | 1 | 0 | 0 | Х | Χ | Х | Х | fclk/2 <sup>4</sup> | 1.25 MHz | | | | 0 | 1 | 0 | 1 | Х | Χ | Х | Х | fclk/2 <sup>5</sup> | 625 MHz | | | | 0 | 1 | 1 | 0 | Х | Χ | Х | Х | fclk/2 <sup>6</sup> | 312.5 kHz | | | | 0 | 1 | 1 | 1 | Χ | Χ | Х | Χ | fclk/2 <sup>7</sup> | 156.2 kHz | | | | 1 | 0 | 0 | 0 | Χ | Χ | Х | Χ | fclk/2 <sup>8</sup> | 78.1 kHz | | | | 1 | 0 | 0 | 1 | Х | Х | Х | Х | fclk/29 | 39.1 kHz | | | | 1 | 0 | 1 | 0 | Х | Х | Х | Х | fclk/2 <sup>10</sup> | 19.5 kHz | | | | 1 | 0 | 1 | 1 | Х | Х | Х | Х | fclк/2 <sup>11</sup> | 9.77 kHz | | | | 1 | 1 | 0 | 0 | Х | Х | Х | Х | fclк/2 <sup>12</sup> | 4.88 kHz | | | | 1 | 1 | 0 | 1 | Х | Х | Х | Х | fclк/2 <sup>13</sup> | 2.44 kHz | | | | 1 | 1 | 1 | 0 | Х | Х | Х | Х | fclк/2 <sup>14</sup> | 1.22 kHz | | | | 1 | 1 | 1 | 1 | Х | Х | Х | Х | fclк/2 <sup>15</sup> | 610 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). Remarks 1. X: don't care 2. m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00 to 03, 10, 11 # (2) Baud rate error during transmission The baud rate error of UART (UART0 to UART2) 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) $\div$ (Target baud rate) $\times$ 100 – 100 [%] Here is an example of setting a UART baud rate at fclk = 20 MHz. | UART Baud Rate | | f | CLK = 20 MHz | | |--------------------|------------------------|-------------|----------------------|-----------------------------| | (Target Baud Rate) | Operation Clock (fмск) | SDRmn[15:9] | Calculated Baud Rate | Error from Target Baud Rate | | 300 bps | fclk/2 <sup>9</sup> | 64 | 300.48 bps | +0.16 % | | 600 bps | fclk/2 <sup>8</sup> | 64 | 600.96 bps | +0.16 % | | 1200 bps | fclk/2 <sup>7</sup> | 64 | 1201.92 bps | +0.16 % | | 2400 bps | fclk/2 <sup>6</sup> | 64 | 2403.85 bps | +0.16 % | | 4800 bps | fclk/2⁵ | 64 | 4807.69 bps | +0.16 % | | 9600 bps | fc∟k/2⁴ | 64 | 9615.38 bps | +0.16 % | | 19200 bps | fclk/2³ | 64 | 19230.8 bps | +0.16 % | | 31250 bps | fclk/2³ | 39 | 31250.0 bps | ±0.0 % | | 38400 bps | fclk/2 <sup>2</sup> | 64 | 38461.5 bps | +0.16 % | | 76800 bps | fclk/2 | 64 | 76923.1 bps | +0.16 % | | 153600 bps | fclk | 64 | 153846 bps | +0.16 % | | 312500 bps | fclk | 31 | 312500 bps | ±0.0 % | **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0, 2), mn = 00, 02, 10 #### (3) Permissible baud rate range for reception The permissible baud rate range for reception during UART (UART0 to UART2) 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. $$(\text{Maximum receivable baud rate}) = \frac{2 \times k \times N \text{fr}}{2 \times k \times N \text{fr} - k + 2} \times \text{Brate}$$ $$(\text{Minimum receivable baud rate}) = \frac{2 \times k \times (N \text{fr} - 1)}{2 \times k \times N \text{fr} - k - 2} \times \text{Brate}$$ Brate: Calculated baud rate value at the reception side (See 11.6.4 (1) Baud rate calculation expression.) SDRmn[15:9] + 1 k: 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, 3), mn = 01, 03, 11 Figure 11-95. Permissible Baud Rate Range for Reception (1 Data Frame Length = 11 Bits) As shown in Figure 11-95 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 to UART2) communication The procedure for processing errors that occurred during UART (UART0 to UART2) communication is described in Figures 11-96 and 11-97. Figure 11-96. Processing Procedure in Case of Parity Error or 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 register mn (SIRmn). | Error flag is cleared. | Error can be cleared only during reading, by writing the value read from the SSRmn register to the SIRmn register without modification. | Figure 11-97. Processing Procedure in Case of Framing 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 serial flag clear trigger register mn- | ► Error flag is cleared. | Error can be cleared only during reading, by writing the value read from the SSRmn register to the SIRmn register without 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 communication is re-established and communication is resumed because it is considered that a framing error has occurred because the start bit has been shifted. | | Sets the SSmn bit of serial channel start register m (SSm) to 1. | The SEmn bit of serial channel enable status register m (SEm) is set to 1 and channel n is enabled to operate. | | **Remark** m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3), mn = 00 to 03, 10, 11 ## 11.7 Operation of Simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) 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. Operate the control registers by software for setting the start and stop conditions while observing the specifications of the I<sup>2</sup>C bus line. [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, n: Channel number (mn = 00, 01, 03, 10) The channels supporting simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) are channels 0, 1, 3 of SAU0 and channel 0 of SAU1. 20- or 24-pin products | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C | |------|---------|-----------------------|--------------|-------------------------------------| | 0 | 0 | CSI00 | UART0 | IIC00 <sup>Note</sup> | | | 1 | CSI01 <sup>Note</sup> | | IIC01 <sup>Note</sup> | 30-pin products | Unit | Channel | Used as CSI | Used as UART | Used as Simplified I <sup>2</sup> C | |------|---------|-----------------------|-----------------------|-------------------------------------| | 0 | 0 | CSI00 | UART0 | IIC00 <sup>Note</sup> | | | 1 | - | ' | - | | | 2 | - | UART1 <sup>Note</sup> | - | | | 3 | CSI11 <sup>Note</sup> | | IIC11 Note | | 1 | 0 | CSI20 <sup>Note</sup> | UART 2Note | IIC20 <sup>Note</sup> | | | 1 | - | ' | _ | Note Provided in the R5F102 products only. Simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) 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 | IIC11 | IIC20 | |---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------|--------------------------------| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | Pins used | SCL00, SDA00 <sup>Note 1</sup> | SCL01, SDA01 <sup>Note 1</sup> | SCL11, SDA11 <sup>Note 1</sup> | SCL20, SDA20 <sup>Note 1</sup> | | Interrupt | INTIIC00 | INTIIC01 | INTIIC11 | INTIIC20 | | | Transfer end interrupt only (Setting the buffer empty interrupt is prohibited.) | | | | | Error detection flag | ACK 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 <sup>Note 2</sup> | Max. fmck/4 [Hz] (SDRmn[15:9] = 1 or more) fmck: Operation clock frequency of target channel However, the following condition must be satisfied in each mode of I <sup>2</sup> C. • Max. 400 kHz (fast mode) • Max. 100 kHz (standard mode) | | | | | Data level | Non-inversion output (default: high level) | | | | | Parity bit | No parity bit | | | | | Stop bit | Appending 1 bit (for ACK transmission/reception timing) | | | | | Data direction | MSB first | | | | - Notes 1. To perform communication via simplified I<sup>2</sup>C, set the N-ch open-drain output (V<sub>DD</sub> tolerance) mode (POMxx = 1 (POM11, POM41 = 1 for 20- or 24-pin products, POM11, POM14, POM50 = 1 for 30-pin products)) for the port output mode registers (POMxx). For details, see 4.3 Registers Controlling Port Function and 4.5 Register Settings When Using Alternate Function. - When IIC00 and IIC20 are communicating with an external device with a different potential, set the N-ch open-drain output (VDD tolerance) mode (POMxx = 1 (POM10 = 1 for 20- or 24-pin products, POM10, POM15 = 1 for 30-pin products)) also for the clock input/output pins (SCL00, SCL20). For details, see **4.4.4 Handling different potentials (1.8 V, 2.5 V, and 3 V) by using I/O buffers**. - Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). **Remark** m: Unit number, n: Channel number (mn = 00, 01, 03, 10) #### (1) Register setting Figure 11-98. Example of Contents of Registers for Address Field Transmission of Simplified I2C (IIC00, IIC01, IIC11, IIC20) #### (a) Serial mode register 0n (SMR0n) 14 13 12 10 15 5 0 **SMRmn** CKSm CCSm STSm MDmn1 MDmn 0/1 0 0 0 0 0 0 0 0 0 0 0 0 0 Operation clock (fmck) of channel n Operation mode 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 (b) Serial communication operation setting register mn (SCRmn) 5 15 14 13 12 11 10 9 6 3 1 0 SCRmn EOCmn XEmn RXEmn DAPmr CKPm PTCmn1 PTCmn0 DIRmr SLCmn1 SLCmn DLSmn1 DLSmn0 0 O 0 0 0 0 0 0 0 Setting of parity bit Setting of stop bit 00B: No parity 01B: Appending 1 bit (ACK) (c) Serial data register mn (SDRmn) (lower 8 bits: SIOr) 15 13 12 11 10 5 SDRmn Transmit data setting (address + R/W) Baud rate setting 0 SIOr (d) Serial output register m (SOm) 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 SO03 SO02 SO01 SOm CKOm1 CKOm0 SOm0 0 0 0 0 0 0 0/1 0/1 0/1 0/1 0/1 Start condition is generated by manipulating the SOmn bit. (e) Serial output enable register m (SOEm) 12 9 8 7 15 14 13 11 10 6 5 3 2 1 0 SOE03 SOE02 SOE01 SOEm SOEm( 0 0 0 0 0 0 0 0/1 0/1 SOEmn = 0 until the start condition is generated, and SOEmn = 1 after generation. (f) Serial channel start register m (SSm) ... Sets only the bits of the target channel is 1. 15 14 13 12 11 10 9 1 0 SS03 SS02 SSm SSmn = 0 until the start condition is generated, and SSmn = 1 after generation. 0/1 0 SSm1 0/1 SSm0 0/1 Notes 1. Provided only in 30-pin product serial array unit 0. 0 0 0 0 2. Only for 20, 24-pin product 0 Remarks 1. m: Unit number, n: Channel number (mn = 00, 01, 03, 10), r: IIC number (r = 00, 01, 11, 20) 2. : Setting is fixed in the CSI master transmission mode, : Setting disabled (set to the initial value) x: 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 0 0 #### (2) Operation procedure Figure 11-99. Initial Setting Procedure for simplified I<sup>2</sup>C Address Field Transmission #### (3) Processing flow Figure 11-100. Timing Chart of Address Field Transmission **Remark** m: Unit number, n: Channel number (mn = 00, 01, 03, 10), r: IIC number (r = 00, 01, 11, 20) Figure 11-101. Flowchart of simplified I<sup>2</sup>C 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 | IIC11 | IIC20 | | | | | | | | | |--------------------------------|----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------|--|--|--|--|--|--|--|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | | | | | | | | Pins used | SCL00, SDA00 <sup>Note1</sup> | SCL01, SDA01 <sup>Note1</sup> | SCL11, SDA11 <sup>Note1</sup> | SCL20, SDA20 <sup>Note1</sup> | | | | | | | | | | Interrupt | INTIIC00 | INTIIC00 INTIIC01 INTIIC11 INTIIC20 | | | | | | | | | | | | | Transfer end interrupt | Transfer end interrupt only (Setting the buffer empty interrupt is prohibited.) | | | | | | | | | | | | Error detection flag | ACK error detection fla | ACK error detection flag (PEFmn) | | | | | | | | | | | | Transfer data length | 8 bits | 8 bits | | | | | | | | | | | | Transfer rate <sup>Note2</sup> | Max. fmck/4 [Hz] (SDRi channel However, the following • Max. 400 kHz (fast n • Max. 100 kHz (stand | g condition must be satisf | fмск: Operation clock fr<br>ied in each mode of I <sup>2</sup> C. | equency of target | | | | | | | | | | Data level | Non-inversion output ( | default: high level) | | | | | | | | | | | | Parity bit | No parity bit | | | | | | | | | | | | | Stop bit | Appending 1 bit (for A | CK reception timing) | | | | | | | | | | | | Data direction | MSB first | | | | | | | | | | | | - Notes 1. To perform communication via simplified I<sup>2</sup>C, set the N-ch open-drain output (Vpb tolerance) mode (POMxx = 1 (POM11, POM41 = 1 for 20- or 24-pin products, POM11, POM14, POM50 = 1 for 30-pin products)) for the port output mode registers (POMxx). For details, see 4.3 Registers Controlling Port Function. When IIC00 and IIC20 are communicating with an external device with a different potential, set the N-ch open-drain output (Vpb tolerance) mode (POMxx = 1 (POM10 = 1 for 20- or 24-pin products, POM10, POM15 = 1 for 30-pin products)) also for the clock input/output pins (SCL00, SCL20). For details, see 4.4.4 Handling different potentials (1.8 V, 2.5 V, and 3 V) by using I/O buffers. - Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). **Remark** m: Unit number, n: Channel number (mn = 00, 01, 03, 10) #### (1) Register setting Figure 11-102. Example of Contents of Registers for Data Transmission of Simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) (a) Serial mode register mn (SMRmn) ... Do not manipulate this register during data transmission/reception. (b) Serial communication operation setting register mn (SCRmn) ... Do not manipulate the bits of this register, except the TXEmn and RXEmn bits, during data transmission/reception. (c) Serial data register mn (SDRmn) ... During data transmission/reception, valid only lower 8-bits (SIOr) (d) Serial output register m (SOm) ... Do not manipulate this register during data transmission/reception. | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|----|----|----|----|----|----|---------------|------------------------|---|---|---|---|---------------------------------|----------------|---------------------------------|-----------------------| | SOm | 0 | 0 | 0 | 0 | 1 | 1 | O/1<br>Note 2 | CKOm0<br>0/1<br>Note 2 | 0 | 0 | 0 | 0 | SOm3<br>Note 1<br>O/1<br>Note 3 | SOm2<br>Note 1 | SOm1<br>Note 2<br>O/1<br>Note 3 | SOm0<br>0/1<br>Note 3 | (e) Serial output enable register m (SOEm) ... Do not manipulate this register during data transmission/reception. | _ | 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 | SOEm3<br>Note 1 | SOEm2<br>Note 1 | SOEm1<br>Note 2 | SOEm0 | (f) Serial channel start register m (SSm) ... Do not manipulate this register during data transmission/reception. Notes 1. Provided only in 30-pin product serial array unit 0. - 2. Only for 20, 24-pin product - 3. The values may change during operation, depending on the communication data. - 4. Because the setting is completed by address field transmission, setting is not required. Remarks 1. m: Unit number, n: Channel number (mn = 00, 01, 03, 10), r: IIC number (r = 00, 01, 11, 20) 2. : Setting is fixed in the IIC master transmission mode, : 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: Set to 0 or 1 depending on the usage of the user # (2) Processing flow Figure 11-103. Timing Chart of Data Transmission Figure 11-104. Flowchart of Simplified I<sup>2</sup>C 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 | IIC11 | IIC20 | | | | | | | | | |---------------------------------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------|--|--|--|--|--|--|--|--| | Target channel | Channel 0 of SAU0 | Channel 1 of SAU0 | Channel 3 of SAU0 | Channel 0 of SAU1 | | | | | | | | | | Pins used | SCL00, SDA00 <sup>Note 1</sup> | SCL01, SDA01 <sup>Note 1</sup> | SCL11, SDA11 <sup>Note 1</sup> | SCL20, SDA20 <sup>Note 1</sup> | | | | | | | | | | Interrupt | INTIIC00 | INTIIC01 | INTIIC11 | INTIIC20 | | | | | | | | | | | Transfer end interrupt of | Transfer end interrupt only (Setting the buffer empty interrupt is prohibited.) | | | | | | | | | | | | Error detection flag | ACK error detection flag | ACK error detection flag (OVFmn) | | | | | | | | | | | | Transfer data length | 8 bits | 8 bits | | | | | | | | | | | | Transfer rate <sup>Note 2</sup> | Max. fmck/4 [Hz] (SDRm channel However, the following • Max. 400 kHz (fast me • Max. 100 kHz (standa | condition must be satisfie | fмск: Operation clock fre<br>d in each mode of I <sup>2</sup> C. | quency of target | | | | | | | | | | Data level | Non-inversion output (d | efault: high level) | | | | | | | | | | | | Parity bit | No parity bit | | | | | | | | | | | | | Stop bit | Appending 1 bit (ACK to | ransmission) | | | | | | | | | | | | Data direction | MSB first | | | | | | | | | | | | Notes 1. To perform communication via simplified I<sup>2</sup>C, set the N-ch open-drain output (V<sub>DD</sub> tolerance) mode (POMxx = 1 (POM11, POM41 = 1 for 20- or 24- pin products, POM11, POM14, POM50 = 1 for 30-pin products)) for the port output mode registers (POMxx). For details, see 4.3 Registers Controlling Port Function and 4.5 Register Settings When Using Alternate Function. When IIC00 and IIC20 is communicating with an external device with a different potential, set the N-ch opendrain output ( $V_{DD}$ tolerance) mode (POMxx = 1 (POM10 = 1 for 20- or 24- pin products, POM10, POM15 = 1 for 30-pin products)) also for the clock input/output pins (SCL00, SCL20). For details, see **4.4.4 Handling** different potentials (**1.8 V, 2.5 V, and 3 V)** by using I/O buffers. 2. Use this operation within a range that satisfies the conditions above and the peripheral functions characteristics in the electrical specifications (see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A, D: TA = -40 to +85°C) or CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: TA = -40 to +105°C)). **Remark** m: Unit number, n: Channel number (mn = 00, 01, 03, 10) #### (1) Register setting Figure 11-105. Example of Contents of Registers for Data Reception of Simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) (a) Serial mode register mn (SMRmn) $\dots$ Do not manipulate this register during data (b) Serial communication operation setting register mn (SCRmn) ... Do not manipulate the bits of this register, except the TXEmn and RXEmn bits, during data transmission/reception. (c) Serial data register mn (SDRmn) (lower 8 bits: SIOr) (d) Serial output register m (SOm) ... Do not manipulate this register during data transmission/reception. | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|----|----|----|----|----|----|------------------------|------------------------|---|---|---|---|---------------------------------|----------------|---------------------------------|-----------------------| | SOm | 0 | 0 | 0 | 0 | 1 | 1 | CKOm1<br>0/1<br>Note 2 | CKOm0<br>0/1<br>Note 2 | 0 | 0 | 0 | 0 | SOm3<br>Note 1<br>O/1<br>Note 3 | SOm2<br>Note 1 | SOm1<br>Note 2<br>O/1<br>Note 3 | SOm0<br>0/1<br>Note 3 | | | | | | | | | | | | | | | | | | | (e) Serial output enable register m (SOEm) ... Do not manipulate this register during data transmission/reception. | | | | | | | | | | | | -p | • | | | | | |------|----|----|----|----|----|----|---|---|---|---|----|---|-----------------|-----------------|-----------------|-------| | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SOEm | | | | | | | | | | | | | SOEm3<br>Note 1 | SOEm2<br>Note 1 | SOEm1<br>Note 2 | SOEm0 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0/1 | × | 0/1 | 0/1 | (f) Serial channel start register m (SSm) ... Do not manipulate this register during data transmission/reception. | | 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 | SSm3<br>Note 1 | SSm2<br>Note1 | SSm1<br>0/1 | SSm0<br>0/1 | - Notes 1. Provided only in 30-pin products serial array unit 0. - 2. Only for 20, 24-pin products. - 3. The values may change during operation, depending on the communication data. - 4. Because the setting is completed by address field transmission, setting is not required. Remarks 1. m: Unit number, n: Channel number (mn = 00, 01, 03, 10), r: IIC number (r = 00, 01, 11, 20) 2. : Setting is fixed in the IIC master transmission mode, : 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: Set to 0 or 1 depending on the usage of the user ## (2) Processing flow Figure 11-106. Timing Chart of Data Reception ## (a) When starting data reception # (b) When receiving last data **Remark** m: Unit number, n: Channel number (mn = 00, 01, 03, 10), r: IIC number (r = 00, 01, 11, 20) Figure 11-107. Flowchart of Simplified I<sup>2</sup>C 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 STmn SEmn SOEmn Note SCLr output SDAr output Operation stop Somn CKOmn bit manipulation bit manipulation bit manipulation Stop Condition Figure 11-108. 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. Figure 11-109. Flowchart of Stop Condition Generation #### 11.7.5 Calculating transfer rate The transfer rate for simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) 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 000000000B. Be sure to set SDRmn[15:9] to a value of at least 00000001B. The duty cycle of the SCL signal output by the simplified I<sup>2</sup>C interface is 50%. The I<sup>2</sup>C bus specifications stipulate that the width at low level of the SCL signal is longer than the width at high level. If 400 kbps (fast mode) is specified, therefore, the width at low level of the SCL output signal will become shorter than the value specified in the I<sup>2</sup>C bus specifications. Make sure that the SDRmn[15:9] value satisfies the I<sup>2</sup>C bus specifications. - **Remarks 1.** The value of SDRmn[15:9] is the value of bits 15 to 9 of the SDRmn register (0000001B to 11111111B) and therefore is 1 to 127. - 2. m: Unit number, n: Channel number (mn = 00, 01, 03, 10) The operation clock (fmck) is determined by serial clock select register m (SPSm) and bit 15 (CKSmn) of serial mode register mn (SMRmn). SMRmn Operation Clock (fMCK)Note SPS0 Register Register CKSmn **PRS PRS PRS PRS PRS PRS PRS PRS** fclk = 20 MHz m13 m12 m10 m03 m02 m01 m00 m11 Χ Χ Χ Χ 0 0 0 0 fclk 20 MHz Χ Χ Χ Χ 0 0 0 1 fclk/2 10 MHz Х fclk/22 Χ Χ Х 0 0 1 0 5 MHz Χ Χ fclk/23 Χ Χ 0 0 1 2.5 MHz Х Х Χ Χ 0 1 0 0 fclk/2 1.25 MHz Χ fclk/25 Х Х Χ 0 1 0 625 KHz 1 Х Χ Χ Х 0 1 1 0 fclk/26 312.5 kHz Χ Χ Χ Х fclk/27 156.2 kHz 0 1 1 1 Χ Χ Χ Χ 1 0 0 0 fclk/28 78.1 kHz Χ Χ Χ Х 1 0 0 1 fclk/29 39.1 kHz Χ Χ Χ Χ 1 0 1 0 fclk/210 19.5 kHz fclk/2<sup>11</sup> Χ Χ Χ Χ 1 0 1 9.77 kHz Χ Χ Χ Χ 1 1 0 0 fclk/2<sup>12</sup> 4.87 kHz Х fcLK/2<sup>13</sup> Х Χ 1 1 Χ 0 2.44 kHz fclk/2<sup>14</sup> Χ Χ 0 1.22 kHz Χ Χ 1 1 1 $f_{CLK}/2^{15}$ Х Χ Χ 1 1 1 Х 610 Hz 1 0 Χ 20 MHz 0 0 0 Χ Х Χ fclk 0 0 0 1 Х Х Х Х fclk/2 10 MHz 0 0 1 0 Χ Χ Χ fclk/22 5 MHz Х 0 0 1 Χ Χ Χ Χ fclk/23 2.5 MHz 1 0 1 0 0 Χ Χ fclk/24 1.25 MHz 0 1 0 1 Χ Χ Χ Χ fclk/25 625 KHz 0 1 Χ Χ Χ Χ fclk/26 1 0 312.5 KHz 0 Χ Χ Χ fclk/27 156.2 kHz 1 1 1 Χ 1 0 0 0 Χ Х Χ Χ fclk/28 78.1 kHz fclk/29 Χ 39.1 kHz 1 0 0 1 Χ Х Х 1 0 1 0 Х Х Х Х fclk/210 19.5 kHz 1 0 Χ Χ fclk/211 9.76 kHz 1 1 Χ Χ Χ fclk/2<sup>12</sup> 1 1 0 0 Χ Χ Χ 4.87 kHz 1 Χ Χ Χ fclk/2<sup>13</sup> 2.44 kHz 1 0 1 Χ 1 Χ Χ Χ Χ fclk/2<sup>14</sup> 1.22 kHz 1 1 0 fclk/2<sup>15</sup> 610 Hz Table 11-5. Selection of Operation Clock for Simplified I2C **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). Remarks 1. X: don't care 2. m: Unit number, n: Channel number (mn = 00, 01, 03, 10) Here is an example of setting an IIC transfer rate where $f_{MCK} = f_{CLK} = 20 \text{ MHz}$ . | IIC Transfer Mode | fclk = 20 MHz | | | | | | | | | |-------------------------|------------------------|-------------|---------------|-----------------------------|--|--|--|--|--| | (Desired Transfer Rate) | Operation Clock (fмск) | SDRmn[15:9] | Calculated | Error from Desired Transfer | | | | | | | | | | Transfer Rate | Rate | | | | | | | 100 kHz | fclk/2 | 49 | 100 kHz | 0.0% | | | | | | | 400 kHz | fclk | 25 | 384.6 kHz | 3.8% 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, IIC11, IIC20) communication The procedure for processing errors that occurred during simplified I<sup>2</sup>C (IIC00, IIC01, IIC11, IIC20) communication is described in Figure 11-110 and Figure 11-111. Figure 11-110. 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). | | 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 cleared, by writing the value read from the SSRmn register to the SIRmn register without modification. | Figure 11-111. 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 (SIRmn). | ►Error flag is cleared. | Error can be cleared only during reading, by writing the value read from the SSRmn register to the SIRmn register without modification. | | Sets the STmn bit of serial channel stop-<br>register m (STm) to 1. | The SEmn bit of serial channel enable status register m (SEm) is set to 0 and channel n stops operation. | Slave is not ready for reception because ACK is not returned. Therefore, a stop condition is created, the bus is released, and communication is started again from the start condition. Or, a restart | | Creates stop condition. | | condition is generated and transmission can be redone from | | Creates start condition. | | address transmission. | | Sets the SSmn bit of serial channel start register m (SSm) to 1. | The SEmn bit of serial channel enable status register m (SEm) is set to 1 and channel n is enabled to operate. | | **Remark** m: Unit number, n: Channel number (mn = 00, 01, 03, 10), r: IIC number (r = 00, 01, 11, 20) #### **CHAPTER 12 SERIAL INTERFACE IICA** #### 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 (SCLA0) line and a serial data bus (SDAA0) 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 SCLA0 and SDAA0 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 (INTIICA0) 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 WUP0 bit of IICA control register 01 (IICCTL01). 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. + VDD + VDD Serial data bus Master CPU1 Master CPU2 SDAA0 SDAA0 Slave CPU1 Slave CPU2 Serial clock SCLA0 SCLA0 Address 0 Address 1 SDAA0 Slave CPU3 Address 2 SCLA0 SDAA0 Slave IC Address 3 SCLA0 SDAA0 Slave IC Address N SCLA0 Figure 12-2. Serial Bus Configuration Example Using I<sup>2</sup>C Bus ## 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 0 (IICA0)<br>Slave address register 0 (SVA0) | | Control registers | Peripheral enable register 0 (PER0) IICA control register 00 (IICCTL00) IICA status register 0 (IICS0) IICA flag register 0 (IICF0) IICA control register 01 (IICCTL01) IICA low-level width setting register 0 (IICWL0) IICA high-level width setting register 0 (IICWH0) Port mode register 6 (PM6) Port register 6 (P6) | ## (1) IICA shift register 0 (IICA0) The IICA0 register is used to convert 8-bit serial data to 8-bit parallel data and vice versa in synchronization with the serial clock. The IICA0 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 IICA0 register. Cancel the wait state and start data transfer by writing data to the IICA0 register during the wait period. The IICA0 register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears IICA0 to 00H. Figure 12-3. Format of IICA Shift Register 0 (IICA0) # **Cautions 1.** Do not write data to the IICA0 register during data transfer. - 2. Write or read the IICA0 register only during the wait period. Accessing the IICA0 register in a communication state other than during the wait period is prohibited. When the device serves as the master, however, the IICA0 register can be written only once after the communication trigger bit (STT0) is set to 1. - **3.** When communication is reserved, write data to the IICAO register after the interrupt triggered by a stop condition is detected. #### (2) Slave address register 0 (SVA0) This register stores seven bits of local addresses {A6, A5, A4, A3, A2, A1, A0} when in slave mode. The SVA0 register can be set by an 8-bit memory manipulation instruction. However, rewriting to this register is prohibited while STD0 = 1 (while the start condition is detected). Reset signal generation clears the SVA0 register to 00H. Figure 12-4. Format of Slave Address Register 0 (SVA0) Note Bit 0 is fixed to 0. ## (3) SO latch The SO latch is used to retain the SDAA0 pin's output level. #### (4) Wakeup controller This circuit generates an interrupt request (INTIICA0) when the address received by this register matches the address value set to the slave address register 0 (SVA0) 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 (INTIICA0). 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 WTIM0 bit) - Interrupt request generated when a stop condition is detected (set by the SPIE0 bit) Remark WTIM0 bit: Bit 3 of IICA control register 00 (IICCTL00) SPIE0 bit: Bit 4 of IICA control register 00 (IICCTL00) # (7) Serial clock controller In master mode, this circuit generates the clock output via the SCLA0 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 STT0 bit is set to 1. However, in the communication reservation disabled status (IICRSV0 bit = 1), when the bus is not released (IICBSY0 bit = 1), start condition requests are ignored and the STCF bit is set to 1. # (12) Stop condition generator This circuit generates a stop condition when the SPT0 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 STCEN bit. Remark STT0 bit: Bit 1 of IICA control register 00 (IICCTL00) SPT0 bit: Bit 0 of IICA control register 00 (IICCTL00) IICRSV0 bit: Bit 0 of IICA flag register 0 (IICF0) IICBSY0 bit: Bit 6 of IICA flag register 0 (IICF0) STCF0 bit: Bit 7 of IICA flag register 0 (IICF0) STCEN0 bit: Bit 1 of IICA flag register 0 (IICF0) ## 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 00 (IICCTL00) - IICA flag register 0 (IICF0) - IICA status register 0 (IICS0) - IICA control register 01 (IICCTL01) - IICA low-level width setting register 0 (IICWL0) - IICA high-level width setting register 0 (IICWH0) - Port mode register 6 (PM6) - Port register 6 (P6) #### 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 IICA is used, be sure to set bit 4 (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: F00 | FOH After re | set: 00H R/ | VV | | | | | | |--------------|--------------|-------------|-------|---------|-------------|--------|---|--------| | Symbol | <7> | 6 | <5> | <4> | <3> | <2> | 1 | <0> | | PER0 | TMKAEN | 0 | ADCEN | IICA0EN | SAU1EN Note | SAU0EN | 0 | TAU0EN | | IICA0EN | Control of serial interface IICA clock supply | |---------|--------------------------------------------------------------------------------------------------------------------------| | 0 | Stops clock supply. SFR used by serial interface IICA cannot be written. Serial interface IICA is in the reset status. | | 1 | Enables clock supply. • SFR used by serial interface IICA can be read/written. | Note 30-pin products only **Cautions 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 register 6 (PM6) and port register 6 (P6)). - IICA control register 00 (IICCTL00) - IICA flag register 0 (IICF0) - IICA status register 0 (IICS0) - IICA control register 01 (IICCTL01) - IICA low-level width setting register 0 (IICWL0) - IICA high-level width setting register 0 (IICWH0) - 2. Be sure to clear the following bits to 0. 20- or 24-pin products: Bits 1, 3, and 6 30-pin products: Bits 1 and 6 ## 12.3.2 IICA control register 00 (IICCTL00) 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 IICCTL00 register can be set by a 1-bit or 8-bit memory manipulation instruction. However, set the SPIE0, WTIM0, and ACKE0 bits while IICE0 = 0 or during the wait period. These bits can be set at the same time when the IICE0 bit is set from "0" to "1". Reset signal generation clears this register to 00H. Figure 12-6. Format of IICA Control Register 00 (IICCTL00) (1/4) After reset: 00H Address: F0230H R/W Symbol <6> <5> <3> <2> <0> <7> <4> <1> IICCTL00 IICE0 LREL0 WREL0 SPIE0 **WTIM0** ACKE0 STT0 SPT0 | IICE0 | I <sup>2</sup> C operation enable | | | |----------------------------------|-------------------------------------------------------------------------------------------|--------------------|--| | 0 | Stop operation. Reset the IICA status register 0 (IICS0) Note 1. Stop internal operation. | | | | 1 | Enable operation. | | | | Be sure to s | Be sure to set this bit (1) while the SCLA0 and SDAA0 lines are at high level. | | | | Condition fo | Condition for clearing (IICE0 = 0) Condition for setting (IICE0 = 1) | | | | Cleared by instruction Reset | | Set by instruction | | | LREL0<br>Notes 2, 3 | Exit from communications | |---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Normal operation | | 1 | 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 SCLA0 and SDAA0 lines are set to high impedance. The following flags of IICA control register 00 (IICCTL00) and the IICA status register 0 (IICS0) are cleared to 0. • STT0 • SPT0 • MSTS0 • EXC0 • COI0 • TRC0 • ACKD0 • STD0 | The standby mode following exit from communications remains in effect until the following communications entry conditions are met. - After a stop condition is detected, restart is in master mode. - An address match or extension code reception occurs after the start condition. | Condition for clearing (LREL0 = 0) | Condition for setting (LREL0 = 1) | |-------------------------------------------------|-----------------------------------| | Automatically cleared after execution Reset | Set by instruction | | WREL0<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 WREL0 bit is set (wait canceled) during the wait period at the ninth clock pulse in the transmission status (TRC0 = 1), the SDAA0 line goes into the high impedance state (TRC0 = 0). | | | | Condition for | Condition for clearing (WREL0 = 0) Condition for setting (WREL0 = 1) | | | Automatically cleared after execution Reset Set by instruction | | Set by instruction | (Notes and Caution are listed on the next page.) - Notes 1. The IICA status register 0 (IICS0), the STCF and IICBSY bits of the IICA flag register 0 (IICF0), and the CLD0 and DAD0 bits of IICA control register 01 (IICCTL01) are reset. - 2. The signal of this bit is invalid while IICE0 is 0. - 3. When the LREL0 and WREL0 bits are read, 0 is always read. Caution If the operation of I<sup>2</sup>C is enabled (IICE0 = 1) when the SCLA0 line is high level, the SDAA0 line is low level, and the digital filter is turned on (DFC0 bit of IICCTL01 register = 1), a start condition will be inadvertently detected immediately. In this case, set (1) the LREL0 bit by using a 1-bit memory manipulation instruction immediately after enabling operation of $I^2C$ (IICE0 = 1). Figure 12-6. Format of IICA Control Register 00 (IICCTL00) (2/4) | SPIE0 <sup>Note 1</sup> | Enable/disable generation of interrupt request when stop condition is detected | | |-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------| | 0 | Disable | | | 1 | Enable | | | If the WUP0 bit of IICA control register 01 (IICCTL01) is 1, no stop condition interrupt will be generated even if SPIE0 = 1. | | | | Condition for | Condition for clearing (SPIE0 = 0) Condition for setting (SPIE0 = 1) | | | Cleared by instruction Reset | | Set by instruction | | WTIM0 <sup>Note 1</sup> | Control of wait and interrupt request generation | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0 | Interrupt request is generated at the eighth clock's falling edge. Master mode: After output of eight clocks, clock output is set to low level and wait is set. Slave mode: After input of eight clocks, the clock is set to low level and wait is set for master device. | | | 1 | Interrupt request is generated at the ninth clock's falling edge. Master mode: After output of nine clocks, clock 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 generated at the falling edge of the ninth clock during address transfer independently of the setting of this 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 the ninth clock during address transfers. For a slave device that has received a local | | | | Condition for clearing (WTIM0 = 0) | Condition for setting (WTIM0 = 1) | |------------------------------------|-----------------------------------| | Cleared by instruction | Set by instruction | | • Reset | | address, a wait is inserted at the falling edge of the ninth clock after an acknowledge (ACK) signal is issued. However, when the slave device has received an extension code, a wait is inserted at the falling edge of the eighth | ACKE0<br>Notes 1, 2 | Acknowledgment control | | |----------------------------------|-------------------------------------------------------------------------------------------|--------------------| | 0 | Disable acknowledgment. | | | 1 | Enable acknowledgment. During the ninth clock period, the SDAA0 line is set to low level. | | | Condition for | ondition for clearing (ACKE0 = 0) Condition for setting (ACKE0 = 1) | | | Cleared by instruction Reset | | Set by instruction | Notes 1. The signal of this bit is invalid while IICE0 is 0. Set this bit during that period. 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. clock. Figure 12-6. Format of IICA Control Register 00 (IICCTL00) (3/4) | STT0<br>Notes 1, 2 | Start condition trigger | | | |---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--| | 0 | Do not generate a start condition. | | | | 1 | When bus is released (in standby state, when | IICBSY = 0): | | | | If this bit is set (1), a start condition is gener | ated (startup as the master). | | | | When a third party is communicating: | | | | | When communication reservation function | n is enabled (IICRSV = 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 | n is disabled (IICRSV = 1) | | | | Even if this bit is set (1), the STT0 bit is cleared and the STT0 clear flag (STCF) is set (1). No start condition is generated. | | | | | In the wait state (when master device): | | | | | Generates a restart condition after releasing the wait. | | | | Cautions co | oncerning set timing | | | | | | sfer. Can be set to 1 only in the waiting period when the | | | ACKE0 bit has been cleared to 0 and slave has been notified of final reception. | | 0 and slave has been notified of final reception. | | | • For maste | er transmission: A start condition cannot be ger | nerated normally during the acknowledge period. Set to 1 | | | | during the wait period that follo | ws output of the ninth clock. | | | Cannot be | e set to 1 at the same time as stop condition trig | ger (SPT0). | | | Setting the | e STT0 bit to 1 and then setting it again before i | it is cleared condition is prohibited. | | | Condition for clearing (STT0 = 0) | | Condition for setting (STT0 = 1) | | | Cleared b | by setting the STT0 bit to 1 while | Set by instruction | | | communication reservation is prohibited. | | · | | | Cleared by loss in arbitration | | | | | Cleared after start condition is generated by master | | | | | device | | | | | <ul> <li>Cleared b</li> </ul> | y LREL0 = 1 (exit from communications) | | | | When IICI | E0 = 0 (operation stop) | | | | <ul> <li>Reset</li> </ul> | | | | Notes 1. The signal of this bit is invalid while IICE0 is 0. $\begin{tabular}{ll} \textbf{2.} & \textbf{The value read from the STT0 bit is always 0.} \end{tabular}$ Remark IICRSV0: Bit 0 of IIC flag register 0 (IICF0) STCF0: Bit 7 of IIC flag register 0 (IICF0) Figure 12-6. Format of IICA Control Register 00 (IICCTL00) (4/4) | SPT0 Note | Stop condition trigger | | | |---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------|--| | 0 | Stop condition is not generated. | | | | 1 | Stop condition is generated (termination of ma | ster device's transfer). | | | Cautions co | oncerning set timing | | | | <ul> <li>For maste</li> </ul> | aster reception: Cannot be set to 1 during transfer. | | | | | Can be set to 1 only in the waiting period when the ACKE0 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. | | | | • Cannot be | Cannot be set to 1 at the same time as start condition trigger (STT0). | | | | • The SPT0 | bit can be set to 1 only when in master mode. | | | | <ul> <li>When the</li> </ul> | WTIM0 bit has been cleared to 0, if the SPT0 b | it is set to 1 during the wait period that follows output of | | | eight clock | ks, note that a stop condition will be generated o | during the high-level period of the ninth clock. The WTIM0 | | | bit should | be changed from 0 to 1 during the wait period for | ollowing the output of eight clocks, and the SPT0 bit should | | | be set to 1 | during the wait period that follows the output o | f the ninth clock. | | | Setting the SPT0 bit to 1 and then setting it again before it is cleared condition is prohibited. | | | | | Condition fo | Condition for clearing (SPT0 = 0) Condition for setting (SPT0 = 1) | | | | Cleared by loss in arbitration | | Set by instruction | | | Automatic | ally cleared after stop condition is detected | | | | • Cleared b | y LREL0 = 1 (exit from communications) | | | | When IICI | E0 = 0 (operation stop) | | | | <ul> <li>Reset</li> </ul> | | | | **Note** The value read from the STT0 bit is always 0. Caution When bit 3 (TRC0) of the IICA status register 0 (IICS0) is set to 1 (transmission status), bit 5 (WREL0) of IICA control register 00 (IICCTL00) is set to 1 during the ninth clock and wait is canceled, after which the TRC0 bit is cleared (reception status) and the SDAA0 line is set to high impedance. Release the wait performed while the TRC0 bit is 1 (transmission status) by writing to the IICA shift register 0. Remark Bit 0 (SPT0) becomes 0 when it is read after data setting. #### 12.3.3 IICA status register 0 (IICS0) This register indicates the status of I<sup>2</sup>C. The IICS0 register is read by a 1-bit or 8-bit memory manipulation instruction only when STT0 = 1 and during the wait period. Reset signal generation clears this register to 00H. Caution Reading the IICS0 register while the address match wakeup function is enabled (WUP0 = 1) in STOP mode is prohibited. When the WUP0 bit is changed from 1 to 0 (wakeup operation is stopped), regardless of the INTIICA0 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 (SPIE0 = 1) the interrupt generated by detecting a stop condition and read the IICS0 register after the interrupt has been detected. Remark STT0: bit 1 of IICA control register 00 (IICCTL00) WUP0: bit 7 of IICA control register 01 (IICCTL01) Figure 12-7. Format of IICA Status Register 0 (IICS0) (1/3) Address: FFF51H After reset: 00H <0> Symbol <7> <6> <5> <4> <3> <2> <1> IICS0 SPD0 MSTS0 ALD0 EXC0 CO<sub>10</sub> TRC0 ACKD0 STD0 | MSTS0 | Master status check flag | | |------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0 | Slave device status or communication standby status | | | 1 | Master device communication status | | | Condition f | Condition for clearing (MSTS0 = 0) Condition for setting (MSTS0 = 1) | | | When AL Cleared by | When a stop condition is detected When ALD0 = 1 (arbitration loss) Cleared by LREL0 = 1 (exit from communications) When the IICE0 bit changes from 1 to 0 (operation stop) | | | ALD0 | 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 MSTS0 bit is cleared. | | | | Condition f | or clearing (ALD0 = 0) | Condition for setting (ALD0 = 1) | | | Automatically cleared after the IICS0 register is read Note | | When the arbitration result is a "loss". | | | When the IICE0 bit changes from 1 to 0 (operation stop) | | | | | Reset | | | | Note This register is also cleared when a 1-bit memory manipulation instruction is executed for bits other than the IICS0 register. Therefore, when using the ALD0 bit, read the data of this bit before the data of the other bits. Remark LREL0: Bit 6 of IICA control register 00 (IICCTL00) > Bit 7 of IICA control register 00 (IICCTL00) IICE0: Figure 12-7. Format of IICA Status Register 0 (IICS0) (2/3) | EXC0 | Detection of extension code reception | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | Extension code was not received. | | | | | 1 | Extension code was received. | Extension code was received. | | | | Condition for clearing (EXC0 = 0) | | Condition for setting (EXC0 = 1) | | | | When a start condition is detected When a stop condition is detected Cleared by LREL0 = 1 (exit from communications) When the IICE0 bit changes from 1 to 0 (operation stop) Reset | | When the higher four bits of the received address data is either "0000" or "1111" (set at the rising edge of the eighth clock). | | | | COI0 | Detection of matching addresses | | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | Addresses do not match. | Addresses do not match. | | | | 1 | Addresses match. | | | | | Condition f | for clearing (COI0 = 0) | Condition for setting (COI0 = 1) | | | | When a start condition is detected When a stop condition is detected Cleared by LREL0 = 1 (exit from communications) When the IICE0 bit changes from 1 to 0 (operation stop) Reset | | When the received address matches the local address (slave address register 0 (SVA0)) (set at the rising edge of the eighth clock). | | | | TRC0 | Detection of transmit/receive status | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | Receive status (other than transmit status). The SDAA0 line is set for high impedance. | | | | | 1 | | Transmit status. The value in the SO0 latch is enabled for output to the SDAA0 line (valid starting at the falling edge of the first byte's ninth clock). | | | | Condition f | or clearing (TRC0 = 0) | Condition for setting (TRC0 = 1) | | | | When a set of Cleared to the stop) Cleared to the stop) Cleared to the stop) Cleared to the stop) Reset When not = 0) Master> When "1" direction Slave> When a set of the stop sto | ter and slave> stop condition is detected by LREL0 = 1 (exit from communications) e IICE0 bit changes from 1 to 0 (operation by WREL0 = 1 <sup>Note</sup> (wait cancel) e ALD0 bit changes from 0 to 1 (arbitration used for communication (MSTS0, EXC0, COI0 is output to the first byte's LSB (transfer specification bit) start condition is detected is input to the first byte's LSB (transfer specification bit) | 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) | | | Note When bit 3 (TRC0) of the IICA status register 0 (IICS0) is set to 1 (transmission status), bit 5 (WREL0) of IICA control register 00 (IICCTL00) is set to 1 during the ninth clock and wait is canceled, after which the TRC0 bit is cleared (reception status) and the SDAA0 line is set to high impedance. Release the wait performed while the TRC0 bit is 1 (transmission status) by writing to the IICA shift register 0. Remark LREL0: Bit 6 of IICA control register 00 (IICCTL00) Bit 7 of IICA control register 00 (IICCTL00) IICE0: Figure 12-7. Format of IICA Status Register 0 (IICS0) (3/3) | ACKD0 | Detection of acknowledge (ACK) | | | |----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--| | 0 | Acknowledge was not detected. | | | | 1 | Acknowledge was detected. | | | | Condition for | n for clearing (ACKD0 = 0) Condition for setting (ACKD0 = 1) | | | | At the risi Cleared by | top condition is detected ng edge of the next byte's first clock by LREL0 = 1 (exit from communications) HICE0 bit changes from 1 to 0 (operation | After the SDAA0 line is set to low level at the rising edge of SCLA0 line's ninth clock | | | STD0 | Detection of start condition | | | |------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--| | 0 | Start condition was not detected. | | | | 1 | Start condition was detected. This indicates | s that the address transfer period is in effect. | | | Condition f | for clearing (STD0 = 0) Condition for setting (STD0 = 1) | | | | <ul><li>At the risi following</li><li>Cleared to</li></ul> | stop condition is detected ing edge of the next byte's first clock address transfer by LREL0 = 1 (exit from communications) is IICE0 bit changes from 1 to 0 (operation | When a start condition is detected | | | SPD0 | 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 f | on for clearing (SPD0 = 0) Condition for setting (SPD0 = 1) | | | | clock follo<br>start cond<br>• When the | ing edge of the address transfer byte's first owing setting of this bit and detection of a dition e WUP0 bit changes from 1 to 0 e IICE0 bit changes from 1 to 0 (operation | When a stop condition is detected | | Remark LREL0: Bit 6 of IICA control register 00 (IICCTL00) IICE0: Bit 7 of IICA control register 00 (IICCTL00) ## 12.3.4 IICA flag register 0 (IICF0) 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 IICF0 register can be set by a 1-bit or 8-bit memory manipulation instruction. However, the STT0 clear flag (STCF) and I<sup>2</sup>C bus status flag (IICBSY) bits are read-only. The IICRSV bit can be used to enable/disable the communication reservation function. The STCEN bit can be used to set the initial value of the IICBSY bit. The IICRSV and STCEN bits can be written only when the operation of I2C is disabled (bit 7 (IICE0) of IICA control register 00 (IICCTL00) = 0). When operation is enabled, the IICF0 register can be read. Reset signal generation clears this register to 00H. # Figure 12-8. Format of IICA Flag Register 0 (IICF0) | Address | : FFF52H | After re | eset: 00H | R/W <sup>Not</sup> | е | | | | |---------|----------|----------|-----------|--------------------|---|---|--------|---------| | Symbol | <7> | <6> | 5 | 4 | 3 | 2 | <1> | <0> | | IICF0 | STCF0 | IICBSY0 | 0 | 0 | 0 | 0 | STCEN0 | IICRSV0 | | STCF0 | STT0 clear flag | | | |-----------------------------------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--| | 0 | Generate start condition | | | | 1 | Start condition generation unsuccessful: clear the STT0 flag | | | | Condition for clearing (STCF0 = 0) Condition for setting (STCF0 = 1) | | Condition for setting (STCF0 = 1) | | | - Cleared by STT0 = 1 - When IICE0 = 0 (operation stop) - Reset | | - Generating start condition unsuccessful and the STT0 bit cleared to 0 when communication reservation is disabled (IICRSV0 = 1). | | | IICBSY0 | I <sup>2</sup> C bus status flag | | | |-------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------|--| | 0 | Bus release status (communication initial status when STCEN0 = 1) | | | | 1 | Bus communication status (communication initial status when STCEN0 = 0) | | | | Condition | n for clearing (IICBSY0 = 0) | Condition for setting (IICBSY0 = 1) | | | - Detection of stop condition<br>- When IICE0 = 0 (operation stop)<br>- Reset | | - Detection of start condition<br>- Setting of the IICE0 bit when STCEN0 = 0 | | | STCEN0 | Initial start enable trigger | | | |-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------|--| | 0 | After operation is enabled (IICE0 = 1), enable generation of a start condition upon detection of a stop condition. | | | | 1 | After operation is enabled (IICE0 = 1), enable generation of a start condition without detecting a stop condition. | | | | Condition | for clearing (STCEN0 = 0) | Condition for setting (STCEN0 = 1) | | | - Cleared by instruction - Detection of start condition - Reset | | - Set by instruction | | | IICRSV0 | Communication reservation function disable bit | | | |--------------------------------------------------------------------------|------------------------------------------------|-------------------------------------|--| | 0 | Enable communication reservation | | | | 1 | Disable communication reservation | | | | Condition for clearing (IICRSV0 = 0) Condition for setting (IICRSV0 = 1) | | Condition for setting (IICRSV0 = 1) | | | - Cleared by instruction<br>- Reset | | - Set by instruction | | Note Bits 6 and 7 are read-only. **Cautions 1.** Write to the STCEN bit only when the operation is stopped (IICE0 = 0). - 2. As the bus release status (IICBSY = 0) is recognized regardless of the actual bus status when STCEN = 1, when generating the first start condition (STT0 = 1), it is necessary to verify that no third party communications are in progress in order to prevent such communications from being destroyed. - 3. Write to IICRSV only when the operation is stopped (IICE0 = 0). Remarks 1. STT0: Bit 1 of IICA control register 00 (IICCTL00) 2. IICE0: Bit 7 of IICA control register 00 (IICCTL00) # 12.3.5 IICA control register 01 (IICCTL01) This register is used to set the operation mode of I<sup>2</sup>C and detect the statuses of the SCLA0 and SDAA0 pins. The IICCTL01 register can be set by a 1-bit or 8-bit memory manipulation instruction. However, the CLD0 and DAD0 bits are read-only. Set the IICCTL01 register, except the WUP0 bit, while operation of I<sup>2</sup>C is disabled (bit 7 (IICE0) of IICA control register 00 (IICCTL00) is 0). Reset signal generation clears this register to 00H. Figure 12-9. Format of IICA Control Register 01 (IICCTL01) (1/2) | Address: F0231H After reset: 00H | | OH R/W | Note 1 | | | | | | |----------------------------------|------|--------|--------|------|------|------|---|------| | Symbol | 7 | 6 | <5> | <4> | <3> | <2> | 1 | <0> | | IICCTL01 | WUP0 | 0 | CLD0 | DAD0 | SMC0 | DFC0 | 0 | PRS0 | | WUP0 | Control of address match wakeup | | | | |--------------------------------------------------------------------|----------------------------------------------------------------|--|--|--| | 0 | Stops operation of address match wakeup function in STOP mode. | | | | | 1 Enables operation of address match wakeup function in STOP mode. | | | | | To shift to STOP mode when WUP0 = 1, execute the STOP instruction at least three cycles of the fmck clocks after setting (1) the WUP0 bit (see **Figure 12-22 Flow When Setting WUP0 = 1**). Clear (0) the WUP0 bit after the address has matched or an extension code has been received. The subsequent communication can be entered by the clearing (0) WUP0 bit. (The wait must be released and transmit data must be written after the WUP0 bit has been cleared (0).) The interrupt timing when the address has matched or when an extension code has been received, while WUP0 = 1, is identical to the interrupt timing when WUP0 = 0. (A delay of the difference of sampling by the clock will occur.) Furthermore, when WUP0 = 1, a stop condition interrupt is not generated even if the SPIE0 bit is set to $\frac{1}{2}$ When WUP0 = 0 is set by a source other than an interrupt from serial interface IICA, operation as the master device cannot be performed until the subsequent start condition or stop condition is detected. Do not output a start condition by setting (1) the STT0 bit, without waiting for the detection of the subsequent start condition or stop condition. | Condition for clearing (WUP0 = 0) | Condition for setting (WUP0 = 1) | |--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------| | Cleared by instruction (after address match or extension code reception) | Set by instruction (when the MSTS0, EXC0, and COI0 bits are "0", and the STD0 bit also "0" (communication not entered)) | #### Notes 1. Bits 4 and 5 are read-only. 2. The status of the IICA status register 0 (IICS0) must be checked and the WUP0 bit must be set during the period shown below. Figure 12-9. Format of IICA Control Register 01 (IICCTL01) (2/2) | CLD0 | Detection of SCLA0 p | in level (valid only when IICE0 = 1) | | | |-----------------------------------|------------------------------------------------------|--------------------------------------|--|--| | 0 | The SCLA0 pin was detected at low level. | | | | | 1 | The SCLA0 pin was detected at high level. | | | | | Condition for clearing (CLD0 = 0) | | Condition for setting (CLD0 = 1) | | | | | SCLA0 pin is at low level<br>E0 = 0 (operation stop) | When the SCLA0 pin is at high level | | | | DAD0 | Detection of SDAA0 pin level (valid only when IICE0 = 1) | | | | |--------------------------------------------------------------------------|----------------------------------------------------------|-------------------------------------|--|--| | 0 | The SDAA0 pin was detected at low level. | | | | | 1 | The SDAA0 pin was detected at high level. | | | | | Condition for clearing (DAD0 = 0) | | Condition for setting (DAD0 = 1) | | | | When the SDAA0 pin is at low level When IICE0 = 0 (operation stop) Reset | | When the SDAA0 pin is at high level | | | | SMC0 | Operation mode switching | | |------------------------------------------------------------|--------------------------------------------------------------|--| | 0 | Operates in standard mode (fastest transfer rate: 100 kbps). | | | 1 Operates in fast mode (fastest transfer rate: 400 kbps). | | | | DFC0 | Digital filter operation control | | | | | |----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--|--|--|--| | 0 | 0 Digital filter off. | | | | | | 1 | 1 Digital filter on. | | | | | | Use the dig | Use the digital filter in fast mode. | | | | | | In fast mode, the transfer clock does not vary, regardless of the DFC0 bit being set (1) or cleared (0). | | | | | | | The digital | The digital filter is used for noise elimination in fast mode. | | | | | | Ī | PRS0 | Control of the IICA operation clock (fмск) | | | | |---|------|--------------------------------------------|--|--|--| | Ī | 0 | Selects fclk (1 MHz ≤ fclk ≤ 20 MHz) | | | | | Ī | 1 | Selects fclk/2 (20 MHz < fclk) | | | | Cautions 1. The fastest operation frequency of IICA operation clock (fmck) is 20 MHz (Max.). When only the fmck exceeds 20 MHz, set bit 0 (PRSn) of the IICA control register n1 (IICCTLn1) to 1. 2. Note the minimum fclk operation frequency when setting the transfer clock. The minimum $f_{CLK}$ operation frequency for serial interface IICA is determined according to the mode. Fast mode: fclk = 3.5 MHz (min.) Normal mode: fclk = 1 MHz (min.) Remark IICE0: Bit 7 of IICA control register 00 (IICCTL00) #### 12.3.6 IICA low-level width setting register 0 (IICWL0) This register is used to set the low-level width (tLow) of the SCLA0 pin signal and the SDAAn pin signal that are output by serial interface IICA. The IICWL0 register can be set by an 8-bit memory manipulation instruction. Set the IICWL0 register while operation of I<sup>2</sup>C is disabled (bit 7 (IICE0) of IICA control register 00 (IICCTL00) is 0). Reset signal generation sets this register to FFH. For details about setting the IICWL0 register, see 12.4.2 Setting transfer clock by using IICWL0 and IICWH0 registers. <R> The data hold time is one-quarter of the time set by the IICWL0 register. Figure 12-10. Format of IICA Low-Level Width Setting Register 0 (IICWL0) #### 12.3.7 IICA high-level width setting register 0 (IICWH0) This register is used to set the high-level width (thigh) of the SCLA0 pin signal and the SDAAn pin signal that are output by serial interface IICA. The IICWH0 register can be set by an 8-bit memory manipulation instruction. Set the IICWH0 register while operation of I<sup>2</sup>C is disabled (bit 7 (IICE0) of IICA control register 00 (IICCTL00) is 0). Reset signal generation sets this register to FFH. Figure 12-11. Format of IICA High-Level Width Setting Register 0 (IICWH0) **Remark** For how to set the transfer clock on the master side, see 12.4.2 (1). For how to set the transfer clock by using the IICWL0 and IICWH0 registers, see 12.4.2 (2). # 12.3.8 Port mode register 6 (PM6) This register sets the input/output of port 6 in 1-bit units. When using the P60/SCLA0 pin as clock I/O and the P61/SDAA0 pin as serial data I/O, clear PM60 and PM61, and the output latches of P60 and P61 to 0. Set the IICE0 bit (bit 7 of IICA control register 00 (IICCTL00)) to 1 before setting the output mode because the P60/SCLA0 and P61/SDAA0 pins output a low level (fixed) when the IICE0 bit is 0. The PM6 register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation sets this register to FFH. Figure 12-12. Format of Port Mode Register 6 (PM6) | Address: FFF26H | | After reset: | FFH R/W | | | | | | | |-----------------|---|--------------|---------|---|---|---|------|------|--| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PM6 | 1 | 1 | 1 | 1 | 1 | 1 | PM61 | PM60 | | | PM6n | P6n pin I/O mode selection (n = 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 (SCLA0) and the serial data bus pin (SDAA0) are configured as follows. - (1) SCLA0 .... 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) SDAA0 .... 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. Slave device Master device SCLA0 SCLA0 Clock output (Clock output) VDD Vss <del>//</del> (Clock input) Clock input SDAA0 SDAA0 Data output Data output Data input Data input - RENESAS Figure 12-13. Pin Configuration Diagram #### 12.4.2 Setting transfer clock by using IICWL0 and IICWH0 registers # (1) Setting transfer clock on master side Transfer clock = $$\frac{f_{MCK}}{IICWL + IICWH + f_{MCK}(t_R + t_F)}$$ At this time, the optimal setting values of the IICWL0 and IICWH0 registers are as follows. (The fractional parts of all setting values are rounded up.) • When the fast mode $$\begin{split} & \text{IICWL0} = \frac{0.52}{\text{Transfer clock}} \times \text{fmck} \\ & \text{IICWH0} = (\frac{0.48}{\text{Transfer clock}} - \text{tr} - \text{tr}) \times \text{fmck} \end{split}$$ • When the normal mode $$\begin{split} & \text{IICWL0} = \frac{0.47}{\text{Transfer clock}} \times f_{\text{MCK}} \\ & \text{IICWH0} = (\frac{0.53}{\text{Transfer clock}} - t_{\text{R}} - t_{\text{F}}) \times f_{\text{MCK}} \end{split}$$ #### (2) Setting IICWL0 and IICWH0 registers on slave side (The fractional parts of all setting values are truncated.) • When the fast mode IICWL0 = 1.3 $$\mu$$ s × fmck IICWH0 = (1.2 $\mu$ s - tr - tr) × fmck • When the normal mode IICWL0 = 4.7 $$\mu$$ s × fmck IICWH0 = (5.3 $\mu$ s - tr - tr) × fmck - Cautions 1. The fastest operation frequency of IICA operation clock (fMCK) is 20 MHz (max.). When only the fcLK exceeds 20 MHz, set bit 0 (PRSn) of the IICA control register n1 (IICCTLn1) to 1. - 2. Note the minimum fclk operation frequency when setting the transfer clock. The minimum fclk operation frequency for serial interface IICA is determined according to the mode. Fast mode: $f_{CLK} = 3.5 \text{ MHz (min.)}$ Normal mode: $f_{CLK} = 1 \text{ MHz (min.)}$ - Remarks 1. Calculate the rise time (t<sub>R</sub>) and fall time (t<sub>F</sub>) of the SDAA0 and SCLA0 signals separately, because they differ depending on the pull-up resistance and wire load. - IICWL0: IICA low-level width setting register 0IICWH0: IICA high-level width setting register 0 tr: SDAA0 and SCLA0 signal falling times tr: SDAA0 and SCLA0 signal rising times fмск: IICA operation clock frequency #### 12.5 I<sup>2</sup>C Bus Definitions and Control Methods The following section describes the I<sup>2</sup>C bus's serial data communication format and the signals used by the I<sup>2</sup>C bus. Figure 12-14 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. SCLA0 1-7 8 9 1-8 9 1-8 9 SDAA0 Start Address R/W ACK Data ACK Stop condition Figure 12-14. I<sup>2</sup>C Bus Serial Data Transfer Timing 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 (SCLA0) is continuously output by the master device. However, in the slave device, the SCLA0 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 SCLA0 pin is at high level and the SDAA0 pin changes from high level to low level. The start conditions for the SCLA0 pin and SDAA0 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. Figure 12-15. Start Conditions A start condition is output when bit 1 (STT0) of IICA control register 00 (IICCTL00) is set (1) after a stop condition has been detected (SPD0: Bit 0 of the IICA status register 0 (IICS0) = 1). When a start condition is detected, bit 1 (STD0) of the IICS0 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 0 (SVA0). If the address data matches the SVA0 register values, the slave device is selected and communicates with the master device until the master device generates a start condition or stop condition. Figure 12-16. Address **Note** INTIICA0 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 0 (IICA0). The received addresses are written to the IICA0 register. The slave address is assigned to the higher 7 bits of the IICA0 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. Figure 12-17. Transfer Direction Specification **Note** INTIICA0 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 (ACKD0) of the IICA status register 0 (IICS0). 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 SDAA0 line low at the ninth clock (indicating normal reception). Automatic generation of ACK is enabled by setting bit 2 (ACKE0) of IICA control register 00 (IICCTL00) to 1. Bit 3 (TRC0) of the IICS0 register is set by the data of the eighth bit that follows 7-bit address information. Usually, set the ACKE0 bit to 1 for reception (TRC0 = 0). If a slave can receive no more data during reception (TRC0 = 0) or does not require the next data item, then the slave must inform the master, by clearing the ACKE0 bit to 0, that it will not receive any more data. When the master does not require the next data item during reception (TRC0 = 0), it must clear the ACKE0 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). Figure 12-18. ACK When the local address is received, ACK is automatically generated, regardless of the value of the ACKE0 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 ACKE0 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 (WTIM0) of IICCTL00 register = 0): By setting the ACKE0 bit to 1 before releasing the wait state, ACK is generated at the falling edge of the eighth clock of the SCLA0 pin. - When 9-clock wait state is selected (bit 3 (WTIM0) of IICCTL00 register = 1): ACK is generated by setting the ACKE0 bit to 1 in advance. ## 12.5.5 Stop condition When the SCLA0 pin is at high level, changing the SDAA0 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-19. Stop Condition A stop condition is generated when bit 0 (SPT0) of IICA control register 00 (IICCTL00) is set to 1. When the stop condition is detected, bit 0 (SPD0) of the IICA status register 0 (IICS0) is set to 1 and INTIICA0 is generated when bit 4 (SPIE0) of the IICCTL00 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 SCLA0 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. Figure 12-20. Wait (1/2) (1) When master device has a nine-clock wait and slave device has an eight-clock wait (master transmits, slave receives, and ACKE0 = 1) # Figure 12-20. Wait (2/2) # (2) When master and slave devices both have a nine-clock wait (master transmits, slave receives, and ACKE0 = 1) Remark ACKE0: Bit 2 of IICA control register 00 (IICCTL00) WREL0: Bit 5 of IICA control register 00 (IICCTL00) A wait may be automatically generated depending on the setting of bit 3 (WTIM0) of IICA control register 00 (IICCTL00). Normally, the receiving side cancels the wait state when bit 5 (WREL0) of the IICCTL00 register is set to 1 or when FFH is written to the IICA shift register 0 (IICA0), and the transmitting side cancels the wait state when data is written to the IICA0 register. The master device can also cancel the wait state via either of the following methods. - By setting bit 1 (STT0) of the IICCTL00 register to 1 - By setting bit 0 (SPT0) of the IICCTL00 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 0 (IICA0) - Setting bit 5 (WREL0) of IICA control register 00 (IICCTL00) (canceling wait) - Setting bit 1 (STT0) of the IICCTL00 register (generating start condition) Note - Setting bit 0 (SPT0) of the IICCTL00 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 IICA0 register. To receive data after canceling a wait state, or to complete data transmission, set bit 5 (WREL0) of the IICCTL00 register to 1. To generate a restart condition after canceling a wait state, set bit 1 (STT0) of the IICCTL00 register to 1. To generate a stop condition after canceling a wait state, set bit 0 (SPT0) of the IICCTL00 register to 1. Execute the canceling processing only once for one wait state. If, for example, data is written to the IICA0 register after canceling a wait state by setting the WREL0 bit to 1, an incorrect value may be output to SDAA0 line because the timing for changing the SDAA0 line conflicts with the timing for writing the IICA0 register. In addition to the above, communication is stopped if the IICE0 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 (LREL0) of the IICCTL00 register, so that the wait state can be canceled. Caution If a processing to cancel a wait state is executed when WUP0 = 1, the wait state will not be canceled. ## 12.5.8 Interrupt request (INTIICA0) generation timing and wait control The setting of bit 3 (WTIM0) of IICA control register 00 (IICCTL00) determines the timing by which INTIICA0 is generated and the corresponding wait control, as shown in Table 12-2. Table 12-2. INTIICA0 Generation Timing and Wait Control | WTIMO | Duri | ng Slave Device Ope | eration | During Master Device Operation | | | | |-------|-------------------------|---------------------|---------------------|--------------------------------|----------------|-------------------|--| | | Address | Data Reception | Data Transmission | Address | Data Reception | Data Transmission | | | 0 | 9 <sup>Notes 1, 2</sup> | 8 <sup>Note 2</sup> | 8 <sup>Note 2</sup> | 9 | 8 | 8 | | | 1 | 9 <sup>Notes 1, 2</sup> | 9 <sup>Note 2</sup> | 9 <sup>Note 2</sup> | 9 | 9 | 9 | | **Notes 1.** The slave device's INTIICA0 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 0 (SVA0). At this point, ACK is generated regardless of the value set to the IICCTL00 register's bit 2 (ACKE0). For a slave device that has received an extension code, INTIICA0 occurs at the falling edge of the eighth clock. However, if the address does not match after restart, INTIICA0 is generated at the falling edge of the 9th clock, but wait does not occur. 2. If the received address does not match the contents of the slave address register 0 (SVA0) and extension code is not received, neither INTIICA0 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 WTIM0 bit. - Master device operation: Interrupt and wait timing occur at the falling edge of the ninth clock regardless of the WTIM0 bit. # (2) During data reception · Master/slave device operation: Interrupt and wait timing are determined according to the WTIM0 bit. ## (3) During data transmission · Master/slave device operation: Interrupt and wait timing are determined according to the WTIM0 bit. #### (4) Wait cancellation method The four wait cancellation methods are as follows. - Writing data to the IICA shift register 0 (IICA0) - Setting bit 5 (WREL0) of IICA control register 00 (IICCTL00) (canceling wait) - Setting bit 1 (STT0) of IICCTL00 register (generating start condition) Note - Setting bit 0 (SPT0) of IICCTL00 register (generating stop condition)<sup>Note</sup> Note Master only. When an 8-clock wait has been selected (WTIM0 = 0), the presence/absence of ACK generation must be determined prior to wait cancellation. ## (5) Stop condition detection INTIICA0 is generated when a stop condition is detected (only when SPIE0 = 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 (INTIICA0) occurs when the address set to the slave address register 0 (SVA0) 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 (SDAA0) during data transmission is captured by the IICA shift register 0 (IICA0) 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 (EXC0) is set to 1 for extension code reception and an interrupt request (INTIICA0) is issued at the falling edge of the eighth clock. The local address stored in the slave address register 0 (SVA0) 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 SVA0 register is set to 11110xx0. Note that INTIICA0 occurs at the falling edge of the eighth clock. Higher four bits of data match: EXC0 = 1 Seven bits of data match: COI0 = 1 Remark EXC0: Bit 5 of IICA status register 0 (IICS0) COI0: Bit 4 of IICA status register 0 (IICS0) (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 (LREL0) of IICA control register 00 (IICCTL00) to 1 to set the standby mode for the next communication operation. Table 12-3. Bit Definitions of Major Extension Codes | Slave Address | R/W Bit | Description | |---------------|---------|---------------------------------------------------------------------------------------| | 0000 000 | 0 | General call address | | 11110xx | 0 | 10-bit slave address specification (during address authentication) | | 11110xx | 1 | 10-bit slave address specification (after address match, when read command is issued) | **Remark** 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 STT0 bit is set to 1 before the STD0 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 (ALD0) in the IICA status register 0 (IICS0) is set (1) via the timing by which the arbitration loss occurred, and the SCLA0 and SDAA0 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 ALD0 = 1 setting that has been made by software. For details of interrupt request timing, see 12.5.8 Interrupt request (INTIICA0) generation timing and wait control. Remark STD0: Bit 1 of IICA status register 0 (IICS0) STT0: Bit 1 of IICA control register 00 (IICCTL00) Figure 12-21. Arbitration Timing Example Table 12-4. Status During Arbitration and Interrupt Request Generation Timing | 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 SPIE0 = 1) 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 SPIE0 = 1) 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 transfer Note 1 | | | | | When SCLA0 is at low level while attempting to generate a restart condition | | | | | - **Notes 1.** When the WTIM0 bit (bit 3 of IICA control register 00 (IICCTL00)) = 1, an interrupt request occurs at the falling edge of the ninth clock. When WTIM0 = 0 and the extension code's slave address is received, an interrupt request occurs at the falling edge of the eighth clock. - 2. When there is a chance that arbitration will occur, set SPIE0 = 1 for master device operation. Remark SPIE0: Bit 4 of IICA control register 00 (IICCTL00) ## 12.5.13 Wakeup function The I<sup>2</sup>C bus slave function is a function that generates an interrupt request signal (INTIICA0) when a local address and extension code have been received. This function makes processing more efficient by preventing unnecessary INTIICA0 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 WUP0 bit to 1. Addresses can be received regardless of the operation clock. An interrupt request signal (INTIICA0) 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 WUP0 bit after this interrupt has been generated. Figure 12-22 shows the flow for setting WUP0 = 1 and Figure 12-23 shows the flow for setting WUP0 = 0 upon an address match. Figure 12-22. Flow When Setting WUP0 = 1 Yes WuP0 = 0 Wait Wait : Waits for 5 cycles of the fmck clock. Figure 12-23. Flow When Setting WUP0 = 0 upon Address Match (Including Extension Code Reception) Executes processing corresponding to the operation to be executed after checking the operation state of serial interface IICA. Use the following flows to perform the processing to release the STOP mode other than by an interrupt request (INTIICA0) generated from serial interface IICA. <R> - When operating next IIC communication as master: Flow shown in Figure 12-24. - When operating next IIC communication as slave: When restored by INTIICAn interrupt: Same as the flow in Figure 12-23. When restored by other than INTIICAn interrupt: Wait for INTIICAn interrupt with WUPn left set to 1. **START** SPIE0 = 1WUP0 = 1 Wait : Wait for 3 cycles of the fmck clock. STOP instruction STOP mode state Releasing STOP mode : Releases STOP mode by an interrupt other than INTIICA0. WUP0 = 0No INTIICA0 = 1? Yes : Generates a STOP condition or selects as a slave device. Wait : Waits for 5 clocks. Reading IICS0 Figure 12-24. When Operating as Master Device after Releasing STOP Mode other than by INTIICA0 Executes processing corresponding to the operation to be executed after checking the operation state of serial interface IICA. #### 12.5.14 Communication reservation (1) When communication reservation function is enabled (bit 0 (IICRSV) of IICA flag register 0 (IICF0) = 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 (LREL0) of IICA control register 00 (IICCTL00) to 1 and saving communication). If bit 1 (STT0) of the IICCTL00 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 0 (IICA0) after bit 4 (SPIE0) of the IICCTL00 register was set to 1, and it was detected by generation of an interrupt request signal (INTIICA0) that the bus was released (detection of the stop condition), then the device automatically starts communication as the master. Data written to the IICA0 register before the stop condition is detected is invalid. When the STT0 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 MSTS0 bit (bit 7 of the IICA status register 0 (IICS0)) after the STT0 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 STT0 = 1 to checking the MSTS0 flag: (IICWL0 setting value + IICWH0 setting value + 4) / $f_{MCK}$ + $t_F \times 2$ Remark IICWL0: IICA low-level width setting register 0 IICWH0: IICA high-level width setting register 0 tr: SDAA0 and SCLA0 signal falling times fmck: IICA operation clock frequency <R> <R> Figure 12-25 shows the communication reservation timing. Figure 12-25. Communication Reservation Timing Remark IICA0: IICA shift register 0 STT0: Bit 1 of IICA control register 00 (IICCTL00) STD0: Bit 1 of IICA status register 0 (IICS0) SPD0: Bit 0 of IICA status register 0 (IICS0) Communication reservations are accepted via the timing shown in Figure 12-26. After bit 1 (STD0) of the IICA status register 0 (IICS0) is set to 1, a communication reservation can be made by setting bit 1 (STT0) of IICA control register 00 (IICCTL00) to 1 before a stop condition is detected. Figure 12-26. Timing for Accepting Communication Reservations Figure 12-27 shows the communication reservation protocol. Figure 12-27. Communication Reservation Protocol - <R> Notes 1. The wait time is calculated as follows. - (IICWL0 setting value + IICWH0 setting value + 4) / $f_{MCK}$ + $t_F \times 2$ - 2. The communication reservation operation executes a write to the IICA shift register 0 (IICA0) when a stop condition interrupt request occurs. Remark STT0: Bit 1 of IICA control register 00 (IICCTL00) MSTS0: Bit 7 of IICA status register 0 (IICS0) IICA0: IICA shift register 0 IICWL0: IICA low-level width setting register 0 IICWH0: IICA high-level width setting register 0 tr: SDAA0 and SCLA0 signal falling times fмск: IICA operation clock frequency # (2) When communication reservation function is disabled (bit 0 (IICRSV) of IICA flag register 0 (IICF0) = 1) When bit 1 (STT0) of IICA control register 00 (IICCTL00) 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 (LREL0) of the IICCTL00 register to 1 and saving communication) To confirm whether the start condition was generated or request was rejected, check STCF (bit 7 of the IICF0 register). It takes up to 5 cycles of the $f_{MCK}$ clock until the STCF bit is set to 1 after setting STT0 = 1. Therefore, secure the time by software. #### 12.5.15 Cautions ## (1) When STCEN = 0 Immediately after $I^2C$ operation is enabled (IICE0 = 1), the bus communication status (IICBSY = 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 01 (IICCTL01). - <2> Set bit 7 (IICE0) of IICA control register 00 (IICCTL00) to 1. - <3> Set bit 0 (SPT0) of the IICCTL00 register to 1. #### (2) When STCEN = 1 Immediately after $I^2C$ operation is enabled (IICE0 = 1), the bus released status (IICBSY = 0) is recognized regardless of the actual bus status. To generate the first start condition (STT0 = 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 SDAA0 pin is low and the SCLA0 pin is high, the macro of I<sup>2</sup>C recognizes that the SDAA0 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 (SPIE0) of the IICCTL00 register to 0 to disable generation of an interrupt request signal (INTIICA0) when the stop condition is detected. - <2> Set bit 7 (IICE0) of the IICCTL00 register to 1 to enable the operation of I2C. - <3> Wait for detection of the start condition. - <4> Set bit 6 (LREL0) of the IICCTL00 register to 1 before ACK is returned (4 to 72 cycles of the fMCK clocks after setting the IICE0 bit to 1), to forcibly disable detection. - (4) Setting the STT0 and SPT0 bits (bits 1 and 0 of the IICCTL00 register) again after they are set and before they are cleared to 0 is prohibited. - (5) When transmission is reserved, set the SPIE0 bit (bit 4 of the IICTL0 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 0 (IICA0) 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 SPIE0 bit to 1 when the MSTS0 bit (bit 7 of the IICA status register 0 (IICS0)) 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 RL78/G12 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 RL78/G12 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 RL78/G12 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 RL78/G12 is used as the I<sup>2</sup>C 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 INTIICA0 interrupt occurrence (communication waiting). When an INTIICA0 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. <R> # (1) Master operation in single-master system Figure 12-28. Master Operation in Single-Master System START Setting the PER0 register Release the serial interface IICAn from the reset status and start clock supply. Initializing I2C busNote Setting of the port used alternatively as the pin to be used. First, set the port to input mode and the output latch to 0 (see 12.3.8 Port mode register 6 (PM6)) Setting port IICWL0, IICWH0 ← XXH Sets a transfer clock. $\mathsf{SVA0} \leftarrow \mathsf{XXH}$ Sets a local address. IICF0 ← 0XH Setting STCEN0, IICRSV0 = 0 Setting IICCTL01 Initial setting IICCTL00 ← 0XX111XXB ACKE0 = WTIM0 = SPIE0 = IICCTL00 ← 1XX111XXB IICE0 = 1 Set the port from input mode to output mode and enable the output of the I°C bus (see 12.3.8 Port mode register 6 (PM6)). Setting port STCEN0 = 1? No Prepares for starting communication (generates a stop condition). SPT0 = 1 INTIICA0 interrupt occurs? Waits for detection of the stop condition Prepares for starting communication (generates a start condition). STT0 = 1Starts communication (specifies an address and transfer Writing IICA0 INTIICA0 Waits for detection of acknowledge. ACKD0 = 1? ACKE0 = Yes WTIM0 = 0TRC0 = 1? WREL0 = 1 Starts reception Yes Communication processing Writing IICA0 Starts transmission. INTIICAO Waits for data Yes INTIICA0 Reading IICA0 interrupt occurs? Waits for data transmission. Yes End of transfer? ACKD0 = 13 Yes ACKE0 = 0 End of transfer? WTIM0 = 1WREL0 = 1 Restart? INTIICAO SPT0 = 1 interrupt occurs Waits for detection of acknowledge. Yes **Note** Release (SCLA0 and SDAA0 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 SDAA0 pin, for example, set the SCLA0 pin in the output port mode, and output a clock pulse from the output port until the SDAA0 pin is constantly at high level. **Remark** Conform to the specifications of the product that is communicating, with respect to the transmission and reception formats. ## (2) Master operation in multi-master system Figure 12-29. Master Operation in Multi-Master System (1/3) **Note** Confirm that the bus is released (CLD0 bit = 1, DAD0 bit = 1) for a specific period (for example, for a period of one frame). If the SDAA0 pin is constantly at low level, decide whether to release the I<sup>2</sup>C bus (SCLA0 and SDAA0 pins = high level) in conformance with the specifications of the product that is communicating. <R> Enables reserving communication. Prepares for starting communication STT0 = 1 (generates a start condition). Secure wait time Note by software. Wait Communication processing MSTS0 = 1? Yes INTIICA0 interrupt occurs? Waits for bus release (communication being reserved). Yes EXC0 = 1 or COI0 =1 Wait state after stop condition was detected and start condition Yes was generated by the communication reservation function. Slave operation Figure 12-29. Master Operation in Multi-Master System (2/3) Note The wait time is calculated as follows. (IICWL0 setting value + IICWH0 setting value + 4) / $f_{MCK}$ + $t_F \times 2$ Remark IICWL0: IICA low-level width setting register 0 IICWH0: IICA high-level width setting register 0 tr: SDAA0 and SCLA0 signal falling times fcLk: CPU/peripheral hardware clock frequency fmck: IICA operation clock frequency <R> Figure 12-29. Master Operation in Multi-Master System (3/3) **Remarks 1.** Conform to the specifications of the product that is communicating, with respect to the transmission and reception formats. - 2. To use the device as a master in a multi-master system, read the MSTS0 bit each time interrupt INTIICA0 has occurred to check the arbitration result. - 3. To use the device as a slave in a multi-master system, check the status by using the IICA status register 0 (IICS0) and IICA flag register 0 (IICF0) each time interrupt INTIICA0 has occurred, and determine the processing to be performed next. #### (3) Slave operation The processing procedure of the slave operation is as follows. Basically, the slave operation is event-driven. Therefore, processing by the INTIICA0 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 INTIICA0 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 INTIICA0. #### <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) stop condition detection, no detection of Aox non-master, address mismatch ## <2> Ready flag This flag indicates that data communication is enabled. Its function is the same as the INTIICA0 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 TRC0 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. Figure 12-30. Slave Operation Flowchart (1) **Remark** Conform to the specifications of the product that is in communication, regarding the transmission and reception formats. An example of the processing procedure of the slave with the INTIICA0 interrupt is explained below (processing is performed assuming that no extension code is used). The INTIICA0 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 I<sup>2</sup>C bus remaining in the wait state. Remark <1> to <3> above correspond to <1> to <3> in Figure 12-31 Slave Operation Flowchart (2). Figure 12-31. Slave Operation Flowchart (2) # 12.5.17 Timing of I<sup>2</sup>C interrupt request (INTIICA0) occurrence The timing of transmitting or receiving data and generation of interrupt request signal INTIICA0, and the value of the IICA status register 0 (IICS0) when the INTIICA0 signal is generated are shown below. Remark ST: Start condition AD6 to AD0: Address $R/\overline{W}$ : Transfer direction specification ACK: Acknowledge D7 to D0: Data SP: Stop condition # (1) Master device operation # (a) Start ~ Address ~ Data ~ Data ~ Stop (transmission/reception) # (i) When WTIM0 = 0 ▲1: IICS0 = 1000×110B **▲**2: IICS0 = 1000×000B ▲3: IICS0 = 1000×000B (Sets the WTIM0 bit to 1)<sup>Note</sup> $\triangle 4$ : IICS0 = 1000××00B (Sets the SPT0 bit to 1)<sup>Note</sup> △5: IICS0 = 00000001B **Note** To generate a stop condition, set the WTIM0 bit to 1 and change the timing for generating the INTIICA0 interrupt request signal. Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # (ii) When WTIM0 = 1 ▲1: IICS0 = 1000×110B ▲2: IICS0 = 1000×100B $\blacktriangle$ 3: IICS0 = 1000××00B (Sets the SPT0 bit to 1) △4: IICS0 = 00000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 # (b) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop (restart) ## (i) When WTIM0 = 0 **▲**1: IICS0 = 1000×110B ▲2: IICS0 = 1000×000B (Sets the WTIM0 bit to 1) Note 1 $\triangle$ 3: IICS0 = 1000××00B (Clears the WTIM0 bit to $0^{Note 2}$ , sets the STT0 bit to 1) ▲4: IICS0 = 1000×110B ▲5: IICS0 = 1000×000B (Sets the WTIM0 bit to 1)<sup>Note 3</sup> $\blacktriangle$ 6: IICS0 = 1000××00B (Sets the SPT0 bit to 1) △7: IICS0 = 00000001B - **Notes 1.** To generate a start condition, set the WTIM0 bit to 1 and change the timing for generating the INTIICA0 interrupt request signal. - 2. Clear the WTIM0 bit to 0 to restore the original setting. - **3.** To generate a stop condition, set the WTIM0 bit to 1 and change the timing for generating the INTIICA0 interrupt request signal. **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # (ii) When WTIM0 = 1 **▲**1: IICS0 = 1000×110B $\triangle$ 2: IICS0 = 1000××00B (Sets the STT0 bit to 1) ▲3: IICS0 = 1000×110B $\blacktriangle$ 4: IICS0 = 1000××00B (Sets the SPT0 bit to 1) △5: IICS0 = 00000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 # (c) Start ~ Code ~ Data ~ Data ~ Stop (extension code transmission) # (i) When WTIM0 = 0 ▲1: IICS0 = 1010×110B ▲2: IICS0 = 1010×000B ▲3: IICS0 = $1010 \times 000B$ (Sets the WTIM0 bit to 1)<sup>Note</sup> $\blacktriangle$ 4: IICS0 = 1010××00B (Sets the SPT0 bit to 1) △5: IICS0 = 00000001B **Note** To generate a stop condition, set the WTIM0 bit to 1 and change the timing for generating the INTIICA0 interrupt request signal. Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care ## (ii) When WTIM0 = 1 ▲1: IICS0 = 1010×110B **▲**2: IICS0 = 1010×100B $\triangle 3$ : IICS0 = 1010××00B (Sets the SPT0 bit to 1) △4: IICS0 = 00001001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 # (2) Slave device operation (slave address data reception) # (a) Start ~ Address ~ Data ~ Data ~ Stop # (i) When WTIM0 = 0 ▲1: IICS0 = 0001×110B ▲2: IICS0 = 0001×000B ▲3: IICS0 = 0001×000B △4: IICS0 = 00000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # (ii) When WTIM0 = 1 **▲**1: IICS0 = 0001×110B ▲2: IICS0 = 0001×100B ▲3: IICS0 = 0001××00B △4: IICS0 = 00000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 # (b) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop (i) When WTIM0 = 0 (after restart, matches with SVA0) # (ii) When WTIM0 = 1 (after restart, matches with SVA0) # (c) Start ~ Address ~ Data ~ Start ~ Code ~ Data ~ Stop (i) When WTIM0 = 0 (after restart, does not match address (= extension code)) (ii) When WTIM0 = 1 (after restart, does not match address (= extension code)) # (d) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop (i) When WTIM0 = 0 (after restart, does not match address (= not extension code)) (ii) When WTIM0 = 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 WTIM0 = 0 | | | | | | | | | | _ | |----|------------|-----|-----|----------|-----|----------|------------|----|---------| | ST | AD6 to AD0 | R/W | ACK | D7 to D0 | ACK | D7 to D0 | ACK | SP | | | | <b>▲</b> 1 | | | | ▲2 | | <b>A</b> 3 | | -<br>∆4 | ▲1: IICS0 = 0010×010B ▲2: IICS0 = 0010×000B ▲3: IICS0 = 0010×000B △4: IICS0 = 00000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # (ii) When WTIM0 = 1 ▲1: IICS0 = 0010×010B ▲2: IICS0 = 0010×110B **▲**3: IICS0 = 0010×100B ▲4: IICS0 = 0010××00B △5: IICS0 = 00000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 # (b) Start ~ Code ~ Data ~ Start ~ Address ~ Data ~ Stop # (i) When WTIM0 = 0 (after restart, matches SVA0) # (ii) When WTIM0 = 1 (after restart, matches SVA0) # (c) Start ~ Code ~ Data ~ Start ~ Code ~ Data ~ Stop # (i) When WTIM0 = 0 (after restart, extension code reception) # (ii) When WTIM0 = 1 (after restart, extension code reception) # (d) Start ~ Code ~ Data ~ Start ~ Address ~ Data ~ Stop (i) When WTIM0 = 0 (after restart, does not match address (= not extension code)) (ii) When WTIM0 = 1 (after restart, does not match address (= not extension code)) ## (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 $\triangle$ 1 $\triangle$ 1: IICS0 = 000000001B Remark $\triangle$ : Generated only when SPIE0 = 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 MSTS0 bit each time interrupt request signal INTIICA0 has occurred to check the arbitration result. # (a) When arbitration loss occurs during transmission of slave address data ## (i) When WTIM0 = 0 Don't care # (ii) When WTIM0 = 1 ST AD6 to AD0 R/W ACK D7 to D0 ACK D7 to D0 ACK SP **▲**1: IICS0 = 0101×110B ▲2: IICS0 = 0001×100B ▲3: IICS0 = 0001××00B △4: IICS0 = 00000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # (b) When arbitration loss occurs during transmission of extension code # (i) When WTIM0 = 0 ▲1: IICS0 = 0110×010B ▲2: IICS0 = 0010×000B ▲3: IICS0 = 0010×000B △4: IICS0 = 00000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care ## (ii) When WTIM0 = 1 ST AD6 to AD0 R/W ACK D7 to D0 ACK D7 to D0 ACK SP ▲1: IICS0 = 0110×010B ▲2: IICS0 = 0010×110B ▲3: IICS0 = 0010×100B ▲4: IICS0 = 0010××00B △5: IICS0 = 00000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don'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 MSTS0 bit each time interrupt request signal INTIICA0 has occurred to check the arbitration result. #### (a) When arbitration loss occurs during transmission of slave address data (when WTIM0 = 1) ▲1: IICS0 = 01000110B △2: IICS0 = 00000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 # (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: IICS0 = 0110×010B Sets LREL0 = 1 by software △2: IICS0 = 00000001B Remark ▲: Always generated △: Generated only when SPIE0 = 1 ×: Don't care ## (c) When arbitration loss occurs during transmission of data # (i) When WTIM0 = 0 # (ii) When WTIM0 = 1 # (d) When loss occurs due to restart condition during data transfer # (i) Not extension code (Example: unmatches with SVA0) # (ii) Extension code **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care n = 6 to 0 # (e) When loss occurs due to stop condition during data transfer ## (f) When arbitration loss occurs due to low-level data when attempting to generate a restart condition ## (i) When WTIM0 = 0 ▲1: IICS0 = 1000×110B ▲2: IICS0 = 1000×000B (Sets the WTIM0 bit to 1) ▲3: IICS0 = 1000×100B (Clears the WTIM0 bit to 0) **▲**4: IICS0 = 01000000B △5: IICS0 = 00000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care ## (ii) When WTIM0 = 1 ▲1: IICS0 = 1000×110B $\triangle$ 2: IICS0 = 1000×100B (Sets the STT0 bit to 1) ▲3: IICS0 = 01000100B △4: IICS0 = 00000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # (g) When arbitration loss occurs due to a stop condition when attempting to generate a restart condition ## (i) When WTIM0 = 0 ▲1: IICS0 = 1000×110B ▲2: IICS0 = 1000×000B (Sets the WTIM0 bit to 1) $\blacktriangle$ 3: IICS0 = 1000××00B (Sets the STT0 bit to 1) △4: IICS0 = 01000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # (ii) When WTIM0 = 1 **▲**1: IICS0 = 1000×110B $\triangle$ 2: IICS0 = 1000××00B (Sets the STT0 bit to 1) △3: IICS0 = 01000001B Remark ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 ×: Don't care ## (h) When arbitration loss occurs due to low-level data when attempting to generate a stop condition ## (i) When WTIM0 = 0 ▲1: IICS0 = 1000×110B ▲2: IICS0 = 1000×000B (Sets the WTIM0 bit to 1) $\blacktriangle$ 3: IICS0 = 1000×100B (Clears the WTIM0 bit to 0) **▲**4: IICS0 = 01000100B △5: IICS0 = 00000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care ## (ii) When WTIM0 = 1 **▲**1: IICS0 = 1000×110B ▲2: IICS0 = 1000×100B (Sets the SPT0 bit to 1) **▲**3: IICS0 = 01000100B △4: IICS0 = 00000001B **Remark** ▲: Always generated $\triangle$ : Generated only when SPIE0 = 1 x: Don't care # 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 TRC0 bit (bit 3 of the IICA status register 0 (IICS0)), which specifies the data transfer direction, and then starts serial communication with the slave device. Figures 12-32 and 12-33 show timing charts of the data communication. The IICA shift register 0 (IICA0)'s shift operation is synchronized with the falling edge of the serial clock (SCLA0). The transmit data is transferred to the SO latch and is output (MSB first) via the SDAA0 pin. Data input via the SDAA0 pin is captured into IICA0 at the rising edge of SCLA0. Figure 12-32. Example of Master to Slave Communication (9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (1/4) #### (1) Start condition ~ address ~ data **Notes 1.** Write data to IICA0, not setting the WREL0 bit, in order to cancel a wait state during transmission by a master device. - 2. Make sure that the time between the fall of the SDAA0 pin signal and the fall of the SCLA0 pin signal is at least 4.0 $\mu$ s when specifying standard mode and at least 0.6 $\mu$ s when specifying fast mode. - 3. For releasing wait state during reception of a slave device, write "FFH" to IICA0 or set the WREL0 bit. The meanings of <1> to <6> in (1) Start condition ~ address ~ data in Figure 12-32 are explained below. - <1> The start condition trigger is set by the master device (STT0 = 1) and a start condition (SDAA0 = 0 and SCLA0 = 1) is generated once the bus data line goes low (SDAA0 = 0). When the start condition is subsequently detected, the master device enters the master device communication status (MSTS0 = 1). The master device is ready to communicate once the bus clock line goes low (SCLA0 = 0) after the hold time has elapsed. - <2> The master device writes the address + W (transmission) to the IICA shift register 0 (IICA0) and transmits the slave address. - <3> In the slave device if the address received matches the address (SVA0 value) of a slave device hat slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <4> The master device issues an interrupt (INTIICA0: 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 (SCLA0 = 0) and issues an interrupt (INTIICA0: address match)<sup>Note</sup>. - <5> The master device writes the data to transmit to the IICA0 register and releases the wait status that it set by the master device. - <6> If the slave device releases the wait status (WREL0 = 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: SDAA0 = 1). The slave device also does not issue the INTIICA0 interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICA0 interrupt (end of address transmission) regardless of whether it receives an ACK or NACK. Remark <1> to <15> in Figure 12-32 show the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12-32 (1) Start condition ~ address ~ data shows the processing from <1> to <6>, Figure 12-32 (2) Address ~ data ~ data shows the processing from <3> to <10>, and Figure 12-32 (3) Data ~ data ~ stop condition shows the processing from <7> to <15>. Figure 12-32. Example of Master to Slave Communication (9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (2/4) ## (2) Address ~ data ~ data **Notes 1.** Write data to IICA0, not setting the WREL0 bit, in order to cancel a wait state during transmission by a master device. 2. For releasing wait state during reception of a slave device, write "FFH" to IICA0 or set the WREL0 bit. The meanings of <3> to <10> in (2) Address ~ data ~ data in Figure 12-32 are explained below. - <3> In the slave device if the address received matches the address (SVA0 value) of a slave device Note, that slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <4> The master device issues an interrupt (INTIICA0: 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 (SCLA0 = 0) and issues an interrupt (INTIICA0: address match)<sup>Note</sup>. - <5> The master device writes the data to transmit to the IICA shift register 0 (IICA0) and releases the wait status that it set by the master device. - <6> If the slave device releases the wait status (WREL0 = 1), the master device starts transferring data to the slave device. - <7> After data transfer is completed, because of ACKE0 = 1, the slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <8> The master device and slave device set a wait status (SCLA0 = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICA0: end of transfer). - <9> The master device writes the data to transmit to the IICA0 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 (WREL0 = 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: SDAA0 = 1). The slave device also does not issue the INTIICA0 interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICA0 interrupt (end of address transmission) regardless of whether it receives an ACK or NACK. Remark <1> to <15> in Figure 12-32 show the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12-32 (1) Start condition ~ address ~ data shows the processing from <1> to <6>, Figure 12-32 (2) Address ~ data ~ data shows the processing from <3> to <10>, and Figure 12-32 (3) Data ~ data ~ stop condition shows the processing from <7> to <15>. Figure 12-32. Example of Master to Slave Communication (9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (3/4) #### (3) Data ~ data ~ Stop condition **Notes 1.** Write data to IICA0, not setting the WREL0 bit, in order to cancel a wait state during transmission by a master device. - 2. Make sure that the time between the rise of the SCLA0 pin signal and the generation of the stop condition after a stop condition has been issued is at least 4.0 $\mu$ s when specifying standard mode and at least 0.6 $\mu$ s when specifying fast mode. - 3. For releasing wait state during reception of a slave device, write "FFH" to IICA0 or set the WREL0 bit. The meanings of <7> to <15> in (3) Data ~ data ~ stop condition in Figure 12-32 are explained below. - <7> After data transfer is completed, because of ACKE0 = 1, the slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <8> The master device and slave device set a wait status (SCLA0 = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICA0: end of transfer). - <9> The master device writes the data to transmit to the IICA shift register 0 (IICA0) 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 (WREL0 = 1). The master device then starts transferring data to the slave device. - <11> When data transfer is complete, the slave device (ACKE0 =1) sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <12> The master device and slave device set a wait status (SCLA0 = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICA0: end of transfer). - <13> The slave device reads the received data and releases the wait status (WREL0 = 1). - <14> By the master device setting a stop condition trigger (SPT0 = 1), the bus data line is cleared (SDAA0 = 0) and the bus clock line is set (SCLA0 = 1). After the stop condition setup time has elapsed, by setting the bus data line (SDAA0 = 1), the stop condition is then generated (i.e. SCLA0 =1 changes SDAA0 from 0 to 1). - <15> When a stop condition is generated, the slave device detects the stop condition and issues an interrupt (INTIICA0: stop condition). Remark <1> to <15> in Figure 12-32 show the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12-32 (1) Start condition ~ address ~ data shows the processing from <1> to <6>, Figure 12-32 (2) Address ~ data ~ data shows the processing from <3> to <10>, and Figure 12-32 (3) Data ~ data ~ stop condition shows the processing from <7> to <15>. Figure 12-32. Example of Master to Slave Communication (9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (4/4) ## (4) Data ~ restart condition ~ address **Notes 1.** Make sure that the time between the rise of the SCLA0 pin signal and the generation of the start condition after a restart condition has been issued is at least 4.7 $\mu$ s when specifying standard mode and at least 0.6 $\mu$ s when specifying fast mode. 2. For releasing wait state during reception of a slave device, write "FFH" to IICA0 or set the WREL0 bit. The following describes the operations in Figure 12-32 (4) Data ~ restart condition ~ address. After the operations in steps <7> and <8>, the operations in steps <1> to <3> are performed. These steps return the processing to step <3>, the data transmission step. - <7> After data transfer is completed, because of ACKE0 = 1, the slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <8> The master device and slave device set a wait status (SCLA0 = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICA0: end of transfer). - <i> The slave device reads the received data and releases the wait status (WREL0 = 1). - <ii> The start condition trigger is set again by the master device (STT0 = 1) and a start condition (i.e. SCLA0 = 1 changes SDAA0 from 1 to 0) is generated once the bus clock line goes high (SCLA0 = 1) and the bus data line goes low (SDAA0 = 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 (SCLA0 = 0) after the hold time has elapsed. - <ii> The master device writing the address + R/W (transmission) to the IICA shift register (IICA0) enables the slave address to be transmitted. Figure 12-33. Example of Slave to Master Communication (8-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (1/3) #### (1) Start condition ~ address ~ data Notes 1. For releasing wait state during reception of a master device, write "FFH" to IICA0 or set the WREL0 bit. - 2. Make sure that the time between the fall of the SDAA0 pin signal and the fall of the SCLA0 pin signal is at least 4.0 $\mu$ s when specifying standard mode and at least 0.6 $\mu$ s when specifying fast mode. - 3. Write data to IICA0, not setting the WREL0 bit, in order to cancel a wait state during transmission by a slave device. The meanings of <1> to <7> in (1) Start condition ~ address ~ data in Figure 12-33 are explained below. - <1> The start condition trigger is set by the master device (STT0 = 1) and a start condition (i.e. SCLA0 =1 changes SDAA0 from 1 to 0) is generated once the bus data line goes low (SDAA0). When the start condition is subsequently detected, the master device enters the master device communication status (MSTS0 = 1). The master device is ready to communicate once the bus clock line goes low (SCLA0 = 0) after the hold time has elapsed. - <2> The master device writes the address + R (reception) to the IICA shift register 0 (IICA0) and transmits the slave address. - <3> In the slave device if the address received matches the address (SVA0 value) of a slave device Note, that slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <4> The master device issues an interrupt (INTIICA0: 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 (SCLA0 = 0) and issues an interrupt (INTIICA0: address match) Note. - <5> The timing at which the master device sets the wait status changes to the 8th clock (WTIM0 = 0). - <6> The slave device writes the data to transmit to the IICA0 register and releases the wait status that it set by the slave device. - <7> The master device releases the wait status (WREL0 = 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: SDAA0 = 1). The slave device also does not issue the INTIICA0 interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICA0 interrupt (end of address transmission) regardless of whether it receives an ACK or NACK. Remark <1> to <19> in Figure 12-33 show descriptions the entire procedure for communicating data using the Figure 12-33 (1) Start condition ~ address ~ data shows the processing from <1> to <7>, Figure 12-33 (2) Address ~ data ~ data shows the processing from <3> to <12>, and Figure 12-33 (3) Data ~ data ~ stop condition shows the processing from <8> to <19>. Figure 12-33. Example of Slave to Master Communication (8-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (2/3) ## (2) Address ~ data ~ data Notes 1. For releasing wait state during reception of a master device, write "FFH" to IICA0 or set the WREL0 bit. 2. Write data to IICA0, not setting the WREL0 bit, in order to cancel a wait state during transmission by a slave device. The meanings of <3> to <12> in (2) Address ~ data ~ data in Figure 12-33 are explained below. - <3> In the slave device if the address received matches the address (SVA0 value) of a slave device hat slave device sends an ACK by hardware to the master device. The ACK is detected by the master device (ACKD0 = 1) at the rising edge of the 9th clock. - <4> The master device issues an interrupt (INTIICA0: 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 (SCLA0 = 0) and issues an interrupt (INTIICA0: address match)<sup>Note</sup>. - <5> The master device changes the timing of the wait status to the 8th clock (WTIM0 = 0). - <6> The slave device writes the data to transmit to the IICA shift register 0 (IICA0) and releases the wait status that it set by the slave device. - <7> The master device releases the wait status (WREL0 = 1) and starts transferring data from the slave device to the master device. - <8> The master device sets a wait status (SCLA0 = 0) at the falling edge of the 8th clock, and issues an interrupt (INTIICA0: end of transfer). Because of ACKE0 = 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 (WREL0 = 1). - <10> The ACK is detected by the slave device (ACKD0 = 1) at the rising edge of the 9th clock. - <11> The slave device set a wait status (SCLA0 = 0) at the falling edge of the 9th clock, and the slave device issue an interrupt (INTIICA0: end of transfer). - <12> By the slave device writing the data to transmit to the IICA0 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: SDAA0 = 1). The slave device also does not issue the INTIICA0 interrupt (address match) and does not set a wait status. The master device, however, issues the INTIICA0 interrupt (end of address transmission) regardless of whether it receives an ACK or NACK. - **Remark** <1> to <19> in Figure 12-33 show descriptions the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12-33 (1) Start condition $\sim$ address $\sim$ data shows the processing from <1> to <7>, Figure 12-33 (2) Address $\sim$ data $\sim$ data shows the processing from <3> to <12>, and Figure 12-33 (3) Data $\sim$ data $\sim$ stop condition shows the processing from <8> to <19>. Figure 12-33. Example of Slave to Master Communication (8-Clock and 9-Clock Wait Is Selected for Master, 9-Clock Wait Is Selected for Slave) (3/3) #### (3) Data ~ data ~ stop condition Notes 1. To cancel a wait state, write "FFH" to IICA0 or set the WREL0 bit. - 2. Make sure that the time between the rise of the SCLA0 pin signal and the generation of the stop condition after a stop condition has been issued is at least 4.0 $\mu$ s when specifying standard mode and at least 0.6 $\mu$ s when specifying fast mode. - **3.** Write data to IICA0, not setting the WREL0 bit, in order to cancel a wait state during transmission by a slave device. - **4.** If a wait state during transmission by a slave device is canceled by setting the WREL0 bit, the TRC0 bit will be cleared. The meanings of <8> to <19> in (3) Data ~ data ~ stop condition in Figure 12-33 are explained below. - <8> The master device sets a wait status (SCLA0 = 0) at the falling edge of the 8th clock, and issues an interrupt (INTIICA0: end of transfer). Because of ACKE0 = 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 (WREL0 = 1). - <10> The ACK is detected by the slave device (ACKD0 = 1) at the rising edge of the 9th clock. - <11> The slave device set a wait status (SCLA0 = 0) at the falling edge of the 9th clock, and the slave device issue an interrupt (INTIICA0: 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 (INTIICA0: end of transfer) at the falling edge of the 8th clock, and sets a wait status (SCLA0 = 0). Because ACK control (ACKE0 = 1) is performed, the bus data line is at the low level (SDAA0 = 0) at this stage. - <14> The master device sets NACK as the response (ACKE0 = 0) and changes the timing at which it sets the wait status to the 9th clock (WTIM0 = 1). - <15> If the master device releases the wait status (WREL0 = 1), the slave device detects the NACK (ACK = 0) at the rising edge of the 9th clock. - <16> The master device and slave device set a wait status (SCLA0 = 0) at the falling edge of the 9th clock, and both the master device and slave device issue an interrupt (INTIICA0: end of transfer). - <17> When the master device issues a stop condition (SPT0 = 1), the bus data line is cleared (SDAA0 = 0) and the master device releases the wait status. The master device then waits until the bus clock line is set (SCLA0 = 1). - <18> The slave device acknowledges the NACK, halts transmission, and releases the wait status (WREL0 = 1) to end communication. Once the slave device releases the wait status, the bus clock line is set (SCLA0 = 1). - <19> Once the master device recognizes that the bus clock line is set (SCLA0 = 1) and after the stop condition setup time has elapsed, the master device sets the bus data line (SDAA0 = 1) and issues a stop condition (i.e. SCLA0 =1 changes SDAA0 from 0 to 1). When a stop condition is generated, the slave device detects the stop condition and issues an interrupt (INTIICA0: stop condition). - **Remark** <1> to <19> in Figure 12-33 show descriptions the entire procedure for communicating data using the I<sup>2</sup>C bus. Figure 12-33 (1) Start condition $\sim$ address $\sim$ data shows the processing from <1> to <7>, Figure 12-33 (2) Address $\sim$ data $\sim$ data shows the processing from <3> to <12>, and Figure 12-33 (3) Data $\sim$ data $\sim$ stop condition shows the processing from <8> to <19>. ## CHAPTER 13 MULTIPLIER AND DIVIDER/MULTIPLY-ACCUMULATOR # 13.1 Functions of Multiplier and Divider/Multiply-Accumulator The multiplier and divider/multiply-accumulator has the following functions. - 16 bits × 16 bits = 32 bits (Unsigned) - 16 bits × 16 bits = 32 bits (Signed) - 16 bits × 16 bits + 32 bits = 32 bits (Unsigned) - 16 bits × 16 bits + 32 bits = 32 bits (Signed) - 32 bits ÷ 32 bits = 32 bits, 32-bits remainder (Unsigned) # 13.2 Configuration of Multiplier and Divider/Multiply-Accumulator The multiplier and divider/multiply-accumulator consists of the following hardware. Table 13-1. Configuration of Multiplier and Divider/Multiply-Accumulator | Item | Configuration | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Registers | Multiplication/division data register A (L) (MDAL) Multiplication/division data register A (H) (MDAH) Multiplication/division data register B (L) (MDBL) Multiplication/division data register B (H) (MDBH) Multiplication/division data register C (L) (MDCL) Multiplication/division data register C (H) (MDCH) | | | | Control register | Multiplication/division control register (MDUC) | | | Figure 13-1 shows a block diagram of the multiplier and divider/multiply-accumulator. Figure 13-1. Block Diagram of Multiplier and Divider/Multiply-Accumulator Remark fclk: CPU/peripheral hardware clock frequency #### 13.2.1 Multiplication/division data register A (MDAH, MDAL) The MDAH and MDAL registers set the values that are used for a multiplication or division operation and store the operation result. They set the multiplier and multiplicand data in the multiplication mode or multiply-accumulator mode, and set the dividend data in the division mode. Furthermore, the operation result (quotient) is stored in the MDAH and MDAL registers in the division mode. The MDAH and MDAL registers can be set by a 16-bit manipulation instruction. Reset signal generation clears these registers to 0000H. Figure 13-2. Format of Multiplication/Division Data Register A (MDAH, MDAL) - **Cautions 1.** Do not rewrite the MDAH and MDAL registers values during division operation processing (when the multiplication/division control register (MDUC) value is 81H or C1H). The operation will be executed in this case, but the operation result will be an undefined value. - 2. The MDAH and MDAL registers values read during division operation processing (when the MDUC register value is 81H or C1H) will not be guaranteed. - 3. The data is in the two's complement format in either the multiplication mode (signed) or multiply-accumulator mode (signed). The following table shows the functions of the MDAH and MDAL registers during operation execution. Table 13-2. Functions of MDAH and MDAL Registers During Operation Execution | Operation Mode | Setting | Operation Result | |--------------------------------------|-------------------------------|---------------------------------------------| | Multiplication mode (unsigned) | MDAH: Multiplier (unsigned) | - | | Multiply-accumulator mode (unsigned) | MDAL: Multiplicand (unsigned) | | | Multiplication mode (signed) | MDAH: Multiplier (signed) | _ | | Multiply-accumulator mode (signed) | MDAL: Multiplicand (signed) | | | Division mode (unsigned) | MDAH: Dividend (unsigned) | MDAH: Division result (quotient) (unsigned) | | | (higher 16 bits) | Higher 16 bits | | | MDAL: Dividend (unsigned) | MDAL: Division result (quotient) (unsigned) | | | (lower 16 bits) | Lower 16 bits | #### 13.2.2 Multiplication/division data register B (MDBL, MDBH) The MDBH and MDBL registers set the values that are used for multiplication or division operation and store the operation result. They store the operation result (product) in the multiplication mode and multiply-accumulator mode, and set the divisor data in the division mode. The MDBH and MDBL registers can be set by a 16-bit manipulation instruction. Reset signal generation clears these registers to 0000H. Figure 13-3. Format of Multiplication/Division Data Register B (MDBH, MDBL) - Cautions 1. Do not rewrite the MDBH and MDBL registers values during division operation processing (when the multiplication/division control register (MDUC) value is 81H or C1H) or multiply-accumulation processing. The operation result will be an undefined value. - 2. Do not set the MDBH and MDBL registers to 0000H in the division mode. If they are set, the operation result will be an undefined value. - 3. The data is in the two's complement format in either the multiplication mode (signed) or multiply-accumulator mode (signed). The following table shows the functions of the MDBH and MDBL registers during operation execution. Table 13-3. Functions of MDBH and MDBL Registers During Operation Execution | Operation Mode | Setting | Operation Result | |---------------------------------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | Multiplication mode (unsigned) Multiply-accumulator mode (unsigned) | _ | MDBH: Multiplication result (product) (unsigned) Higher 16 bits MDBL: Multiplication result (product) (unsigned) Lower 16 bits | | Multiplication mode (signed) Multiply-accumulator mode (signed) | - | MDBH: Multiplication result (product) (signed) Higher 16 bits MDBL: Multiplication result (product) (signed) Lower 16 bits | | Division mode (unsigned) | MDBH: Divisor (unsigned) (higher 16 bits) MDBL: Divisor (unsigned) (lower 16 bits) | _ | ## 13.2.3 Multiplication/division data register C (MDCL, MDCH) The MDCH and MDCL registers are used to store the accumulated result while in the multiply-accumulator mode or the remainder of the operation result while in the division mode. These registers are not used while in the multiplication mode. The MDCH and MDCL registers can be set by a 16-bit manipulation instruction. Reset signal generation clears these registers to 0000H. Figure 13-4. Format of Multiplication/Division Data Register C (MDCH, MDCL) - **Cautions 1.** The MDCH and MDCL registers values read during division operation processing (when the multiplication/division control register (MDUC) value is 81H or C1H) will not be guaranteed. - 2. During multiply-accumulator processing, do not use software to rewrite the values of the MDCH and MDCL registers. If this is done, the operation result will be undefined. - 3. The data is in the two's complement format in the multiply-accumulator mode (signed). Table 13-4. Functions of MDCH and MDCL Registers During Operation Execution | Operation Mode | Setting | Operation Result | |------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------| | Multiplication mode (unsigned or signed) | - | - | | Multiply-accumulator mode (unsigned) | MDCH: Initial accumulated value (unsigned) (higher 16 bits) MDCL: Initial accumulated value (unsigned) (lower 16 bits) | MDCH: accumulated value (unsigned) (higher 16 bits) MDCL: accumulated value (unsigned) (lower 16 bits) | | Multiply-accumulator mode (signed) | MDCH: Initial accumulated value (signed) (higher 16 bits) MDCL: Initial accumulated value (signed) (lower 16 bits) | MDCH: accumulated value (signed) (higher 16 bits) MDCL: accumulated value (signed) (lower 16 bits) | | Division mode (unsigned) | _ | MDCH: Remainder (unsigned) (higher 16 bits) MDCL: Remainder (unsigned) (lower 16 bits) | The register configuration differs between when multiplication is executed and when division is executed, as follows. • Register configuration during multiplication • Register configuration during multiply-accumulation ``` < Multiplier A > < Multiplier B > < accumulated value > < accumulated result > MDAL (bits 15 to 0) \times MDAH (bits 15 to 0) + MDC (bits 31 to 0) = [MDCH (bits 15 to 0), MDCL (bits 15 to 0)] (The multiplication result is stored in the MDBH (bits 15 to 0) and MDBL (bits 15 to 0).) ``` • Register configuration during division # 13.3 Register Controlling Multiplier and Divider/Multiply-Accumulator The multiplier and divider/multiply-accumulator is controlled by using the multiplication/division control register (MDUC). # 13.3.1 Multiplication/division control register (MDUC) The MDUC register is an 8-bit register that controls the operation of the multiplier and divider/multiply-accumulator. The MDUC register can be set by a 1-bit or 8-bit memory manipulation instruction. Note that the overflow flag (MACOF) and sign flag (MACSF) of the multiply-accumulation result (accumulated) are read-only flags. Reset signal generation clears this register to 00H. **MACOF** MACSF DIVST Figure 13-5. Format of Multiplication/Division Control Register (MDUC) Address: F00E8H After reset: 00H R/W<sup>Note 1</sup> Symbol <7> <6> <3> <2> <1> <0> 0 0 **MDUC** DIVMODE | DIVMODE | MACMODE | MDSM | Operation mode selection | |------------------|---------|------|-------------------------------------------------------------------------------------| | 0 | 0 | 0 | Multiplication mode (unsigned) (default) | | 0 | 0 | 1 | Multiplication mode (signed) | | 0 | 1 | 0 | Multiply-accumulator mode (unsigned) | | 0 | 1 | 1 | Multiply-accumulator mode (signed) | | 1 | 0 | 0 | Division mode (unsigned), generation of a division completion interrupt (INTMD) | | 1 | 1 | 0 | Division mode (unsigned), not generation of a division completion interrupt (INTMD) | | Other than above | | /e | Setting prohibited | **MDSM** | MACOF | Overflow flag of multiply-accumulation result (accumulated value) | |-------|-------------------------------------------------------------------| | 0 | No overflow | | 1 | With over flow | #### <Set condition> · For the multiply-accumulator mode (unsigned) MACMODE The bit is set when the accumulated value goes outside the range from 00000000h to FFFFFFFh. For the multiply-accumulator mode (signed) The bit is set when the result of adding a positive product to a positive accumulated value exceeds 7FFFFFFh and is negative, or when the result of adding a negative product to a negative accumulated value exceeds 80000000h and is positive. | MACSF | Sign flag of multiply-accumulation result (accumulated value) | | | |-------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------|--| | 0 | The accumulated value is positive. | | | | 1 | The accumulated value is negative. | | | | Multiply-accumulator mode (unsigned): The | | The bit is always 0. | | | Multiply-accumulator mode (signed): | | The bit indicates the sign bit of the accumulated value. | | | DIVST <sup>Note 2</sup> | Division operation start/stop | | | |-------------------------|---------------------------------------------------------------------|--|--| | 0 | Division operation processing complete | | | | 1 | Starts division operation/division operation processing in progress | | | #### **Notes** - 1. Bits 1 and 2 are read-only bits. - 2. The DIVST bit can only be set (1) in the division mode. In the division mode, division operation is started by setting (1) the DIVST bit. The DIVST bit is automatically cleared (0) when the operation ends. In the multiplication mode, operation is automatically started by setting the multiplier and multiplicand to multiplication/division data register A (MDAH, MDAL), respectively. - Cautions 1. Do not rewrite the DIVMODE, MDSM bits during operation processing (while the DIVST bit is 1). If it is rewritten, the operation result will be an undefined value. - 2. The DIVST bit cannot be cleared (0) by using software during division operation processing (while the DIVST bit is 1). ## 13.4 Operations of Multiplier and Divider/Multiply-Accumulator ## 13.4.1 Multiplication (unsigned) operation - · Initial setting - <1> Set the multiplication/division control register (MDUC) to 00H. - <2> Set the multiplicand to multiplication/division data register A (L) (MDAL). - <3> Set the multiplier to multiplication/division data register A (H) (MDAH). (There is no preference in the order of executing steps <2> and <3>. Multiplication operation is automatically started when the multiplier and multiplicand are set to the MDAH and MDAL registers, respectively.) - · During operation processing - <4> Wait for at least one clock. The operation will end when one clock has been issued. - · Operation end - <5> Read the product (lower 16 bits) from multiplication/division data register B (L) (MDBL). - <6> Read the product (higher 16 bits) from multiplication/division data register B (H) (MDBH). (There is no preference in the order of executing steps <5> and <6>.) - · Next operation - <7> Start with the initial settings of each step to change the operation mode. When the same operation mode is used sequentially, settings <1> and <2> can be omitted. Remark Steps <1> to <7> correspond to <1> to <7> in Figure 13-6. Figure 13-6. Timing Diagram of Multiplication (Unsigned) Operation ( $2 \times 3 = 6$ ) #### 13.4.2 Multiplication (signed) operation - · Initial setting - <1> Set the multiplication/division control register (MDUC) to 08H. - <2> Set the multiplicand to multiplication/division data register A (L) (MDAL). - <3> Set the multiplier to multiplication/division data register A (H) (MDAH). (There is no preference in the order of executing steps <2> and <3>. Multiplication operation is automatically started when the multiplier and multiplicand are set to the MDAH and MDAL registers, respectively.) - · During operation processing - <4> Wait for at least one clock. The operation will end when one clock has been issued. - · Operation end - <5> Read the product (lower 16 bits) from multiplication/division data register B (L) (MDBL). - <6> Read the product (higher 16 bits) from multiplication/division data register B (H) (MDBH). (There is no preference in the order of executing steps <5> and <6>.) - · Next operation - <7> Start with the initial settings of each step to change the operation mode. When the same operation mode is used sequentially, settings <1> and <2> can be omitted. Caution The data is in the two's complement format in multiplication mode (signed). Remark Steps <1> to <7> correspond to <1> to <7> in Figure 13-7. Figure 13-7. Timing Diagram of Multiplication (Signed) Operation ( $-2 \times 32767 = -65534$ ) #### 13.4.3 Multiply-accumulation (unsigned) operation - · Initial setting - <1> Set the multiplication/division control register (MDUC) to 40H. - <2> Set the initial accumulated value of higher 16 bits to multiplication/division data register C (L) (MDCL). - <3> Set the initial accumulated value of lower 16 bits to multiplication/division data register C (H) (MDCH). - <4> Set the multiplicand to multiplication/division data register A (L) (MDAL). - <5> Set the multiplier to multiplication/division data register A (H) (MDAH). (There is no preference in the order of executing steps <2>, <3>, and <4>. Multiplication operation is automatically started when the multiplier is set to the MDAH register, respectively.) - · During operation processing - <6> The multiplication operation finishes in one clock cycle. (The multiplication result is stored in multiplication/division data register B (L) (MDBL) and multiplication/division data register B (H) (MDBH).) - <7> After <6>, the multiply-accumulation operation finishes in one additional clock cycle. (There is a wait of at least two clock cycles after specifying the initial settings is finished (<5>).) - · Operation end - <8> Read the accumulated value (lower 16 bits) from the MDCL register. - <9> Read the accumulated value (higher 16 bits) from the MDCH register. (There is no preference in the order of executing steps <8> and <9>.) - (<10> If the result of the multiply-accumulation operation causes an overflow, the MACOF bit is set to 1, INTMD signal is occurred.) - Next operation - <11> Start with the initial settings of each step to change the operation mode. When the same operation mode is used sequentially, settings <1> and <4> can be omitted. Remark Steps <1> to <10> correspond to <1> to <10> in Figure 13-8. Figure 13-8. Timing Diagram of Multiply-Accumulation (Unsigned) Operation $(2 \times 3 + 3 = 9 \rightarrow 32767 \times 2 + 4294901762 = 0 \text{ (over flow generated))}$ #### 13.4.4 Multiply-accumulation (signed) operation - · Initial setting - <1> Set the multiplication/division control register (MDUC) to 48H. - <2> Set the initial accumulated value of higher 16 bits to multiplication/division data register C (H) (MDCH). (<3> If the accumulated value in the MDCH register is negative, the MACSF bit is set to 1.) - <4> Set the initial accumulated value of lower 16 bits to multiplication/division data register C (L) (MDCL). - <5> Set the multiplicand to multiplication/division data register A (L) (MDAL). - <6> Set the multiplier to multiplication/division data register A (H) (MDAH). (There is no preference in the order of executing steps <2>, <4>, and <5>. Multiplication operation is automatically started when the multiplier is set to the MDAH register of <6>, respectively.) - · During operation processing - <7> The multiplication operation finishes in one clock cycle. (The multiplication result is stored in multiplication/division data register B (L) (MDBL) and multiplication/division data register B (H) (MDBH).) - <8> After <7>, the multiply-accumulation operation finishes in one additional clock cycle. (There is a wait of at least two clock cycles after specifying the initial settings is finished (<6>).) - · Operation end - <9> If the accumulated value stored in the MDCL and MDCH registers is positive, the MACSF bit is cleared to 0. - <10> Read the accumulated value (lower 16 bits) from the MDCL register. - <11> Read the accumulated value (higher 16 bits) from the MDCH register. (There is no preference in the order of executing steps <10> and <11>.) - (<12> If the result of the multiply-accumulation operation causes an overflow, the MACOF bit is set to 1, INTMD signal is occurred.) - · Next operation - <13> Start with the initial settings of each step to change the operation mode. When the same operation mode is used sequentially, settings <1> and <5> can be omitted. Caution The data is in the two's complement format in multiply-accumulation (signed) operation. Remark Steps <1> to <12> correspond to <1> to <12> in Figure 13-9. Figure 13-9. Timing Diagram of Multiply-Accumulation (signed) Operation $(2 \times 3 + (-4) = 2 \rightarrow 32767 \times (-1) + (-2147483647) = -2147450882$ (overflow occurs.)) ### 13.4.5 Division operation - · Initial setting - <1> Set the multiplication/division control register (MDUC) to 80H. - <2> Set the dividend (higher 16 bits) to multiplication/division data register A (H) (MDAH). - <3> Set the dividend (lower 16 bits) to multiplication/division data register A (L) (MDAL). - <4> Set the divisor (higher 16 bits) to multiplication/division data register B (H) (MDBH). - <5> Set the divisor (lower 16 bits) to multiplication/division data register B (L) (MDBL). - <6> Set bit 0 (DIVST) of the MDUC register to 1. (There is no preference in the order of executing steps <2> to <5>.) - · During operation processing - <7> The operation will end when one of the following processing is completed. - A wait of at least 16 clocks (The operation will end when 16 clocks have been issued.) - A check whether the DIVST bit has been cleared (The read values of the MDBL, MDBH, MDCL, and MDCH registers during operation processing are not guaranteed.) - · Operation end - <8> The DIVST bit is cleared and the operation ends. At this time, an interrupt request signal (INTMD) is generated if the operation was performed with MACMODE = 0. - <9> Read the quotient (lower 16 bits) from the MDAL register. - <10> Read the quotient (higher 16 bits) from the MDAH register. - <11> Read the remainder (lower 16 bits) from multiplication/division data register C (L) (MDCL). - <12> Read the remainder (higher 16 bits) from multiplication/division data register C (H) (MDCH). (There is no preference in the order of executing steps <9> to <12>.) - · Next operation - <13> Start with the initial settings of each step to change the operation mode. When the same operation mode is used sequentially, settings <1> and <5> can be omitted. Remark Steps <1> to <12> correspond to <1> to <12> in Figure 13-10. ### **CHAPTER 14 DMA CONTROLLER** The R5F102 products of the RL78/G12 have an internal DMA (Direct Memory Access) controller. Data can be automatically transferred between the peripheral hardware supporting DMA, SFRs, and internal RAM without via CPU. As a result, the normal internal operation of the CPU and data transfer can be executed in parallel with transfer between the SFR and internal RAM, and therefore, a large capacity of data can be processed. In addition, real-time control using communication, timer, and A/D can also be realized. #### 14.1 Functions of DMA Controller - O Number of DMA channels: 2 channels (R5F102 products) - O Transfer unit: 8 or 16 bits - O Maximum transfer unit: 1024 times - O Transfer type: 2-cycle transfer (One transfer is processed in 2 clocks and the CPU stops during that processing.) - O Transfer mode: Single-transfer mode - O Transfer request: Selectable from the following peripheral hardware interrupts - A/D converter - Serial interface (CSI00, CSI01, CSI11, CSI20, UART0 to UART2) - Timer (channel 0, 1, 2, 3) - O Transfer target: Between SFR and internal RAM Here are examples of functions using DMA. - · Successive transfer of serial interface - · Consecutive capturing of A/D conversion results - Capturing A/D conversion result at fixed interval - · Capturing port value at fixed interval # 14.2 Configuration of DMA Controller The DMA controller includes the following hardware. Table 14-1. Configuration of DMA Controller | Item | Configuration | |-------------------|----------------------------------------------------------------------------------------------------------------------| | Address registers | <ul> <li>DMA SFR address registers 0, 1 (DSA0, DSA1)</li> <li>DMA RAM address registers 0, 1 (DRA0, DRA1)</li> </ul> | | Count register | DMA byte count registers 0, 1 (DBC0, DBC1) | | Control registers | DMA mode control registers 0, 1 (DMC0, DMC1) DMA operation control register 0, 1 (DRC0, DRC1) | # 14.2.1 DMA SFR address register n (DSAn) This is an 8-bit register that is used to set an SFR address that is the transfer source or destination of DMA channel n. Set the lower 8 bits of the SFR addresses FFF00H to FFFFFH. This register is not automatically incremented but fixed to a specific value. In the 16-bit transfer mode, the least significant bit is ignored and is treated as an even address. The DSAn register can be read or written in 8-bit units. However, it cannot be written during DMA transfer. Reset signal generation clears this register to 00H. Figure 14-1. Format of DMA SFR Address Register n (DSAn) 7 6 5 4 3 2 1 0 DSAn ### 14.2.2 DMA RAM address register n (DRAn) This is a 16-bit register that is used to set a RAM address that is the transfer source or destination of DMA channel n. Addresses of the internal RAM area other than the general-purpose registers (see table 14-2) can be set to this register. Set the lower 16 bits of the RAM address. This register is automatically incremented when DMA transfer has been started. It is incremented by +1 in the 8-bit transfer mode and by +2 in the 16-bit transfer mode. DMA transfer is started from the address set to this DRAn register. When the data of the last address has been transferred, the DRAn register stops with the value of the last address +1 in the 8-bit transfer mode, and the last address +2 in the 16-bit transfer mode. In the 16-bit transfer mode, the least significant bit is ignored and is treated as an even address. The DRAn register can be read or written in 8-bit or 16-bit units. However, it cannot be written during DMA transfer. Reset signal generation clears this register to 0000H. Address: FFFB2H, FFFB3H (DRA0), FFFB4H, FFFB5H (DRA1), After reset: 0000H R/W DRA0H: FFFB3H DRA0L: FFFB2H DRA1H: FFFB5H DRA1L: FFFB4H 15 14 13 12 11 10 9 8 7 6 5 DRAn Figure 14-2. Format of DMA RAM Address Register n (DRAn) **Remark** n: DMA channel number (n = 0, 1) Table 14-2 Internal RAM Area other than the General-purpose Registers | Part Number | Internal RAM Area other than the General-purpose Registers | |------------------------------|------------------------------------------------------------| | R5F10x66 | 256 × 8 bits (FFE00H to FFEDFH) | | R5F10x67, R5F10x77, R5F10xA7 | 512 × 8 bits (FFD00H to FFEDFH) | | R5F10x68, R5F10x78, R5F10xA8 | 768 × 8 bits (FFC00H to FFEDFH) | | R5F10x69, R5F10x79, R5F10xA9 | 1024 × 8 bits (FFB00H to FFEDFH) | | R5F10x6A, R5F10x7A | 1536 × 8 bits (FF900H to FFEDFH) | | R5F10xAA | 2048 × 8 bits (FF700H to FFEDFH) | (x = 2, 3) ### 14.2.3 DMA byte count register n (DBCn) This is a 10-bit register that is used to set the number of times DMA channel n executes transfer. Be sure to set the number of times of transfer to this DBCn register before executing DMA transfer (up to 1024 times). Each time DMA transfer has been executed, this register is automatically decremented. By reading this DBCn register during DMA transfer, the remaining number of times of transfer can be learned. The DBCn register can be read or written in 8-bit or 16-bit units. However, it cannot be written during DMA transfer. Reset signal generation clears this register to 0000H. Address: FFFB6H, FFFB7H (DBC0), FFFB8H, FFFB9H (DBC1) After reset: 0000H DBC0H:FFFB7H DBC0L:FFFB6H DBC1H:FFFB9H DBC1L:FFFB8H 15 14 13 12 11 10 9 8 6 DBCn 0 0 0 0 0 0 Figure 14-3. Format of DMA Byte Count Register n (DBCn) | DBCn[9:0] | Number of Times of Transfer (When DBCn is Written) | Remaining Number of Times of Transfer (When DBCn is Read) | | | |-----------|----------------------------------------------------|------------------------------------------------------------------|--|--| | 000H | 1024 | Completion of transfer or waiting for 1024 times of DMA transfer | | | | 001H | 1 | Waiting for remaining one time of DMA transfer | | | | 002H | 2 | Waiting for remaining two times of DMA transfer | | | | 003H | 3 | Waiting for remaining three times of DMA transfer | | | | • | • | • | | | | • | • | • | | | | • | • | • | | | | 3FEH | 1022 | Waiting for remaining 1022 times of DMA transfer | | | | 3FFH | 1023 | Waiting for remaining 1023 times of DMA transfer | | | Cautions 1. Be sure to clear bits 15 to 10 to 0. 2. If the general-purpose register is specified or the internal RAM space is exceeded as a result of continuous transfer, the general-purpose register or SFR space are written or read, resulting in loss of data in these spaces. Be sure to set the number of times of transfer that is within the internal RAM space. ## 14.3 Registers Controlling DMA Controller DMA controller is controlled by the following registers. - DMA mode control register n (DMCn) - DMA operation control register n (DRCn) **Remark** n: DMA channel number (n = 0, 1) ### 14.3.1 DMA mode control register n (DMCn) The DMCn register is a register that is used to set a transfer mode of DMA channel n. It is used to select a transfer direction, data size, setting of pending, and start source. Bit 7 (STGn) is a software trigger that starts DMA. Rewriting bits 6, 5, and 3 to 0 of the DMCn register is prohibited during operation (when DSTn = 1). The DMCn register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 14-4. Format of DMA Mode Control Register n (DMCn) (1/2) Address: FFFBAH (DMC0), FFFBBH (DMC1) After reset: 00H R/W Symbol <7> <5> <4> 3 2 1 0 IFCn3 IFCn2 IFCn1 IFCn0 DMCn STGn DRSn DSn **DWAITn** | STGn <sup>Note 1</sup> | DMA transfer start software trigger | | |------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--| | 0 | No trigger operation | | | 1 | DMA transfer is started when DMA operation is enabled (DENn = 1). | | | DMA transfer is performed once by writing 1 to the STGn bit when DMA operation is enabled (DENn = 1). When this bit is read, 0 is always read. | | | | DRSn | Selection of DMA transfer direction | |------|-------------------------------------| | 0 | SFR to internal RAM | | 1 | Internal RAM to SFR | | DSn | Specification of transfer data size for DMA transfer | |-----|------------------------------------------------------| | 0 | 8 bits | | 1 | 16 bits | | DWAITn Note 2 | Pending of DMA transfer | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--| | 0 | Executes DMA transfer upon DMA start request (not held pending). | | | 1 | Holds DMA start request pending if any. | | | DMA transfer that has been held pending can be started by clearing the value of the DWAITn bit to 0. It takes 2 clocks to actually hold DMA transfer pending when the value of the DWAITn bit is set to 1. | | | Notes 1. The software trigger (STGn) can be used regardless of the IFCn0 to IFCn3 bits values. 2. When DMA transfer is held pending while using two or more DMA channels, be sure to hold the DMA transfer pending for all channels (by setting the DWAIT0, DWAIT1, DWAIT2, and DWAIT3 bits to 1). Figure 14-4. Format of DMA Mode Control Register n (DMCn) (2/2) Address: FFFBAH (DMC0), FFFBBH (DMC1) After reset: 00H R/W Symbol 2 0 <7> <6> <5> <4> 3 1 DMCn STGn DRSn DSn DWAITn IFCn3 IFCn2 IFCn1 IFCn0 | IFCn3 | IFCn2 | IFCn1 | IFCn0 | Selection of DMA start source <sup>Note</sup> | | | |-------|----------|---------|-------|-----------------------------------------------|-------------------------------------------------------------------------|--| | | | | | Trigger signal | Trigger contents | | | 0 | 0 | 0 | 0 | - | Disables DMA transfer by interrupt. (Only software trigger is enabled.) | | | 0 | 0 | 0 | 1 | INTAD | A/D conversion end interrupt | | | 0 | 0 | 1 | 0 | INTTM00 | End of timer channel 0 count or capture | | | | | | | | end interrupt | | | 0 | 0 | 1 | 1 | INTTM01 | End of timer channel 1 count or capture | | | | | | | | end interrupt | | | 0 | 1 | 0 | 0 | INTTM02 | End of timer channel 2 count or capture | | | | | | | | end interrupt | | | 0 | 1 | 0 | 1 | INTTM03 | End of timer channel 3 count or capture | | | | | | | | end interrupt | | | 0 | 1 | 1 | 0 | INTST0/INTCSI00 | UART0 transmission transfer end or | | | | | | | | buffer empty interrupt/CSI00 transfer end or buffer empty interrupt | | | 0 | 1 | 1 | 1 | INTSR0/INTCSI01 | UART0 reception transfer end | | | | | ' | ' | 11416/10/114166161 | interrupt/CSI01 transfer end or buffer | | | | | | | | empty interrupt | | | 1 | 0 | 0 | 0 | INTST1 | UART1 transmission transfer end or | | | | | | | | buffer empty interrupt | | | 1 | 0 | 0 | 1 | INTSR1/INTCSI11 | UART1 reception transfer end | | | | | | | | interrupt/CSI11 transfer end or buffer empty interrupt | | | 1 | 0 | 1 | 0 | INTST2/INTCSI20 | UART2 transmission transfer end or | | | | | | | | buffer empty interrupt/CSI20 transfer end | | | | | | | | or buffer empty interrupt | | | 1 | 0 | 1 | 1 | INTSR2 | UART2 reception transfer end interrupt | | | C | ther tha | an abov | re | Setting prohibited | | | **Note** The software trigger (STGn) can be used regardless of the IFCn0 to IFCn3 bits values. ### 14.3.2 DMA operation control register n (DRCn) The DRCn register is a register that is used to enable or disable transfer of DMA channel n. Rewriting bit 7 (DENn) of this register is prohibited during operation (when DSTn = 1). The DRCn register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 14-5. Format of DMA Operation Control Register n (DRCn) Address: FFFBCH (DRC0), FFFBDH (DRC1) After reset: 00H R/W Symbol DRCn | <7> | 6 | 5 | 4 | 3 | 2 | 1 | <0> | |------|---|---|---|---|---|---|------| | DENn | 0 | 0 | 0 | 0 | 0 | 0 | DSTn | | DENn | DMA operation enable flag | | |--------------|---------------------------------------------------------------------------------------|--| | 0 | Disables operation of DMA channel n (stops operating cock of DMA). | | | 1 | Enables operation of DMA channel n. | | | DMAC waits f | DMAC waits for a DMA trigger when DSTn = 1 after DMA operation is enabled (DENn = 1). | | | DSTn | DMA transfer mode flag | |------|-------------------------------------------------------------------------| | 0 | DMA transfer of DMA channel n is completed. | | 1 | DMA transfer of DMA channel n is not completed (still under execution). | DMAC waits for a DMA trigger when DSTn = 1 after DMA operation is enabled (DENn = 1). When a software trigger (STGn) or the start source trigger set by the IFCn3 to IFCn0 bits is input, DMA transfer is started. When DMA transfer is completed after that, this bit is automatically cleared to 0. Write 0 to this bit to forcibly terminate DMA transfer under execution. **Caution** The DSTn flag is automatically cleared to 0 when a DMA transfer is completed. Writing the DENn flag is enabled only when DSTn = 0. When a DMA transfer is terminated without waiting for generation of the interrupt (INTDMAn) of DMAn, therefore, set the DSTn bit to 0 and then the DENn bit to 0 (for details, refer to 14.5.5 Forced termination by software). ### 14.4 Operation of DMA Controller ### 14.4.1 Operation procedure - <1> The DMA controller is enabled to operate when DENn = 1. Before writing the other registers, be sure to set the DENn bit to 1. Use 80H to write with an 8-bit manipulation instruction. - <2> Set an SFR address, a RAM address, the number of times of transfer, and a transfer mode of DMA transfer to DMA SFR address register n (DSAn), DMA RAM address register n (DRAn), DMA byte count register n (DBCn), and DMA mode control register n (DMCn). - <3> The DMA controller waits for a DMA trigger when DSTn = 1. Use 81H to write with an 8-bit manipulation - <4> When a software trigger (STGn) or a start source trigger specified by the IFCn3 to IFCn0 bits is input, a DMA transfer is started. - <5> Transfer is completed when the number of times of transfer set by the DBCn register reaches 0, and transfer is automatically terminated by occurrence of an interrupt (INTDMAn). - <6> Stop the operation of the DMA controller by clearing the DENn bit to 0 when the DMA controller is not used. Figure 14-6. Operation Procedure # 14.4.2 Transfer mode The following four modes can be selected for DMA transfer by using bits 6 and 5 (DRSn and DSn) of DMA mode control register n (DMCn). | DRSn | DSn | DMA Transfer Mode | |------|-----|----------------------------------------------------------------------------------------| | 0 | 0 | Transfer from SFR of 1-byte data (fixed address) to RAM (address is incremented by +1) | | 0 | 1 | Transfer from SFR of 2-byte data (fixed address) to RAM (address is incremented by +2) | | 1 | 0 | Transfer from RAM of 1-byte data (address is incremented by +1) to SFR (fixed address) | | 1 | 1 | Transfer from RAM of 2-byte data (address is incremented by +2) to SFR (fixed address) | By using these transfer modes, up to 1024 bytes of data can be consecutively transferred by using the serial interface, data resulting from A/D conversion can be consecutively transferred, and port data can be scanned at fixed time intervals by using a timer. #### 14.4.3 Termination of DMA transfer When DBCn = 00H and DMA transfer is completed, the DSTn bit is automatically cleared to 0. An interrupt request (INTDMAn) is generated and transfer is terminated. When the DSTn bit is cleared to 0 to forcibly terminate DMA transfer, DMA byte count register n (DBCn) and DMA RAM address register n (DRAn) hold the value when transfer is terminated. The interrupt request (INTDMAn) is not generated if transfer is forcibly terminated. **Remark** n: DMA channel number (n = 0, 1) ### 14.5 Example of Setting of DMA Controller ### 14.5.1 CSI consecutive transmission A flowchart showing an example of setting for CSI consecutive transmission is shown below. - Consecutive transmission of CSI00 (256 bytes) - DMA channel 0 is used for DMA transfer. - DMA start source: INTCSI00 (software trigger (STG0) only for the first start source) - Interrupt of CSI00 is specified by IFC03 to IFC00 = 0110B. - Transfers FFB00H to FFBFFH (256 bytes) of RAM to FFF10H of the data register (SIO00) of CSI. Remark IFC03 to IFC00: Bits 3 to 0 of DMA mode control registers 0 (DMC0) Figure 14-7. Example of Setting for CSI Consecutive Transmission **Note** The DST0 flag is automatically cleared to 0 when a DMA transfer is completed. Writing the DEN0 flag is enabled only when DST0 = 0. To terminate a DMA transfer without waiting for occurrence of the interrupt of DMA0 (INTDMA0), set the DST0 bit to 0 and then the DEN0 bit to 0 (for details, refer to **14.5.5 Forced termination by software**). The first trigger for consecutive transmission is not started by the interrupt of CSI. In this example, it start by a software trigger. CSI transmission of the second time and onward is automatically executed. A DMA interrupt (INTDMA0) occurs when the last transmit data has been written to the data register. ### 14.5.2 Consecutive capturing of A/D conversion results A flowchart of an example of setting for consecutively capturing A/D conversion results is shown below. - Consecutive capturing of A/D conversion results. - DMA channel 1 is used for DMA transfer. - DMA start source: INTAD - Interrupt of A/D is specified by IFC13 to IFC10 = 0001B. - Transfers FFF1EH and FFF1FH (2 bytes) of the 10-bit A/D conversion result register (ADCR) to 512 bytes of FFCE0H to FFEDFH of RAM. Remark IFC13 to IFC10: Bits 3 to 0 of DMA mode control registers 1 (DMC1) Figure 14-8. Example of Setting of Consecutively Capturing A/D Conversion Results Note The DST1 flag is automatically cleared to 0 when a DMA transfer is completed. Writing the DEN1 flag is enabled only when DST1 = 0. To terminate a DMA transfer without waiting for occurrence of the interrupt of DMA1 (INTDMA1), set the DST1 bit to 0 and then the DEN1 bit to 0 (for details, refer to 14.5.5 Forced termination by software). ### 14.5.3 UART consecutive reception + ACK transmission A flowchart illustrating an example of setting for UART consecutive reception + ACK transmission is shown below. - Consecutively receives data from UART0 and outputs ACK to P10 on completion of reception. - DMA channel 0 is used for DMA transfer. - DMA start source: Software trigger (DMA transfer on occurrence of an interrupt is disabled.) - Transfers FFF12H of UART receive data register 0 (RXD0) to 64 bytes of FFE00H to FFE3FH of RAM. Figure 14-9. Example of Setting for UART Consecutive Reception + ACK Transmission Note The DST0 flag is automatically cleared to 0 when a DMA transfer is completed. Writing the DEN0 flag is enabled only when DST0 = 0. To terminate a DMA transfer without waiting for occurrence of the interrupt of DMA0 (INTDMA0), set the DST0 bit to 0 and then the DEN0 bit to 0 (for details, refer to 14.5.5 Forced termination by software). **Remark** This is an example where a software trigger is used as a DMA start source. If ACK is not transmitted and if only data is consecutively received from UART, the UART reception end interrupt (INTSR0) can be used to start DMA for data reception. ### 14.5.4 Holding DMA transfer pending by DWAITn bit When DMA transfer is started, transfer is performed while an instruction is executed. At this time, the operation of the CPU is stopped and delayed for the duration of 2 clocks. If this poses a problem to the operation of the set system, a DMA transfer can be held pending by setting the DWAITn bit to 1. The DMA transfer for a transfer trigger that occurred while DMA transfer was held pending is executed after the pending status is canceled. However, because only one transfer trigger can be held pending for each channel, even if multiple transfer triggers occur for one channel during the pending status, only one DMA transfer is executed after the pending status is canceled. To output a pulse with a width of 10 clocks of the operating frequency from the P10 pin, for example, the clock width increases to 12 if a DMA transfer is started midway. In this case, the DMA transfer can be held pending by setting the DWAITn bit to 1. After setting the DWAITn bit to 1, it takes two clocks until a DMA transfer is held pending. Figure 14-10. Example of Setting for Holding DMA Transfer Pending by DWAITn Bit Caution When DMA transfer is held pending while using two or more DMA channels, be sure to held the DMA transfer pending for all channels (by setting DWAIT0, DWAIT1, DWAIT2, and DWAIT3 to 1). If the DMA transfer of one channel is executed while that of the other channel is held pending, DMA transfer might not be held pending for the latter channel. **Remarks 1.** n: DMA channel number (n = 0, 1) 2. 1 clock: 1/fclk (fclk: CPU clock) ### 14.5.5 Forced termination by software After the DSTn bit is set to 0 by software, it takes up to 2 clocks until a DMA transfer is actually stopped and the DSTn bit is set to 0. To forcibly terminate a DMA transfer by software without waiting for occurrence of the interrupt (INTDMAn) of DMAn, therefore, perform either of the following processes. ## <When using one DMA channel> - Set the DSTn bit to 0 (use DRCn = 80H to write with an 8-bit manipulation instruction) by software, confirm by polling that the DSTn bit has actually been cleared to 0, and then set the DENn bit to 0 (use DRCn = 00H to write with an 8-bit manipulation instruction). - Set the DSTn bit to 0 (use DRCn = 80H to write with an 8-bit manipulation instruction) by software and then set the DENn bit to 0 (use DRCn = 00H to write with an 8-bit manipulation instruction) two or more clocks after. ### <When using two DMA channels> • To forcibly terminate DMA transfer by software when using two DMA channels (by setting DSTn to 0), clear the DSTn bit to 0 after the DMA transfer is held pending by setting the DWAITn bits of both using channels to 1. Next, clear the DWAITn bits of both using channels to 0 to cancel the pending status, and then clear the DENn bit to 0. Figure 14-11. Forced Termination of DMA Transfer (1/2) **Remarks 1.** n: DMA channel number (n = 0, 1) 2. 1 clock: 1/fclk (fclk: CPU clock) Figure 14-11. Forced Termination of DMA Transfer (2/2) # Example 3 - Procedure for forcibly terminating the DMA transfer for one channel if both channels are used - Procedure for forcibly terminating the DMA transfer for both channels if both channels are used #### Caution In example 3, the system is not required to wait two clock cycles after the DWAITn bit is set to 1. In addition, the system does not have to wait two clock cycles after clearing the DSTn bit to 0, because more than two clock cycles elapse from when the DSTn bit is cleared to 0 to when the DENn bit is cleared to 0. **Remarks 1.** n: DMA channel number (n = 0, 1) 2. 1 clock: 1/fclk (fclk: CPU clock) ## 14.6 Cautions on Using DMA Controller ### (1) Priority of DMA During DMA transfer, a request from the other DMA channel is held pending even if generated. The pending DMA transfer is started after the ongoing DMA transfer is completed. If two or more DMA requests are generated at the same time, however, their priority are DMA channel 0 > DMA channel 1 > DMA channel 2 > DMA channel 3. If a DMA request and an interrupt request are generated at the same time, the DMA transfer takes precedence, and then interrupt servicing is executed. ## <R> (2) Interrupt requests and operation in case of contention During DMA transfer, interrupt requests are held pending even if they are generated. After the DMA transfer in progress is completed, the pending interrupt request is accepted. At this time, an instruction will not be inserted between DMA transfer processing and reception of the interrupt request. If a DMA start request is generated at the time an interrupt request is received, priority is given to the DMA transfer. ### (3) DMA response time The response time of DMA transfer is as follows. Table 14-2. Response Time of DMA Transfer | | Minimum Time | Maximum Time | |---------------|--------------|---------------------------| | Response time | 3 clocks | 10 clocks <sup>Note</sup> | Note The maximum time necessary to execute an instruction from internal RAM is 16 clock cycles. Cautions 1. The above response time does not include the two clock cycles required for a DMA transfer. - 2. When executing a DMA pending instruction (see 14.6 (4)), the maximum response time is extended by the execution time of that instruction to be held pending. - **3.** Do not specify successive transfer triggers for a channel within a period equal to the maximum response time plus one clock cycle, because they might be ignored. Remark 1 clock: 1/fclk (fclk: CPU clock) ## (4) Operation in standby mode The DMA controller operates as follows in the standby mode. Table 14-3. DMA Operation in Standby Mode | Status | DMA Operation | |-----------|-----------------------------------------------------------------------------| | HALT mode | Normal operation | | STOP mode | Stops operation. | | | If DMA transfer and STOP instruction execution contend, DMA transfer may be | | | damaged. Therefore, stop DMA before executing the STOP instruction. | ### (5) DMA pending forwarding Even if a DMA request is generated, DMA transfer is held pending immediately after the following instructions. - CALL !addr16 CALL \$!addr20 CALL !laddr20 CALL rp CALLT [addr5] - BRK - MOV PSW, #byte - MOV PSW, A - MOV1 PSW. bit, CY - SET1 PSW. bit - CLR1 PSW. bit - POP PSW - BTCLR PSW. bit, \$addr20 - EI - DI - Write instructions for registers IF0L, IF0H, IF1L, IF1H, IF2L, IF2H, IF3L, MK0L, MK0H, MK1L, MK1H, MK2L, MK2H, MK3L, PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR03L, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H, PR13L, and PSW each. - Instruction for accessing the data flash memory # (6) Operation if address in general-purpose register area or other than those of internal RAM area is specified The address indicated by DMA RAM address register n (DRAn) is incremented during DMA transfer. If the address is incremented to an address in the general-purpose register area or exceeds the area of the internal RAM, the following operation is performed. - In mode of transfer from SFR to RAM The data of that address is lost. - In mode of transfer from RAM to SFR Undefined data is transferred to SFR. In either case, malfunctioning may occur or damage may be done to the system. Therefore, make sure that the address is within the internal RAM area other than the general-purpose register area. # (7) Operation if instructions for accessing the data flash area If the data flash area is accessed after the next instruction execution from start of DMA transfer, a 3-clock wait will be inserted to the next instruction. Instruction 1 DMA transfer Instruction 2 3-clock wait is inserted. MOV A, ! DataFlash area #### **CHAPTER 15 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. | | | R5F1026x products | R5F1036x products | R5F102Ax products | R5F103Ax products | | | |---------------------|----------|-------------------|-------------------|-------------------|-------------------|--|--| | | | R5F1027x products | R5F1037x products | | | | | | Maskable interrupts | External | 5 | | 6 | | | | | | Internal | 18 | 16 | 26 | 19 | | | **Remark** x = 6, 7, 8, 9, A ## 15.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, PR10L, PR10H, PR11L). 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. For the default priority, see Tables 15-1 and 15-2. 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. ## 15.2 Interrupt Sources and Configuration Interrupt sources include maskable interrupts and software interrupts. In addition, they also have up to seven reset sources (see Tables 15-1 and 15-2). 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 OFFFFH. Table 15-1. Interrupt Source List (20-, 24-pin products) (1/2) | Interrupt Type | Default Priority Note 1 | Name | Interrupt Source | Internal/External | Vector Table Address | Basic Configuration<br>Type Note 2 | R5F1026x, R5F1027x<br>products | R5F1036x, R5F1037x<br>products | |----------------|-------------------------|-----------|---------------------------------------------------------------------------------|-------------------|----------------------|------------------------------------|--------------------------------|--------------------------------| | 40 | | Name | Trigger | | | | | | | Maskable | 0 | INTWDTI | Watchdog timer interval Note 3 (75%+1/2fi∟ of overflow time) | Internal | 00004H | (A) | <b>√</b> | <b>√</b> | | Ĕ | 1 | INTLVI | Voltage detection Note 4 | | 00006H | | ✓ | ✓ | | | 2 | INTP0 | Pin input edge detection | External | 00008H | (B) | ✓ | ✓ | | | 3 | INTP1 | | | 0000AH | | ✓ | ✓ | | | 4 | INTP2 | | | 0000CH | | ✓ | ✓ | | | 5 | INTP3 | | | 0000EH | | ✓ | ✓ | | | 6 | INTDMA0 | End of DMA0 transfer | Internal | 00010H | (A) | ✓ | - | | | 7 | INTDMA0 | End of DMA1 transfer | | 00012H | | ✓ | _ | | | 8 | INTST0/ | UART0 transmission transfer end or buffer empty | | 00014H | | ✓ | ✓ | | | | INTCSI00/ | interrupt/CSI00 transfer end or buffer empty | | | | | ✓ | | | | INTIIC00 | interrupt/IIC00 transfer end | | | | | - | | | 9 | INTSR0/ | UART0 reception transfer end/CSI01 transfer end or | | 00016H | | ✓ | ✓ | | | | INTCSI01/ | buffer empty interrupt/IIC01 transfer end | | | | | - | | | | INTIIC01 | | | | | | _ | | | 10 | INTSRE0 | UARTO reception communication error occurrence | | 00018H | | ✓ | ✓ | | | 11 | INTTM01H | End of timer channel 1 count or capture (at higher 8-bit timer operation) | | 0001AH | | ✓ | <b>√</b> | | | 12 | INTTM03H | End of timer channel 3 count or capture (at higher 8-bit timer operation) | | 0001CH | | <b>&gt;</b> | <b>√</b> | | | 13 | INTIICA0 | End of IICA0 communication | | 0001EH | | ✓ | ✓ | | | 14 | INTTM00 | End of timer channel 0 count or capture (16 bit/at lower 8-bit timer operation) | | 00020H | | ✓ | <b>✓</b> | | | 15 | INTTM01 | End of timer channel 1 count or capture (16 bit/at lower 8-bit timer operation) | | 00022H | | ✓ | <b>✓</b> | | | 16 | INTTM02 | End of timer channel 2 count or capture (16 bit/at lower 8-bit timer operation) | | 00024H | | ✓ | <b>√</b> | | | 17 | INTTM03 | End of timer channel 3 count or capture (16 bit/at lower 8-bit timer operation) | | 00026H | | ✓ | <b>√</b> | | | 18 | INTAD | End of A/D conversion | ] | 00028H | ] | ✓ | ✓ | | | 19 | INTIT | Interval signal detection from 12-bit Interval timer | | 0002AH | ] | ✓ | ✓ | | | 20 | INTKR | Key return signal detection | External | 0002CH | (C) | ✓ | ✓ | | | 21 | INTMD | End of division operation/ | Internal | 0002EH | (A) | ✓ | ✓ | | | | | Overflow of multiply-accumulation result occurs | | | | | | | | 22 | INTFL | Reserved Note 5 | ] | 00030H | ] | ✓ | ✓ | **Notes 1.** The default priority determines the sequence of interrupts if two or more maskable interrupts occur simultaneously. 0 indicates the highest priority and 22 indicates the lowest priority. - 2. Basic configuration types (A) to (D) correspond to (A) to (D) in Figure 15-1. - 3. When bit 7 (WDTINT) of the option byte (000C0H) is set to 1. - 4. When bit 7 (LVIMD) of the voltage detection level register (LVIS) is cleared to 0. - 5. Used for flash self programming library and data flash library. Table 15-1. Interrupt Source List (20-, 24-pin products) (2/2) | Interrupt Type | Default Priority Note 1 | | Interrupt Source | Internal/External | Vector Table Address | Basic Configuration<br>Type Note 2 | R5F1026x, R5F1027x<br>products | R5F1036x, R5F1037x<br>products | |----------------|-------------------------|-------|----------------------------------------|-------------------|----------------------|------------------------------------|--------------------------------|--------------------------------| | | | Name | Trigger | | > | | Œ | Œ | | Software | - | BRK | Execution of BRK instruction | _ | 0007EH | (D) | <b>&gt;</b> | <b>*</b> | | Reset | - | RESET | RESET pin input | _ | 00000H | _ | ✓ | ✓ | | P. B. | | POR | Power-on-reset | | | | <b>✓</b> | ✓ | | | | LVD | Voltage detection <sup>Note 3</sup> | | | | <b>✓</b> | ✓ | | | | WDT | Overflow of watchdog timer | | | | <b>✓</b> | ✓ | | | | TRAP | Execution of illegal instructionNote 4 | | | | <b>✓</b> | ✓ | | | | IAW | Illegal memory access | | | | ✓ | ✓ | | | | RPE | RAM parity error | | | | ✓ | ✓ | **Notes 1.** The default priority determines the sequence of interrupts if two or more maskable interrupts occur simultaneously. Zero indicates the highest priority and 22 indicates the lowest priority. - 2. Basic configuration types (A) to (D) correspond to (A) to (D) in Figure 15-1. - 3. When bit 7 (LVIMD) of the voltage detection level register (LVIS) is cleared to 1. - 4. When the instruction code in FFH is executed. No reset is issued even if an illegal instruction is executed during emulation with the in-circuit emulator or on-chip debug emulator. Table 15-2. Interrupt Source List (30-pin products) (1/2) | | ite 1 | | Interrupt Source | E E | | no | cts | cts | |----------------|-------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------|------------------------------------|-------------------|-------------------| | Interrupt Type | Default Priority Note 1 | Name | Trigger | Internal/External | Vector Table<br>Address | Basic Configuration<br>Type Note 2 | R5F102Ax products | R5F103Ax products | | able | 0 | INTWDTI | Watchdog timer interval Note 3 (75% + 1/2fı∟ of overflow time) | Internal | 00004H | (A) | ✓ | ✓ | | Maskable | 1 | INTLVI | Voltage detection Note 4 | | 00006H | | ✓ | ✓ | | 2 | 2 | INTP0 | Pin input edge detection | External | 00008H | (B) | ✓ | ✓ | | | 3 | INTP1 | | | 0000AH | | ✓ | ✓ | | | 4 | INTP2 | | | 0000CH | | ✓ | ✓ | | | 5 | INTP3 | | | 0000EH | | ✓ | ✓ | | | 6 | INTP4 | | | 00010H | | ✓ | ✓ | | | 7 | INTP5 | | | 00012H | | ✓ | ✓ | | | 8 | INTST2/<br>INTCSI20/<br>INTIIC20 | UART2 transmission transfer end, buffer empty interrupt/CSI20 transfer end or buffer empty interrupt/IIC20 transfer end | Internal | 00014H | (A) | <b>√</b> | - | | | 9 | INTSR2 | UART2 reception transfer end | | 00016H | | <b>√</b> | = | | | 10 | INTSRE2 | UART2 reception communication error occurrence | - | 00018H | - | <b>√</b> | _ | | | 11 | INTDMA0 | DMA0 transfer end | - | 0001AH | | <b>√</b> | _ | | | 12 | INTDMA1 | DMA1 transfer end | 1 | 0001CH | | <b>✓</b> | - | | | 13 | INTSTO/<br>INTCSI00/<br>INTIIC00 | UART0 transmission transfer end, buffer empty interrupt/CSI00 transfer end or buffer empty interrupt/IIC00 transfer end | | 0001EH | | ✓ | ✓<br>✓ | | | 14 | INTSR0 | UART0 reception transfer end | | 00020H | | <b>√</b> | ✓ | | | 15 | INTSRE0 | UART0 reception communication error occurrence | | 00022H | | ✓ | ✓ | | | | INTTM01H | End of timer channel 1 count or capture (at higher 8-bit timer operation) | | | | ✓ | <b>√</b> | | | 16 | INTST1 | UART1 transmission transfer end | 00024H | | ✓ | - | | | | 17 | INTSR1/<br>INTCSI11/<br>INTIIC11 | UART1 reception transfer end/CSI11 transfer end or buffer empty interrupt/IIC11 transfer end | | 00026H | | <b>√</b> | _ | | | 18 | INTSRE1 | UART1 reception communication error occurrence | | 00028H | | ✓ | = | | | | INTTM03H | End of timer channel 3 count or capture (at higher 8-bit timer operation) | | | | <b>√</b> | <b>√</b> | | | 19 | INTIICA0 | IICA0 communication end | | 0002AH | | ✓ | ✓ | **Notes 1.** The default priority determines the sequence of interrupts if two or more maskable interrupts occur simultaneously. 0 indicates the highest priority and 31 indicates the lowest priority. - 2. Basic configuration types (A) to (D) correspond to (A) to (D) in Figure 15-1 respectively. - 3. When bit 7 (WDTINT) of the option byte (000C0H) is set to 1. - 4. When bit 7 (LVIMD) of the voltage detection level register (LVIS) is cleared to 0. Table 15-2. Interrupt Source List (30-pin products) (2/2) | | te 1 | | Interrupt Source | <u> </u> | | ion | ıcts | icts | |----------------|----------------------------------------------|---------|-----------------------------------------------------------------------------------|-------------------|-------------------------|------------------------------------|-------------------|-------------------| | Interrupt Type | Default Priority Note 1 | Name | Trigger | Internal/External | Vector Table<br>Address | Basic Configuration<br>Type Note 2 | R5F102Ax products | R5F103Ax products | | Maskable | 20 | INTTM00 | End of timer channel 0 count or capture (16 bit / at lower 8-bit timer operation) | Internal | 0002CH | (A) | <b>√</b> | <b>√</b> | | Mask | 21 | INTTM01 | End of timer channel 1 count or capture (16 bit / at lower 8-bit timer operation) | | 0002EH | | <b>&gt;</b> | <b>√</b> | | | 22 | INTTM02 | End of timer channel 2 count or capture (16 bit / at lower 8-bit timer operation) | | 00030H | | <b>&gt;</b> | <b>√</b> | | | 23 | INTTM03 | End of timer channel 3 count or capture (16 bit / at lower 8-bit timer operation) | | 00032H | | ✓ | <b>√</b> | | | 24 | INTAD | End of A/D conversion | | 00034H | | <b>✓</b> | ✓ | | | 25 | INTIT | Interval signal detection from 12-bit interval timer | | 00038H | | ✓ | ✓ | | | 26 | INTTM04 | End of timer channel 4 count or capture (16 bit / at lower 8-bit timer operation) | | 00042H | | <b>~</b> | ✓ | | | 27 | INTTM05 | End of timer channel 5 count or capture (16 bit / at lower 8-bit timer operation) | | 00044H | | ✓ | ✓ | | | 28 | INTTM06 | End of timer channel 6 count or capture (16 bit / at lower 8-bit timer operation) | | 00046H | | ✓ | ✓ | | | 29 | INTTM07 | End of timer channel 7 count or capture (16 bit / at lower 8-bit timer operation) | | 00048H | | ✓ | <b>√</b> | | | 30 | INTMD | End of division operation/ Overflow of multiply-accumulation result occurs | | 0005EH | | <b>√</b> | <b>√</b> | | | 31 | INTFL | Reserved Note 3 | | 00062H | | ✓ | ✓ | | Software | - | BRK | Execution of BRK instruction | - | 0007EH | (D) | <b>√</b> | <b>√</b> | | Reset | | RESET | RESET pin input | _ | 00000H | _ | ✓ | ✓ | | Œ | | POR | Power-on-reset | | | | ✓ | ✓ | | | | LVD | Voltage detection <sup>Note 4</sup> | | | | ✓ | ✓ | | | | WDT | Overflow of watchdog timer | | | | ✓ | ✓ | | | TRAP Execution of illegal instruction Note 5 | | | | | | ✓ | ✓ | | | | IAW | Illegal memory access | | | | ✓ | ✓ | | | | RPE | RAM parity error | | | | ✓ | ✓ | **Notes 1.** The default priority determines the sequence of interrupts if two or more maskable interrupts occur simultaneously. 0 indicates the highest priority and 31 indicates the lowest priority. - 2. Basic configuration types (A) to (D) correspond to (A) to (D) in Figure 15-1 respectively. - 3. Used for flash self programming library and data flash library. - 4. When bit 7 (LVIMD) of the voltage detection level register (LVIS) is cleared to 0. - 5. When the instruction code in FFH is executed. No reset is issued even if an illegal instruction is executed during emulation with the in-circuit emulator or on-chip debug emulator. <R> Figure 15-1. Basic Configuration of Interrupt Function (1/2) ## (a) Internal maskable interrupt ## (b) External maskable interrupt (INTPn) IF: Interrupt request flag IE: Interrupt enable flag ISP0: In-service priority flag 0 ISP1: In-service priority flag 1 MK: Interrupt mask flag PR0: Priority specification flag 0 PR1: Priority specification flag 1 **Remark** 20, 24-pin product : n = 0 to 3 30-pin product : n = 0 to 5 Figure 15-1. Basic Configuration of Interrupt Function (2/2) # (c) External maskable interrupt (INTKR) IF: Interrupt request flag IE: Interrupt enable flag ISP0: In-service priority flag 0 ISP1: In-service priority flag 1 MK: Interrupt mask flag PR0: Priority specification flag 0 PR1: Priority specification flag 1 **Remark** 24-pin product : n = 0 to 9 20-pin product : n = 0 to 5 # (d) Software interrupt # 15.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, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) - External interrupt rising edge enable register (EGP0) - External interrupt falling edge enable register (EGN0) - Program status word (PSW) Tables 15-3 and 15-4 show a list of interrupt request flags, interrupt mask flags, and priority specification flags corresponding to interrupt request sources. Table 15-3. Flags Corresponding to Interrupt Request Sources (20-, 24-pin products) (1/2) | Interrupt Source | Interrupt Reque | st Flag | Interrupt Mask Flag | | Priority Specification Flag | | cts | cts | |------------------|-----------------|----------|---------------------|----------|-----------------------------|----------|--------------------------------|--------------------------------| | | | Register | | Register | | Register | R5F1026x,<br>R5F1027x products | R5F1036x,<br>R5F1037x products | | INTWDTI | WDTIIF | IF0L | WDTIMK | MK0L | WDTIPR0, WDTIPR1 | PR00L, | ✓ | ✓ | | INTLVI | LVIIF | | LVIMK | | LVIPR0, LVIPR1 | PR10L | ✓ | ✓ | | INTP0 | PIF0 | | РМК0 | | PPR00, PPR10 | | <b>✓</b> | <b>✓</b> | | INTP1 | PIF1 | | PMK1 | | PPR01, PPR11 | | <b>✓</b> | ✓ | | INTP2 | PIF2 | | PMK2 | | PPR02, PPR12 | | <b>✓</b> | ✓ | | INTP3 | PIF3 | | PMK3 | | PPR03, PPR13 | | ✓ | ✓ | | INTDMA0 | DMAIF0 | | DMAMK0 | | DMAPR00, DMAPR10 | | ✓ | - | | INTDMA1 | DMAIF1 | | DMAMK1 | | DMAPR01, DMAPR11 | | ✓ | - | | INTST0 Note 1 | STIF0 Note 1 | IF0H | STMK0 Note 1 | МКОН | STPR00, STPR10 Note 1 | PR00H, | ✓ | ✓ | | INTCSI00 Note 1 | CSIIF00 Note 1 | | CSIMK00 Note 1 | | CSIPR000, CSIPR100 Note 1 | PR10H | ✓ | ✓ | | INTIIC00 Note 1 | IICIF00 Note 1 | | IICMK00 Note 1 | | IICPR000, IICPR100 Note 1 | | ✓ | - | | INTSR0 Note 2 | SRIF0 Note 2 | | SRMK0 Note 2 | | SRPR00, SRPR10 Note 2 | | ✓ | ✓ | | INTCSI01 Note 2 | CSIIF01 Note 2 | | CSIMK01 Note 2 | | CSIPR001, CSIPR101 Note 2 | | ✓ | - | | INTIIC01 Note 2 | IICIF01 Note 2 | | IICMK01 Note 2 | | IICPR001, IICPR101 Note 2 | | ✓ | = | | INTSRE0 | SREIF0 | | SREMK0 | | SREPR00, SREPR10 | | <b>✓</b> | <b>✓</b> | | INTTM01H | TMIF01H | | TMMK01H | | TMPR001H, TMPR101H | | ✓ | ✓ | | INTTM03H | TMIF03H | | ТММКОЗН | | TMPR003H, TMPR103H | | ✓ | ✓ | | INTIICA0 | IICAIF0 | | IICAMK0 | | IICAPR00, IICAPR10 | | ✓ | ✓ | | INTTM00 | TMIF00 | | TMMK00 | | TMPR000, TMPR100 | | ✓ | ✓ | | INTTM01 | TMIF01 | | TMMK01 | | TMPR001, TMPR101 | | ✓ | ✓ | | INTTM02 | TMIF02 | IF1L | TMMK02 | MK1L | TMPR002, TMPR102 | PR01L, | ✓ | ✓ | | INTTM03 | TMIF03 | | TMMK03 | | TMPR003, TMPR103 | PR11L | ✓ | ✓ | Interrupt Source Interrupt Request Flag Interrupt Mask Flag Priority Specification Flag R5F1036x, R5F1037x products R5F1027x products Register Register Register R5F1026x, ADIF IF1L ADMK MK1L PR01L, ✓ ADPR0, ADPR1 INTAD PR11L ✓ **TMKAIF TMKAMK** TMKAPR0, TMKAPR1 INTIT KRIF KRMK ✓ KRPR0, KRPR1 **INTKR MDMK MDIF** MDPR0, MDPR1 ✓ ✓ **INTMD** FLIF **FLMK** FLPR0, FLPR1 INTFL Table 15-3. Flags Corresponding to Interrupt Request Sources (20-, 24-pin products) (2/2) **Notes 1.** If interrupt source INTST0, INTCSI00, or INTIIC00 occurs, bit 5 of the IF0H register is set to 1. Bit 5 of the MK0H, PR00H, and PR10H registers corresponds these three interrupt sources. **<sup>2.</sup>** If interrupt source INTSR0, INTCSI01, or INTIIC01 occurs, bit 6 of the IF0H register is set to 1. Bit 6 of the MK0H, PR00H, and PR10H registers corresponds these three interrupt sources. Table 15-4. Flags Corresponding to Interrupt Request Sources (30-pin products) (1/2) | Interrupt | Interrupt Requ | uest Flag | Interrupt Mask Flag | J | Priority Specification Flag | | ucts | ucts | |---------------------------|--------------------------|-----------|--------------------------|----------|-------------------------------------|----------|-------------------|-------------------| | Source | | Register | | Register | | Register | R5F102Ax products | R5F103Ax products | | 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 | | ✓ | ✓ | | INTST2 <sup>Note1</sup> | STIF2 <sup>Note1</sup> | IF0H | STMK2 <sup>Note1</sup> | МКОН | STPR02, STPR12 <sup>Note1</sup> | PR00H, | ✓ | _ | | INTCSI20 <sup>Note1</sup> | CSIIF20 <sup>Note1</sup> | | CSIMK20 <sup>Note1</sup> | | CSIPR020, CSIPR120 <sup>Note1</sup> | PR10H | | | | INTIIC20 <sup>Note1</sup> | IICIF20 <sup>Note1</sup> | | IICMK20 <sup>Note1</sup> | | IICPR020, IICPR120 <sup>Note1</sup> | | | | | INTSR2 | SRIF2 | | SRMK2 | | SRPR02, SRPR12 | | ✓ | = | | INTSRE2 | SREIF2 | | SREMK2 | | SREPR02, SREPR12 | | ✓ | - | | INTDMA0 | DMAIF0 | | DMAMK0 | | DMAPR00, DMAPR10 | | ✓ | - | | INTDMA1 | DMAIF1 | | DMAMK1 | | DMAPR01, DMAPR11 | | ✓ | - | | INTST0 <sup>Note2</sup> | STIF0 <sup>Note2</sup> | | STMK0 <sup>Note2</sup> | | STPR00, STPR10 Note2 | | ✓ | ✓ | | INTCSI00 <sup>Note2</sup> | CSIIF00 <sup>Note2</sup> | | CSIMK00 <sup>Note2</sup> | | CSIPR000, CSIPR100 Note2 | | | | | INTIIC00 <sup>Note2</sup> | IICIF00 <sup>Note2</sup> | | IICMK00 <sup>Note2</sup> | | IICPR000, IICPR100 Note2 | | | | | INTSR0 | SRIF0 | | SRMK0 | | SRPR00, SRPR10 | | ✓ | ✓ | | INTSRE0 <sup>Note3</sup> | SREIF0 <sup>Note3</sup> | | SREMK0 <sup>Note3</sup> | | SREPR00, SREPR10 <sup>Note3</sup> | | ✓ | ✓ | | INTTM01H <sup>Note3</sup> | TMIF01H <sup>Note3</sup> | | TMMK01H <sup>Note3</sup> | | TMPR001H, TMPR101H <sup>Note3</sup> | | | | | INTST1 | STIF1 | IF1L | STMK1 | MK1L | STPR01, STPR11 | PR01L, | ✓ | - | | INTSR1 Note4 | SRIF1 <sup>Note4</sup> | | SRMK1 <sup>Note4</sup> | | SRPR01, SRPR11 Note4 | PR11L | ✓ | _ | | INTCSI11Note4 | CSIIF11 <sup>Note4</sup> | | CSIMK11 <sup>Note4</sup> | | CSIPR011, CSIPR111 Note4 | | | | | INTIIC11 <sup>Note4</sup> | IICIF11 <sup>Note4</sup> | | IICMK11 <sup>Note4</sup> | | IICPR011, IICPR111 Note4 | | | | | INTSRE1 Note5 | SREIF1 <sup>Note5</sup> | | SREMK1 <sup>Note5</sup> | | SREPR01, SREPR11 Note5 | | ✓ | - | | INTTM03H <sup>Note5</sup> | TMIF03HNote5 | | TMMK03H <sup>Note5</sup> | | TMPR003H, TMPR103H Note5 | | | ✓ | | INTIICA0 | IICAIF0 | | IICAMK0 | | IICAPR00, IICAPR10 | | ✓ | ✓ | | INTTM00 | TMIF00 | | TMMK00 | | TMPR000, TMPR100 | | ✓ | ✓ | | INTTM01 | TMIF01 | | TMMK01 | | TMPR001, TMPR101 | | ✓ | ✓ | | INTTM02 | TMIF02 | | TMMK02 | | TMPR002, TMPR102 | | ✓ | ✓ | | INTTM03 | TMIF03 | | ТММК03 | | TMPR003, TMPR103 | | ✓ | ✓ | | INTAD | ADIF | IF1H | ADMK | MK1H | ADPR0, ADPR1 | PR01H, | ✓ | ✓ | | INTIT | TMKAIF | | ТМКАМК | | TMKAPR0, TMKAPR1 | PR11H | ✓ | ✓ | | INTTM04 | TMIF04 | | TMMK04 | | TMPR004, TMPR104 | | ✓ | ✓ | | Interrupt | Interrupt Requ | est Flag | Interrupt Mask Flag | | Priority Specification Flag | | ts | ts | |-----------|----------------|----------|---------------------|----------|-----------------------------|----------|-------------------|-------------------| | Source | | Register | | Register | | Register | R5F102Ax products | R5F103Ax products | | INTTM05 | TMIF05 | IF2L | TMMK05 | MK2L | TMPR005, TMPR105 | PR02L, | ✓ | ✓ | | INTTM06 | TMIF06 | 1 | TMMK06 | | TMPR006, TMPR106 | PR12L | ✓ | ✓ | | INTTM07 | TMIF07 | | TMMK07 | | TMPR007, TMPR107 | | ✓ | ✓ | | INTMD | MDIF | IF2H | MDMK | MK2H | MDPR0, MDPR1 | PR02H, | ✓ | ✓ | | INTFL | FLIF | | FLMK | 1 | FLPR0, FLPR1 | PR12H | ✓ | ✓ | Table 15-4. Flags Corresponding to Interrupt Request Sources (30-pin products) (2/2) - **Notes 1.** If interrupt source INTST2, INTCSI20, or INTIIC20 occurs, bit 0 of the IF0H register is set to 1. In addition, bit 0 of the MK0H, PR00H, and PR10H registers corresponds to these three interrupt sources. - 2. If interrupt source INTST0, INTCSI00, or INTIIC00 occurs, bit 5 of the IF0H register is set to 1. In addition, bit 5 of the MK0H, PR00H, and PR10H registers corresponds to these three interrupt sources. - 3. Do not use a UART0 reception error interrupt and an interrupt of channel 1 of TAU0 (at higher 8-bit timer operation) at the same time because they share flags for the interrupt request sources. If the UART0 reception error interrupt is not used (EOC01 = 0), UART0 and channel 1 of TAU0 (at higher 8-bit timer operation) can be used at the same time. If one of the interrupt sources INTSRE0 and INTTM01H is generated, bit 7 of the IF0H register is set to 1. Bit 7 of the MK0H, PR00H, and PR10H registers supports these two interrupt sources. - **4.** If interrupt source INTST1, INTCSI11, or INTIIC11 occurs, bit 1 of the IF1L register is set to 1. Bit 1 of the MK1L, PR01L, and PR11L registers corresponds to these three interrupt sources. - 5. Do not use a UART1 reception error interrupt and an interrupt of channel 3 of TAU0 (at higher 8-bit timer operation) at the same time because they share flags for the interrupt request sources. If the UART1 reception error interrupt is not used (EOC01 = 0), UART1 and channel 3 of TAU0 (at higher 8-bit timer operation) can be used at the same time. If interrupt source INTTM03H is generated, bit 2 of the IF1L register is set to 1. Bit 2 of the MK1L, PR01L, and PR11L registers supports these two interrupt sources. ### 15.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 the interrupt request is acknowledged, a reset signal is generated, or an instruction is executed. 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, 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. Figure 15-2. Format of Interrupt Request Flag Registers (IF0L, IF0H, IF1L) (20-, 24-pin product) | Address: FFF | Address: FFFE0H After reset: 00H R/W | | | | | | | | |--------------|----------------------------------------------------------------------------|------------------------|---------|--------|--------|--------|-------------------------------------------------------------|---------------------------------------------| | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | IF0L | DMAIF1 <sup>Note</sup> | DMAIF0 <sup>Note</sup> | PIF3 | PIF2 | PIF1 | PIF0 | LVIIF | WDTIIF | | Address: FFF | E1H After r | eset: 00H I | R/W | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | IF0H | TMIF01 | TMIF00 | IICAIF0 | DMAIF1 | MIF01H | SREIF0 | SRIF0<br>CSIIF01 <sup>Note</sup><br>IICIF01 <sup>Note</sup> | STIF0<br>CSIIF00<br>IICIF00 <sup>Note</sup> | | Address: FFF | Address: FFFE2H After reset: 00H R/W Symbol 7 <6> <5> <4> <3> <2> <1> <0> | | | | | | | | | • | | | | | | | | | | IF1L | 0 | FLIF | MDIF | KRIF | TMKAIF | ADIF | TMIF03 | TMIF02 | | XXIFXX | Interrupt request flag | | | | | | |----------------------------------------------------------|---------------------------------------|--|--|--|--|--| | 0 | interrupt request signal is generated | | | | | | | Interrupt request is generated, interrupt request status | | | | | | | Note Provided in the R5F102 products only. (Cautions are listed on the next page) Figure 15-3. Format of Interrupt Request Flag Registers (IF0L, IF0H, IF1L, IF1H, IF2L, IF2H) (30-pin product) | Address: FFF | E0H After re | set: 00H R/\ | V | | | | | | |--------------|--------------|---------------|-------------------------|------------------------|------------------------|------------------------|-------------------------|-------------------------| | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | IF0L | PIF5 | PIF4 | PIF3 | PIF2 | PIF1 | PIF0 | LVIIF | WDTIIF | | • | | | | | | | | | | Address: FFF | E1H After re | set: 00H R/V | V | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | IF0H | SREIF0 | SRIF0 | STIF0 | DMAIF1 <sup>Note</sup> | DMAIF0 <sup>Note</sup> | SREIF2 <sup>Note</sup> | SRIF2 <sup>Note</sup> | STIF2 <sup>Note</sup> | | | TMIF01H | | CSIIF00 | | | | | CSIIF20 <sup>Note</sup> | | | | | IICIF00 <sup>Note</sup> | | | | | IICIF20 <sup>Note</sup> | | | | | | | | | | | | Address: FFF | E2H After re | set: 00H R/V | V | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | IF1L | TMIF03 | TMIF02 | TMIF01 | TMIF00 | IICAIF0 | SREIF1 Note | SRIF1 <sup>Note</sup> | STIF1 <sup>Note</sup> | | | | | | | | TMIF03H | CSIIF11 <sup>Note</sup> | | | | | | | | | | IICIF11 <sup>Note</sup> | | | | | | | | | | | | | Address: FFF | | | | | | | | | | Symbol | <7> | 6 | 5 | 4 | 3 | <2> | 1 | <0> | | IF1H | TMIF04 | 0 | 0 | 0 | 0 | TMKAIF | 0 | ADIF | | | | | | | | | | | | Address: FFF | D0H After re | eset: 00H R/\ | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | <2> | <1> | <0> | | IF2L | 0 | 0 | 0 | 0 | 0 | TMIF07 | TMIF06 | TMIF05 | | | | | | | | | | | | Address: FFF | D1H After re | eset: 00H R/\ | N | | | | | | | Symbol | 7 | 6 | <5> | 4 | 3 | 2 | 1 | 0 | | IF2H | FLIF | 0 | MDIF | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | XXIFXX | Interrupt request flag | | | | | |--------|----------------------------------------------------------|--|--|--|--| | 0 | No interrupt request signal is generated | | | | | | 1 | Interrupt request is generated, interrupt request status | | | | | Note Provided in the R5F102 products only. Cautions 1. Be sure to set bits that are not available to the initial value. 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. mov a, IF0L mov a, IF0L 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. # 15.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, 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 15-4. Format of Interrupt Mask Flag Registers (MK0L, MK0H, MK1L) (20, 24-pin product) | Address: FFI | FE4H After | reset: FFH | R/W | | | | | | |--------------|------------------------|------------------------------|-------|---------|---------|--------|-------------------------|-------------------------| | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | MK0L | DMAMK1 <sup>Note</sup> | DMAMK0 <sup>Note</sup> | PMK3 | PMK2 | PMK1 | PMK0 | LVIMK | WDTIMK | | | | | | | | | | | | Address: FFI | FE5H After | reset: FFH | R/W | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | MK0H | TMMK01 | TMMK00 | CAMK0 | TMMK03H | ТММК03Н | SREMK0 | RMK0 | TMK0 | | | | | | | | | CSIMK01 <sup>Note</sup> | CSIMK00 | | | | | | | | | IICMK01 <sup>Note</sup> | IICMK00 <sup>Note</sup> | | | | | | | | | | | | Address: FFI | FE6H After | reset: FFH | R/W | | | | | | | Symbol | 7 | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | MK1L | 1 | FLMK | MDMK | KRMK | TMKAMK | ADMK | TMMK03 | TMMK02 | | | | _ | | | | | | | | | XXMKXX | Interrupt servicing control | | | | | | | | | 0 | Interrupt servicing enabled | | | | | | | | | 1 | Interrupt servicing disabled | | | | | | | Note Provided in the R5F102 products only. **Caution** Be sure to set bits that are not available to the initial value. Figure 15-5. Format of Interrupt Mask Flag Registers (MK0L, MK0H, MK1L, MK1H, MK2L, MK2H) (30-pin product) | Address: F | FFE4H Afte | er reset: FFH | R/W | | | | | | |------------|-------------|---------------|-------------------------|------------------------|------------------------|------------------------|-------------------------|-------------------------| | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | MK0L | PMK5 | PMK4 | РМК3 | PMK2 | PMK1 | PMK0 | LVIMK | WDTIMK | | | | | | | | | | | | Address: F | FFFE5H Afte | er reset: FFH | R/W | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | MK0H | SREMK0 | SRMK0 | STMK0 | DMAMK1 <sup>Note</sup> | DMAMK0 <sup>Note</sup> | SREMK2 <sup>Note</sup> | SRMK2 <sup>Note</sup> | STMK2 <sup>Note</sup> | | | TMMK01H | | CSIMK01 | | | | | CSIMK20 <sup>Note</sup> | | | | | IICMK01 <sup>Note</sup> | | | | | IICMK20 <sup>Note</sup> | | | | | | | | | | | | Address: F | FFFE6H Afte | er reset: FFH | R/W | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | MK1L | TMMK03 | TMMK02 | TMMK01 | TMMK00 | IICAMK0 | SREMK1 <sup>Note</sup> | SRMK1 <sup>Note</sup> | STMK1 <sup>Note</sup> | | | | | | | | ТММК03Н | CSIMK11 <sup>Note</sup> | | | | | | | | | | IICMK11 <sup>Note</sup> | | | | | | | | | | | | | Address: F | FFFE7H Afte | er reset: FFH | R/W | | | | | | | Symbol | <7> | 6 | 5 | 4 | 3 | <2> | 1 | <0> | | MK1H | TMMK04 | 1 | 1 | 1 | 1 | TMKAMK | 1 | ADMK | | | | | | | | | | | | Address: F | FFD4H Afte | er reset: FFH | R/W | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | <2> | <1> | <0> | | MK2L | 1 | 1 | 1 | 1 | 1 | TMMK07 | TMMK06 | TMMK05 | | | | | | | | | | | | Address: F | FFD5H Afte | er reset: FFH | R/W | | | | | | | Symbol | 7 | 6 | <5> | 4 | 3 | 2 | 1 | 0 | | MK2H | FLMK | 1 | MDMK | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | | | | | | | | | XXMKXX | Interrupt servicing control | | | | | |--------|------------------------------|--|--|--|--| | 0 | Interrupt servicing enabled | | | | | | 1 | Interrupt servicing disabled | | | | | Note Provided in the R5F102 products only. Caution Be sure to set bits that are not available to the initial value. # 15.3.3 Priority specification flag registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) The priority specification flag registers are used to set the priority level of the corresponding maskable interrupt. 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 L 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 PR02L and PR02H 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 and PR10, 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 15-6. Format of Priority Specification Flag Registers (PR00L, PR00H, PR01L, PR10L, PR10H, PR11L) (20-, 24-pin product) | Address: FF | FE8H After | reset: FFH | R/W | | | | | | |-------------|-------------------------|-------------------------|----------|-------------|-----------|---------|--------------------------|--------------------------------------| | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | PR00L | DMAPR01 <sup>Note</sup> | DMAPR00 <sup>Note</sup> | PPR03 | PPR02 | PPR01 | PPR00 | LVIPR0 | WDTIPR0 | | | | | | | | | | | | Address: FF | FECH After | reset: FFH | R/W | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | PR10L | DMAPR11 | DMAPR10 | PPR13 | PPR12 | PPR11 | PPR10 | LVIPR1 | WDTIPR1 | | | | | | | | | | | | Address: FF | FE9H After | reset: FFH | R/W | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | PR00H | TMPR001 | TMPR000 | IICAPR00 | TMPR003H | TMPR001H | SREPR00 | SRPR00 | STPR00 | | | | | | | | | CSIPR001 <sup>Note</sup> | CSIPR000<br>IICPR000 <sup>Note</sup> | | | | | | | | | IICPR001 | IICPR000 | | Address: FF | EEDU Aftor | reset: FFH | R/W | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | PR10H | TMPR101 | TMPR100 | IICAPR10 | TMPR103H | TMPR101H | SREPR10 | SRPR10 | STPR10 | | FRIUII | TWIFTIOT | TIVIENTOO | IICAFRIO | TWIFTTIOSIT | TWIFTIUTT | SHEFHIO | CSIPR101 | CSIPR100 | | | | | | | | | IICPR101 | IICPR100 | | | | | | | | | | | | Address: FF | FEAH After | reset: FFH | R/W | | | | | | | Symbol | 7 | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | PR01L | 1 | FLPR0 | MDPR0 | KRPR0 | TMKAPR0 | ADPR0 | TMPR003 | TMPR002 | | | | | | | | | | | | Address: FF | FEEH After | reset: FFH | R/W | | | | | | | Symbol | 7 | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | PR11L | 1 | FLPR1 | MDPR1 | KRPR1 | TMKAPR1 | ADPR1 | TMPR001 | TMPR102 | | | | | | | | | | | | | | | | | | | | | | XXPR1X | XXPR0X | Priority Level Selection | | | | | |--------|--------|-----------------------------------|--|--|--|--| | 0 | 0 | pecifying level 0 (high priority) | | | | | | 0 | 1 | Specifying level 1 | | | | | | 1 | 0 | Specifying level 2 | | | | | | 1 | 1 | Specifying level 3 (low priority) | | | | | **Note** Provided in the R5F102 products only. **Caution** Be sure to set bits that are not available to the initial value. Figure 15-7. Format of Priority Specification Flag Registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) (30-pin product) (1/2) | Address: FF | FE8H After i | reset: FFH | R/W | | | | | | | | |--------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------|----------------------------------------|-------------------------|-------------------------|---------------------------------------------|------------------------------------------------------------------------------------------|----------------------------|--|--| | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | | | PR00L | PPR05 | PPR04 | PPR03 | PPR02 | PPR01 | PPR00 | LVIPR0 | WDTIPR0 | | | | Address: FF | FECH After | reset: FFH | R/W | | | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | | | PR10L | PPR15 | PPR14 | PPR13 | PPR12 | PPR11 | PPR10 | LVIPR1 | WDTIPR1 | | | | Address: FF | Address: FFFE9H After reset: FFH R/W | | | | | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | | | PR00H | SREPR00 | SRPR00 | STPR00 | DMAPR01 <sup>Note</sup> | DMAPR00 <sup>Note</sup> | SREPR02 <sup>Note</sup> | SRPR02 <sup>Note</sup> | STPR02 <sup>Note</sup> | | | | | TMPR001H | | CSIPR000 | | | | | CSIPR020 <sup>Note</sup> | | | | | | | IICPR000 <sup>Note</sup> | | | | | IICPR020 <sup>Note</sup> | | | | | | | | I | | | | | | | | Address: FF | FEDH After | reset: FFH | R/W | | | | | | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> | <0> | | | | PR10H | SREPR10 | SRPR10 | STPR10 | DMAPR11 <sup>Note</sup> | DMAPR10 <sup>Note</sup> | SREPR12 <sup>Note</sup> | SRPR12 <sup>Note</sup> | STPR12 | | | | | TMPR101H | | CSPR100 | | | | | CSIPR120 | | | | | | | IICPR100 <sup>Note</sup> | | | | | IICPR120 <sup>Note</sup> | | | | | | | | | | | | | | | | Address, FF | | recet: FFII | DAM | | | | | | | | | Address: FF | | reset: FFH | R/W | .45 | -0- | .0. | 4. | .0. | | | | Symbol | <7> | <6> | <5> | <4> | <3> | <2> | <1> Note | <0> | | | | | | | | <4><br>TMPR000 | <3> | SREPR01 | SRPR01<br>Note | <0> STPR01 <sup>Note</sup> | | | | Symbol | <7> | <6> | <5> | 1 | | Note | SRPR01<br>Note<br>CSIPR011 | | | | | Symbol | <7> | <6> | <5> | 1 | | SREPR01 | SRPR01<br>Note | | | | | Symbol<br>PR01L | <7> TMPR003 | <6><br>TMPR002 | <5><br>TMPR001 | 1 | | SREPR01 | SRPR01<br>Note<br>CSIPR011 | | | | | Symbol PR01L Address: FF | <7> TMPR003 FEEH After | <6><br>TMPR002 | <5><br>TMPR001 | TMPR000 | IICAPR00 | SREPR01<br>TMPR003H | SRPR01 Note CSIPR011 IICPR011 Note | STPR01 <sup>Note</sup> | | | | Symbol PR01L Address: FFI Symbol | <7> TMPR003 FEEH After 1 <7> | <6> TMPR002 reset: FFH <6> | <5><br>TMPR001<br>R/W<br><5> | TMPR000 | IICAPR00 | SREPR01 Note SREPR01 TMPR003H | SRPR01 Note CSIPR011 IICPR011 Note | STPR01 <sup>Note</sup> | | | | Symbol PR01L Address: FF | <7> TMPR003 FEEH After | <6><br>TMPR002 | <5><br>TMPR001 | TMPR000 | IICAPR00 | SREPR01 TMPR003H <2> SREPR11 Note | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note | STPR01 <sup>Note</sup> | | | | Symbol PR01L Address: FFI Symbol | <7> TMPR003 FEEH After 1 <7> | <6> TMPR002 reset: FFH <6> | <5><br>TMPR001<br>R/W<br><5> | TMPR000 | IICAPR00 | SREPR01 Note SREPR01 TMPR003H | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note CSIPR111 Note | STPR01 <sup>Note</sup> | | | | Symbol PR01L Address: FFI Symbol | <7> TMPR003 FEEH After 1 <7> | <6> TMPR002 reset: FFH <6> | <5><br>TMPR001<br>R/W<br><5> | TMPR000 | IICAPR00 | SREPR01 TMPR003H <2> SREPR11 Note | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note | STPR01 <sup>Note</sup> | | | | Symbol PR01L Address: FFI Symbol | <7> TMPR003 FEEH After <7> TMPR103 | <6> TMPR002 reset: FFH <6> | <5><br>TMPR001<br>R/W<br><5> | TMPR000 | IICAPR00 | SREPR01 TMPR003H <2> SREPR11 Note | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note CSIPR111 Note | STPR01 <sup>Note</sup> | | | | Symbol PR01L Address: FFI Symbol PR11L | <7> TMPR003 FEEH After <7> TMPR103 | <6> TMPR002 reset: FFH <6> TMPR102 | <5> TMPR001 R/W <5> TMPR101 | TMPR000 | IICAPR00 | SREPR01 TMPR003H <2> SREPR11 Note | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note CSIPR111 Note | STPR01 <sup>Note</sup> | | | | Symbol PR01L Address: FFI Symbol PR11L Address: FFI | <7> TMPR003 FEEH After <7> TMPR103 FEBH After | <6> TMPR002 reset: FFH <6> TMPR102 | <5> TMPR001 R/W <5> TMPR101 | TMPR000 <4> TMPR100 | IICAPR00 | SREPR01 TMPR003H <2> SREPR11 Note TMPR103H | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note CSIPR111 Note IICPR111 Note | <0> STPR11Note | | | | Symbol PR01L Address: FFI Symbol PR11L Address: FFI Symbol | <7> TMPR003 FEEH After <7> TMPR103 FEBH After <7> | <6> TMPR002 reset: FFH <6> TMPR102 reset: FFH 6 | <5> TMPR001 R/W <5> TMPR101 R/W 5 | TMPR000 <4> TMPR100 | IICAPR00 <3> IICAPR10 | SREPR01 TMPR003H <2> SREPR11 Note TMPR103H | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note CSIPR111 Note IICPR111 Note IICPR111 | <0> STPR11 Note | | | | Symbol PR01L Address: FFI Symbol PR11L Address: FFI Symbol | <7> TMPR003 FEEH After <7> TMPR103 FEBH After <7> TMPR004 | <6> TMPR002 reset: FFH <6> TMPR102 reset: FFH 6 | <5> TMPR001 R/W <5> TMPR101 R/W 5 | TMPR000 <4> TMPR100 | IICAPR00 <3> IICAPR10 | SREPR01 TMPR003H <2> SREPR11 Note TMPR103H | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note CSIPR111 Note IICPR111 Note IICPR111 | <0> STPR11 Note | | | | Symbol PR01L Address: FFI Symbol PR11L Address: FFI Symbol PR01H | <7> TMPR003 FEEH After <7> TMPR103 FEBH After <7> TMPR004 | <6> TMPR002 reset: FFH <6> TMPR102 reset: FFH 6 1 | <5> TMPR001 R/W <5> TMPR101 R/W 5 1 | TMPR000 <4> TMPR100 | IICAPR00 <3> IICAPR10 | SREPR01 TMPR003H <2> SREPR11 Note TMPR103H | SRPR01 Note CSIPR011 IICPR011 Note <1> SRPR11 Note CSIPR111 Note IICPR111 Note IICPR111 | <0> STPR11 Note | | | Note Provided in the R5F102 products only. Figure 15-7. Format of Priority Specification Flag Registers (PR00L, PR00H, PR01L, PR01H, PR02L, PR02H, PR10L, PR10H, PR11L, PR11H, PR12L, PR12H) (30-pin product) (2/2) | Address: FFF | FD8H After | reset: FFH | R/W | | | | | | | |--------------------------------------|--------------------------------------|------------|-------|---|---|---------|---------|---------|--| | Symbol | 7 | 6 | 5 | 4 | 3 | <2> | <1> | <0> | | | PR02L | 1 | 1 | 1 | 1 | 1 | TMPR007 | TMPR006 | TMPR005 | | | | | | | | | | | | | | Address: FFFDCH After reset: FFH R/W | | | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | <2> | <1> | <0> | | | PR12L | 1 | 1 | 1 | 1 | 1 | TMPR107 | TMPR106 | TMPR105 | | | | | | | | | | | | | | Address: FFI | FD9H After | reset: FFH | R/W | | | | | | | | Symbol | 7 | 6 | <5> | 4 | 3 | 2 | 1 | 0 | | | PR02H | FLPR0 | 1 | MDPR0 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | Address: FFI | Address: FFFDDH After reset: FFH R/W | | | | | | | | | | Symbol | 7 | 6 | <5> | 4 | 3 | 2 | 1 | 0 | | | PR12H | FLPR1 | 1 | MDPR1 | 1 | 1 | 1 | 1 | 1 | | | XXPR1X | XXPR0X | Priority Level Selection | | | | | |--------|--------|------------------------------------|--|--|--|--| | 0 | 0 | Specifying level 0 (high priority) | | | | | | 0 | 1 | Specifying level 1 | | | | | | 1 | 0 | Specifying level 2 | | | | | | 1 | 1 | Specifying level 3 (low priority) | | | | | **Caution** Be sure to set bits that are not available to the initial value. ## 15.3.4 External interrupt rising edge enable register (EGP0), external interrupt falling edge enable register (EGN0) These registers specify the valid edge for INTP0 to INTP5. The EGP0 and EGN0 registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears these registers to 00H. Figure 15-8. Format of External Interrupt Rising Edge Enable Register (EGP0) and External Interrupt Falling Edge Enable Register (EGN0) # 20-, 24-pin products | Address: FFF | F38H After | reset: 00H | R/W | | | | | | | | |--------------|------------|------------|-----|---|------|------|------|------|--|--| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | EGP0 | 0 | 0 | 0 | 0 | EGP3 | EGP2 | EGP1 | EGP0 | | | | | | | | | | | | | | | | Address: FFF | F39H After | reset: 00H | R/W | | | | | | | | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | EGN0 | 0 | 0 | 0 | 0 | EGN3 | EGN2 | EGN1 | EGN0 | | | | | L | | | | | | | | | | ## 30-pin products | Address: FFF | 38H After | reset: 00H | R/W | | | | | | |--------------|-----------|------------|------|------|------|------|------|------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | EGP0 | 0 | 0 | EGP5 | EGP4 | EGP3 | EGP2 | EGP1 | EGP0 | | | | | | | | | | | | Address: FFI | F39H After | reset: 00H | R/W | | | | | | |--------------|------------|------------|------|------|------|------|------|------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | EGN0 | 0 | 0 | EGN5 | EGN4 | EGN3 | EGN2 | EGN1 | EGN0 | | EGPn | EGNn | INTPn pin valid edge selection (n = 0 to 5) | | | | | | |------|------|---------------------------------------------|--|--|--|--|--| | 0 | 0 | Edge detection disabled | | | | | | | 0 | 1 | Falling edge | | | | | | | 1 | 0 | Rising edge | | | | | | | 1 | 1 | Both rising and falling edges | | | | | | 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** n = 0 to 5 ### 15.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 15-9. Configuration of Program Status Word #### 15.4 Interrupt Servicing Operations #### 15.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 15-5 below. For the interrupt request acknowledgment timing, see Figures 15-11 and 15-12. Table 15-5. Time from Generation of Maskable Interrupt Until Servicing | | 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 15-10 shows the interrupt request acknowledgment 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 15-10. Interrupt Request Acknowledgment Processing Algorithm x×IF: Interrupt request flag x×MK: Interrupt mask flag ××PR0: Priority specification flag 0××PR1: 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 15-9**) Note For the default priority, refer to Tables 15-1 and 15-2 Interrupt Source List. CPU processing Instruction Instruction PSW and PC saved, jump to interrupt servicing program xxIF 9 clocks Figure 15-11. Interrupt Request Acknowledgment Timing (Minimum Time) Remark 1 clock: 1/fclk (fclk: CPU clock) Figure 15-12. Interrupt Request Acknowledgment Timing (Maximum Time) Remark 1 clock: 1/fclk (fclk: CPU clock) #### 15.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. # 15.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 lower than that of the interrupt currently being serviced is generated during interrupt servicing, it is not acknowledged for multiple interrupt servicing. 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 15-6 shows relationship between interrupt requests enabled for multiple interrupt servicing and Figure 15-13 shows multiple interrupt servicing examples. Table 15-6. Relationship Between Interrupt Requests Enabled for Multiple Interrupt Servicing During Interrupt Servicing | Multiple Interru | Multiple Interrupt Request | | Maskable Interrupt Request | | | | | | | | |-------------------------|----------------------------|--------|------------------------------------------------------|--------|--------|--------|------------------|----------------------|--------|---| | | | | riority Level 0 Priority Level 1 (PR = 00) (PR = 01) | | 1 ' | | Level 3<br>= 11) | Interrupt<br>Request | | | | Interrupt Being Service | ed | IE = 1 | IE = 0 | IE = 1 | IE = 0 | IE = 1 | IE = 0 | IE = 1 | IE = 0 | | | Maskable interrupt | ISP1 = 0<br>ISP0 = 0 | 0 | × | × | × | × | × | × | × | 0 | | | ISP1 = 0<br>ISP0 = 1 | 0 | × | 0 | × | × | × | × | × | 0 | | | ISP1 = 1<br>ISP0 = 0 | 0 | × | 0 | × | 0 | × | × | × | 0 | | | ISP1 = 1<br>ISP0 = 1 | 0 | × | 0 | × | 0 | × | 0 | × | 0 | | Software interrupt | | 0 | × | 0 | × | 0 | × | 0 | × | 0 | ## Remarks 1. O: Multiple interrupt servicing enabled - 2. x: Multiple interrupt servicing disabled - 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 are enabled). IE = 0: Interrupt request acknowledgment is disabled. IE = 1: Interrupt request acknowledgment is enabled. 4. PR is a flag contained in the PR00L, PR00H, PR01L, PR10L, PR10H, PR11L registers. PR = 00: Specify level 0 with $\times \times$ PR1 $\times$ = 0, $\times \times$ PR0 $\times$ = 0 (higher priority level) PR = 01: Specify level 1 with $\times \times PR1 \times = 0$ , $\times \times PR0 \times = 1$ PR = 10: Specify level 2 with $\times \times PR1 \times = 1$ , $\times \times PR0 \times = 0$ PR = 11: Specify level 3 with $\times \times$ PR1 $\times$ = 1, $\times \times$ PR0 $\times$ = 1 (lower priority level) Figure 15-13. 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. Example 2. Multiple interrupt servicing does not occur due to priority control 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 $\times \times$ PR1 $\times$ = 0, $\times \times$ PR0 $\times$ = 0 (higher priority level) PR = 01: Specify level 1 with $\times \times$ PR1 $\times$ = 0, $\times \times$ PR0 $\times$ = 1 PR = 10: Specify level 2 with $\times \times PR1 \times = 1$ , $\times \times PR0 \times = 0$ PR = 11: Specify level 3 with $\times \times$ PR1 $\times$ = 1, $\times \times$ PR0 $\times$ = 1 (lower priority level) IE = 0: Interrupt request acknowledgment is disabled IE = 1: Interrupt request acknowledgment is enabled. Main processing INTxx servicing INTyy servicing INTxx = 0 Figure 15-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 $\times \times$ PR1 $\times$ = 0, $\times \times$ PR0 $\times$ = 0 (higher priority level) PR = 01: Specify level 1 with $\times \times$ PR1 $\times$ = 0, $\times \times$ PR0 $\times$ = 1 PR = 10: Specify level 2 with $\times \times PR1 \times = 1$ , $\times \times PR0 \times = 0$ PR = 11: Specify level 3 with $\times \times$ PR1 $\times$ = 1, $\times \times$ PR0 $\times$ = 1 (lower priority level) IE = 0: Interrupt request acknowledgment is disabled IE = 1: Interrupt request acknowledgment is enabled. #### 15.4.4 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 - EI - DI - SKC - SKNC - SKZ - SKNZ - SKH - SKNH - 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 15-14 shows the timing at which interrupt requests are held pending. Figure 15-14. Interrupt Request Hold Remarks 1. Instruction N: Interrupt request hold instruction 2. Instruction M: Instruction other than interrupt request hold instruction #### **CHAPTER 16 KEY INTERRUPT FUNCTION** The number of key interrupt input channels differs depending on the product. | | 20-pin | 24-pin | 30-pin | |------------------------------|--------|--------|-------------| | Key interrupt input channels | 6 ch | 4 ch | Not mounted | **Remark** Most of the subsequent descriptions in this chapter use 24-pin products as an example. #### 16.1 Functions of Key Interrupt In 20- and 24-pin products, a key interrupt (INTKR) can be generated by inputting a rising edge/falling edge to the key interrupt input pins (KR0 to KR9). There are two ways to identify the channel(s) to which a valid edge has been input: - Identify the channel(s) (KR0 to KR9) by using the port input level. - Identify the channel(s) (KR0 to KR5) by using the key interrupt flag. Table 16-1. Assignment of Key Interrupt Detection Pins | Key interrupt pin | Key return mode registers (KRM0, KRM1) | Key return flag register (KRF) | | |-------------------|----------------------------------------|--------------------------------|--| | KR0 | KRM00 | KRF0 | | | KR1 | KRM01 | KRF1 | | | KR2 | KRM02 | KRF2 | | | KR3 | KRM03 | KRF3 | | | KR4 | KRM04 | KRF4 | | | KR5 | KRM05 | KRF5 | | | KR6 | KRM06 | - | | | KR7 | KRM07 | - | | | KR8 | KRM08 | - | | | KR9 | KRM09 | _ | | Remark KR0 to KR5: 20-pin products KR0 to KR9: 24-pin products # 16.2 Configuration of Key Interrupt The key interrupt includes the following hardware. Table 16-2. Configuration of Key Interrupt | Item | Configuration | |------------------|------------------------------------------------| | Control register | Key return control register (KRCTL) | | | Key return mode control registers (KRM0, KRM1) | | | Key return flag register (KRF) | | | Port mode registers 0, 4, 6 (PM0, PM4, PM6) | Figure 16-1. Block Diagram of Key Interrupt Remark KR0 to KR5: 20-pin products KR0 to KR9: 24-pin products # 16.3 Register Controlling Key Interrupt The key interrupt function is controlled by the following registers: - Key return control register (KRCTL) - Key return mode control registers (KRM0, KRM1) - Key return flag register (KRF) - Port mode registers 0, 4, 6 (PM0, PM4, PM6) # 16.3.1 Key return control register (KRCTL) This register controls the usage of the key interrupt flags (KRF0 to KRF5) and sets the detection edge. The KRCTL register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 16-2. Format of Key Return Control Register (KRCTL) Address: FFF34H After reset: 00H R/W | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|---|---|---|---|---|---|------| | KRCTL | KRMD | 0 | 0 | 0 | 0 | 0 | 0 | KREG | | KRMD | Usage of Key Interrupt Flags (KRF0 to KRF5) | | | | | |------|---------------------------------------------|--|--|--|--| | 0 | Does not use key interrupt flags | | | | | | 1 | Uses key interrupt flags | | | | | | KRRG | Selection of Detection Edge (KR0 to KR9) | |------|------------------------------------------| | 0 | Falling edge | | 1 | Rising edge | | KRMD | KREG | Interrupt Function | |------|------|-------------------------------------------------------------------------| | 0 | 0 | Generates a key interrupt (INTKR) when detecting a falling edge. | | | | (Identify the channel by checking the port level). | | 0 | 1 | Generates a key interrupt (INTKR) when detecting a rising edge. | | | | (Identify the channel by checking the port level). | | 1 | 0 | Generates a key interrupt (INTKR) when detecting a falling edge. | | | | (Identify the channel by using the key interrupt flags (KRF0 to KRF5)). | | 1 | 1 | Generates a key interrupt (INTKR) when detecting a rising edge. | | | | (Identify the channel by using the key interrupt flags (KRF0 to KRF5)). | #### 16.3.2 Key return mode control registers (KRM0, KRM1) These registers set the key interrupt mode. The KRM0 and KRM1 registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears these registers to 00H. Figure 16-3. Format of Key Return Control Registers (KRM0, KRM1) # 20-pin products Address: FFF37H After reset: 00H R/W | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|-------|-------|-------|-------|-------|-------| | KRM0 | 0 | 0 | KRM05 | KRM04 | KRM03 | KRM02 | KRM01 | KRM00 | #### 24-pin products Address: FFF37H After reset: 00H R/W | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | KRM0 | KRM07 | KRM06 | KRM05 | KRM04 | KRM03 | KRM02 | KRM01 | KRM00 | Address: FFF36H After reset: 00H R/W | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|---|---|---|---|-------|-------| | KRM1 | 0 | 0 | 0 | 0 | 0 | 0 | KRM09 | KRM08 | | KRM0n | Key interrupt mode control (n = 0 to 9) | |-------|-----------------------------------------| | 0 | Does not detect key interrupt signal | | 1 | Detects key interrupt signal | - Cautions 1. When a falling edge (KRMD = 0) is selected and a key interrupt signal is detected (KRM0n = 1), pull up the relevant input pins to VDD by an external resistor. The internal pull-up resistor can be used by setting the relevant bits to 1 in the key interrupt input pins PU125 and PU00 to PU03 (pull-up resistor registers 12 and 0 (the bit 5 of PU12 and bits 0 to 3 of PU0)). - 2. An interrupt is generated if the target bits of the KRM0 and KRM1 registers are set while a low level (when KREG = 0) or high level (when KREG = 1) is input to the key interrupt input pin. To ignore this interrupt, set the KRM0 and KRM1 registers after disabling interrupt servicing by using the interrupt mask flag. After waiting for the key interrupt input high-level width or low-level width (see 28.4 AC characteristics or 29.4 AC characteristics), clear the interrupt request flag and enable interrupt servicing. - 3. The bits not used in the key interrupt mode can be used as normal ports. #### 16.3.3 Key return flag register (KRF) This register controls the key interrupt flags (KRF0 to KRF5). The KRF register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 16-4. Format of Key Return Flag Register (KRF) Address: FFF35H After reset: 00H R/W Note Symbol 7 6 5 4 3 2 0 1 KRF KRF5 KRF4 KRF3 KRF2 KRF0 0 0 KRF1 | KRFn | Key interrupt flag (n = 0 to 5) | |------|--------------------------------------------| | 0 | No key interrupt signal has been detected. | | 1 | A key interrupt signal has been detected. | **Note** Writing "1" is invalid. To clear KRFn, write "0" to the target bits and write "1" to other bits, with the 8-bit memory manipulation instruction. **Caution** For KR6 to KR9 pins, identify the channels by sequentially verifying the input levels. # 16.3.4 Port mode registers 0, 4, 6 (PM0, PM4, PM6) These registers set the input and output of ports 0, 4, and 6 in 1-bit units. To use a key interrupt input (KR0 to KR9), set 1 to the bit of port mode register (PM0, PM4, PM6) corresponding to each port. The PM0, PM4, and PM6 registers can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation clears these registers to FFH. Figure 16-5. Format of Port Mode Registers 0, 4, 6 (PM0, PM4, PM6) Address: FFF20H After reset: 00H R/W | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|---|---|------|------|------|------| | PM0 | 1 | 1 | 1 | 1 | PM03 | PM02 | PM01 | PM00 | Address: FFF24H After reset: FFH R/W | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|---|---|---|------|------|------| | PM4 | 1 | 1 | 1 | 1 | 1 | PM42 | PM41 | PM40 | Address: FFF26H After reset: FFH R/W Symbol 7 6 5 4 3 2 1 0 PM6 1 1 1 1 1 1 PM61 PM60 | PMmn | I/O mode selection for PMmn pin (m = 0, 4, 6, n = 0 to 3) | | | | |------|-----------------------------------------------------------|--|--|--| | 0 | Output mode (output buffer on) | | | | | 1 | 1 Input mode (output buffer off) | | | | #### 16.4 Key Interrupt Operation ## 16.4.1 When not using the key interrupt flag (KRMD = 0) A key interrupt (INTKR) is generated when the valid edge specified by the setting of the KREG bit is input to a key interrupt pin (KR0 to KR9). The channel to which the valid edge was input can be identified by reading the port register and checking the port level after the key interrupt (INTKR) is generated. The INTKR signal changes according to the input level of the key interrupt input pin (KR0 to KR5). Figure 16-6. Operation of INTKR Signal When a Key Interrupt is Input to a Single Channel (When KRMD = 0 and KREG = 0) - **Notes 1.** The maximum delay time is the maximum value of the high-level width and low-level width of the key interrupt input (see **28.4 AC Characteristics** or **29.4 AC Characteristics**). - 2. Cleared by acknowledgment of vectored interrupt request or software. The operation when a valid edge is input to multiple key interrupt input pins is shown in Figure 16-7. The INTKR signal is set while a low level is being input to one pin (when KREG is set to 0). Therefore, even if a falling edge is input to another pin in this period, a key interrupt (INTKR) will not be generated again (<1> in the figure). Figure 16-7. Operation of INTKR Signal When Key Interrupts Are Input to Multiple Channels (When KRMD = 0 and KREG = 0) - Notes 1. The maximum delay time is the maximum value of the high-level width and low-level width of the key interrupt input (see 28.4 AC Characteristics or 29.4 AC Characteristics). - 2. Cleared by acknowledgment of vectored interrupt request or bit cleared by software. #### 16.4.2 When using the key interrupt flag (KRMD = 1) A key interrupt (INTKR) is generated when the valid edge specified by the setting of the KREG bit is input to a key interrupt pin (KR0 to KR5). The channels to which the valid edge was input can be identified by reading the key return flag register (KRF) after the key interrupt (INTKR) is generated. If the KRMD bit is set to 1, the INTKR signal is cleared by clearing the corresponding bit in the KRF register. As shown in Figure 16-8, only one interrupt is generated each time a falling edge is input to one channel (when KREG = 0), regardless of whether the KRFn bit is cleared before or after a rising edge is input. Figure 16-8. Basic Operation of the INTKR Signal When the Key Interrupt Flag Is Used (When KRMD = 1 and KREG = 0) (a) KRF0 is cleared after a rising edge is input to the KR0 pin (b) KRF0 is cleared before a rising edge is input to the KR0 pin Notes 1. The maximum delay time is the maximum value of the high-level width and low-level width of the key interrupt input (see 28.4 AC Characteristics or 29.4 AC Characteristics). 2. Cleared by acknowledgment of vectored interrupt request or bit cleared by software. The operation when a valid edge is input to multiple key interrupt input pins is shown in Figure 16-9. A falling edge is also input to the KR1 and KR6 pins after a falling edge was input to the KR0 pin (when KREG = 0). The KRF1 bit is set when the KRF0 bit is cleared. A key interrupt (INTKR) is therefore generated one clock (fclk) after the KRF0 bit is cleared (<1> in the figure). Also, after a falling edge has been input to the KR6 pin, a low level continues to be input to this pin (<3> in the figure) until the KRF1 bit is cleared (<2> in the figure). A key interrupt (INTKR) is therefore generated one clock (fclk) after the KRF1 bit is cleared (<4> in the figure). It is thus possible to generate a key interrupt (INTKR) when a valid edge is input to multiple channels. Figure 16-9. Operation of INTKR Signal When Key Interrupts Are Input to Multiple Channels (When KRMD = 1 and KREG = 0) - Notes 1. The maximum delay time is the maximum value of the high-level width and low-level width of the key interrupt input (see 28.4 AC Characteristics or 29.4 AC Characteristics). - 2. Cleared by acknowledgment of vectored interrupt request or bit cleared by software. Remark fclk: CPU/peripheral hardware clock frequency The operation when a valid edge is input to the KR6 to KR9 pins without generating a key interrupt (INTKR) is shown in Figure 16-10. A falling edge is also input to the KR1 and KR6 pins after a falling edge was input to the KR0 pin (when KREG = 0). The KR1 pin becomes high level when the KRF0 bit is cleared, but because the KRF1 bit is set, a key interrupt (INTKR) is generated one clock (fclk) after the KRF0 bit is cleared (<1> in the figure). Also, because the KR6 pin was high level (<3> in the figure) before the KRF1 bit was cleared (<2> in the figure) a key interrupt (INTKR) is not generated for the KR6 pin. Figure 16-10. Operation When an INTKR Signal Is Not Generated upon Input of a Valid Edge to KR6 to KR9 (When KRMD = 1 and KREG = 0) - Notes 1. The maximum delay time is the maximum value of the high-level width and low-level width of the key interrupt input (see 28.4 AC Characteristics or 29.4 AC Characteristics). - 2. Cleared by acknowledgment of vectored interrupt request or bit cleared by software. Remark fclk: CPU/peripheral hardware clock frequency #### **CHAPTER 17 STANDBY FUNCTION** #### 17.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 and 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 clock 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. **Cautions 1.** When shifting to the STOP mode, be sure to stop the peripheral hardware operation operating with main system clock before executing STOP instruction (other than SNOOZE mode setting unit). - 2. When using CSI00, UART0, or the A/D converter in the SNOOZE mode, set up serial standby control register 0 (SSC0) 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. - **3.** To reduce the current consumption 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, and then execute the STOP instruction. - **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 23 OPTION BYTE. ## 17.2 Registers controlling standby function The registers which control the standby function are described below. - 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. # 17.3 Standby Function Operation #### 17.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 the 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. Table 17-1. Operating Statuses in HALT Mode | HALT Mode Setting | | When HALT Instruction Is Executed While CPU Is Operating on Main System Clock | | | | | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--| | tem | | When CPU Is Operating on High-speed On-chip Oscillator Clock (fiн) When CPU Is Operating on X1 Clock (fx) External Main System Clock (fex) | | | | | | System clock | | Clock supply to the CPU is stopped | | | | | | Main system clock f <sub>IH</sub> | | Operation continues (cannot be stopped) Operation disabled | | | | | | | fx | Operation disabled | Operation continues (cannot be stopped) | Cannot operate | | | | | fex | | Cannot operate | Operation continues (cannot be stopped) | | | | fı∟ | | operation speed mode control r | | C0H), and WUTMMCK0 bit of | | | | | | | | | | | | | | | • | | | | | | | · · | | es | | | | | | WUTMMCK0 = 0, WDTON = 1, and WDSTBYON = 0: Stops | | | | | | | | Operation stopped | | | | | | | | Operation stopped | | | | | | | | | | | | | | | | | | | | | | | | Status before HALT mode was set is retained | | | | | | Timer array unit | | Operable | | | | | | 12-bit interval timer | | | | | | | | Natchdog timer | | Set by bit 0 (WDSTBYON) of option byte (000C0H) • WDSTBYON = 0: Operation stopped • WDSTBYON = 1: Operation continues (cannot be stopped) | | | | | | Clock output/buzzer output | | | | | | | | A/D converter | • | ' | | | | | | Serial arrav unit (SAU) | | | | | | | | | | | | | | | | Multiplier and | | | | | | | | DMA controller | | | | | | | | Power-on-reset function | | | | | | | | Voltage detection functi | on | | | | | | | External interrupt | | | | | | | | Key interrupt function | | | | | | | | CRC operation function | | In the calculation of the RAM area, operable when DMA is executed only | | | | | | RAM parity error detection function | | Operable when DMA is executed only | | | | | | RAM guard function | | 1 | | | | | | SFR guard function | | 1 | | | | | | llegal-memory access | | | | | | | | | Main system clock Main system clock Main system clock fil. CPU Code flash memory Data flash memory Port (latch) Fimer array unit 12-bit interval timer Watchdog timer Clock output/buzzer out A/D converter Serial array unit (SAU) Gerial interface (IICA) Multiplier and divider/multiplyaccumulation DMA controller Power-on-reset function Voltage detection function External interrupt Key interrupt function CRC operation function RAM parity error detection CRM guard function BFR guard function Illegal-memory access detection function | System clock Main system clock fill fx fill CPU Code flash memory Data flash memory Port (latch) Fimer array unit 12-bit interval timer Watchdog timer Clock output/buzzer output A/D converter Serial array unit (SAU) Serial interface (IICA) Multiplier and divider/multiplyaccumulator DMA controller Power-on-reset function Woltage detection function External interrupt Key interrupt function CRC operation function RAM parity error detection function RAM guard function SFR guard function Illegal-memory access detection function | High-speed On-chip Oscillator Clock (fiii) System clock Main system clock fix fix Set by bits 0 (WDSTBYON) and operation speed mode control in wUTMMCK0 = 1: Oscillates wUTMMCK0 = 0, WDTON = wUT | High-speed On-chip Oscillator Clock (fix) System clock Main system clock | | | **Remark** Operation stopped: Operation is automatically stopped before switching to the HALT mode. Operation disabled: Operation is stopped before switching to the HALT mode. fін: High-speed on-chip oscillator clock fıL: 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. Figure 17-1. HALT Mode Release by Interrupt Request Generation Notes 1. For details of the standby release signal, see Figure 15-1 Basic Configuration of Interrupt Function. - 2. Wait time for HALT mode release - When vectored interrupt servicing is carried out: 15 to 16 clocks - When vectored interrupt servicing is not carried out: 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. Figure 17-2. HALT Mode Release by Reset ## (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 reset processing time, see CHAPTER 18 RESET FUNCTION. For reset processing time for Poweron-reset circuit (POR) and Voltage detection (LVD) circuit, see CHAPTER 19 POWER-ON-RESET CIRCUIT. #### 17.3.2 STOP mode ## (1) STOP mode setting and operating statuses The STOP mode is set by executing the STOP instruction, and the mode can be set regardless of whether the CPU clock before the setting was the high-speed system clock or the high-speed on-chip oscillator clock. Caution 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 operation after the elapse of release time from the STOP mode. The operating statuses in the STOP mode are shown below. Table 17-2. Operating Statuses in STOP Mode | STOP Mod | e Setting | When STOP Instruction Is | Executed While CPU Is Operat | ing on Main System Clock | | | |-------------------------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------------------|--|--| | Item | | When CPU Is Operating on High-speed On-chip Oscillator Clock (fiн) When CPU Is Operating on X1 Clock (fx) X1 Clock (fx) External Main System Clock (f∈x) | | | | | | System clock | | Clock supply to the CPU is stopped | | | | | | Main system clock | fıн | Stopped | | | | | | | fx | | | | | | | | fex | | | | | | | fiL | | Set by bits 0 (WDSTBYON) and 4 (WDTON) of option byte (000C0H), and WUTMMCK0 bit of operation speed mode control register (OSMC) • WUTMMCK = 1: Oscillates • WUTMMCK = 0 and WDTON = 0: Stops • WUTMMCK = 0, WDTON = 1, and WDSTBYON = 1: Oscillates • WUTMMCK = 0, WDTON = 1, and WDSTBYON = 0: Stops | | | | | | CPU | | Operation stopped | | | | | | Code flash memory | | | | | | | | Data flash memory | | Operation stopped | | | | | | RAM | | Operation stopped | | | | | | Port (latch) | | Status before STOP mode was set is retained | | | | | | Timer array unit | | Operation disabled | | | | | | 12-bit interval timer | | Operable | | | | | | Watchdog timer | | Set by bit 0 (WDSTBYON) of option byte (000C0H) • WDSTBYON = 0: Operation stopped • WDSTBYON = 1: Operation continues (cannot be stopped) | | | | | | Clock output/buzzer output | | Operation disabled | | | | | | A/D converter | | Wakeup operation is enabled (switching to the SNOOZE mode) | | | | | | Serial array unit (SAU) | | Wakeup operation is enabled only for CSI00 and UART0 (switching to the SNOOZE mode) Operation is disabled for anything other than CSI00 and UART0 | | | | | | Serial interface (IICA) | | Wakeup by address match operable | | | | | | Multiplier and divider/multiply-<br>accumulator | | Operation disabled | | | | | | DMA controller | | | | | | | | Power-on-reset function | | Operable | | | | | | Voltage detection function | | | | | | | | External interrupt | | | | | | | | Key interrupt function | | | | | | | | CRC operation function | | Operation stopped | | | | | | RAM parity error | | | | | | | | detection function | | | | | | | | RAM guard function | | | | | | | | SFR guard function | | | | | | | | Illegal-memory access detection function | | | | | | | **Remark** Operation stopped: Operation is automatically stopped before switching to the STOP mode. Operation disabled: Operation is stopped before switching to the STOP mode. fін: High-speed on-chip oscillator clock fıL: 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 17-3. STOP Mode Release by Interrupt Request Generation (1/2) # (1) When high-speed on-chip oscillator clock is used as CPU clock Notes 1. For details of the standby release signal, see Figure 15-1 Basic Configuration of Interrupt Function. 2. STOP mode release time Supply of the clock is stopped: 18 $\mu s$ to 65 $\mu s$ Wait • When vectored interrupt servicing is carried out: 7 clocks · When vectored interrupt servicing is not carried out: 1 clock - **Remarks 1.** The clock supply stop time varies depending on the temperature conditions and STOP mode period. - 2. The broken lines indicate the case when the interrupt request that has released the standby mode is acknowledged. Figure 17-3. STOP Mode Release by Interrupt Request Generation (2/2) #### (2) When high-speed system clock (X1 oscillation) is used as CPU clock Notes 1. For details of the standby release signal, see Figure 15-1 Basic Configuration of Interrupt Function. 2. STOP mode release time Supply of the clock is stopped: $18 \mu s$ to "whichever is longer 65 $\mu s$ and 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 - Notes 1. For details of the standby release signal, see Figure 15-1. - 2. STOP mode release time Supply of the clock is stopped: $18 \mu s$ to $65 \mu 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. - **Remarks 1.** The clock supply stop time varies depending on the temperature conditions and STOP mode period. - 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. Figure 17-4. STOP Mode Release by Reset ## (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 reset processing time, see CHAPTER 18 RESET FUNCTION. For reset processing time for Poweron-reset circuit (POR) and Voltage detection (LVD) circuit, see CHAPTER 19 POWER-ON-RESET CIRCUIT. #### 17.3.3 SNOOZE mode #### (1) SNOOZE mode setting and operating statuses The SNOOZE mode can only be specified for CSI00, UART0, or the 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 the SWC0 bit of the serial standby control register 0 (SSC0) to 1 immediately 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 the AWC bit of the A/D converter mode register 2 (ADM2) to 1 immediately 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: 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. From SNOOZE to normal operation • When vectored interrupt servicing is carried out: HS (high-speed main) mode : "6.65 $\mu$ s to 9.44 $\mu$ s" + 7 clocks LS (low-speed main) mode : "1.10 $\mu$ s to 5.08 $\mu$ s" + 7 clocks • When vectored interrupt servicing is not carried out: HS (high-speed main) mode : "6.65 $\mu$ s to 9.44 $\mu$ s" + 1 clock LS (low-speed main) mode : "1.10 $\mu$ s to 5.08 $\mu$ s" + 1 clock The operating statuses in the SNOOZE mode are shown below. Table 17-3. Operating Statuses in SNOOZE Mode | Iter | STOP Mode Setting | | When Inputting CSI00/UART0 Data Reception Signal or A/D Converter Timer Trigger Signal While in STOP Mode | | | | |------------------------------------------|------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | | | When CPU Is Operating on High-speed On-chip Oscillator Clock (fℍ) | | | | | Sys | stem clock | | Clock supply to the CPU is stopped | | | | | | Main system clock f <sub>IH</sub> fx f <sub>EX</sub> | | Operation started | | | | | | | | Stopped | | | | | | | | | | | | | | fiL | | Set by bits 0 (WDSTBYON) and 4 (WDTON) of option byte (000C0H), and WUTMMCK0 bit of operation speed mode control register (OSMC) • WUTMMCK = 1: Oscillates • WUTMMCK = 0 and WDTON = 0: Stops • WUTMMCK = 0, WDTON = 1, and WDSTBYON = 1: Oscillates • WUTMMCK = 0, WDTON = 1, and WDSTBYON = 0: Stops | | | | | СР | U | | Operation stopped | | | | | Cod | de flash memory | | | | | | | Dat | a flash memory | | | | | | | RA | M | | Operation stopped (operable when DMA is executed) | | | | | Por | t (latch) | | Status while in STOP mode continues | | | | | Tim | ner array unit | | Operation disabled | | | | | 12- | bit interval timer | | Operable | | | | | Watchdog timer | | | Set by bit 0 (WDSTBYON) of option byte (000C0H) • WDSTBYON = 0: Operation stopped • WDSTBYON = 1: Operation continues (cannot be stopped) | | | | | Clo | ck output/buzzer out | put | Operation stopped | | | | | A/E | ) converter | | Operable | | | | | Ser | rial array unit (SAU) | | Operable only CSI00 and UART0 only. | | | | | | | | Operation disabled other than CSI00 and UART0. | | | | | Ser | rial interface (IICA) | | Operation disabled | | | | | | Itiplier and divider/mu<br>umulator | ultiply- | | | | | | DM | DMA controller | | | | | | | Pov | Power-on-reset function | | Operable | | | | | Vol | Voltage detection function | | | | | | | Ext | External interrupt | | | | | | | Key interrupt function | | | | | | | | CRC operation function | | | Operation disabled | | | | | RAM parity error | | | | | | | | detection function | | | | | | | | RAM guard function | | | | | | | | SFI | R guard function | | | | | | | Illegal-memory access detection function | | | | | | | **Remark** Operation stopped: Operation is automatically stopped before switching to the STOP mode. Operation disabled: Operation is stopped before switching to the STOP mode. $f_{IH}$ : High-speed on-chip oscillator clock $f_{IL}$ : Low-speed on-chip oscillator clock fx: X1 clock fex: External main system clock #### (2) Timing diagram when the interrupt request signal is generated in the SNOOZE mode Figure 17-5. When the Interrupt Request Signal is Generated in the SNOOZE Mode - Notes 1. For details of the standby release signal, see Figure 15-1. - 2. Transition time from STOP mode to SNOOZE mode - 3. Transition time from SNOOZE mode to normal operation - 4. Enable the SNOOZE mode (AWC = 1 or SWC = 1) immediately before switching to the STOP mode. - **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 17-6. When the Interrupt Request Signal is not Generated in the SNOOZE Mode - Notes 1. For details of the standby release signal, see Figure 15-1. - 2. Transition time from STOP mode to SNOOZE mode - 3. Enable the SNOOZE mode (AWC = 1 or SWC = 1) immediately before switching to the STOP mode. Remark For details of the SNOOZE mode function, see CHAPTER 10 A/D CONVERTER and CHAPTER 11 SERIAL ARRAY UNIT. #### **CHAPTER 18 RESET FUNCTION** The following seven operations are available to generate a reset signal. - (1) External reset input via RESET 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 00000H and 00001H when the reset signal is generated. A reset is effected when a low level is input to the RESET pin, the watchdog timer overflows, or by POR and LVD circuit voltage detection, execution of illegal instruction RAM parity error or illegal-memory access, and each item of hardware is set to the status shown in Table 18-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. - **Cautions 1.** After power is turned on, P125 functions as the RESET pin (20- or 24-pin products only). Even if the internal reset signal is released by the power-on reset (POR), the reset state is retained while a low level is input to this pin. - When P125/KR1/SI01 is used, select the port function (PORTSELB = 0) by the option byte (000C1H) and release all reset sources. - 2. For an external reset, input a low level for 10 μs or more to the RESET pin. To perform an external reset upon power application, input a low level to the RESET pin, turn power on, continue to input a low level on the pin for 10 us or more within the operating voltage range shown in 28.4 or 29.4 AC Characteristics, and then input a high level to the pin. - **3.** During reset input, the X1 clock, high-speed on-chip oscillator clock, and low-speed on-chip oscillator clock stop oscillating, and external main system clock input is invalid. - 4. 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 internal pull-up resistor). - P125: High level during the reset period or after receiving a reset signal (connected to the internal pullup resistor). - Ports other than P40 and p125: High-impedance during the reset period or after receiving a reset signal. Remark VPOR: POR power supply rise detection voltage Caution An LVD circuit internal reset does not reset the LVD circuit. Remarks 1. LVIM: Voltage detection register 2. LVIS: Voltage detection level register ## 18.1 Timing of Reset Operation This LSI is reset by input of the low level on the RESET pin and released from the reset state by input of the high level on the RESET pin. After reset processing, execution of the program with the high-speed on-chip oscillator clock as the operating clock starts. Figure 18-2. Timing of Reset by RESET Input 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, execution of the program with the high-speed on-chip oscillator clock as the operating clock starts. Figure 18-3. Timing of Reset Due to Watchdog Timer Overflow, Execution of Illegal Instruction, Detection of a RAM Parity Error, or Detection of Illegal Memory Access Wait for oscillation (Notes are listed on the next page.) Notes 1. Reset times (times for release from the 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. - 2. P40 and P125 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 or after receiving a reset signal (connected to the internal pull-up resistor). - P125: High level during the reset period or after receiving a reset signal (connected to the internal pull-up resistor). Reset by POR and LVD circuit supply voltage detection is automatically released when $V_{DD} \ge V_{POR}$ or $V_{DD} \ge V_{LVD}$ 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 19 POWER-ON-RESET CIRCUIT** or **CHAPTER 20 VOLTAGE DETECTOR**. # 18.2 States of Operation During Reset Periods Table 18-1 shows the states of operation during reset periods. Table 18-2 shows the states of the hardware after receiving a reset signal. Table 18-1. Operation Statuses During Reset Period | | Item | | During Reset Period | | | | |-------------------------|------------------------------------------------|-----|----------------------------------------------------------------------------------------------------|--|--|--| | System clock | | | Clock supply to the CPU is stopped. | | | | | Main system clock fін | | 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) | | | | | | fiL | | Operation stopped | | | | | CF | PU | | Operation stopped | | | | | Co | ode flash memory | | Operation stopped | | | | | Da | ata flash memory | | Operation stopped | | | | | R/ | AM | | Operation stopped | | | | | Po | ort (latch) | | High impedance Note | | | | | Tir | mer array unit | | Operation stopped | | | | | 12 | -bit Interval timer | | | | | | | Wa | atchdog timer | | | | | | | Clo | ock output/buzzer output | | | | | | | A/I | A/D converter | | | | | | | Serial array unit (SAU) | | | | | | | | Se | Serial interface (IICA) | | | | | | | | Multiplier & divider, multiply-<br>accumulator | | | | | | | D١ | MA controller | | | | | | | Po | wer-on-reset function | | Detection operation possible | | | | | Vo | oltage detection function | | Operation is possible in the case of an LVD reset and stopped in the case of other types of reset. | | | | | Ex | ternal interrupt | | Operation stopped | | | | | Ke | Key interrupt function | | | | | | | CRC operation function | | | | | | | | R/ | RAM parity error detection function | | | | | | | RA | AM guard function | | | | | | | SF | SFR guard function | | | | | | | | egal-memory access detect | ion | | | | | Note P40 and P125 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 or after receiving a reset signal (connected to the internal pull-up resistor). - P125: High level during the reset period or after receiving a reset signal (connected to the internal pull-up resistor). Remark fin: High-speed on-chip oscillator clock fx: X1 oscillation clock fex: External main system clock fı∟: Low-speed on-chip oscillator clock <R> Table 18-2. State of Hardware After Receiving a Reset Signal Hardware After Reset Acknowledgment Note Program counter (PC) The contents of the reset vector table (00000H, 00001H) are set. Stack pointer (SP) Undefined Program status word (PSW) 06H RAM Data memory Undefined General-purpose registers Undefined **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. # 18.3 Register for Confirming Reset Source # 18.3.1 Reset Control Flag Register (RESF) Many internal reset generation sources exist in the RL78 microcontroller. 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. RESET input, reset by power-on-reset (POR) circuit, and reading the RESF register clear TRAP, WDTRF, RPERF, IAWRF, and LVIRF flags. Figure 18-4. Format of Reset Control Flag Register (RESF) | <r></r> | Address: FFI | FA8H After | reset: Undefi | ned Note 1 R | | | | | | |---------|--------------|------------|---------------|--------------|-------|---|-------|-------|-------| | | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESF | TRAP | 0 | 0 | WDTRF | 0 | RPERF | IAWRF | LVIRF | | TRAP | Internal reset request by execution of illegal instructionNote 2 | | | | | |------|---------------------------------------------------------------------------|--|--|--|--| | 0 | Internal reset request is not generated, or the RESF register is cleared. | | | | | | 1 | Internal reset request is generated. | | | | | | WDTRF | Internal reset request by watchdog timer (WDT) | | | | | |-------|---------------------------------------------------------------------------|--|--|--|--| | 0 | Internal reset request is not generated, or the RESF register is cleared. | | | | | | 1 | Internal reset request is generated. | | | | | | RPERF | Internal reset request t by RAM parity | | | | | |-------|--------------------------------------------------------------------------|--|--|--|--| | 0 | nternal reset request is not generated, or the RESF register is cleared. | | | | | | 1 | Internal reset request is generated. | | | | | | IAWRF | Internal reset request t by illegal-memory access | | | | | |-------|---------------------------------------------------------------------------|--|--|--|--| | 0 | Internal reset request is not generated, or the RESF register is cleared. | | | | | | 1 | 1 Internal reset request is generated. | | | | | | LVIRF | Internal reset request by voltage detector (LVD) | | | | | |-------|---------------------------------------------------------------------------|--|--|--|--| | 0 | Internal reset request is not generated, or the RESF register is cleared. | | | | | | 1 | 1 Internal reset request is generated. | | | | | **Notes 1.** The value after reset varies depending on the reset source. See table 18-3. 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. **Cautions 1.** Do not read data by a 1-bit memory manipulation instruction. 2. 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 21.3.2 RAM parity error detection function. The status of the RESF register when a reset request is generated is shown in Table 18-3. Table 18-3. RESF Register Status When Reset Request Is Generated | Reset Source<br>Flag | RESET Input | Reset by<br>POR | Reset by Execution of Illegal Instruction | Reset by<br>WDT | Reset by<br>RAM parity<br>error | Reset by<br>illegal-<br>memory<br>access | Reset by<br>LVD | |----------------------|-------------|-----------------|-------------------------------------------|-----------------|---------------------------------|------------------------------------------|-----------------| | TRAP bit | Cleared (0) | Cleared (0) | Set (1) | Held | Held | Held | Held | | WDTRF bit | | | Held | Set (1) | | | | | RPERF bit | | | | Held | Set (1) | | | | IAWRF bit | | | | | Held | Set (1) | | | LVIRF bit | | | | | | Held | Set (1) | The RESF register is automatically cleared when it is read by an 8-bit memory manipulation instruction. Figure 18-5 shows the procedure for checking a reset source. Figure 18-5. Procedure for Checking Reset Source <R> The flow described above is an example of the procedure for checking. #### CHAPTER 19 POWER-ON-RESET CIRCUIT #### 19.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 28.4 or 29.4 AC Characteristics. 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 28.4 or 29.4 AC Characteristics. When restarting the operation, make sure that the operation voltage has returned within the range of operation.</li> **Caution** If an internal reset signal is generated in the power-on-reset circuit, the reset control flag register (RESF) is cleared to 00H. Remarks 1. The RL78 microcontroller 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 18 RESET FUNCTION. 2. VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage For details, see 28.6.3 or 29.6.3 POR circuit characteristics. # 19.2 Configuration of Power-on-reset Circuit The block diagram of the power-on-reset circuit is shown in Figure 19-1. V<sub>DD</sub> Internal reset signal Reference voltage source Figure 19-1. Block Diagram of Power-on-reset Circuit # 19.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 below. Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector (1/3) # (1) When the external reset input via RESET pin is used - **Notes 1.** The internal reset processing time includes the oscillation accuracy stabilization time of the high-speed onchip oscillator clock. - 2. The high-speed on-chip oscillator clock can be switched to the high-speed system clock 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. - 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 RESET 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) 4. 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) 5. After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 28.4 or 29.4 AC Characteristics. 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 RESET pin when the LVD is off. For details, see CHAPTER 20 VOLTAGE DETECTOR. Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector (2/3) (2) LVD interrupt & reset mode (option byte 000C1H/LVIMDS1, LVIMDS0 = 1, 0) - **Notes 1.** The internal reset processing time includes the oscillation accuracy stabilization time of the high-speed onchip oscillator clock. - 2. The high-speed on-chip oscillator clock can be switched to the high-speed system clock 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. - 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 20-8 Processing Procedure After an Interrupt Is Generated and Figure 20-9 Initial Setting of Interrupt and Reset Mode, 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). - 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. Remark VLVDH, VLVDL: LVD detection voltage VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage LVD reset processing time: 0 ms to 0.0701 ms (max.) <R> Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector (3/3) ## **Notes** - **1.** The internal reset processing time includes the oscillation accuracy stabilization time of the high-speed on-chip oscillator clock. - 2. The high-speed on-chip oscillator clock can be switched to the high-speed system clock 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. - 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.) - 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.0629 ms (typ.), 0.0701 ms (max.) # Remarks 1. VLVDH, VLVDL: LVD detection voltage VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage 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 19-2 (3). ### **CHAPTER 20 VOLTAGE DETECTOR** ## 20.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 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 interrupt request signal. - The detection level for the power supply detection voltage (VLVDH, VLVDL, VLVD) can be selected by using the option byte as one of 12 levels (For details, see CHAPTER 23 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 28.4 or 29.4 AC Characteristics. This is done by utilizing the voltage detector 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). - (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. The low-voltage detection level (VLVDL) is used for generating resets. - (b) Reset mode (option byte LVIMDS1, LVIMDS0 = 1, 1) The detection voltage (V<sub>LVD</sub>) selected by the option byte 000C1H is used for generating/releasing resets. - (c) Interrupt mode (option byte LVIMDS1, LVIMDS0 = 0, 1) The detection voltage (V<sub>LVD</sub>) selected by the option byte 000C1H is used for releasing resets/generating interrupts. The reset and interrupt request signals are generated in each mode as follows. | | Interrupt & reset mode | Reset mode | Interrupt mode | |---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <r></r> | (LVIMDS1, LVIMDS0 = 1, 0) | (LVIMDS1, LVIMDS0 = 1, 1) | (LVIMDS1, LVIMDS0 = 0, 1) | | | Generates an interrupt request signal by detecting $V_{DD} < V_{LVDH}$ when the operating voltage falls, and an internal reset by detecting $V_{DD} < V_{LVDL}$ . Releases an internal reset by detecting $V_{DD} \ge V_{LVDH}$ . | Releases an internal reset by detecting $V_{DD} \ge V_{LVD}$ . Generates an internal reset signal by detecting $V_{DD} < V_{LVD}$ . | Retains the state of an internal reset by the LVD immediately after a reset until $V_{DD} \ge V_{LVD}$ . Releases the LVD internal reset by detecting $V_{DD} \ge V_{LVD}$ . Generates an interrupt request signal (INTLVI) by detecting $V_{DD} < V_{LVD}$ or $V_{DD} \ge V_{LVD}$ after the LVD internal reset is | | | | | 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 18 RESET FUNCTION**. <R> # 20.2 Configuration of Voltage Detector The block diagram of the voltage detector is shown in Figure 20-1. ■ N-ch Internal reset signal Voltage detection level selector Controller $V_{\text{LVDH}}$ Selector VLVDL/VLVD INTLVI Reference voltage source Option byte (000C1H) LVIS1, LVIS0 LVIF LVIOMSK LVISEN LVIMD LVILV Option byte (000C1H) Voltage detection Voltage detection VPOC2 to VPOC0 register (LVIM) level register (LVIS) Internal bus Figure 20-1. Block Diagram of Voltage Detector # 20.3 Registers Controlling Voltage Detector The voltage detector is controlled by the following registers. - Voltage detection register (LVIM) - Voltage detection level register (LVIS) ## 20.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 20-2. Format of Voltage Detection Register (LVIM) | Address: | FFFA9H | After reset: Note 1 | R/W Note 2 | | | | | | |----------|------------------|---------------------|------------|---|---|---|---------|------| | Symbol | <7> | 6 | 5 | 4 | 3 | 2 | <1> | <0> | | LVIM | LVISEN<br>Note 3 | 0 | 0 | 0 | 0 | 0 | LVIOMSK | LVIF | | LVISEN<br>Note 3 | 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 (LVIOMSK = 1 (Mask of LVD output is valid)) | | | | | LVIOMSK | Mask status flag of LVD output | | | | |---------|------------------------------------|--|--|--| | 0 | Mask of LVD output is invalid | | | | | 1 | Mask of LVD output is valid Note 4 | | | | | LVIF | Voltage detection flag | |------|-----------------------------------------------------------------------------------------------| | 0 | Supply voltage (V <sub>DD</sub> ) ≥ detection voltage (V <sub>LVD</sub> ), or when LVD is off | | 1 | Supply voltage (V <sub>DD</sub> ) < detection voltage (V <sub>LVD</sub> ) | # Notes 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. The value of this LVISEN is reset to "0" if a reset other than by LVD is effected. - 2. Bits 0 and 1 are read-only. - 3. LVISEN and LVIOMSK can only be set in the interrupt & reset mode (option byte LVIMDS1, LVIMDS0 = 1, 0). Do not change the initial value in other modes. - 4. LVIOMSK bit is only automatically set to "1" when the interrupt & reset mode is selected (option byte LVIMDS1, LVIMDS0 = 1, 0) and reset or interrupt by LVD is masked. - Period during LVISEN = 1 - · Waiting period from the time when LVD interrupt is generated until LVD detection voltage becomes stable - Waiting period from the time when the value of LVILV bit changes until LVD detection voltage becomes stable ## 20.3.2 Voltage detection level register (LVIS) This register selects the voltage detection level. This register can be set by a 1-bit or 8-bit memory manipulation instruction. Reset signal generation input sets this register to 00H/01H/81H Note 1. Figure 20-3. Format of Voltage Detection Level Select Register (LVIS) | Address: | FFFAAH A | After reset: 00H | H/01H/81H Note | <sup>1</sup> R/W | | | | | |----------|----------|------------------|----------------|------------------|---|---|---|-------| | Symbol | <7> | 6 | 5 | 4 | 3 | 2 | 1 | <0> | | LVIS | LVIMD | 0 | 0 | 0 | 0 | 0 | 0 | LVILV | | LVIMD Note 2 | Operation mode of voltage detection | |--------------|-------------------------------------| | 0 | Interrupt mode | | 1 | Reset mode | | LVILV Note 2 | LVD detection level | |--------------|---------------------------------------------| | 0 | High-voltage detection level (VLVDH) | | 1 | Low-voltage detection level (VLVDL or VLVD) | **Notes 1.** The reset value changes depending on the reset source and the setting of the option byte. This register is not cleared (00H) by LVD reset. The generation of reset signal other than an LVD reset sets as follows. - When option byte LVIMDS1, LVIMDS0 = 1, 0: 00H - When option byte LVIMDS1, LVIMDS0 = 1, 1: 81H - When option byte LVIMDS1, LVIMDS0 = 0, 1: 01H - 2. Writing "0" can only be allowed in the interrupt & reset mode (option byte LVIMDS1, LVIMDS0 = 1, 0). Do not set LVIMD and LVILV in other cases. The value is switched automatically when reset or interrupt is generated in the interrupt & reset mode. - Cautions 1. Rewrite the value of the LVIS register according to Figures 20-8 and 20-9. - 2. Specify the LVD operation mode and detection voltage (VLVDH, VLVDL, VLVD) of each mode by using the option byte 000C1H. Figure 20-4 shows the format of the user option byte (000C1H). For details about the option byte, see CHAPTER 23 OPTION BYTE. Figure 20-4. LVD Operation Mode and Detection Voltage Settings for User Option Byte (000C1H) (1/2) Address: 000C1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------|-------|-------|----------|-------|-------|---------|---------|--| | VPOC2 | VPOC1 | VPOC0 | PORTSELB | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 | | • LVD setting (interrupt & reset mode) | Detection voltage | | | Option byte Setting Value | | | | | | | | | | | |-------------------|--------------|--------------|---------------------------|----------------|----------------|--------|-------|--------------|---------|--|--|--|--| | VL | VLVDH VLVE | | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | Mode setting | | | | | | | Rising edge | Falling edge | Falling edge | | | | | | LVIMDS1 | LVIMDS0 | | | | | | 1.98 V | 1.94 V | 1.84 V | 0 | 0 | 1 | 1 | 0 | 1 | 0 | | | | | | 2.09 V | 2.04 V | | | | | 0 | 1 | | | | | | | | 3.13 V | 3.06 V | | | | | 0 | 0 | | | | | | | | 2.61 V | 2.55 V | 2.45 V | | 1 | 0 | 1 | 0 | | | | | | | | 2.71 V | 2.65 V | | | | | 0 | 1 | | | | | | | | 3.75 V | 3.67 V | | | | | 0 | 0 | | | | | | | | 2.92 V | 2.86 V | 2.75 V | | 1 | 1 | 1 | 0 | | | | | | | | 3.02 V | 2.96 V | | | | | 0 | 1 | | | | | | | | 4.06 V | 3.98 V | | | | | 0 | 0 | | | | | | | | | _ | | Setting of val | ues other than | above is prohi | bited. | | | | | | | | • LVD setting (reset mode) | Detection | n voltage | | | Option | n byte Setting \ | Value | | | |-------------|--------------|----------------|----------------|----------------|------------------|-------|---------|---------| | VL | .VD | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | Mode | setting | | Rising edge | Falling edge | | | | | | LVIMDS1 | LVIMDS0 | | 1.88 V | 1.84 V | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | 1.98 V | 1.94 V | | 0 | 1 | 1 | 0 | | | | 2.09 V | 2.04 V | | 0 | 1 | 0 | 1 | | | | 2.50 V | 2.45 V | | 1 | 0 | 1 | 1 | | | | 2.61 V | 2.55 V | | 1 | 0 | 1 | 0 | | | | 2.71 V | 2.65 V | | 1 | 0 | 0 | 1 | | | | 2.81 V | 2.75 V | | 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 | | | | _ | _ | Setting of val | ues other than | above is prohi | bited. | | | | Remarks 1. For details on the LVD circuit, see CHAPTER 20 VOLTAGE DETECTOR. 2. The detection voltage is a TYP. value. For details, see 28.6.4 or 29.6.4 LVD circuit characteristics. (Cautions are listed on the next page.) Figure 20-4. LVD Operation Mode and Detection Voltage Settings for User Option Byte (000C1H) (2/2) Address: 000C1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|----------|-------|-------|---------|---------| | VPOC2 | VPOC1 | VPOC0 | PORTSELB | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 | • LVD setting (interrupt mode) | Detection | n voltage | | Option byte Setting Value | | | | | | | | | | | | |-------------|--------------|----------------|---------------------------|----------------|--------|---------|---------|---------|--|--|--|--|--|--| | Vı | .VD | VPOC2 | VPOC1 | VPOC0 LVIS | | LVIS0 | Mode | setting | | | | | | | | Rising edge | Falling edge | | | | | LVIMDS1 | LVIMDS0 | | | | | | | | | 1.88 V | 1.84 V | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | | | | | | | 1.98 V | 1.94 V | | 0 | 1 | 1 | 0 | | | | | | | | | | 2.09 V | 2.04 V | | 0 | 1 | 0 | 1 | | | | | | | | | | 2.50 V | 2.45 V | | 1 | 0 | 1 | 1 | | | | | | | | | | 2.61 V | 2.55 V | | 1 | 0 | 1 | 0 | | | | | | | | | | 2.71 V | 2.65 V | | 1 | 0 | 0 | 1 | | | | | | | | | | 2.81 V | 2.75 V | | 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 | | | | | | | | | | _ | _ | Setting of val | ues other than | above is prohi | oited. | | | | | | | | | | • LVD off (use of external reset input via RESET pin) | Detection voltage | | Option byte Setting Value | | | | | | | | | | | |--------------------------|---|---------------------------|----------------|-----------------|--------|-------|---------|---------|--|--|--|--| | VLVDH | | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | Mode | setting | | | | | | Rising edge Falling edge | | | | | | | LVIMDS1 | LVIMDS0 | | | | | | | | 1 | × | × | × | × | × | 1 | | | | | | _ | _ | Setting of val | ues other than | above is prohil | oited. | | | | | | | | ## Cautions 1. Set bit 4 to 1. 2. After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 28.4 or 29.4 AC Characteristics. 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). # Remarks 1. x: don't care - 2. For details on the LVD circuit, see CHAPTER 20 VOLTAGE DETECTOR. - 3. The detection voltage is a TYP. value. For details, see 28.6.4 or 29.6.4 LVD circuit characteristics. # 20.4 Operation of Voltage Detector #### 20.4.1 When used as reset mode Specify the operation mode (the reset mode (LVIMDS1, LVIMDS0 = 1, 1)) and the detection voltage ( $V_{LVD}$ ) by using the option byte 000C1H. 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. - 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 (V<sub>DD</sub>) exceeds the voltage detection level (V<sub>LVD</sub>) after power is supplied. The internal reset is released when the supply voltage (V<sub>DD</sub>) exceeds the voltage detection level (V<sub>LVD</sub>). At the fall of the operating voltage, an internal reset by LVD is generated when the supply voltage $(V_{DD})$ falls below the voltage detection level $(V_{LVD})$ . Figure 20-5 shows the timing of the internal reset signal generated in the LVD reset mode. Figure 20-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 <R> ### 20.4.2 When used as interrupt mode Specify the operation mode (the interrupt mode (LVIMDS1, LVIMDS0 = 0, 1)) and the detection voltage ( $V_{LVD}$ ) by using the option byte 000C1H. 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)) - The initial value of the voltage detection level select register (LVIS) is set to 01H. 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 ( $V_{DD}$ ) exceeds the voltage detection level ( $V_{LVD}$ ). The internal reset is released when the supply voltage ( $V_{DD}$ ) exceeds the voltage detection level ( $V_{LVD}$ ). 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 **28.4 or 29.4 AC Characteristics**. When restarting the operation, make sure that the operation voltage has returned within the range of operation. Figure 20-6 shows the timing of the interrupt request signal generated in the LVD interrupt mode. Figure 20-6. Timing of Voltage Detector Interrupt Request Signal Generation (Option Byte LVIMDS1, LVIMDS0 = 0, 1) Notes 1. The LVIMK flag is set to "1" by reset signal generation. 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 28.4 or 29.4 AC characteristics. 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 #### 20.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. 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)) - The initial value of the voltage detection level select register (LVIS) is set to 00H. 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 (INTLVD) 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 low-voltage detection level (VLVDL). After INTLVD 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 20-8 Processing Procedure After an Interrupt Is Generated and Figure 20-9 Initial Setting of Interrupt and Reset Mode. Figure 20-7 shows the timing of the internal reset signal and interrupt request signal generated in the LVD interrupt & reset mode. If a reset is not generated after releasing the mask, determine that a condition of V<sub>DD</sub> becomes V<sub>DD</sub> $\geq$ V<sub>LVDH</sub>, clear LVIMD bit to 0, and the MCU shift to normal operation. Supply voltage (VDD) VLVDH $V_{\text{LVDL}}$ Lower limit of operation voltage Vpor = 1.51 V (TYP.) VPDR = 1.50 V (TYP.) Time LVIMK flag (set by software) H<sup>Note 1</sup> Cleared by software Cleared by Wait for stabilization by software (400 $\mu s$ or 5 clocks of fill) $^{\text{Note 3}}$ Normal operation software Normal Save Normal Operation status RESET RESET Save processing Cleared LVIF flag LVISEN flag (set by software) LVIOMSK flag LVIMD flag Cleared by software Note LVILV flag Cleared by software Note 2 LVIRF flag Cleared LVD reset signal POR reset signal Internal reset signal INTLVI LVIIF flag Figure 20-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.) - **Notes 1.** The LVIMK flag is set to "1" by reset signal generation. - 2. After an interrupt is generated, perform the processing according to Figure 20-8 Processing Procedure After an Interrupt Is Generated. - 3. After a reset is released, perform the processing according to Figure 20-9 Initial Setting of Interrupt and Reset Mode. Remark VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage When a condition of $V_{DD}$ is $V_{DD} < V_{LVIH}$ after releasing the mask, a reset is generated because of LVIMD = 1 (reset mode). Supply voltage (VDD) $V_{LVDH}$ VLVDL Lower limit of operation voltage VPOR = 1.51 V (TYP.) $V_{PDR} = 1.50 V (TYP.)$ Time LVIMK flag H Note 1 (set by software) Cleared by software Cleared by software Wait for stabilization by software (400 $\mu s$ or 5 clocks of $f_{L})$ $^{\text{Note 3}}$ Save RESET RESET Operation status RESET operation Save processing Cleared LVIF flag LVISEN flag (set by software) LVIOMSK flag LVIMD flag Cleared by software Note 3 LVILV flag Cleared by software Note 2 LVIRF flag LVD reset signal POR reset signal Internal reset signal INTLVI LVIIF flag Figure 20-7. 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.) - Notes 1. The LVIMK flag is set to "1" by reset signal generation. - After an interrupt is generated, perform the processing according to Figure 20-8 Processing Procedure After an Interrupt Is Generated in interrupt and reset mode. - 3. After a reset is released, perform the processing according to Figure 20-9 Initial Setting of Interrupt and Reset Mode in interrupt and reset mode. **Remark** VPOR: POR power supply rise detection voltage VPDR: POR power supply fall detection voltage Figure 20-8. Processing Procedure After an Interrupt Is Generated When setting an interrupt and reset mode (LVIMDS1, LVIMDS0 = 1, 0), voltage detection stabilization wait time for 400 $\mu$ s or 5 clocks of fill is necessary after LVD reset is released (LVIRF = 1). After waiting until voltage detection stabilizes, (0) clear the LVIMD bit for initialization. While voltage detection stabilization wait time is being counted and when the LVIMD bit is rewritten, set LVISEN to 1 to mask a reset or interrupt generation by LVD. Figure 20-9. shows the procedure for initial setting of interrupt and reset mode. Figure 20-9 Initial Setting of Interrupt and Reset Mode Remark fil: Low-speed on-chip oscillator clock frequency # 20.5 Cautions for Voltage Detector # (1) Voltage fluctuation when power is supplied In a system where the supply voltage (V<sub>DD</sub>) 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 microcontroller 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 20-10. 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** n = 0 to 3 (20- and 24-pin products) n = 0 to 7 (30-pin products) ## (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 $(V_{DD}) < LVD$ detection voltage $(V_{LVD})$ until the time LVD reset has been generated. In the same way, there is also some delay from the time LVD detection voltage $(V_{LVD}) \le supply$ voltage $(V_{DD})$ until the time LVD reset has been released (see **Figure 20-11**). Supply voltage (Voo) VLVD Time Figure 20-11. Delay from the time LVD reset source is generated until the time LVD reset has been generated or released <1>: Detection delay (300 $\mu$ s (MAX.)) ### (3) Power on when LVD is off Use the external rest input via the RESET pin when the LVD is off. For an external reset, input a low level for 10 $\mu$ s or more to the $\overline{RESET}$ pin. To perform an external reset upon power application, input a low level to the $\overline{RESET}$ 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 **28.4** or **29.4 AC Characteristics**, 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 **28.4** or **29.4** AC characteristics. When restarting the operation, make sure that the operation voltage has returned within the range of operation. ### **CHAPTER 21 SAFETY FUNCTIONS** ## 21.1 Overview of Safety Functions The following safety functions are provided in the RL78/G12 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 This detects data errors in the flash memory by performing CRC operations. This can be used for checking various data in addition to the code flash memory area while the CPU is running. This function is available in the R5F102 products. ### (2) RAM parity error detection function This detects parity errors when reading RAM is read. ## (3) RAM guard function This prevents RAM data from being rewritten when the CPU freezes. This function is available in the R5F102 products. #### (4) SFR guard function This prevents SFRs from being rewritten when the CPU freezes. This function is available in the R5F102 products. #### (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 function allows a self-check of the CPU/peripheral hardware clock frequencies using the timer array unit. #### (7) A/D test function This is used to perform a self-check of the A/D converter by performing A/D conversion of the A/D converter's positive and negative reference voltages, analog input channel (ANI), temperature sensor output voltage, and internal reference voltage. **Remark** For usage examples of the safety functions complying with the IEC60730 safety standards, refer to the RL78 MCU series IEC60730/60335 application notes (R01AN0749). ## 21.2 Registers Used by Safety Functions The safety functions use the following registers for each function. | Register | Each Function of Safety Function | |-----------------------------------------------------------|------------------------------------------| | CRC input register (CRCIN) Note | CRC operation function | | CRC data register (CRCD) Note | (general-purpose CRC) | | 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 | Note Only in the R5F102 products. # 21.3 Operation of Safety Functions # 21.3.1 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 the RL78/G12, 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). CRC calculation function in the HALT mode can be used only during the DMA transmission The CRC generator polynomial used is "X16 + X12 + X5 + 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. # 21.3.1.1 CRC input register (CRCIN) CRCIN register is an 8-bit register that is used to set the CRC operation data. 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 21-1. Format of CRC Input Register (CRCIN) ## 21.3.1.2 CRC data register (CRCD) This register is used to store the CRC operation result. The 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 21-2. Format of CRC Data Register (CRCD) | Address: F02FAH | | After reset: 0000H | | | R/W | | | | | | | | | | | | | |-----------------|----|--------------------|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|--| | Symbol | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CRCD | | | | | | | | | | | | | | | | | | Cautions 1. Read the value written to CRCD register before writing to CRCIN register. 2. If conflict between writing and storing operation result to CRCD register occurs, the writing is ignored. # <Operation flow> Figure 21-3. CRC Operation Function (General-Purpose CRC) # 21.3.2 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 the RL78/G12'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. ### 21.3.2.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 21-4. Format of RAM Parity Error Control Register (RPECTL) | Address: Fo | 00F5H After | reset: 00H R | /W | | | | | | |-------------|-------------|--------------|----|---|---|---|---|------| | Symbol | <7> | 6 | 5 | 4 | 3 | 2 | 1 | <0> | | RPECTL | RPERDIS | 0 | 0 | 0 | 0 | 0 | 0 | RPEF | | RPERDIS | Parity error reset mask flag | |---------|------------------------------| | 0 | Enable parity error resets. | | 1 | Disable parity error resets. | | RPEF | Parity 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. The RL78'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. ### **Remarks 1.** The parity error reset is enabled by default (RPERDIS = 0). - 2. Even if the parity error reset is disabled (RPERDIS = 1), the RPEF flag will be set (1) if a parity error occurs. If parity error resets are enabled (RPERDIS = 0) with RPEF set to 1, a parity error reset is generated when the RPERDIS bit is cleared to 0. - 3. The RPEF flag in the RPECTL register is set (1) when the RAM parity error occurs 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. - 4. The general registers are not included for RAM parity error detection. Figure 21-5. Flowchart of RAM Parity Check Note To check internal reset status using a RAM parity error, see CHAPTER 18 RESET FUNCTION. ### 21.3.3 RAM guard function 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. # 21.3.3.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. Figure 21-6. Format of Invalid Memory Access Detection Control Register (IAWCTL) | Address: Fo | 0078H After i | reset: 00H R | /W | | | | | | |-------------|---------------|--------------|-------|-------|---|-------|------|------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | IAWCTL | IAWEN | 0 | GRAM1 | GRAM0 | 0 | GPORT | GINT | GCSC | | GRAM1 | GRAM0 | RAM guard space Note | |-------|-------|-------------------------------------------------------------------------------------------------| | 0 | 0 | Disabled. RAM can be written to. | | 0 | 1 | The 128 bytes starting at the beginning RAM address | | 1 | 0 | The 256 bytes starting at the beginning RAM address | | 1 | 1 | The 512 bytes starting at the beginning RAM address (setting prohibited for R5F10266, R5F10366) | **Note** The RAM start address differs depending on the size of the RAM provided with the product (refer to **Figure 21-8**). Furthermore, the general-purpose register area (FFEE0H to FFEFFH) is not guarded. ### 21.3.4 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. # 21.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. 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 21-7. Format of Invalid Memory Access Detection Control Register (IAWCTL) | Address: Fo | 0078H After i | reset: 00H 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. | | | [Guarded SFR] PMxx, PUxx, PIMxx, POMxx, PMCxx, ADPC, PIOR Note | | GINT | Registers of interrupt function guard | |------|--------------------------------------------------------------------------------------| | 0 | Disabled. Registers of interrupt function can be read or written to. | | 1 | Enabled. Writing to registers of interrupt function is disabled. Reading is enabled. | | | [Guarded SFR] IFxx, MKxx, PRxx, EGPx, EGNx | | GCSC | 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. | | | [Guarded SFR] CMC, CSC, OSTS, CKC, PERx, OSMC, LVIM, LVIS, RPECTL | Note Pxx (Port register) is not guarded. ### 21.3.5 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 21-8. Possibility access Fetching instructions (execute) Read Write FFFFFH Special function register (SFR) 256 byte NG FFF00H General-purpose register 32 byte FFEFFHOK FFEE0H FFEDFH RAM<sup>Note</sup> OK уууууН Reserved F4000H F3FFFH Mirror ΟK F2000H F1FFFH NG NG Reserved F1800H F17FFH Data flash memory F1000H F0FFFH Reserved OK F0800H F07FFH OK Special function register (2nd SFR) NG 2 Kbyte F0000H EFFFFH OK EF000H EEFFFH NG NG NG Reserved 10000H 0FFFFH хххххН OK OK Code flash memory<sup>Note</sup> 00000H Figure 21-8. Invalid access detection area Note Code flash memory and RAM address of each product are as follows. | | · | | |------------------------------|----------------------------------|---------------------------------| | Products $(x = 2, 3)$ | Code flash memory | RAM | | | (00000H to xxxxxH) | (yyyyyH to FFEFFH) | | R5F10x66 | 2048 × 8 bit (00000H to 007FFH) | 256 × 8 bit (FFE00H to FFEFFH) | | R5F10x67, R5F10x77, R5F10xA7 | 4096 × 8 bit (00000H to 00FFFH) | 512 × 8 bit (FFD00H to FFEFFH) | | R5F10x68, R5F10x78, R5F10xA8 | 8192 × 8 bit (00000H to 01FFFH) | 768 × 8 bit (FFC00H to FFEFFH) | | R5F10x69, R5F10x79, R5F10xA9 | 12288 × 8 bit (00000H to 02FFFH) | 1024 × 8 bit (FFB00H to FFEFFH) | | R5F10x6A, R5F10x7A | 16384 × 8 bit (00000H to 03FFFH) | 1536 × 8 bit (FF900H to FFEFFH) | | R5F10xAA | | 2048 × 8 bit (FF700H to FFEFFH) | ### 21.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. 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 21-9. Format of Invalid Memory Access Detection Control Register (IAWCTL) | Address: Fo | 0078H After i | reset: 00H R | W | | | | | | |-------------|---------------|--------------|-------|-------|---|-------|------|------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | IAWCTL | IAWEN | 0 | GRAM1 | GRAM0 | 0 | GPORT | GINT | GCSC | | IAWEN Note | Control of invalid memory access detection | | | | | | |------------|------------------------------------------------|--|--|--|--|--| | 0 | isable 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 (watchdog timer operation enable) for the option byte (000C0H), the invalid memory access detection function is enabled even IAWEN = 0. #### 21.3.6 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 (20- and 24-pin products) or channel 5 (30-pin products) 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. Caution The following description is applicable in the case of the channel configuration in the 20- and 24-pin products. ### <Clocks to be compared> <1> CPU/peripheral hardware clock frequency (fclk): - High-speed on-chip oscillator clock (fiн) - High-speed system clock (fmx) <2> Input to channel 1 of the timer array unit: - Timer input to channel 1 (TI01) - Low-speed on-chip oscillator clock (fil: 15 kHz (typ.)) Figure 21-10. Configuration of Frequency Detection Function If input pulse interval measurement results in an abnormal value, it can be concluded that the clock frequency is abnormal. For how to execute input pulse interval measurement, see 6.8.4 Operation as input pulse interval measurement. # 21.3.6.1 Timer input select register 0 (TIS0) This register is used to select the timer input of channel 1 of the timer array unit 0 (TAU0) in 20- and 24-pin products. The TIS0 register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 21-11. Format of Timer Input Select Register 0 (TIS0) | Address: F0074H Afte | | After reset: 00H | R/W | | | | | | |----------------------|---|------------------|-----|---|---|---|-------|-------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TIS0 | 0 | 0 | 0 | 0 | 0 | 0 | TIS01 | TIS00 | | TIS01 | TIS00 | Selection of timer input used with channel 1 | | | | |-------|-------|----------------------------------------------|--|--|--| | × | 0 | nput signal of timer input pin (TI01) | | | | | 0 | 1 | Low-speed on-chip oscillator clock (f⊩) | | | | | 1 | 1 | Setting prohibited | | | | Remark x: don't care #### 21.3.7 A/D test function The IEC60730 standard mandates testing the A/D converter. The A/D test function checks whether or not the A/D converter is operating normally by executing A/D conversions of the A/D converter's positive and negative reference voltages, analog input channel (ANI), temperature sensor output voltage, and the internal reference voltage. For details of the check method, see the safety function (A/D test) application note (R01AN0955). The analog multiplexer can be checked using the following procedure. - <1> Select the ANIx pin for A/D conversion using the ADTES register (ADTES1 = 0, ADTES0 = 0). - <2> Perform A/D conversion for the ANIx pin (conversion result 1-1). - <3> Select the A/D converter's negative reference voltage for A/D conversion using the ADTES register (ADTES1 = 1, ADTES0 = 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 for A/D conversion using the ADTES register (ADTES1 = 0, ADTES0 = 0). - <6> Perform A/D conversion for the ANIx pin (conversion result 1-2). - <7> Select the A/D converter's positive reference voltage for A/D conversion using the ADTES register (ADTES1 = 1, ADTES0 = 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 for A/D conversion using the ADTES register (ADTES1 = 0, ADTES0 = 0). - <10> Perform A/D conversion for the ANIx pin (conversion result 1-3). - <11> Check that the conversion results 1-1, 1-2, and 1-3 are equal. - <12> Check that the A/D conversion result 2-1 is all zero and conversion result 2-2 is all one. Using the procedure above can confirm that the analog multiplexer is selected and all wiring is connected. - **Remarks 1.** If the analog input voltage is variable during A/D conversion in steps <1> to <10> above, use another method to check the analog multiplexer. - 2. The conversion results might contain an error. Consider an appropriate level of error when comparing the conversion results. Figure 21-12. Configuration of A/D Test Function **Note** This setting can be used only in HS (high-speed main) mode. # 21.3.7.1 A/D test register (ADTES) This register is used to select the A/D converter's positive reference voltage, A/D converter's negative reference voltage, analog input channel (ANIxx), temperature sensor output voltage, or internal reference voltage (1.45 V) as the target of A/D conversion. When using the A/D test function, specify the following settings: - Select negative reference voltage as the target of A/D conversion for zero-scale measurement. - Select positive reference voltage as the target of A/D conversion for full-scale measurement. The ADTES register can be set by an 8-bit memory manipulation instruction. Reset signal generation clears this register to 00H. Figure 21-13. Format of A/D Test Register (ADTES) | Address: F0013H | | After reset: 00H | R/W | | | | | | |-----------------|---|------------------|-----|---|---|---|--------|--------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADTES | 0 | 0 | 0 | 0 | 0 | 0 | ADTES1 | ADTES0 | | ADTES1 | ADTES0 | A/D conversion target | |------------|-----------|--------------------------------------------------------------------------------------------| | 0 | 0 | ANIxx / temperature sensor output Note / internal reference voltage (1.45 V) Note (This is | | | | specified using the analog input channel specification register (ADS).) | | 1 | 0 | Negative reference voltage (selected with the ADREFM bit in ADM2) | | 1 | 1 | Positive reference voltage (selected with the ADREFP1 or ADREFP0 bit in ADM2) | | Other than | the above | Setting prohibited | **Note** Temperature sensor output voltage and internal reference voltage (1.45 V) can be used only in HS (high-speed main) mode. # 21.3.7.2 Analog input channel specification register (ADS) This register specifies the input channel of the analog voltage to be A/D converted. Set A/D test register (ADTES) to 00H when measuring the ANIxx/temperature sensor output voltage/internal reference voltage (1.45 V). 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 21-14. Format of Analog Input Channel Specification Register (ADS) (1/2) Address: FFF31H After reset: 00H R/W Symbol 6 5 4 3 2 0 1 ADS **ADISS** 0 0 ADS4 ADS3 ADS2 ADS1 ADS0 O Select mode (ADMD = 0) (20- and 24-pin products) | ADISS | ADS4 | ADS3 | ADS2 | ADS1 | ADS0 | Analog input channel | Input source | |-------|------|------------|-----------|----------------|------|----------------------|-------------------------------------------------| | 0 | 0 | 0 | 0 | 0 | 0 | ANI0 | P20/ANI0/AVREFP pin | | 0 | 0 | 0 | 0 | 0 | 1 | ANI1 | P21/ANI1/AV <sub>REFM</sub> pin | | 0 | 0 | 0 | 0 | 1 | 0 | ANI2 | P22/ANI2 pin | | 0 | 0 | 0 | 0 | 1 | 1 | ANI3 | P23/ANI3 pin | | 0 | 1 | 0 | 0 | 0 | 0 | ANI16 | P10/ANI16 pin | | 0 | 1 | 0 | 0 | 0 | 1 | ANI17 | P11/ANI17 pin | | 0 | 1 | 0 | 0 | 1 | 0 | ANI18 | P12/ANI18 pin | | 0 | 1 | 0 | 0 | 1 | 1 | ANI19 | P13/ANI19 pin | | 0 | 1 | 0 | 1 | 0 | 0 | ANI20 | P14/ANI20 pin | | 0 | 1 | 0 | 1 | 0 | 1 | ANI21 | P42/ANI21 pin | | 0 | 1 | 0 | 1 | 1 | 0 | ANI22 | P41/ANI22 pin | | 1 | 0 | 0 | 0 | 0 | 0 | _ | Temperature sensor output Note | | 1 | 0 | 0 | 0 | 0 | 1 | _ | Internal reference voltage output (1.45 V) Note | | | • | Other than | the above | Setting prohib | ited | | | Note This setting can be used only in HS (high-speed main) mode. O Select mode (ADMD = 0) (30-pin products) | ADISS | ADS4 | ADS3 | ADS2 | ADS1 | ADS0 | Analog input 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 | 1 | 0 | 0 | 0 | 0 | ANI16 | P01/ANI16 pin | | 0 | 1 | 0 | 0 | 0 | 1 | ANI17 | P00/ANI17 pin | | 0 | 1 | 0 | 0 | 1 | 0 | ANI18 | P147/ANI18 pin | | 0 | 1 | 0 | 0 | 1 | 1 | ANI19 | P120/ANI19 pin | | 1 | 0 | 0 | 0 | 0 | 0 | _ | Temperature sensor output Note | | 1 | 0 | 0 | 0 | 0 | 1 | _ | Internal reference voltage output (1.45 V) Note | | | | Other than | the above | Setting prohib | ited | | | Note This setting can be used only in HS (high-speed main) mode. - Cautions 1. Be sure to clear bits 5 and 6 to 0. - 2. Select input mode for the ports which are set to analog input with the ADPC and PMC registers, using the port mode registers 0, 1, 2, 4, 12, and 14 (PM0, PM1, PM2, PM4, PM12, and PM14). - **3.** Do not use the ADS register to set the pins which should be set as digital I/O with the A/D port configuration register (ADPC). - **4.** Do not use the ADS register to set the pins which should be set as digital I/O with the port mode control registers 0, 1, 4, 12, and 14 (PMC0, PMC1, PMC4, PMC12, and PMC14). - **5.** Only rewrite the value of the ADISS bit while conversion operation is stopped (ADCS = 0, ADCE = 0). - **6.** If using AV<sub>REFP</sub> as the positive reference voltage source of the A/D converter, do not select ANIO as an A/D conversion channel. - 7. If using AVREFM as the negative reference voltage source of the A/D converter, do not select ANI1 as an A/D conversion channel. - 8. When ADISS is 1, the internal reference voltage (1.45 V) cannot be used for the positive reference voltage. In addition, the first conversion result obtained after setting ADISS to 1 is not available. For detailed setting flow, see 10.7.4 Setup when temperature sensor output voltage/internal reference voltage is selected. - 9. If a transition is made to STOP mode, do not set ADISS to 1. When ADISS is 1, the A/D converter reference voltage current (IADREF) shown in 28.3.2 Supply current characteristics is added. ### **CHAPTER 22 REGULATOR** # 22.1 Overview of Regulators The 30-pin product of the RL78/G12 incorporates the circuit for constant voltage operation in the device. To stabilize the regulator output, connect the REGC pin to Vss via a capacitor (0.47 to 1 $\mu$ F) for regulator stabilization. Use a capacitor with good characteristics because it is used for stabilization of 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 22-1. **Table 22-1. Regulator Output Voltage Conditions** | Mode | Output<br>voltage | Condition | |--------------------------|-------------------|-----------------------------------------------------| | LS (low-speed main) mode | 1.8 V | _ | | HS (high-speed | 1.8 V | In the STOP mode | | main) mode | 2.1 V | Other than STOP mode (include during OCD mode) Note | **Note** When shifting to the STOP mode during on-chip debugging, the regulator output voltage is kept at 2.1 V (not decline to 1.8 V). #### **CHAPTER 23 OPTION BYTE** # 23.1 Functions of Option Bytes Addresses 000C0H to 000C3H of the flash memory of the RL78/G12 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. Caution The option bytes should always be set regardless of whether each function is used. #### 23.1.1 User option byte (000C0H to 000C2H) #### (1) 000C0H - O Operation of watchdog timer - Enabling or disabling of counter operation - · Enabling or disabling of counter operation in the HALT or STOP mode - O Setting of overflow time of watchdog timer - O Setting of window open period of watchdog timer - O Setting of interval interrupt of watchdog timer - Whether or not to use the interval interrupt is selectable. # (2) 000C1H - O Setting of LVD operation mode - Interrupt & reset mode - Reset mode - · Interrupt mode - LVD off (by controlling the externally input reset signal on the RESET pin) - O Setting of LVD detection level (VLVDH, VLVDL, VLVD) - O Controlling of P125/RESET pin - P125/KR1/SI01 or RESET Caution After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 28.4 or 29.4 AC Characteristics. 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). # (3) 000C2H <R> O Setting of flash operation mode Make the setting depending on the main system clock frequency ( $f_{MAIN}$ ) and power supply voltage ( $V_{DD}$ ) to be used. - LS (low speed main) mode - HS (high speed main) mode - O Setting of the frequency of the high-speed on-chip oscillator - Select from 24 MHz/16 MHz/12 MHz/8 MHz/6 MHz/4 MHz /3 MHz/2 MHz/1 MHz (TYP.). # 23.1.2 On-chip debug option byte (000C3H) - O Control of on-chip debug operation - On-chip debug operation is disabled or enabled. - O 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. # 23.2 Format of User Option Byte The format of user option byte is shown below. Figure 23-1. Format of User Option Byte (000C0H) Address: 000C0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|-------|-------|-------|-------|----------| | WDTINIT | WINDOW1 | WINDOW0 | WDTON | WDCS2 | WDCS1 | WDCS0 | WDSTBYON | | WDTINIT | Use of interval interrupt of watchdog timer | | | | |---------|------------------------------------------------------------------------------------|--|--|--| | 0 | Interval interrupt is not used. | | | | | 1 | Interval interrupt is generated when 75% + 1/2 f⊾ of the overflow time is reached. | | | | | WINDOW1 | WINDOW0 | Watchdog timer window open period <sup>Note</sup> | |---------|---------|---------------------------------------------------| | 0 | 0 | Setting prohibited | | 0 | 1 | 50% | | 1 | 0 | 75% | | 1 | 1 | 100% | | WDTON | Operation control of watchdog timer counter | | | | |-------|-----------------------------------------------------------|--|--|--| | 0 | Counter operation disabled (counting stopped after reset) | | | | | 1 | Counter operation enabled (counting started after reset) | | | | | WDCS2 | WDCS1 | WDCS0 | Watchdog timer overflow time | |-------|-------|-------|---------------------------------------------| | | | | (fil = 17.25 kHz (MAX.)) | | 0 | 0 | 0 | 2 <sup>6</sup> /f <sub>IL</sub> (3.71 ms) | | 0 | 0 | 1 | 2 <sup>7</sup> /f <sub>L</sub> (7.42 ms) | | 0 | 1 | 0 | 2 <sup>8</sup> /f <sub>IL</sub> (14.84 ms) | | 0 | 1 | 1 | 2 <sup>9</sup> /f <sub>I</sub> ∟ (29.68 ms) | | 1 | 0 | 0 | 2 <sup>11</sup> /fiL (118.72 ms) | | 1 | 0 | 1 | 2 <sup>13</sup> /fi∟ (474.89 ms) | | 1 | 1 | 0 | 2¹⁴/fi∟ (949.79 ms) | | 1 | 1 | 1 | 2 <sup>16</sup> /fi∟ (3799.18 ms) | | WDSTBYON | Operation control of watchdog timer counter (HALT/STOP mode) | |----------|--------------------------------------------------------------| | 0 | Counter operation stopped in HALT/STOP mode <sup>Note</sup> | | 1 | Counter operation enabled in HALT/STOP mode | **Note** The window open period is 100% when WDSTBYON = 0, regardless the value of the WINDOW1 and WINDOW0 bits. Remark fil: Low-speed on-chip oscillator clock frequency Figure 23-2. Format of User Option Byte (000C1H) (1/2) Address: 000C1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|------------------|-------|-------|---------|---------| | VPOC2 | VPOC1 | VPOC0 | PORTSELB<br>Note | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 | • LVD setting (interrupt mode & reset mode) | | ection volt | | Option byte setting value | | | | | | | | |-------------|-----------------|-----------------|---------------------------|----------------|-----------------|--------|-------|---------|---------|--| | VL | VDH | VLVDL | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | Mode | setting | | | Rising edge | Falling<br>edge | Falling<br>edge | | | | | | LVIMDS1 | LVIMDS0 | | | 1.98 V | 1.94 V | 1.84 V | 0 | 0 | 1 | 1 | 0 | 1 | 0 | | | 2.09 V | 2.04 V | | | | | 0 | 1 | | | | | 3.13 V | 3.06 V | | | | | 0 | 0 | | | | | 2.61 V | 2.55 V | 2.45 V | | 1 | 0 | 1 | 0 | | | | | 2.71 V | 2.65 V | | | | | 0 | 1 | | | | | 3.75 V | 3.67 V | | | | | 0 | 0 | | | | | 2.92 V | 2.86 V | 2.75 V | | 1 | 1 | 1 | 0 | | | | | 3.02 V | 2.96 V | | | | | 0 | 1 | | | | | 4.06 V | 3.98 V | | | | | 0 | 0 | | | | | | _ | | Setting of val | ues other than | above is prohil | oited. | · | | · | | • LVD setting (reset mode) | Detection | n voltage | Option byte setting value | | | | | | | | | | |-------------|------------------|---------------------------|----------------|----------------|--------|-------|---------|---------|--|--|--| | Vı | V <sub>LVD</sub> | | VPOC1 | VPOC0 | LVIS1 | LVIS0 | Mode | setting | | | | | Rising edge | Falling edge | | | | | | LVIMDS1 | LVIMDS0 | | | | | 1.88 V | 1.84 V | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | | | | 1.98 V | 1.94 V | | 0 | 1 | 1 | 0 | | | | | | | 2.09 V | 2.04 V | | 0 | 1 | 0 | 1 | | | | | | | 2.50 V | 2.45 V | | 1 | 0 | 1 | 1 | | | | | | | 2.61 V | 2.55 V | | 1 | 0 | 1 | 0 | | | | | | | 2.71 V | 2.65 V | | 1 | 0 | 0 | 1 | | | | | | | 2.81 V | 2.75 V | | 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 | | | | | | | _ | _ | Setting of val | ues other than | above is prohi | bited. | | | | | | | Note 20- and 24-pin products only Figure 23-2. Format of User Option Byte (000C1H) (2/2) Address: 000C1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|------------------|-------|-------|---------|---------| | VPOC2 | VPOC1 | VPOC0 | PORTSELB<br>Note | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 | • LVD setting (interrupt mode) | | n voltage | , | Option byte setting value | | | | | | | |-------------|--------------|----------------|---------------------------|----------------|--------|-------|---------|---------|--| | Vı | .VD | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | Mode | setting | | | Rising edge | Falling edge | | | | | | LVIMDS1 | LVIMDS0 | | | 1.88 V | 1.84 V | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | | 1.98 V | 1.94 V | | 0 | 1 | 1 | 0 | | | | | 2.09 V | 2.04 V | | 0 | 1 | 0 | 1 | | | | | 2.50 V | 2.45 V | | 1 | 0 | 1 | 1 | | | | | 2.61 V | 2.55 V | | 1 | 0 | 1 | 0 | | | | | 2.71 V | 2.65 V | | 1 | 0 | 0 | 1 | | | | | 2.81 V | 2.75 V | | 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 | | | | | _ | _ | Setting of val | ues other than | above is prohi | bited. | | | | | • LVD off (by controlling the externally input reset signal on the RESET pin) | Detection | n voltage | Option byte setting value | | | | | | | |-------------|--------------|---------------------------|----------------|-----------------|--------|-------|--------------|---------| | Vı | _VD | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | Mode setting | | | Rising edge | Falling edge | | | | | | LVIMDS1 | LVIMDS0 | | _ | - | 1 | × | × | × | × | × | 1 | | _ | _ | | ues other than | above is prohil | oited. | | | | • Setting of the P125/KR1/SI01/RESET Pin (20-, 24-pin products) | PORTSELB | P125/RESET pin control | |----------|----------------------------------------------------------------| | 0 | Port function (P125/KR1/SI01) | | 1 | RESET input (The internal pull-up resistor is always enabled.) | Note 20- and 24-pin products only Cautions 1. In the 30-pin products, be sure to set bit 4 (PORTSELB) to 1. 2. After power is supplied, the reset state must be retained until the operating voltage becomes in the range defined in 28.4 or 29.4 AC Characteristics. 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). Remarks 1. x: don't care - 2. For details on the LVD circuit, see CHAPTER 20 VOLTAGE DETECTOR. - 3. The detection voltage is a typical value. For details, see 28.6.4 or 29.6.4 LVD circuit characteristics. Figure 23-3. Format of Option Byte (000C2H) Address: 000C2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---|---|---------|---------|---------|---------| | CMODE1 | CMODE0 | 1 | 0 | FRQSEL3 | FRQSEL2 | FRQSEL1 | FRQSEL0 | | CMODE1 | CMODE0 | Setting of flash operation mode | | | | | | | |----------|----------|---------------------------------|-----------------------------------|----------------------------------|--|--|--|--| | | | | Operating Frequency Range (fmain) | Operating Voltage<br>Range (VDD) | | | | | | 1 | 0 | LS (low speed main) mode | 1 to 8 MHz | 1.8 to 5.5 V | | | | | | 1 | 1 | HS (high speed main) mode | 1 to 16 MHz | 2.4 to 5.5 V | | | | | | | | | 1 to 24 MHz | 2.7 to 5.5 V | | | | | | Other th | an above | Setting prohibited | | | | | | | | FRQSEL3 | FRQSEL2 | FRQSEL1 | FRQSEL0 | Frequency of the high-speed on-chip oscillator | |---------|------------------|---------|---------|------------------------------------------------| | 0 | 0 | 0 | 0 | 24 MHz | | 1 | 0 | 0 | 1 | 16 MHz | | 0 | 0 | 0 | 1 | 12 MHz | | 1 | 0 | 1 | 0 | 8 MHz | | 0 | 0 | 1 | 0 | 6 MHz | | 1 | 0 | 1 | 1 | 4 MHz | | 0 | 0 | 1 | 1 | 3 MHz | | 1 | 1 | 0 | 0 | 2 MHz | | 1 | 1 | 0 | 1 | 1 MHz | | | Other than above | | | Setting prohibited | Cautions 1. Be sure to set bit 5 to "1" and bit 4 to "0" **2.** The ranges of operation frequency and operation voltage vary depending on the flash operation mode. For details, see 28.4 or 29.4 AC Characteristics. # 23.3 Format of On-chip Debug Option Byte The format of on-chip debug option byte is shown below. Figure 23-4. Format of On-chip Debug Option Byte (000C3H) Address: 000C3H | 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. | | | | | | | Erases data of flash memory in case of failures in authenticating on-chip debug | | | | | | | security ID. | | | | | 1 | 1 | Enables on-chip debugging. | | | | | | | Does not erases data of flash memory in case of failures in authenticating on-chip | | | | | | | debug security ID. | | | | 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. # 23.4 Setting of Option Byte The user option byte and on-chip debug option byte can be set using the link option, in addition to describing to 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_BYT | E | |-----|------|---------|-----------------------------------------------------------------------| | | 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 29/fil, | | | | | ; Stops watchdog timer operation during HALT/STOP mode | | | DB | 2AH | ; Select 1.84 V for VLVDL | | | | | ; Select 1.94 V for VLVDH | | | | | ; Select the interrupt & reset mode as the LVD operation mode | | | | | ; Do not use reset input | | | DB | ADH | ; Select the LS (low-speed main) mode as the flash operation mode | | | | | and 1 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. ### **CHAPTER 24 FLASH MEMORY** The RL78 microcontroller incorporates the flash memory to which a program can be written, erased, and overwritten. The flash memory includes the "code flash memory", in which programs can be executed, and the "data flash memory", an area for storing data. Note This area is reserved in the R5F103 products. 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 24.4) 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 (UART communication) (see 24.2) Data can be written to the flash memory on-board through UART communication with an external device (microcontroller or ASIC). - Self-programming (see 24.6) The user application can execute self-programming of the code flash memory by using the flash self-programming library. Note The self-programming function is not available in R5F10266 and R5F10366. 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 **24.8 Data Flash**. # 24.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 the RL78 microcontroller. - PG-FP5, FL-PR5 - E1 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 the RL78 microcontroller 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 (FA series) before the RL78 microcontroller is mounted on the target system. Remark FL-PR5 and FA series are products of Naito Densei Machida Mfg. Co., Ltd. Table 24-1. Wiring Between RL78/G12 and Dedicated Flash Memory Programmer | Pin Configuration of Dedicated Flash Memory Programmer | | | | | Pin No. | | | |--------------------------------------------------------|--------------------------------------------------------|------------------|---------------------------------------------------------|----------------------|---------|-----------------|--------| | Pili Colli | Fin Configuration of Dedicated Flash Memory Programmer | | | | | | 30-pin | | Signal | Name | | | Pin<br>Name | | MOEN | | | PG-FP5, FL-PR5 | E1 on-chip debugging emulator | I/O Pin Function | | | SSOP | WQFN<br>(4 × 4) | SSOP | | _ | TOOL0 | I/O | Transmit/receive signal | TOOL0/ | 4 | 24 | 5 | | SI/RxD | _ | I/O | Transmit/receive signal | | | | | | = | RESET | Output | out Reset signal | | 5 | 1 | 6 | | /RESET | _ | Output | | | | | | | V <sub>DD</sub> | | I/O | V <sub>DD</sub> voltage generation/<br>power monitoring | V <sub>DD</sub> | 10 | 6 | 12 | | GND | | - | Ground | Vss | 9 | 5 | 11 | | | | | | REGC <sup>Note</sup> | - | İ | 10 | | FLMD1 | EMV <sub>DD</sub> | _ | Driving power for TOOL pin | V <sub>DD</sub> | 10 | 6 | 12 | **Note** Connect REGC pin to ground via a capacitor (0.47 to 1 $\mu$ F). **Remark** Pins that are not indicated in the above table can be left open when using the flash memory programmer for flash programming. ### 24.1.1 Programming environment The environment required for writing a program to the flash memory of the RL78 microcontroller is illustrated below. Figure 24-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 the RL78 microcontroller, the TOOL0 pin is used for manipulation such as writing and erasing via a dedicated single-line UART. #### 24.1.2 Communication mode Communication between the dedicated flash memory programmer and the RL78 microcontroller is established by serial communication using the TOOL0 pin via a dedicated single-line UART of the RL78 microcontroller. Transfer rate: 1 M, 500k, 250 k, 115.2 kbps Figure 24-2. Communication with Dedicated Flash Memory Programmer - Notes 1. When using E1 on-chip debugging emulator. - 2. When using PG-FP5 or FL-PR5. - 3. Connect the REGC pin to ground via a capacitor (0.47 to 1 $\mu$ F) (30-pin products only). The dedicated flash memory programmer generates the following signals for the RL78 microcontroller. See the manual of PG-FP5, FL-PR5, or E1 on-chip debugging emulator for details. Table 24-2. Pin Connection | | RL78 Microcontroller | | | | |-------------------|-------------------------------------------------------------------------|--------|-----------------------------|-----------------| | Signal | Name | I/O | Pin Function | Pin Name | | PG-FP5,<br>FL-PR5 | E1 on-chip<br>debugging<br>emulator | | | | | V | V <sub>DD</sub> I/O V <sub>DD</sub> voltage generation/power monitoring | | | V <sub>DD</sub> | | GI | GND – | | Ground | Vss, REGC Note | | FLMD1 | EMV <sub>DD</sub> | _ | Driving power for TOOL0 pin | V <sub>DD</sub> | | /RESET | П | Output | Reset signal | RESET | | - | RESET | Output | | | | _ | TOOL0 | I/O | Transmit/receive signal | TOOL0 | | SI/RxD | _ | I/O | Transmit/receive signal | | **Note** Connect REGC pin to ground via a capacitor (0.47 to 1 $\mu$ F) (30-pin products only). Caution Pins to be connected differ with the product. For details, see Table 24-1. ### 24.2 Serial Programming Using External Device (that Incorporates UART) On-board data writing to the internal flash memory is possible by using the RL78 microcontroller 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). ## 24.2.1 Programming environment The environment required for writing a program to the flash memory of the RL78 microcontroller is illustrated below. Figure 24-3. Environment for Writing Program to Flash Memory Processing to write data to or delete data from the RL78 microcontroller by using an external device is performed onboard. Off-board writing is not possible. #### 24.2.2 Communication mode Communication between the external device and the RL78 microcontroller is established by serial communication using the TOOLTxD and TOOLRxD pins via the dedicated UART of the RL78 microcontroller. Transfer rate: 1 M, 500 k, 250 k, 115.2 kbps Figure 24-4. Communication with External Device **Note** Connect the REGC pin to ground via a capacitor (0.47 to 1 $\mu$ F) (30-pin products only). The external device generates the following signals for the RL78 microcontroller. Table 24-3. Pin Connection | | 1 | RL78 Microcontroller | | |-----------------|--------|-----------------------------------------------------|-----------------| | Signal Name | I/O | Pin Function | Pin Name | | V <sub>DD</sub> | I/O | V <sub>DD</sub> voltage generation/power monitoring | V <sub>DD</sub> | | GND | - | Ground | Vss, REGC Note | | RESETOUT | Output | Reset signal output | RESET | | 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 $\mu$ F) (30-pin products only). #### 24.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 the flash memory programming mode, see 24.4.2 Flash memory programming mode. #### 24.3.1 P40/TOOL0 pin In the flash memory programming mode, pull up externally with a 1 k $\Omega$ resister, and connect it to the dedicated flash memory programmer. When using it as a port pin, use it as described below. When used as an input pin: Do not input a low level for the period after the 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. Remarks 1. thd: How long to keep the TOOL0 pin at the low level from when the external reset ends for setting of the flash memory programming mode (see 28.10 or 29.10 Timing of Entry to Flash Memory Programming Modes) 2. The SAU and IICA pins are not used for communication between the RL78 microcontroller and dedicated flash memory programmer, because single-line UART (TOOL0 pin) is used. # 24.3.2 RESET pin Signal conflict will occur if the reset signal of the dedicated flash memory programmer and external device are connected to the RESET 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 24-5. Signal Conflict (RESET 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. #### 24.3.3 Port pins 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 either to V<sub>DD</sub> or Vss via a resistor. # 24.3.4 REGC pins 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 (30-pin products only). Also, use a capacitor with good characteristics, since it is used to stabilize internal voltage. ### 24.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 oscillation clock (fin) is used. ### 24.3.6 Power supply To use the supply voltage output of the flash memory programmer, connect the $V_{DD}$ pin to $V_{DD}$ of the flash memory programmer, and the $V_{SS}$ pin 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 V<sub>DD</sub> and V<sub>SS</sub> pins to V<sub>DD</sub> and GND of the flash memory programmer to use the power monitor function with the flash memory programmer. ## 24.4 Serial Programming Method ## 24.4.1 Serial programming procedure The following figure illustrates a flow for rewriting the code flash memory through serial programming. Controlling TOOL0 pin and RESET pin Flash memory programming mode is set Manipulate code flash memory End? Yes End Figure 24-6. Code Flash Memory Manipulation Procedure # 24.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. <Programming using the dedicated flash memory programmer> Connect the RL78 microcontroller to a dedicated flash memory programmer. Communication from the dedicated flash memory programmer is performed to automatically switch to the flash memory programming mode. <Serial programming using an external device (UART communication)> Set the TOOL0 pin to the low level, and then cancel the reset (see **Table 24-4**). After that, enter flash memory programming mode according to the procedures <1> to <4> shown in **Figure 24-7**. For details, refer to the **RL78 Microcontrollers (RL78 Protocol A) Programmer Edition Application Note (R01AN0815)**. Table 24-4. Relationship Between TOOL0 Pin and Operation Mode After Reset Release | TOOL0 | Operation Mode | | | |-----------------|-------------------------------|--|--| | V <sub>DD</sub> | Normal operation mode | | | | 0 V | Flash memory programming mode | | | Figure 24-7. Setting of Flash Memory Programming Mode - <1> The low level is input to the TOOL0 pin. - <2> The external reset is released (POR and LVD reset must be released before the external reset is released.). - <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: Communication for the initial setting must be completed within 100 ms after the external reset is released during this period. $t_{\text{SU}}$ : Time to release the external reset after the TOOL0 pin is set to the low level thd: Time to hold the TOOL0 pin at the low level after the external reset is released (excluding the processing time of the firmware to control the flash memory) For details, see 28.10 or 29.10 Timing of Entry to Flash Memory Programming Modes. There are two flash memory programming modes: wide voltage mode and full speed mode. The supply voltage value applied to the microcontroller 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 24-5. Programming Modes and Voltages at Which Data Can Be Written, Erased, or Verified | Power Supply Voltage<br>(V <sub>DD</sub> ) | User Option Byte Setting for Switching to Flash Memory Programming Mode | | Flash Programming Mode | |--------------------------------------------|-------------------------------------------------------------------------|---------------------|------------------------| | | Flash Operation Mode | Operating Frequency | | | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$ | Blank state | | Full speed mode | | | HS (high speed main) mode | 1 MHz to 24 MHz | Full speed mode | | | LS (low speed main) mode 1 MHz to 8 MHz | | Wide voltage mode | | $2.4~V \leq V_{DD} < 2.7~V$ | Blank state | | Full speed mode | | | HS (high speed main) mode | 1 MHz to 16 MHz | Full speed mode | | | LS (low speed main) mode | 1 MHz to 8 MHz | Wide voltage mode | | $1.8~V \leq V_{DD} < 2.4~V$ | Blank state | | Wide voltage mode | | | LS (low speed main) mode | 1 MHz to 8 MHz | Wide voltage mode | **Remarks 1.** Using both the wide voltage mode and full speed mode imposes no restrictions on writing, erasing, or verification. 2. For details about communication commands, see 24.4.4 Communication commands. # 24.4.3 Selecting communication mode Communication modes of the RL78 microcontroller are as follows. Standard SettingNote 1 Pins Used Communication Mode Speed Note 2 Port Multiply Rate Frequency 1-line UART **UART** TOOL0 115200 bps, (when flash 250000 bps, memory 500000 bps, programmer is 1 Mbps used, or when external device is used) **Dedicated UART UART** TOOLTXD. 115200 bps, (when external 250000 bps, **TOOLRxD** device is used) 500000 bps, 1 Mbps **Table 24-6. Communication Modes** - Notes 1. Selection items for standard settings on GUI of the flash memory programmer. - 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. #### 24.4.4 Communication commands The RL78 microcontroller executes serial programming through the commands listed in Table 24-7. The signals sent from the dedicated flash memory programmer or external device to the RL78 microcontroller are called commands, and programming functions corresponding to the commands are executed. For details, refer to the RL78 Microcontrollers (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. Erases a specified area in the flash memory. Erase **Block Erase** 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. Note Gets the RL78 microcontroller information (such as the part number and Getting information Silicon Signature flash memory configuration, firmware version). Checksum Gets the checksum data for a specified area. Sets security information. Security Security Set Security Get Gets security information. Security Release Releases the write prohibition setting. Others Reset Used to detect synchronization status of communication. Baud Rate Set Sets baud rate when UART communication mode is selected. Table 24-7. Flash Memory Control Commands **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. Table 24-8 is a list of signature data and Table 24-9 shows an example of signature data. Table 24-8. Signature Data List | Field name | Description | Number of transmit data | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 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 (Sent from lower address. | 3 bytes | | Data flash memory area last address | Example. 00000H to 03FFFH (16 KB) → FFH, 3FH, 00H) Last address of data flash memory area (Sent from lower address. Example. F1000H to F17FFH (2 KB) → FFH, 17H, 0FH) | 3 bytes | | Firmware version | Version information of firmware for programming (Sent from upper address. Example. From Ver. 1.23 → 01H, 02H, 03H) | 3 bytes | Table 24-9. Example of Signature Data | Field name | Description | Number of transmit data | Data (hexadecimal) | |-------------------------------------|---------------------------|-------------------------|--------------------| | Device code | RL78 protocol A | 3 bytes | 10 00 06 | | Device name | R5F102AA | 10 bytes | 52 = "R" | | | | | 35 = "5" | | | | | 46 = "F" | | | | | 31 = "1" | | | | | 30 = "0" | | | | | 32 = "2" | | | | | 41 = "A" | | | | | 41 = "A" | | | | | 20 = " " | | | | | 20 = " " | | Code flash memory area last address | Code flash memory area | 3 bytes | FF FF 00 | | | 00000H to 03FFFH (16 KB) | | | | Data flash memory area last address | Data flash memory area | 3 bytes | FF 17 0F | | | F1000H to F17FFH (2 KB) | | | | Firmware version | Ver.1.23 → 01H, 02H, 03H) | 3 bytes | 01 02 03 | # 24.5 Processing Time for Each Command When PG-FP5 Is in Use (Reference Value) The following shows the processing time for each command (reference value) when PG-FP5 is used as a dedicated flash memory programmer. Table 24-10. Processing Time for Each Command When PG-FP5 Is in Use (Reference Value) | PG-FP5 Command | Code Flash | | | Unit | | | |-----------------------|------------|----------|----------|-----------|-----------|---| | | 2 Kbytes | 4 Kbytes | 8 Kbytes | 12 Kbytes | 16 Kbytes | | | Erasing | 0.5 | 0.5 | 1 | 1 | 1.5 | S | | Writing | 1 | 1 | 1 | 1.5 | 1.5 | S | | Verification | 1 | 1 | 1 | 1 | 1.5 | S | | Writing after erasing | 1 | 1 | 1 | 1.5 | 2 | 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) <R> ## 24.6 Self-Programming The RL78 microcontroller supports a self-programming function that can be used to rewrite the code flash memory via a user program. Because this function allows a user application to rewrite the code flash memory by using the flash selfprogramming library, it can be used to upgrade the program in the field. - Cautions 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 El instruction, and then execute the flash self-programming library. - 2. The high-speed on-chip oscillator should be kept operating during self-programming. If it is kept stopping, the high-speed on-chip oscillator clock should be operated (HIOSTOP = 0). The flash self-programming library should be executed after 30 $\mu$ s have elapsed. - 3. The self-programming function cannot be used in the R5F10266 and R5F10366. - 4. RL78/G12 does not support the boot swap function. - Remarks 1. For details of the self-programming function, refer to RL78 Microcontroller Flash Self Programming Library Type01 User's Manual (R01US0050). - 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. Specify the wide voltage mode when the LS (low 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** Using both the wide voltage mode and full speed mode imposes no restrictions on writing, erasing, or verification. # 24.6.1 Self-programming procedure The following figure illustrates a flow for rewriting the code flash memory by using a flash self-programming library. Code flash memory control start Initialize flash environment Flash shield window setting Erase Inhibit access to flash memory Inhibit shifting STOP mode Inhibit clock stop Flash information getting Flash information setting Close flash environment End Figure 24-8. Flow of Self Programming (Rewriting Flash Memory) #### 24.6.2 Flash shield window function The flash shield window function is provided as one of the security functions for self-programming. It disables writing and erasing areas outside the range specified as 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 by only serial 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. Available rewriting method 03FFFH Block 0FH OK: Serial programming Flash shield Block 0FH NG: Self-programming area 01C00H 01BFFH Block 06H (End block) OK: Serial programming OK: Self-programming Block 05H Window area Flash memory Block 04H area 01000H (Start block) 00FFFH Block 03H Block 02H OK: Serial programming Flash shield NG: Self-programming area Block 01H Block 00H Figure 24-9. An example of setting a flash shield window (Target device: R5F1026A, start block: 04H, and end block: 06H) - **Cautions 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. - 2. The flash shield window can only be used for the code flash memory (and is not supported for the data flash memory). Table 24-11. Relationship between Flash Shield Window Function Setting/Change Methods and Commands | Programming condition | Setting/Changing window | Execution command | | | |---------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------|--| | | range | Block erasure | Writing | | | During serial programming | Specify the start block and end block of the window on the GUI of the dedicated flash memory programmer. | Block erasure can be done also outside the window range. | Writing can be done also outside the window range. | | Note To prohibit writing and erasing during serial programming, refer to 24.7 Security Settings. 00000H ### 24.7 Security Settings The RL78 microcontroller 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 by 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 code flash memory is prohibited during serial programming. However, data 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 code flash memory is prohibited by this setting. The block erase, write, and rewriting boot cluster0 commands are enabled by the default setting when the flash memory is shipped. Security can be set by serial programming and self-programming. The security settings can be used in combination. Table 24-12 shows the relationship between the erase and write commands when the RL78 microcontroller security function is enabled. Caution The security function of the dedicated flash programmer does not support self-programming. **Remark** To prohibit writing and erasing during self-programming, use the flash shield window function (see **24.6.2** for detail). Table 24-12. Relationship between Enabled Security Function and Commands # (1) During serial programming | Enabled Security Function | Executed Command | | | | | |-----------------------------------------|----------------------------------|------------------------------------|--|--|--| | | Block Erase Write | | | | | | Prohibition of block erasure | 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 when block erase is prohibited, do not write data if the data has not been erased. #### (2) During self-programming | Enabled Security Function | Executed Command | | | | |-----------------------------------------|----------------------------------|-----------------------------------|--|--| | | Block Erase Write | | | | | Prohibition of block erasure | 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 **24.6.2** for detail). Table 24-13. Security Setting in Each Programming Mode ## **Serial programming** | Security | Security Setting | How to Disable Security Setting | |-----------------------------------------|---------------------------------------|--------------------------------------------------------| | Prohibition of block erasure | Set via GUI of dedicated flash memory | Cannot be disabled after setting. | | Prohibition of writing | programmer, etc. | Set via GUI of dedicated flash memory programmer, etc. | | Prohibition of rewriting boot cluster 0 | | Cannot be disabled after setting. | **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. #### 24.8 Data Flash #### 24.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 data flash library. For details, refer to RL78 Family Data Flash 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-Kbyte) 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. - **Cautions 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. - 2. Interrupts are disabled during data flash rewrite for only the R5F10266. Execute the data flash library with the IE flag cleared (0) by the DI instruction. - 3. The high-speed on-chip oscillator should be kept operating during data flash rewrite. If it is kept stopping, the high-speed on-chip oscillator clock should be operated (HIOSTOP = 0). The data flash library should be executed after 30 $\mu$ s have elapsed. Remark For rewriting the code flash memory via a user program, see 24.6 Self-Programming. # 24.8.2 Register controlling data flash memory #### 24.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 24-10. Format of Data Flash Control Register (DFLCTL) | Address: F00 | 90H After | reset: 00H R/ | W | | | | | | |--------------|-----------|---------------|---|---|---|---|---|-------| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | <0> | | DFLCTL | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DFLEN | | DFLEN | Data flash access control | |-------|----------------------------| | 0 | Disables data flash access | | 1 | Enables data flash access | Caution Manipulating the DFLCTL register is not possible while rewriting the data flash memory. #### 24.8.3 Procedure for accessing data flash memory The data flash memory is stopped after a reset ends. To access the data flash, make initial settings according to the following procedure. - <1> Set bit 0 (DFLEN) of the data flash control register (DFLCTL) to 1. - <2> Wait for the setup to finish for software timer, etc. The time setup takes differs for each flash operation mode for the main clock. <Setup time for each flash operation mode> HS (High speed main): 5 μs LS (Low speed main): 720 ns <3> After the wait, the data flash memory can be accessed. Cautions 1. Accessing the data flash memory is not possible during the setup time. - 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. - **3.** The high-speed on-chip oscillator should be kept operating during data flash rewrite. If it is kept stopping, the high-speed on-chip oscillator clock should be operated (HIOSTOP = 0). The data flash library should be executed after 30 $\mu$ s have elapsed. After initial setting, the data flash can be read through CPU instructions and can be read or rewritten to by using the data flash library. Follow one of the procedures below when the DMA controller operates during access to the data flash memory. (A) Hold DMA transfer pending or forcibly terminate it Before reading the data flash memory, hold the DMA transfer pending in all the channels which are in use. The data flash memory should be read 3 clocks (fclk) or more after the DWAITn bit is set to 1. After reading the data flash memory, set the DWAITn bit to 0 and then cancel the pending status. Or, before reading the data flash memory, forcibly terminate the DMA transfer in accordance with the process described in **15.5.5 Forced termination by software**. Resume the DMA transfer after reading the data flash memory. (B) Access the data flash memory by using the library Access the data flash memory by using the latest data flash library. (C) Insert the NOP instruction Insert the NOP instruction immediately before the data flash read instruction. <Example> MOVW HL, !addr16 ; Read RAM NOP ; Insert the NOP instruction before reading the data flash memory MOV A,[DE] ; Read the data flash memory If high-level language like C language is used, the compiler may generate two instructions per code. At that time, the NOP instruction is not inserted immediately before the data flash read instruction. Read the data flash memory by following procedure (A) or (B). Remark fclk: CPU/peripheral hardware clock frequency #### **CHAPTER 25 ON-CHIP DEBUG FUNCTION** ## 25.1 Connecting E1 On-chip Debugging Emulator The RL78 microcontroller uses the V<sub>DD</sub>, RESET, TOOL0, and Vss pins to communicate with the host machine via an E1 on-chip debugging emulator. Serial communication is performed by using a single-line UART that uses the TOOL0 pin. Caution The RL78 microcontroller 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 25-1. Connection Example of E1 On-chip Debugging Emulator and RL78/G12 (20, 24-pin products) Note Connecting the dotted line is not necessary during flash programming. For the target system which uses the RESET pin as a port function (P125) in 20, 24-pin products, its connection to an external circuit should be isolated. Figure 25-2. Connection Example of E1 On-chip Debugging Emulator and RL78/G12 (When using the RESET pin as a port function (P125)) Figure 25-3. Connection Example of E1 On-chip Debugging Emulator and RL78/G12 (30-pin products) **Notes 1.** Connecting the dotted line is not necessary during serial programming. **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 \Omega$ or less) <R> ## 25.2 On-Chip Debug Security ID The RL78 microcontroller has an on-chip debug operation control bit in the flash memory at 000C3H (see **CHAPTER 23 OPTION BYTE**) and an on-chip debug security ID setting area at 000C4H to 000CDH, to prevent third parties from reading memory content. Table 25-1. On-Chip Debug Security ID | Address | On-Chip Debug Security ID | |------------------|-----------------------------------------| | 000C4H to 000CDH | Any ID code of 10 bytes <sup>Note</sup> | #### 25.3 Securing of User Resources To perform communication between the RL78 microcontroller 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 25-4 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 25-4. Memory Spaces Where Debug Monitor Programs Are Allocated Notes 1. Address differs depending on products as follows. | Products (code flash memory capacity) | Address of Note 1 | |---------------------------------------|-------------------| | R5F10266, R5F10366 | 007FFH | | R5F10x67, R5F10x77, R5F10xA7 | 00FFFH | | R5F10x68, R5F10x78, R5F10xA8 | 01FFFH | | R5F10x69, R5F10x79, R5F10xA9 | 02FFFH | | R5F10x6A, R5F10x7A, R5F10xAA | 03FFFH | (x = 2, 3) - 2. When real-time RAM monitor (RRM) function and dynamic memory modification (DMM) function are not used, it is 256 bytes. - 3. In debugging, reset vector is rewritten to address allocated to a monitor program. - **4.** 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 26 BCD CORRECTION CIRCUIT** #### 26.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). ## 26.2 Registers Used by BCD Correction Circuit The BCD correction circuit uses the following registers. • BCD correction result register (BCDADJ) #### 26.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 26-1. Format of BCD Correction Result Register (BCDADJ) | Address: FOUFEH After reset: undefined H | | | | | | | | | |------------------------------------------|---|---|---|---|---|---|---|---| | Symbol | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | BCDADJ | | | | | | | | | ### 26.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<br>Register | |----------------------|------------|---------|---------|--------------------| | MOV A, #99H ; <1> | 99H | - | - | - | | ADD A, #89H ; <2> | 22H | 1 | 1 | 66H | | ADD A, !BCDADJ ; <3> | 88H | 1 | 0 | _ | Examples 2: 85 + 15 = 100 | Instruction | | A Register | CY Flag | AC Flag | BCDADJ<br>Register | |----------------|-------|------------|---------|---------|--------------------| | | | | | | negistei | | 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<br>Register | |----------------|-------|------------|---------|---------|--------------------| | MOV A, #80H | ; <1> | 80H | - | - | _ | | ADD A, #80H | ; <2> | 00H | 1 | 0 | 60H | | ADD A, !BCDADJ | ; <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<br>Register | |----------------|-------|------------|---------|---------|--------------------| | MOV A, #91H | ; <1> | 91H | ı | l | - | | SUB A, #52H | ; <2> | 3FH | 0 | 1 | 06H | | SUB A, !BCDADJ | ; <3> | 39H | 0 | 0 | _ | ## **CHAPTER 27 INSTRUCTION SET** This chapter lists the instructions in the RL78 microcontroller instruction set. For details of each operation and operation code, refer to the separate document RL78 Microcontrollers User's Manual: software (R01US0015E). ### 27.1 Conventions Used in Operation List #### 27.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 Table 27-1 below, R0, R1, R2, etc.) can be used for description. Table 27-1. Operand Identifiers and Specification Methods | 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 Note) | | addr20 | 00000H to FFFFFH Immediate data or labels | | addr16 | 0000H to FFFFH Immediate data or labels (Only even addresses for 16-bit data transfer instructions <sup>Note</sup> ) | | addr5 | 0080H to 00BFH Immediate data or labels (even addresses only <sup>Note</sup> ) | | 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** 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-6 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-7 Extended SFR (2nd SFR) List for the symbols of the extended special function registers. # 27.1.2 Description of operation column The operation when the instruction is executed is shown in the "Operation" column using the following symbols. Table 27-2. Symbols in "Operation" Column | Symbol | Function | |------------|---------------------------------------------------------------------------------| | Α | 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 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: X <sub>H</sub> = higher 8 bits, X <sub>L</sub> = 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) | | <b>∀</b> | 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) | <R> ## 27.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. Table 27-3. Symbols in "Flag" Column | 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 | #### 27.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 and DMA transfer are not acknowledged between a PREFIX instruction code and the instruction immediately after. Table 27-4. Use Example of PREFIX Operation Code | Instruction | Opcode | | | | | | | | | |-----------------------|--------|------|------|-------|-------|--|---|--|--| | | 1 | 2 | 3 | 4 | 5 | | | | | | MOV !addr16, #byte | CFH | !ado | dr16 | #byte | _ | | | | | | MOV ES:!addr16, #byte | 11H | CFH | !add | dr16 | #byte | | | | | | 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. ## 27.2 Operation List Table 27-5. Operation List (1/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | ı | |-------------|--------------------|--------------------|-------|--------|------------------------|------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 8-bit data | MOV | r, #byte | 2 | 1 | - | $r \leftarrow 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 \leftarrow A$ | | | | | | | A, PSW | 2 | 1 | - | A ← 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:!addr16 | 4 | 2 | 5 | A ← (ES, addr16) | | | | | | | !addr16, A | 3 | 1 | _ | (addr16) ← A | | | | | | | ES:!addr16, A | 4 | 2 | _ | (ES, addr16) ← A | | | | | | | A, saddr | 2 | 1 | = | A ← (saddr) | | | | | Notos 1 | | saddr, A | 2 | 1 | | saddr) ← A | | | | **Notes 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. - 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. - 3. Except r = A Table 27-5. Operation List (2/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | | |-------------|----------|-----------------|-------|--------|----------|----------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 8-bit data | MOV | A, sfr | 2 | 1 | - | $A \leftarrow sfr$ | | | | | transfer | | sfr, A | 2 | 1 | - | $sfr \leftarrow A$ | | | | | | | A, [DE] | 1 | 1 | 4 | $A \leftarrow (DE)$ | | | | | | | [DE], A | 1 | 1 | - | $(DE) \leftarrow A$ | | | | | | | A, ES:[DE] | 2 | 2 | 5 | $A \leftarrow (ES,DE)$ | | | | | | | ES:[DE], A | 2 | 2 | - | $(ES, DE) \leftarrow A$ | | | | | | | A, [HL] | 1 | 1 | 4 | $A \leftarrow (HL)$ | | | | | | [HL], A | 1 | 1 | - | (HL) ← A | | | | | | | | A, ES:[HL] | 2 | 2 | 5 | $A \leftarrow (ES, HL)$ | | | | | | | ES:[HL], A | 2 | 2 | - | (ES, HL) ← A | | | | | | | A, [DE+byte] | 2 | 1 | 4 | $A \leftarrow (DE + byte)$ | | | | | | | [DE+byte], A | 2 | 1 | = | (DE + byte) ← A | | | | | | | A, ES:[DE+byte] | 3 | 2 | 5 | $A \leftarrow ((ES, DE) + byte)$ | | | | | | | ES:[DE+byte], A | 3 | 2 | = | $((ES, DE) + byte) \leftarrow A$ | | | | | | | A, [HL+byte] | 2 | 1 | 4 | A ← (HL + byte) | | | | | | | [HL+byte], A | 2 | 1 | _ | (HL + byte) ← A | | | | | | | A, ES:[HL+byte] | 3 | 2 | 5 | $A \leftarrow ((ES, HL) + byte)$ | | | | | | | ES:[HL+byte], A | 3 | 2 | _ | ((ES, HL) + byte) ← A | | | | | | | A, [SP+byte] | 2 | 1 | - | A ← (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) \leftarrow A$ | | | | | | | 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)\leftarrowA$ | | | | - **Notes 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. - 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. Table 27-5. Operation List (3/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | F | -lag | |-------------|----------|-----------------|--------------------------------------|--------|--------|------------------------------------------|---|-------| | Group | | | | Note 1 | Note 2 | | Z | AC CY | | 8-bit data | MOV | A, [HL+B] | 2 | 1 | 4 | $A \leftarrow (HL + B)$ | | | | transfer | | [HL+B], A | 2 | 1 | _ | $(HL + B) \leftarrow 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)$ | | | | | | [HL+C], A | 2 | 1 | - | $(HL + C) \leftarrow A$ | | | | | | A, ES:[HL+C] | 3 | 2 | 5 | $A \leftarrow ((ES,HL) + C)$ | | | | | | ES:[HL+C], A | 3 | 2 | - | $((ES,HL)+C) \leftarrow A$ | | | | | | X, !addr16 | 3 | 1 | 4 | $X \leftarrow (addr16)$ | | | | | | X, ES:!addr16 | 4 | 2 | 5 | $X \leftarrow (ES, addr16)$ | | | | | | X, saddr | 2 | 1 | - | $X \leftarrow (saddr)$ | | | | | | B, !addr16 | 3 | 1 | 4 | $B \leftarrow (addr16)$ | | | | | | B, ES:!addr16 | 4 | 2 | 5 | $B \leftarrow (ES, addr16)$ | | | | | | B, saddr | 2 | 1 | = | $B \leftarrow (saddr)$ | | | | | | C, !addr16 | 3 | 1 | 4 | C ← (addr16) | | | | | | C, ES:!addr16 | 4 | 2 | 5 | $C \leftarrow (ES, addr16)$ | | | | | | C, saddr | 2 | 1 | = | $C \leftarrow (saddr)$ | | | | | | ES, saddr | 3 | 1 | = | ES ← (saddr) | | | | | XCH | A, r Note 3 | 1 (r = X)<br>2 (other<br>than r = X) | 1 | - | $A \longleftrightarrow r$ | | | | | | A, !addr16 | 4 | 2 | = | $A \longleftrightarrow (addr16)$ | | | | | | A, ES:!addr16 | 5 | 3 | - | $A \longleftrightarrow (ES, addr16)$ | | | | | | A, saddr | 3 | 2 | _ | $A \longleftrightarrow (saddr)$ | | | | | | A, sfr | 3 | 2 | _ | $A \longleftrightarrow sfr$ | | | | | | A, [DE] | 2 | 2 | _ | $A \longleftrightarrow (DE)$ | | | | | | A, ES:[DE] | 3 | 3 | _ | $A \longleftrightarrow (ES,DE)$ | | | | | | A, [HL] | 2 | 2 | _ | $A \longleftrightarrow (HL)$ | | | | | | A, ES:[HL] | 3 | 3 | _ | $A \longleftrightarrow (ES, HL)$ | | | | | | A, [DE+byte] | 3 | 2 | - | $A \longleftrightarrow (DE + byte)$ | | | | | | A, ES:[DE+byte] | 4 | 3 | _ | $A \longleftrightarrow ((ES,DE) + byte)$ | | | | | | A, [HL+byte] | 3 | 2 | _ | $A \longleftrightarrow (HL + byte)$ | | | | | | A, ES:[HL+byte] | 4 | 3 | _ | $A \longleftrightarrow ((ES,HL) + byte)$ | | | - **Notes 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. - 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. - 3. Except r = A Table 27-5. Operation List (4/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | |-------------|----------|-----------------|-------|--------|--------|--------------------------------------|---|-------| | Group | | | | Note 1 | Note 2 | | Z | AC CY | | 8-bit data | XCH | A, [HL+B] | 2 | 2 | - | $A \longleftrightarrow (HL + B)$ | | | | transfer | | A, ES:[HL+B] | 3 | 3 | - | $A \longleftrightarrow ((ES, HL)+B)$ | | | | | | A, [HL+C] | 2 | 2 | - | $A \longleftrightarrow (HL + C)$ | | | | | | A, ES:[HL+C] | 3 | 3 | _ | $A \longleftrightarrow ((ES, HL)+C)$ | | | | | ONEB | Α | 1 | 1 | _ | A ← 01H | | | | | | х | 1 | 1 | - | X ← 01H | | | | | | В | 1 | 1 | - | B ← 01H | | | | | | С | 1 | 1 | - | C ← 01H | | | | | | !addr16 | 3 | 1 | - | (addr16) ← 01H | | | | | | ES:!addr16 | 4 | 2 | - | (ES, addr16) ← 01H | | | | | | saddr | 2 | 1 | _ | (saddr) ← 01H | | | | | CLRB | A | 1 | 1 | - | A ← 00H | | | | | | Х | 1 | 1 | - | X ← 00H | | | | | | В | 1 | 1 | _ | B ← 00H | | | | | | С | 1 | 1 | = | C ← 00H | | | | | | !addr16 | 3 | 1 | _ | (addr16) ← 00H | | | | | | ES:!addr16 | 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 | MOVW | rp, #word | 3 | 1 | - | $rp \leftarrow word$ | | | | data | | saddrp, #word | 4 | 1 | _ | $(saddrp) \leftarrow word$ | | | | transfer | | sfrp, #word | 4 | 1 | = | $sfrp \leftarrow word$ | | | | | | AX, rp Note 3 | 1 | 1 | _ | $AX \leftarrow rp$ | | | | | | rp, AX Note 3 | 1 | 1 | _ | rp ← AX | | | | | | AX, !addr16 | 3 | 1 | 4 | AX ← (addr16) | | | | | | !addr16, AX | 3 | 1 | - | (addr16) ← AX | | | | | | AX, ES:!addr16 | 4 | 2 | 5 | AX ← (ES, addr16) | | | | | | ES:!addr16, AX | 4 | 2 | _ | (ES, addr16) ← AX | | | | | | AX, saddrp | 2 | 1 | _ | AX ← (saddrp) | | | | | | saddrp, AX | 2 | 1 | _ | (saddrp) ← AX | | | | | | AX, sfrp | 2 | 1 | _ | AX ← sfrp | | | | | | sfrp, AX | 2 | 1 | _ | $sfrp \leftarrow AX$ | | | - **Notes 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. - 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. - 3. Except rp = AX Table 27-5. Operation List (5/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | | |------------------|----------|------------------|-------|--------|--------|-----------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 16-bit | MOVW | AX, [DE] | 1 | 1 | 4 | $AX \leftarrow (DE)$ | | | | | data<br>transfer | | [DE], AX | 1 | 1 | - | $(DE) \leftarrow AX$ | | | | | liansiei | | AX, ES:[DE] | 2 | 2 | 5 | $AX \leftarrow (ES, DE)$ | | | | | | | ES:[DE], AX | 2 | 2 | - | $(ES, DE) \leftarrow AX$ | | | | | | | AX, [HL] | 1 | 1 | 4 | $AX \leftarrow (HL)$ | | | | | | | [HL], AX | 1 | 1 | - | $(HL) \leftarrow AX$ | | | | | | | AX, ES:[HL] | 2 | 2 | 5 | $AX \leftarrow (ES, HL)$ | | | | | | | ES:[HL], AX | 2 | 2 | - | $(ES, HL) \leftarrow AX$ | | | | | | | AX, [DE+byte] | 2 | 1 | 4 | $AX \leftarrow (DE + byte)$ | | | | | | | [DE+byte], AX | 2 | 1 | - | (DE+byte) ← AX | | | | | | | AX, ES:[DE+byte] | 3 | 2 | 5 | $AX \leftarrow ((ES,DE) + byte)$ | | | | | | | ES:[DE+byte], AX | 3 | 2 | - | $((ES,DE) + byte) \leftarrow AX$ | | | | | | | AX, [HL+byte] | 2 | 1 | 4 | $AX \leftarrow (HL + byte)$ | | | | | | | [HL+byte], AX | 2 | 1 | - | $(HL + byte) \leftarrow AX$ | | | | | | | AX, ES:[HL+byte] | 3 | 2 | 5 | $AX \leftarrow ((ES,HL)+byte)$ | | | | | | | ES:[HL+byte], AX | 3 | 2 | - | $((ES,HL) + byte) \leftarrow AX$ | | | | | | | AX, [SP+byte] | 2 | 1 | - | $AX \leftarrow (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) \leftarrow AX$ | | | | | | | AX, ES:word[B] | 4 | 2 | 5 | $AX \leftarrow ((ES, B) + word)$ | | | | | | | ES:word[B], AX | 4 | 2 | = | $((ES, B) + word) \leftarrow AX$ | | | | | | | 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 \leftarrow ((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$ | | | | **Notes 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. 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. Table 27-5. Operation List (6/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | | |------------------|----------|-----------------|-------|--------|--------|-----------------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 16-bit | MOVW | BC, !addr16 | 3 | 1 | 4 | BC ← (addr16) | | | | | data<br>transfer | | BC, ES:!addr16 | 4 | 2 | 5 | BC ← (ES, addr16) | | | | | transier | | DE, !addr16 | 3 | 1 | 4 | DE ← (addr16) | | | | | | | DE, ES:!addr16 | 4 | 2 | 5 | DE ← (ES, addr16) | | | | | | | HL, !addr16 | 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 3 | 1 | 1 | - | $AX \longleftrightarrow rp$ | | | | | | ONEW | AX | 1 | 1 | ı | AX ← 0001H | | | | | | | BC | 1 | 1 | - | BC ← 0001H | | | | | | CLRW | AX | 1 | 1 | ı | AX ← 0000H | | | | | | | BC | 1 | 1 | - | BC ← 0000H | | | | | 8-bit | ADD | A, #byte | 2 | 1 | - | $A, CY \leftarrow A + byte$ | × | × | × | | operation | | saddr, #byte | 3 | 2 | - | (saddr), CY $\leftarrow$ (saddr)+byte | × | × | × | | | | A, r | 2 | 1 | - | $A, CY \leftarrow A + r$ | × | × | × | | | | r, A | 2 | 1 | = | $r, CY \leftarrow r + A$ | × | × | × | | | | A, !addr16 | 3 | 1 | 4 | $A, CY \leftarrow 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 \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)$ | × | × | × | - **Notes 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. - 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. - 3. Except rp = AX - 4. Except r = A Table 27-5. Operation List (7/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | J | |-------------|-----------------|-----------------|-------|--------|-------------------------------------------|-----------------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 8-bit | ADDC | A, #byte | 2 | 1 | - | A, CY ← A+byte+CY | × | × | × | | operation | | saddr, #byte | 3 | 2 | = | (saddr), CY ← (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 ← A + (addr16)+CY | × | × | × | | | | A, ES:!addr16 | 4 | 2 | 5 | A, CY ← A + (ES, addr16)+CY | × | × | × | | | | A, saddr | 2 | 1 | - | A, CY ← 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 ← 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 ← 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 ← 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 $\leftarrow$ (saddr) – byte | × | × | × | | | | A, r | 2 | 1 | _ | $A, CY \leftarrow A - r$ | × | × | × | | | | r, A | 2 | 1 | _ | $r, CY \leftarrow 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 \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)$ | × | × | × | **Notes 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. - 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. - **3.** Except r = A Table 27-5. Operation List (8/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | J | |-------------|--------------|-----------------|-------|--------|-----------------------------------------|----------------------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 8-bit | SUBC | A, #byte | 2 | 1 | = | $A, CY \leftarrow A - byte - CY$ | × | × | × | | operation | | saddr, #byte | 3 | 2 | = | (saddr), $CY \leftarrow (saddr) - byte - CY$ | × | × | × | | | | A, r | 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:!addr16 | 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$ | × | × | × | | | AND | A, #byte | 2 | 1 | _ | $A \leftarrow A \land byte$ | × | | | | | | saddr, #byte | 3 | 2 | _ | $(saddr) \leftarrow (saddr) \land byte$ | × | | | | | | A, r | 2 | 1 | - | $A \leftarrow A \wedge r$ | × | | | | | | r, A | 2 | 1 | _ | $R \leftarrow r \wedge A$ | × | | | | | | A, !addr16 | 3 | 1 | 4 | $A \leftarrow A \land (addr16)$ | × | | | | | | A, ES:!addr16 | 4 | 2 | 5 | $A \leftarrow A \land (ES:addr16)$ | × | | | | | | A, saddr | 2 | 1 | - | $A \leftarrow A \wedge (saddr)$ | × | | | | | | A, [HL] | 1 | 1 | 4 | $A \leftarrow A \wedge (HL)$ | × | | | | | | A, ES:[HL] | 2 | 2 | 5 | $A \leftarrow A \wedge (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 \wedge ((ES:HL)+C)$ | × | _ | _ | **Notes 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. - 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. - **3.** Except r = A Table 27-5. Operation List (9/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | Flag | |-------------|----------|-----------------|-------|--------|--------|-------------------------------------------------------------------------------------------|---------| | Group | | | | Note 1 | Note 2 | | Z AC CY | | 8-bit | OR | A, #byte | 2 | 1 | - | A ← A√byte | × | | operation | | saddr, #byte | 3 | 2 | - | $(saddr) \leftarrow (saddr) \lor byte$ | × | | | | A, r | 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:!addr16 | 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 \mathord{\vee} (H)$ | × | | | | 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 \lor ((ES:HL) + byte)$ | × | | | | A, [HL+B] | 2 | 1 | 4 | $A \leftarrow 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 \leftarrow A \lor (HL + C)$ | × | | | | A, ES:[HL+C] | 3 | 2 | 5 | $A \leftarrow A \lor ((ES:HL) + C)$ | × | | | XOR | A, #byte | 2 | 1 | - | A ← A <del>∨</del> byte | × | | | | saddr, #byte | 3 | 2 | _ | $(saddr) \leftarrow (saddr) + byte$ | × | | | | A, r | 2 | 1 | _ | $A \leftarrow A \!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | × | | | | r, A | 2 | 1 | _ | $r \leftarrow r + A$ | × | | | | A, !addr16 | 3 | 1 | 4 | A ← A <del>∨</del> (addr16) | × | | | | A, ES:!addr16 | 4 | 2 | 5 | $A \leftarrow A \leftarrow (ES:addr16)$ | × | | | | A, saddr | 2 | 1 | _ | $A \leftarrow A + (saddr)$ | × | | | | A, [HL] | 1 | 1 | 4 | $A \leftarrow A \!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | × | | | | A, ES:[HL] | 2 | 2 | 5 | $A \leftarrow A + (ES:HL)$ | × | | | | A, [HL+byte] | 2 | 1 | 4 | A ← A <del>∨</del> (HL+byte) | × | | | | A, ES:[HL+byte] | 3 | 2 | 5 | $A \leftarrow A + ((ES:HL) + byte)$ | × | | | | A, [HL+B] | 2 | 1 | 4 | $A \leftarrow A + (HL + B)$ | × | | | | A, ES:[HL+B] | 3 | 2 | 5 | $A \leftarrow A + ((ES:HL) + B)$ | × | | | | A, [HL+C] | 2 | 1 | 4 | $A \leftarrow A + (HL + C)$ | × | | | | A, ES:[HL+C] | 3 | 2 | 5 | $A \leftarrow A + ((ES:HL) + C)$ | × | Notes 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. - 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. - Except r = A Table 27-5. Operation List (10/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | 3 | |-------------|----------|-------------------|-------|--------|--------|--------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 8-bit | CMP | A, #byte | 2 | 1 | _ | A – byte | × | × | × | | operation | | !addr16, #byte | 4 | 1 | 4 | (addr16) – byte | × | × | × | | | | ES:!addr16, #byte | 5 | 2 | 5 | (ES:addr16) – byte | × | × | × | | | | saddr, #byte | 3 | 1 | = | (saddr) - byte | × | × | × | | | | A, r | 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 | Α | 1 | 1 | _ | A – 00H | × | 0 | 0 | | | | X | 1 | 1 | _ | X – 00H | × | 0 | 0 | | | | В | 1 | 1 | _ | B – 00H | × | 0 | 0 | | | | С | 1 | 1 | _ | C – 00H | × | 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) | × | × | × | - **Notes 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. - 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. - 3. Except r = A Table 27-5. Operation List (11/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | J | |-------------|----------|-------------------|-------|--------|--------|----------------------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | 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 \leftarrow AX {+} BC$ | × | × | × | | | | AX, DE | 1 | 1 | _ | $AX, CY \leftarrow AX \text{+} DE$ | × | × | × | | | | AX, HL | 1 | 1 | _ | $AX, CY \leftarrow AX\text{+}HL$ | × | × | × | | | | AX, !addr16 | 3 | 1 | 4 | $AX,CY\leftarrowAX+(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 \leftarrow AX+((ES:HL)+byte)$ | × | × | × | | | SUBW | AX, #word | 3 | 1 | _ | $AX, CY \leftarrow AX - word$ | × | × | × | | | | AX, BC | 1 | 1 | _ | $AX, CY \leftarrow 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\leftarrowAX-(addr16)$ | × | × | × | | | | AX, ES:!addr16 | 4 | 2 | 5 | $AX,CY\leftarrowAX-(ES:addr16)$ | × | × | × | | | | AX, saddrp | 2 | 1 | _ | $AX,CY\leftarrowAX-(saddrp)$ | × | × | × | | | | AX, [HL+byte] | 3 | 1 | 4 | $AX,CY \leftarrow AX - (HL+byte)$ | × | × | × | | | | AX, ES: [HL+byte] | 4 | 2 | 5 | $AX,CY \leftarrow 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 | X | 1 | 1 | _ | $AX \leftarrow A {\times} X$ | | | | - **Notes 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. - 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. Table 27-5. Operation List (12/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | | |-------------|----------|---------------|-------|--------|--------|------------------------------------------------------------------------------------------|----------|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC ( | CY | | Increment/ | INC | r | 1 | 1 | _ | r ← r+1 | × | × | | | decrement | | !addr16 | 3 | 2 | _ | (addr16) ← (addr16)+1 | × | × | | | | | ES:!addr16 | 4 | 3 | = | (ES, addr16) ← (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) ← ((ES:HL)+byte)+1 | × | × | | | | DEC | r | 1 | 1 | _ | r ← r − 1 | × | × | | | | | !addr16 | 3 | 2 | _ | (addr16) ← (addr16) - 1 | × | × | | | | | ES:!addr16 | 4 | 3 | _ | (ES, addr16) ← (ES, addr16) - 1 | × | × | | | | | saddr | 2 | 2 | _ | $(saddr) \leftarrow (saddr) - 1$ | × | × | | | | | [HL+byte] | 3 | 2 | _ | (HL+byte) ← (HL+byte) − 1 | × | × | | | | | ES: [HL+byte] | 4 | 3 | = | ((ES:HL)+byte) ← ((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) ← (saddrp)+1 | | | | | | | [HL+byte] | 3 | 2 | _ | (HL+byte) ← (HL+byte)+1 | | | | | | | ES: [HL+byte] | 4 | 3 | _ | ((ES:HL)+byte) ← ((ES:HL)+byte)+1 | | | | | | DECW | 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) ← ((ES:HL)+byte) − 1 | | | | | Shift | SHR | A, cnt | 2 | 1 | = | $(CY \leftarrow A_0, A_{m\text{-}1} \leftarrow A_{m} A_7 \leftarrow 0) \times cnt$ | | | × | | | SHRW | AX, cnt | 2 | 1 | - | $(CY \leftarrow AX_0, AX_{m\text{-}1} \leftarrow AX_m, AX_{15} \leftarrow 0) \times cnt$ | | | × | | | SHL | A, cnt | 2 | 1 | = | $(CY \leftarrow A_7, A_m \leftarrow A_{m\text{-}1}, A_0 \leftarrow 0) \times cnt$ | <u> </u> | | × | | | | B, cnt | 2 | 1 | _ | $(CY \leftarrow B_7, B_m \leftarrow B_{m-1}, B_0 \leftarrow 0) \times cnt$ | | | × | | | | C, cnt | 2 | 1 | _ | $(CY \leftarrow C_7, C_m \leftarrow C_{m\text{-}1}, C_0 \leftarrow 0) \times cnt$ | | | × | | | SHLW | AX, cnt | 2 | 1 | - | $(CY \leftarrow AX_{15}, AX_m \leftarrow AX_{m-1}, AX_0 \leftarrow 0) \times cnt$ | <u> </u> | | × | | | | BC, cnt | 2 | 1 | _ | $(CY \leftarrow BC_{15}, BC_m \leftarrow BC_{m-1}, BC_0 \leftarrow 0) \times cnt$ | <u> </u> | | × | | | SAR | A, cnt | 2 | 1 | _ | $(CY \leftarrow A_0, A_{m-1} \leftarrow A_m, A_7 \leftarrow A_7) \times cnt$ | $\vdash$ | | × | | | SARW | AX, cnt | 2 | 1 | _ | $(CY \leftarrow AX_0, AX_{m-1} \leftarrow AX_m, AX_{15} \leftarrow AX_{15}) \times cnt$ | <u> </u> | | × | - **Notes 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. - 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. - **Remarks 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. - 2. cnt indicates the bit shift count. Table 27-5. Operation List (13/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | |-------------|----------|-----------------|-------|--------|--------|----------------------------------------------------------------------------------------------------|---|-------| | Group | | | | Note 1 | Note 2 | | Z | AC CY | | Rotate | ROR | A, 1 | 2 | 1 | - | (CY, A <sub>7</sub> $\leftarrow$ A <sub>0</sub> , A <sub>m-1</sub> $\leftarrow$ A <sub>m</sub> )×1 | | × | | | ROL | A, 1 | 2 | 1 | = | (CY, $A_0 \leftarrow A_7$ , $A_{m+1} \leftarrow A_m$ )×1 | | × | | | RORC | A, 1 | 2 | 1 | = | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m\text{-}1} \leftarrow A_m) \times 1$ | | × | | | ROLC | A, 1 | 2 | 1 | = | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1$ | | × | | | ROLWC | AX,1 | 2 | 1 | _ | $(CY \leftarrow AX_{15}, AX_0 \leftarrow CY, AX_{m+1} \leftarrow AX_m) \times 1$ | | × | | | | BC,1 | 2 | 1 | = | $(CY \leftarrow BC_{15},BC_0 \leftarrow CY,BC_{m+1} \leftarrow BC_m) \times 1$ | | × | | Bit | MOV1 | CY, A.bit | 2 | 1 | - | CY ← A.bit | | × | | manipulate | | A.bit, CY | 2 | 1 | - | $A.bit \leftarrow CY$ | | | | | | CY, PSW.bit | 3 | 1 | _ | CY ← PSW.bit | | × | | | | PSW.bit, CY | 3 | 4 | _ | $PSW.bit \leftarrow CY$ | × | × | | | | CY, saddr.bit | 3 | 1 | _ | $CY \leftarrow (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 \leftarrow CY$ | | | | | | CY,[HL].bit | 2 | 1 | 4 | CY ← (HL).bit | | × | | | | [HL].bit, CY | 2 | 2 | - | $(HL).bit \leftarrow CY$ | | | | | | CY, ES:[HL].bit | 3 | 2 | 5 | $CY \leftarrow (ES, HL).bit$ | | × | | | | ES:[HL].bit, CY | 3 | 3 | - | (ES, HL).bit $\leftarrow$ 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 \vee A.bit$ | | × | | | | CY, PSW.bit | 3 | 1 | - | $CYX \leftarrow CY \vee \vee 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$ | | × | | | | CY, ES:[HL].bit | 3 | 2 | 5 | $CY \leftarrow CY \vee (ES,HL).bit$ | | × | **Notes 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. 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. Table 27-5. Operation List (14/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | <u> </u> | |-------------|-----------|-----------------|-------|--------|-----------------|---------------------------------|---|------|----------| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | Bit | XOR1 | CY, A.bit | 2 | 1 | - | CY ← CY ← A.bit | | | × | | manipulate | | CY, PSW.bit | 3 | 1 | - | CY ← CY ← PSW.bit | | | × | | | | CY, saddr.bit | 3 | 1 | - | CY ← CY ← (saddr).bit | | | × | | | | CY, sfr.bit | 3 | 1 | - | CY ← CY ₩ sfr.bit | | | × | | | | CY, [HL].bit | 2 | 1 | 4 | CY ← CY ← (HL).bit | | | × | | | | CY, ES:[HL].bit | 3 | 2 | 5 | CY ← CY ← (ES, HL).bit | | | × | | | SET1 | A.bit | 2 | 1 | - | A.bit ← 1 | | | | | | | PSW.bit | 3 | 4 | - | PSW.bit ← 1 | × | × | × | | | | !addr16.bit | 4 | 2 | - | (addr16).bit ← 1 | | | | | | | ES:!addr16.bit | 5 | 3 | - | (ES, addr16).bit ← 1 | | | | | | saddr.bit | 3 | 2 | - | (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 | × | × | × | | | | !addr16.bit | 4 | 2 | - | (addr16).bit ← 0 | | | | | | | ES:!addr16.bit | 5 | 3 | - | (ES, addr16).bit $\leftarrow$ 0 | | | | | | | saddr.bit | 3 | 2 | - | (saddr.bit) ← 0 | | | | | | | sfr.bit | 3 | 2 | - | sfr.bit ← 0 | | | | | | | [HL].bit | 2 | 2 | - | (HL).bit ← 0 | | | | | | | 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 ← CY | | | × | Notes 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. Number of CPU clocks (fclk) when the code flash memory is accessed, or when the data flash memory is 2. accessed by an 8-bit instruction. Table 27-5. Operation List (15/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | | |-----------------|----------|-----------|-------|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | Call/<br>return | CALL | rp | 2 | 3 | - | $(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$ | | | | | | | \$!addr20 | 3 | 3 | _ | $(SP-2) \leftarrow (PC+3)s$ , $(SP-3) \leftarrow (PC+3)H$ , $(SP-4) \leftarrow (PC+3)L$ , $PC \leftarrow PC+3+jdisp16$ , $SP \leftarrow SP-4$ | | | | | | | !addr16 | 3 | 3 | _ | $(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$ | | | | | | | !!addr20 | 4 | 3 | _ | $(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$ | | | | | | CALLT | [addr5] | 2 | 5 | - | $(SP - 2) \leftarrow (PC+2)s, (SP - 3) \leftarrow (PC+2)H,$<br>$(SP - 4) \leftarrow (PC+2)L, PCs \leftarrow 0000,$<br>$PCH \leftarrow (0000, addr5+1),$<br>$PCL \leftarrow (0000, addr5),$<br>$SP \leftarrow SP - 4$ | | | | | | BRK | - | 2 | 5 | - | $(SP - 1) \leftarrow PSW, (SP - 2) \leftarrow (PC+2)s,$<br>$(SP - 3) \leftarrow (PC+2)H, (SP - 4) \leftarrow (PC+2)L,$<br>$PCs \leftarrow 0000,$<br>$PCH \leftarrow (0007FH), PCL \leftarrow (0007EH),$<br>$SP \leftarrow SP - 4, IE \leftarrow 0$ | | | | | | RET | - | 1 | 6 | = | $PC_L \leftarrow (SP), PC_H \leftarrow (SP+1),$<br>$PC_S \leftarrow (SP+2), SP \leftarrow SP+4$ | | | | | | RETI | - | 2 | 6 | - | $PC_L \leftarrow (SP), PC_H \leftarrow (SP+1),$<br>$PC_S \leftarrow (SP+2), PSW \leftarrow (SP+3),$<br>$SP \leftarrow SP+4$ | R | R | R | | | RETB | - | 2 | 6 | - | $PC_L \leftarrow (SP), PC_H \leftarrow (SP+1),$<br>$PC_S \leftarrow (SP+2), PSW \leftarrow (SP+3),$<br>$SP \leftarrow SP+4$ | R | R | R | - **Notes 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. - 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. Table 27-5. Operation List (16/17) | Instruction | Mnemon | Operands | Bytes | Clo | cks | Clocks | | Flag | | |-------------|--------------------------|---------------------|-------|-----------|--------|----------------------------------------------------------------------|---|------|----| | Group | ic | | | Note 1 | Note 2 | | Z | AC | CY | | Stack | PUSH | PSW | 2 | 1 | - | $(SP - 1) \leftarrow PSW, (SP - 2) \leftarrow 00H,$ | | | | | manipulate | | | | | | SP ← SP-2 | | | | | | | rp | 1 | 1 | _ | $(SP-1) \leftarrow rp_H, (SP-2) \leftarrow rp_L,$ | | | | | | | | | | | SP ← 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 \leftarrow SP$ | | | | | | | BC, SP | 3 | 1 | - | $BC \leftarrow SP$ | | | | | | | DE, SP | 3 | 1 | - | $DE \leftarrow SP$ | | | | | | ADDW | SP, #byte | 2 | 1 | - | SP ← SP + byte | | | | | | SUBW | SP, #byte | 2 | 1 | _ | SP ← SP – byte | | | | | Unconditio | BR | AX | 2 | 3 | = | $PC \leftarrow CS$ , AX | | | | | nal branch | | \$addr20 | 2 | 3 | = | $PC \leftarrow PC + 2 + jdisp8$ | | | | | | | \$!addr20 | 3 | 3 | = | PC ← PC + 3 + jdisp16 | | | | | | | !addr16 | 3 | 3 | - | PC ← 0000, addr16 | | | | | | | !!addr20 | 4 | 3 | _ | PC ← addr20 | | | | | Conditional | ВС | \$addr20 | 2 | 2/4 Note3 | = | $PC \leftarrow PC + 2 + jdisp8 \text{ if } CY = 1$ | | | | | branch | BNC | \$addr20 | 2 | 2/4 Note3 | = | $PC \leftarrow PC + 2 + jdisp8 \text{ if } CY = 0$ | | | | | | BZ | \$addr20 | 2 | 2/4 Note3 | - | $PC \leftarrow PC + 2 + jdisp8 \text{ if } Z = 1$ | | | | | | BNZ | \$addr20 | 2 | 2/4 Note3 | - | $PC \leftarrow PC + 2 + jdisp8 \text{ if } Z = 0$ | | | | | | ВН | \$addr20 | 3 | 2/4 Note3 | - | $PC \leftarrow PC + 3 + jdisp8 \text{ if } (Z \lor CY) = 0$ | | | | | | BNH | \$addr20 | 3 | 2/4 Note3 | _ | $PC \leftarrow PC + 3 + jdisp8 \text{ if } (Z \lor CY)=1$ | | | | | | ВТ | saddr.bit, \$addr20 | 4 | 3/5 Note3 | _ | $PC \leftarrow PC + 4 + jdisp8 \text{ if (saddr).bit} = 1$ | | | | | | | sfr.bit, \$addr20 | 4 | 3/5 Note3 | _ | $PC \leftarrow PC + 4 + jdisp8 \text{ if sfr.bit} = 1$ | | | | | | A.bit, | | 3 | 3/5 Note3 | _ | $PC \leftarrow PC + 3 + jdisp8 \text{ if A.bit} = 1$ | | | | | | | PSW.bit, \$addr20 | 4 | 3/5 Note3 | _ | PC ← PC + 4 + jdisp8 if PSW.bit = 1 | | | | | | | [HL].bit, \$addr20 | 3 | 3/5 Note3 | 6/7 | $PC \leftarrow PC + 3 + jdisp8 \text{ if (HL).bit} = 1$ | | | | | | ES:[HL].bit,<br>\$addr20 | | 4 | 4/6 Note3 | 7/8 | PC ← PC + 4 + jdisp8 if (ES, HL).bit = 1 | | | | - **Notes 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. - 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. - 3. This indicates the number of clocks "when condition is not met/when condition is met". Table 27-5. Operation List (17/17) | Instruction | Mnemonic | Operands | Bytes | Clo | cks | Clocks | | Flag | | |-------------|-----------|--------------------------|-------|-----------|--------|-------------------------------------------------------------|---|------|----| | Group | | | | Note 1 | Note 2 | | Z | AC | CY | | Condition | BF | saddr.bit, \$addr20 | 4 | 3/5 Note3 | - | $PC \leftarrow PC + 4 + jdisp8 \text{ if (saddr).bit} = 0$ | | | | | al branch | | sfr.bit, \$addr20 | 4 | 3/5 Note3 | - | $PC \leftarrow PC + 4 + jdisp8 \text{ if sfr.bit} = 0$ | | | | | | | A.bit, \$addr20 | 3 | 3/5 Note3 | - | $PC \leftarrow PC + 3 + jdisp8 \text{ if A.bit} = 0$ | | | | | | | PSW.bit, \$addr20 | 4 | 3/5 Note3 | - | PC ← PC + 4 + jdisp8 if PSW.bit = 0 | | | | | | | [HL].bit, \$addr20 | 3 | 3/5 Note3 | 6/7 | $PC \leftarrow PC + 3 + jdisp8 \text{ if (HL).bit} = 0$ | | | | | | | ES:[HL].bit,<br>\$addr20 | 4 | 4/6 Note3 | 7/8 | $PC \leftarrow PC + 4 + jdisp8 if (ES, HL).bit = 0$ | | | | | | BTCLR | saddr.bit, \$addr20 | 4 | 3/5 Note3 | - | $PC \leftarrow PC + 4 + jdisp8 if (saddr).bit = 1$ | | | | | | | | | | | then reset (saddr).bit | | | | | | | sfr.bit, \$addr20 | 4 | 3/5 Note3 | = | $PC \leftarrow PC + 4 + jdisp8 \text{ if sfr.bit} = 1$ | | | | | | | | | | | then reset sfr.bit | | | | | | | A.bit, \$addr20 | 3 | 3/5 Note3 | = | $PC \leftarrow PC + 3 + jdisp8 \text{ if A.bit} = 1$ | | | | | | | | | | | then reset A.bit | | | | | | | PSW.bit, \$addr20 | 4 | 3/5 Note3 | = | $PC \leftarrow PC + 4 + jdisp8 \text{ if PSW.bit} = 1$ | × | × | × | | | | | | | | then reset PSW.bit | | | | | | | [HL].bit, \$addr20 | 3 | 3/5 Note3 | - | $PC \leftarrow PC + 3 + jdisp8 \text{ if (HL).bit} = 1$ | | | | | | | | | | | then reset (HL).bit | | | | | | | ES:[HL].bit, | 4 | 4/6 Note3 | - | $PC \leftarrow PC + 4 + jdisp8 \text{ if (ES, HL).bit} = 1$ | | | | | | | \$addr20 | | | | 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$ $\vee$ CY)=0 | | | | | | SKNH | - | 2 | 1 | - | Next instruction skip if (Z√CY)=1 | | | | | CPU | SEL Note4 | RBn | 2 | 1 | - | RBS[1:0] ← n | | | | | control | NOP | - | 1 | 1 | | No Operation | | | | | | El | _ | 3 | 4 | _ | IE ← 1 (Enable Interrupt) | | | | | | DI | - | 3 | 4 | = | IE ← 0 (Disable Interrupt) | | | | | | HALT | - | 2 | 3 | = | Set HALT Mode | | | | | | STOP | = | 2 | 3 | - | Set STOP Mode | | | | Notes 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. - 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. - This indicates the number of clocks "when condition is not met/when condition is met". 3. - n indicates the number of register banks (n = 0 to 3). <R> <R> <R> <R> # CHAPTER 28 ELECTRICAL SPECIFICATIONS (TA = -40 to +85°C) - <R> This chapter describes the following electrical specifications. - Target products A: Consumer applications $T_A = -40 \text{ to } +85^{\circ}\text{C}$ R5F102xxAxx, R5F103xxAxx - D: Industrial applications T<sub>A</sub> = -40 to +85°C R5F102xxDxx, R5F103xxDxx - G: Industrial applications when $T_A = -40$ to $+105^{\circ}$ C products is used in the range of $T_A = -40$ to $+85^{\circ}$ C R5F102xxGxx - Cautions 1. The RL78 microcontrollers have 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. - 2. The pins mounted depend on the product. Refer to 2.1 Port Functions to 2.2.1 Functions for each product. ## 28.1 Absolute Maximum Ratings **Absolute Maximum Ratings (TA = 25°C)** | Parameter | Symbols | | Conditions | Ratings | Unit | |----------------------------------------------|------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|------| | Supply Voltage | V <sub>DD</sub> | | | -0.5 to + 6.5 | V | | REGC terminal input voltage <sup>Note1</sup> | Virego | REGC | | -0.3 to +2.8<br>and -0.3 to V <sub>DD</sub> + 0.3<br><sub>Note 2</sub> | V | | Input Voltage | VII | Other than P60, F | P61 | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 3</sup> | V | | | V <sub>12</sub> | P60, P61 (N-ch o | pen drain) | -0.3 to 6.5 | V | | Output Voltage | Vo | | | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 3</sup> | V | | Analog input voltage | Val | 20-, 24-pin produ | cts: ANI0 to ANI3, ANI16 to ANI22 | -0.3 to V <sub>DD</sub> + 0.3 | V | | | | 30-pin products: A | ANI0 to ANI3, ANI16 to ANI19 | and -0.3 to<br>AVREF(+)+0.3 Notes 3, 4 | | | Output current, high | Іон1 | Per pin | Other than P20 to P23 | -40 | mA | | | | Total of all pins | All the terminals other than P20 to P23 | -170 | mA | | | | | 20-, 24-pin products: P40 to P42 | -70 | mA | | | | | 30-pin products: P00, P01, P40, P120 | | | | | | | 20-, 24-pin products: P00 to P03 <sup>Note 5</sup> ,<br>P10 to P14<br>30-pin products: P10 to P17, P30, P31,<br>P50, P51, P147 | -100 | mA | | | <b>І</b> он2 | Per pin | P20 to P23 | -0.5 | mA | | | | Total of all pins | | -2 | mA | | Output current, low | lol1 | Per pin | Other than P20 to P23 | 40 | mA | | | | Total of all pins | All the terminals other than P20 to P23 | 170 | mA | | | | | 20-, 24-pin products: P40 to P42<br>30-pin products: P00, P01, P40, P120 | 70 | mA | | | | | 20-, 24-pin products: P00 to P03 <sup>Note 5</sup> ,<br>P10 to P14, P60, P61<br>30-pin products: P10 to P17, P30, P31,<br>P50, P51, P60, P61, P147 | 100 | mA | | | lo <sub>L2</sub> | Per pin | P20 to P23 | 1 | mA | | | | Total of all pins | | 5 | mA | | Operating ambient temperature | Та | | | -40 to +85 | °C | | Storage temperature | T <sub>stg</sub> | | | -65 to +150 | °C | Notes 1. 30-pin product only. - 2. Connect the REGC pin to Vss via a capacitor (0.47 to 1 $\mu$ F). This value determines the absolute maximum rating of the REGC pin. Do not use it with voltage applied. - 3. Must be 6.5 V or lower. - 4. Do not exceed AVREF(+) + 0.3 V in case of A/D conversion target pin. - 5. 24-pin products only. **Caution** Product quality may suffer if the absolute maximum rating is exceeded even momentarily for any parameter. That is, the absolute maximum ratings are rated values at which the product is on the verge of suffering physical damage, and therefore the product must be used under conditions that ensure that the absolute maximum ratings are not exceeded. **Remarks 1.** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. - **2.** AVREF(+): + side reference voltage of the A/D converter. - 3. Vss: Reference voltage #### 28.2 Oscillator Characteristics ### 28.2.1 X1 oscillator characteristics $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Resonator | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------|---------------------|---------------------------------|------|------|------|------| | X1 clock oscillation | Ceramic resonator / | $2.7~V \leq V_{DD} \leq 5.5~V$ | 1.0 | | 20.0 | MHz | | frequency (fx) <sup>Note</sup> | crystal oscillator | 1.8 V ≤ V <sub>DD</sub> < 2.7 V | 1.0 | | 8.0 | | **Note** Indicates only permissible oscillator frequency ranges. Refer to AC Characteristics for instruction execution time. Request evaluation by the manufacturer of the oscillator circuit mounted on a board to check the oscillator characteristics. Caution Since the CPU is started by the high-speed on-chip oscillator clock after a reset release, check the X1 clock oscillation stabilization time using the oscillation stabilization time counter status register (OSTC) by the user. Determine the oscillation stabilization time of the OSTC register and the oscillation stabilization time select register (OSTS) after sufficiently evaluating the oscillation stabilization time with the resonator to be used. Remark When using the X1 oscillator, refer to 5.4 System Clock Oscillator. ## 28.2.2 On-chip oscillator characteristics $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | 17. 10 10 100 0, 110 1 | | ·, · · · · · · | | | | | | |----------------------------------------------------------|------------|-----------------|---------------------------------------------|------|------|------|------| | Oscillators | Parameters | Condit | tions | MIN. | TYP. | MAX. | Unit | | High-speed on-chip oscillator clock frequency Notes 1, 2 | fін | | | 1 | | 24 | MHz | | High-speed on-chip oscillator | | R5F102 products | $T_A = -20 \text{ to } +85^{\circ}\text{C}$ | -1.0 | | +1.0 | % | | clock frequency accuracy | | | $T_A = -40 \text{ to } -20^{\circ}\text{C}$ | -1.5 | | +1.5 | % | | | | R5F103 products | | -5.0 | | +5.0 | % | | Low-speed on-chip oscillator clock frequency | fıL | | | | 15 | | kHz | | Low-speed on-chip oscillator clock frequency accuracy | | | | -15 | | +15 | % | **Notes 1.** High-speed on-chip oscillator frequency is selected by bits 0 to 3 of option byte (000C2H) and bits 0 to 2 of HOCODIV register. 2. This only indicates the oscillator characteristics. Refer to AC Characteristics for instruction execution time. #### 28.3 DC Characteristics ## 28.3.1 Pin characteristics $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (1/4) | Parameter | Symbol | Conditions | | MIN. | TYP. | MAX. | Unit | |----------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------|------|-----------------|------| | Output current, high <sup>Note 1</sup> | Іонт | 20-, 24-pin products: Per pin for P00 to P03 <sup>Note 4</sup> , P10 to P14, P40 to P42 | | | | -10.0<br>Note 2 | mA | | | | 30-pin products:<br>Per pin for P00, P01, P10 to P17, P30,<br>P31, P40, P50, P51, P120, P147 | | | | | | | | | 20-, 24-pin products:<br>Total of P40 to P42 | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | -30.0 | mA | | | | | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.0~\textrm{V}$ | | | -6.0 | mA | | | | 30-pin products:<br>Total of P00, P01, P40, P120<br>(When duty ≤ 70% Note 3) | 1.8 V ≤ V <sub>DD</sub> < 2.7 V | | | -4.5 | mA | | | | 20-, 24-pin products: Total of P00 to P03 <sup>Note 4</sup> , P10 to P14 30-pin products: Total of P10 to P17, P30, P31, P50, P51, P147 (When duty ≤ 70% Note 3) | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | -80.0 | mA | | | | | $2.7~\textrm{V} \leq \textrm{V}_\textrm{DD} < 4.0~\textrm{V}$ | | | -18.0 | mA | | | | | 1.8 V ≤ V <sub>DD</sub> < 2.7 V | | | -10.0 | mA | | | | Total of all pins (When duty ≤ 70% Note 3) | | | | -100 | mA | | | Іон2 | Per pin for P20 to P23 | | | | -0.1 | mA | | | | Total of all pins | | _ | | -0.4 | mA | - Notes 1. value of current at which the device operation is guaranteed even if the current flows from the VDD pin to an output pin. - 2. However, do not exceed the total current value. - 3. The output current value under conditions where the duty factor $\leq 70\%$ . If duty factor > 70%: The output current value can be calculated with the following expression (where n represents the duty factor as a percentage). - Total output current of pins = $(loh \times 0.7)/(n \times 0.01)$ - <Example> Where n = 80% and IoH = -10.0 mA Total output current of pins = $(-10.0 \times 0.7)/(80 \times 0.01) \approx -8.7$ mA However, the current that is allowed to flow into one pin does not vary depending on the duty factor. A current higher than the absolute maximum rating must not flow into one pin. 4. 24-pin products only. Caution P10 to P12 and P41 for 20-pin products, P01, P10 to P12, and P41 for 24-pin products, and P00, P10 to P15, P17, and P50 for 30-pin products do not output high level in N-ch open-drain mode. Remark Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (2/4) | Parameter | Symbol | Conditions | | MIN. | TYP. | MAX. | Unit | |---------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------|------|----------------|------| | Output current, low <sup>Note 1</sup> | lo <sub>L1</sub> | 20-, 24-pin products: Per pin for P00 to P03 <sup>Note 4</sup> , P10 to P14, P40 to P42 | | | | 20.0<br>Note 2 | mA | | | | 30-pin products:<br>Per pin for P00, P01, P10 to P17, P30,<br>P31, P40, P50, P51, P120, P147 | | | | | | | | | Per pin for P60, P61 | | | | 15.0<br>Note 2 | mA | | | | 20-, 24-pin products: | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | 60.0 | mA | | | | Total of P40 to P42 | $2.7~V \leq V_{DD} < 4.0~V$ | | | 9.0 | mA | | | | 30-pin products:<br>Total of P00, P01, P40, P120<br>(When duty ≤ 70% Note 3) | $1.8~\textrm{V} \leq \textrm{V}_\textrm{DD} < 2.7~\textrm{V}$ | | | 1.8 | mA | | | | 20-, 24-pin products: | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | 80.0 | mA | | | | Total of P00 to P03 <sup>Note 4</sup> , | $2.7~V \leq V_{DD} < 4.0~V$ | | | 27.0 | mA | | | | P10 to P14, P60, P61 30-pin products: Total of P10 to P17, P30, P31, P50, P51, P60, P61, P147 (When duty ≤ 70% Note 3) | 1.8 V ≤ V <sub>DD</sub> < 2.7 V | | | 5.4 | mA | | | | Total of all pins (When duty ≤ 70% Note 3) | | | | 140 | mA | | | lol2 | Per pin for P20 to P23 | | | | 0.4 | mA | | | | Total of all pins | | | | 1.6 | mA | **Notes 1**. Value of current at which the device operation is guaranteed even if the current flows from an output pin to the Vss pin. - 2. However, do not exceed the total current value. - 3. The output current value under conditions where the duty factor $\leq 70\%$ . If duty factor > 70%: The output current value can be calculated with the following expression (where n represents the duty factor as a percentage). - Total output current of pins = $(lol \times 0.7)/(n \times 0.01)$ - <Example> Where n = 80% and IoL = 10.0 mA Total output current of pins = $(10.0 \times 0.7)/(80 \times 0.01) \approx 8.7$ mA However, the current that is allowed to flow into one pin does not vary depending on the duty factor. A current higher than the absolute maximum rating must not flow into one pin. 4. 24-pin products only. **Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. $(TA = -40 \text{ to } +85^{\circ}C, 1.8 \text{ V} \le VDD \le 5.5 \text{ V}, Vss = 0 \text{ V})$ (3/4) | • | | , , | | | | | | |----------------------|----------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------|------|--------------------|----------| | Parameter | Symbol | Condition | s | MIN. | TYP. | MAX. | Unit | | Input voltage, high | V <sub>IH1</sub> | Normal input buffer | | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | | 20-, 24-pin products: P00 to P0<br>P40 to P42 | 03 <sup>Note 2</sup> , P10 to P14, | | | | | | | | 30-pin products: P00, P01, P1<br>P40, P50, P51, P120, P147 | | | | | | | | V <sub>IH2</sub> | TTL input buffer | $4.0~V \leq V_{DD} \leq 5.5~V$ | 2.2 | | V <sub>DD</sub> | ٧ | | | | 20-, 24-pin products: P10, P11 | $3.3~V \leq V_{DD} < 4.0~V$ | 2.0 | | V <sub>DD</sub> | ٧ | | | | 30-pin products: P01, P10,<br>P11, P13 to P17 | 1.8 V ≤ V <sub>DD</sub> < 3.3 V | 1.5 | | V <sub>DD</sub> | <b>V</b> | | | VIH3 | P20 to P23 | | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | V <sub>IH4</sub> | P60, P61 | | 0.7V <sub>DD</sub> | | 6.0 | ٧ | | | V <sub>IH5</sub> | P121, P122, P125 <sup>Note 1</sup> , P137, EXCLK, RESET | | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | Input voltage, low | ge, low V <sub>IL1</sub> Normal input buffer | | | 0 | | 0.2V <sub>DD</sub> | ٧ | | | | 20-, 24-pin products: P00 to P0<br>P40 to P42 | | | | | | | | | 30-pin products: P00, P01, P10<br>P40, P50, P51, P120, P147 | to P17, P30, P31, | | | | | | | V <sub>IL2</sub> | TTL input buffer | $4.0~V \leq V_{DD} \leq 5.5~V$ | 0 | | 0.8 | > | | | | 20-, 24-pin products: P10, P11 | $3.3~V \leq V_{DD} < 4.0~V$ | 0 | | 0.5 | ٧ | | | | 30-pin products: P01, P10,<br>P11, P13 to P17 | $1.8~V \le V_{DD} < 3.3~V$ | 0 | | 0.32 | V | | | V <sub>IL3</sub> | P20 to P23 | | 0 | | 0.3V <sub>DD</sub> | ٧ | | | V <sub>IL4</sub> | P60, P61 | | 0 | | 0.3V <sub>DD</sub> | ٧ | | | V <sub>IL5</sub> | P121, P122, P125 <sup>Note 1</sup> , P137, I | EXCLK, RESET | 0 | | 0.2V <sub>DD</sub> | ٧ | | Output voltage, high | V <sub>OH1</sub> | 20-, 24-pin products:<br>P00 to P03 <sup>Note 2</sup> , P10 to P14, | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ $I_{OH1} = -10.0 \text{ mA}$ | V <sub>DD</sub> -1.5 | | | V | | | | P40 to P42<br>30-pin products: | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ $I_{OH1} = -3.0 \text{ mA}$ | V <sub>DD</sub> -0.7 | | | V | | | | P00, P01, P10 to P17, P30, P31, P40, P50, P51, P120, | $2.7~V \leq V_{DD} \leq 5.5~V,$ $I_{OH1} = -2.0~mA$ | V <sub>DD</sub> -0.6 | | | V | | | | P147 | $1.8 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ $I_{OH1} = -1.5 \text{ mA}$ | V <sub>DD</sub> -0.5 | | | V | | | V <sub>OH2</sub> | P20 to P23 | Iон₂ = −100 μA | V <sub>DD</sub> -0.5 | | | V | Notes 1. 20, 24-pin products only. 2. 24-pin products only. Caution The maximum value of VIH of pins P10 to P12 and P41 for 20-pin products, P01, P10 to P12, and P41 for 24pin products, and P00, P10 to P15, P17, and P50 for 30-pin products is VDD even in N-ch open-drain mode. High level is not output in the N-ch open-drain mode. Remark Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. $(TA = -40 \text{ to } +85^{\circ}C, 1.8 \text{ V} \le VDD \le 5.5 \text{ V}, Vss = 0 \text{ V})$ (4/4) | Parameter | Symbol | | Condition | ons | MIN. | TYP. | MAX. | Unit | |-----------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------|------|------|------------|------| | Output voltage, low | V <sub>OL1</sub> | 20-, 24-pin product<br>P00 to P03 <sup>Note</sup> , P10<br>P40 to P42 | | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ $I_{OL1} = 20.0 \text{ mA}$ $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ | | | 1.3<br>0.7 | V | | | | 30-pin products: P00, P01,<br>P10 to P17, P30, P31, P40,<br>P50, P51, P120, P147 | | $I_{OL1} = 8.5 \text{ mA}$<br>$2.7 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$<br>$I_{OL1} = 3.0 \text{ mA}$ | | | 0.6 | V | | | | | | | | | 0.4 | V | | | | | | $1.8~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 0.6~mA$ | | | 0.4 | V | | | V <sub>OL2</sub> | P20 to P23 | | Iol2 = 400 μA | | | 0.4 | V | | | V <sub>OL3</sub> | P60, P61 | P60, P61 4.1 lot | | | | 2.0 | V | | | | | | $4.0~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 5.0~mA$ | | | 0.4 | V | | | | | | $2.7~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 3.0~mA$ | | | 0.4 | V | | | | | | $1.8~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 2.0~mA$ | | | 0.4 | V | | Input leakage current, high | Ішн1 | Other than P121,<br>P122 | $V_{I} = V_{DD}$ | | | | 1 | μΑ | | | <b>І</b> Lін2 | P121, P122<br>(X1, X2/EXCLK) | $V_{I} = V_{DD}$ | Input port or external clock input | | | 1 | μΑ | | | | | | When resonator connected | | | 10 | μΑ | | Input leakage current, low | ILIL1 | Other than P121,<br>P122 | Vı = Vss | | | | -1 | μΑ | | | ILIL2 | P121, P122<br>(X1, X2/EXCLK) | Vı = Vss | Input port or external clock input | | | -1 | μΑ | | | | | | When resonator connected | | | -10 | μΑ | | On-chip pull-up resistance | Rυ | 20-, 24-pin products:<br>P00 to P03 <sup>Note</sup> , P10 to P14,<br>P40 to P42, P125, RESET<br>30-pin products: P00, P01,<br>P10 to P17, P30, P31, P40,<br>P50, P51, P120, P147 | | V <sub>I</sub> = Vss, input port | 10 | 20 | 100 | kΩ | Note 24-pin products only. **Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. #### 28.3.2 Supply current characteristics ### (1) 20-, 24-pin products $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (1/2) | Parameter | Symbol | | | Conditions | | | MIN. | TYP. | MAX. | Unit | |---------------------------|------------------|-----------|-------------------|---------------------------------------------------------------------|-----------|-------------------------|------|------|------|------| | Supply | I <sub>DD1</sub> | Operating | HS(High-speed | f⊩ = 24 MHz <sup>Note 3</sup> | Basic | V <sub>DD</sub> = 5.0 V | | 1.5 | | mA | | current <sup>Note 1</sup> | | mode | main) mode Note 4 | | operation | V <sub>DD</sub> = 3.0 V | | 1.5 | | | | | | | | | Normal | V <sub>DD</sub> = 5.0 V | | 3.3 | 5.0 | mA | | | | | | | operation | V <sub>DD</sub> = 3.0 V | | 3.3 | 5.0 | | | | | | | f⊩ = 16 MHz <sup>Note 3</sup> | | V <sub>DD</sub> = 5.0 V | | 2.5 | 3.7 | mA | | | | | | | | V <sub>DD</sub> = 3.0 V | | 2.5 | 3.7 | | | | | | LS(Low-speed | f⊩ = 8 MHz <sup>Note 3</sup> | | V <sub>DD</sub> = 3.0 V | | 1.2 | 1.8 | mA | | | | | main) mode Note 4 | | | V <sub>DD</sub> = 2.0 V | | 1.2 | 1.8 | | | | | | HS(High-speed | $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 2.8 | 4.4 | mA | | | | | main) mode Note4 | $V_{DD} = 5.0 \text{ V}$ $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ | | Resonator connection | | 3.0 | 4.6 | | | | | | | | | Square wave input | | 2.8 | 4.4 | mA | | | | | | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 3.0 | 4.6 | | | | | | | $f_{MX} = 10 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 1.8 | 2.6 | mA | | | | | | $V_{DD} = 5.0 \text{ V}$ | | Resonator connection | | 1.8 | 2.6 | | | | | | | $f_{MX} = 10 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 1.8 | 2.6 | mA | | | | | | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 1.8 | 2.6 | | | | | | LS(Low-speed | $f_{MX} = 8 \text{ MHz}^{Note 2},$ | | Square wave input | | 1.1 | 1.7 | mA | | | | | main) mode Note 4 | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 1.1 | 1.7 | | | | | | | f <sub>MX</sub> = 8 MHz <sup>Note 2</sup> , | | Square wave input | | 1.1 | 1.7 | mA | | | | | | $V_{DD} = 2.0 \text{ V}$ | | Resonator connection | | 1.1 | 1.7 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to VDD or Vss. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing during data flash rewrite. - 2. When high-speed on-chip oscillator clock is stopped. - 3. When high-speed system clock is stopped - **4.** Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS(High speed main) mode: $V_{DD}$ = 2.7 V to 5.5 V @1 MHz to 24 MHz $V_{\text{DD}}$ = 2.4 V to 5.5 V @1 MHz to 16 MHz LS(Low speed main) mode: $V_{DD} = 1.8 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 8 \text{ MHz}$ - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - **3.** Temperature condition of the TYP. value is $T_A = 25$ °C. #### (1) 20-, 24-pin products $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{ Vss} = 0 \text{ V})$ (2/2) | Parameter | Symbol | | | Conditions | | MIN. | TYP. | MAX. | Unit | |----------------|-------------------------|------------------------|------------------------------|--------------------------------------------|-------------------------|------|------|------|------| | Supply | I <sub>DD2</sub> Note 2 | HALT | HS (High-speed | fin = 24 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 440 | 1210 | μА | | current Note 1 | | mode | main) mode <sup>Note 6</sup> | | V <sub>DD</sub> = 3.0 V | | 440 | 1210 | | | | | | | fin = 16 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 400 | 950 | μА | | | | | | | V <sub>DD</sub> = 3.0 V | | 400 | 950 | | | | | | LS (Low-speed | fih = 8 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 3.0 V | | 270 | 542 | μА | | | | | main) mode <sup>Note 6</sup> | | V <sub>DD</sub> = 2.0 V | | 270 | 542 | | | | | | HS (High-speed | $f_{MX} = 20 \text{ MHz}^{\text{Note 3}},$ | Square wave input | | 280 | 1000 | μА | | | | | main) mode Note 6 | V <sub>DD</sub> = 5.0 V | Resonator connection | | 450 | 1170 | | | | | | | $f_{MX} = 20 \text{ MHz}^{Note 3},$ | Square wave input | | 280 | 1000 | μA | | | | | V <sub>DD</sub> = 3.0 V | Resonator connection | | 450 | 1170 | | | | | | | | $f_{MX} = 10 \text{ MHz}^{Note 3},$ | Square wave input | | 190 | 590 | μΑ | | | | | | V <sub>DD</sub> = 5.0 V | Resonator connection | | 260 | 660 | | | | | | | $f_{MX} = 10 \text{ MHz}^{Note 3},$ | Square wave input | | 190 | 590 | μΑ | | | | | | V <sub>DD</sub> = 3.0 V | Resonator connection | | 260 | 660 | | | | | | LS (Low-speed | fmx = 8 MHz <sup>Note 3</sup> , | Square wave input | | 110 | 360 | μΑ | | | | | main) mode Note 6 | V <sub>DD</sub> = 3.0 V | Resonator connection | | 150 | 416 | | | | | | | $f_{MX} = 8 MHz^{Note 3},$ | Square wave input | | 110 | 360 | μA | | | | | | V <sub>DD</sub> = 2.0 V | Resonator connection | | 150 | 416 | | | | I <sub>DD3</sub> Note 5 | STOP | T <sub>A</sub> = -40°C | | | | 0.19 | 0.50 | μA | | | mode | T <sub>A</sub> = +25°C | | | | 0.24 | 0.50 | | | | | | T <sub>A</sub> = +50°C | | | | 0.32 | 0.80 | | | | | | T <sub>A</sub> = +70°C | | | | 0.48 | 1.20 | | | | | | | T <sub>A</sub> = +85°C | | | | 0.74 | 2.20 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to VDD or Vss. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing during data flash rewrite. - 2. During HALT instruction execution by flash memory. - 3. When high-speed on-chip oscillator clock is stopped. - 4. When high-speed system clock is stopped. - 5. Not including the current flowing into the 12-bit interval timer and watchdog timer. - **6.** Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS(High speed main) mode: VDD = 2.7 V to 5.5 V @1 MHz to 24 MHz V<sub>DD</sub> = 2.4 V to 5.5 V @1 MHz to 16 MHz LS(Low speed main) mode: VDD = 1.8 V to 5.5 V @1 MHz to 8 MHz - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - 3. Except temperature condition of the TYP. value is $T_A = 25$ °C, other than STOP mode ### (2) 30-pin products $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (1/2) | | , . | | 3 0.0 V, V33 = | / | | | | | | (1/2 | |----------------|------------------|-----------|-------------------|----------------------------------------------------------------------------------------------|--------------------------|-------------------------|----------------------|------|------|------| | Parameter | Symbol | | | Conditions | | | MIN. | TYP. | MAX. | Unit | | Supply | I <sub>DD1</sub> | Operating | HS (High-speed | f⊪ = 24 MHz <sup>Note 3</sup> | Basic | V <sub>DD</sub> = 5.0 V | | 1.5 | | mA | | current Note 1 | | mode | main) mode Note 4 | | operation | V <sub>DD</sub> = 3.0 V | | 1.5 | | | | | | | | | Normal | V <sub>DD</sub> = 5.0 V | | 3.7 | 5.5 | mA | | | | | | | operation | V <sub>DD</sub> = 3.0 V | | 3.7 | 5.5 | | | | | | | f⊪ = 16 MHz <sup>Note 3</sup> | | V <sub>DD</sub> = 5.0 V | | 2.7 | 4.0 | mA | | | | | | | | V <sub>DD</sub> = 3.0 V | | 2.7 | 4.0 | | | | | | LS (Low-speed | f⊪ = 8 MHz <sup>Note 3</sup> | | V <sub>DD</sub> = 3.0 V | | 1.2 | 1.8 | mA | | | | | main) mode Note 4 | | | V <sub>DD</sub> = 2.0 V | | 1.2 | 1.8 | | | | | | HS (High-speed | $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 3.0 | 4.6 | mA | | | | | main) mode Note 4 | $V_{DD} = 5.0 \text{ V}$ $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 3.2 | 4.8 | | | | | | | | | Square wave input | | 3.0 | 4.6 | mA | | | | | | | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 3.2 | 4.8 | | | | | | $f_{MX} = 10 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 1.9 | 2.7 | mA | | | | | | V <sub>DD</sub> = 5.0 V | | Resonator connection | | 1.9 | 2.7 | | | | | | | $f_{MX} = 10 \text{ MHz}^{Note 2},$ | | Square wave input | | 1.9 | 2.7 | mA | | | | | | V <sub>DD</sub> = 3.0 V | | Resonator connection | | 1.9 | 2.7 | | | | | | LS (Low-speed | $f_{MX} = 8 MHz^{Note 2}$ | | Square wave input | | 1.1 | 1.7 | mA | | | | | main) mode Note 4 | V <sub>DD</sub> = 3.0 V | | Resonator connection | | 1.1 | 1.7 | | | | | | | $f_{MX} = 8 MHz^{Note 2}$ | | Square wave input | | 1.1 | 1.7 | mA | | | | | | $V_{DD} = 2.0 \text{ V}$ | | Resonator connection | | 1.1 | 1.7 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to VDD or Vss. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing during data flash rewrite. - 2. When high-speed on-chip oscillator clock is stopped. - 3. When high-speed system clock is stopped - **4.** Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS(High speed main) mode: VDD = 2.7 V to 5.5 V @1 MHz to 24 MHz V<sub>DD</sub> = 2.4 V to 5.5 V @1 MHz to 16 MHz LS(Low speed main) mode: $V_{DD} = 1.8 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 8 \text{ MHz}$ - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - **3.** Temperature condition of the TYP. value is $T_A = 25^{\circ}C$ . ### (2) 30-pin products $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{ Vss} = 0 \text{ V})$ (2/2) | Parameter | Symbol | | | Conditions | | MIN. | TYP. | MAX. | Unit | |----------------|------------------------|-------------------------------------------|-------------------------|----------------------------------------------|-------------------------|------|------|------|------| | Supply | IDD2 Note 2 | HALT | HS (High-speed | fin = 24 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 440 | 1280 | μА | | current Note 1 | | mode | main) mode Note 6 | | V <sub>DD</sub> = 3.0 V | | 440 | 1280 | | | | | | | fin = 16 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 400 | 1000 | μА | | | | | | | V <sub>DD</sub> = 3.0 V | | 400 | 1000 | | | | | | LS (Low-speed | fih = 8 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 3.0 V | | 260 | 530 | μA | | | | | main) mode Note 6 | | V <sub>DD</sub> = 2.0 V | | 260 | 530 | | | | | | HS (High-speed | f <sub>MX</sub> = 20 MHz <sup>Note 3</sup> , | Square wave input | | 280 | 1000 | μА | | | | | main) mode Note 6 | V <sub>DD</sub> = 5.0 V | Resonator connection | | 450 | 1170 | | | | | | | $f_{MX} = 20 \text{ MHz}^{\text{Note 3}},$ | Square wave input | | 280 | 1000 | μA | | | | | V <sub>DD</sub> = 3.0 V | Resonator connection | | 450 | 1170 | | | | | | | | $f_{MX} = 10 \text{ MHz}^{\text{Note 3}},$ | Square wave input | | 190 | 600 | μА | | | | | | V <sub>DD</sub> = 5.0 V | Resonator connection | | 260 | 670 | | | | | | | $f_{MX} = 10 \text{ MHz}^{\text{Note 3}},$ | Square wave input | | 190 | 600 | μΑ | | | | | | V <sub>DD</sub> = 3.0 V | Resonator connection | | 260 | 670 | | | | | | LS (Low-speed | fmx = 8 MHz <sup>Note 3</sup> , | Square wave input | | 95 | 330 | μΑ | | | | | main) mode Note 6 | V <sub>DD</sub> = 3.0 V | Resonator connection | | 145 | 380 | | | | | | | fmx = 8 MHz <sup>Note 3</sup> | Square wave input | | 95 | 330 | μΑ | | | | | | V <sub>DD</sub> = 2.0 V | Resonator connection | | 145 | 380 | | | | IDD3 <sup>Note 5</sup> | STOP | $T_A = -40^{\circ}C$ | | | | 0.18 | 0.50 | μΑ | | | mode | T <sub>A</sub> = +25°C | | | | 0.23 | 0.50 | | | | | | $T_A = +50^{\circ}C$ $T_A = +70^{\circ}C$ | | | | 0.30 | 1.10 | | | | | | | | | | 0.46 | 1.90 | | | | | | | T <sub>A</sub> = +85°C | | | | 0.75 | 3.30 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to VDD or Vss. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing during data flash rewrite. - 2. During HALT instruction execution by flash memory. - 3. When high-speed on-chip oscillator clock is stopped. - 4. When high-speed system clock is stopped. - 5. Not including the current flowing into the 12-bit interval timer and watchdog timer. - 6. Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS (High speed main) mode: VDD = 2.7 V to 5.5 V @1 MHz to 24 MHz $V_{DD} = 2.4 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 16 \text{ MHz}$ LS (Low speed main) mode: VDD = 1.8 V to 5.5 V @1 MHz to 8 MHz - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - 3. Except STOP mode, temperature condition of the TYP. value is $T_A = 25$ °C. ### (3) Peripheral functions (Common to all products) ### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | | Conditions | MIN. | TYP. | MAX. | Unit | |---------------------------------------------------------|------------------------|--------------------|-------------------------------------------------------------------------------------|------|------|-------|------| | Low-speed onchip oscillator operating current | FIL Note 1 | | | | 0.20 | | μΑ | | 12-bit interval<br>timer operating<br>current | ÎTMKA<br>Notes 1, 2, 3 | | | | 0.02 | | μΑ | | Watchdog timer operating current | WDT<br>Notes 1, 2, 4 | fı∟ = 15 kHz | | | 0.22 | | μΑ | | A/D converter | ADC Notes 1, 5 | When conversion at | Normal mode, AV <sub>REFP</sub> = V <sub>DD</sub> = 5.0 V | | 1.30 | 1.70 | mA | | operating current | | maximum speed | Low voltage mode, AVREFP = VDD = 3.0 V | | 0.50 | 0.70 | mA | | A/D converter<br>reference voltage<br>operating current | ADREF Note 1 | | | | 75.0 | | μΑ | | Temperature sensor operating current | TMPS Note 1 | | | | 75.0 | | μΑ | | LVD operating current | ILVD Notes 1, 6 | | | | 0.08 | | μΑ | | Self-<br>programming<br>operating current | FSP Notes 1, 8 | | | | 2.00 | 12.20 | mA | | BGO operating current | IBGO Notes 1, 7 | | | | 2.00 | 12.20 | mA | | SNOOZE | ISNOZ Note 1 | ADC operation | The mode is performed Note 9 | | 0.50 | 0.60 | mA | | operating current | | | The A/D conversion operations are performed, Low voltage mode, AVREFP = VDD = 3.0 V | | 1.20 | 1.44 | mA | | | | CSI/UART operation | | | 0.70 | 0.84 | mA | ### Notes 1. Current flowing to the $V_{\text{DD}}$ . - 2. When high speed on-chip oscillator and high-speed system clock are stopped. - 3. Current flowing only to the 12-bit interval timer (excluding the operating current of the low-speed on-chip oscillator). The current value of the RL78 microcontrollers is the sum of IDD1, IDD2 or IDD3, and IFIL and ITMKA when the 12-bit interval timer operates. - 4. Current flowing only to the watchdog timer (including the operating current of the low-speed on-chip oscillator). The current value of the RL78 microcontrollers is the sum of IDD1, IDD2 or IDD3 and IWDT when the watchdog timer operates. - **5.** Current flowing only to the A/D converter. The current value of the RL78 microcontrollers is the sum of IDD1 or IDD2 and IADC when the A/D converter operates in an operation mode or the HALT mode. - **6.** Current flowing only to the LVD circuit. The current value of the RL78 microcontrollers is the sum of IDD1, IDD2 or IDD3 and ILVD when the LVD circuit operates. - 7. Current flowing only during data flash rewrite. - 8. Current flowing only during self programming. - 9. For shift time to the SNOOZE mode, see 17.3.3 SNOOZE mode. ### Remarks 1. fil: Low-speed on-chip oscillator clock frequency **2.** Temperature condition of the TYP. value is $T_A = 25^{\circ}C$ ### 28.4 AC Characteristics $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Items | Symbol | | Condition | s | MIN. | TYP. | MAX. | Unit | |------------------------------------------------------------|--------------|--------------------------------|---------------------------------|---------------------------------------------------------------|----------------|------|------|------| | Instruction cycle (minimum | Tcy | Main system | HS (High- | $2.7~V \leq V_{DD} \leq 5.5~V$ | 0.04167 | | 1 | μS | | instruction execution time) | | clock (fmain) operation | speed main)<br>mode | $2.4~V \leq V_{DD} < 2.7~V$ | 0.0625 | | 1 | μs | | | | | LS (Low-<br>speed main)<br>mode | $1.8~V \leq V_{DD} \leq 5.5~V$ | 0.125 | | 1 | μS | | | | During self | HS (High- | $2.7~V \leq V_{DD} \leq 5.5~V$ | 0.04167 | | 1 | μS | | | | programming | speed main)<br>mode | $2.4~\textrm{V} \leq \textrm{V}_\textrm{DD} < 2.7~\textrm{V}$ | 0.0625 | | 1 | μS | | | | | LS (Low-<br>speed main)<br>mode | $1.8~V \leq V_{DD} \leq 5.5~V$ | 0.125 | | 1 | μS | | External main system clock | fex | $2.7~V \leq V_{DD} \leq 5$ | .5 V | | 1.0 | | 20.0 | MHz | | frequency | | $2.4~V \leq V_{DD} < 2$ | .7 V | | 1.0 | | 16.0 | MHz | | | | 1.8 V ≤ V <sub>DD</sub> < 2 | .4 V | | 1.0 | | 8.0 | MHz | | External main system clock | texh, texl | $2.7~V \le V_{DD} \le 5$ | .5 V | | 24 | | | ns | | input high-level width, low-<br>level width | | $2.4~V \leq V_{DD} < 2$ | .7 V | | 30 | | | ns | | level width | | $1.8~V \leq V_{DD} < 2$ | .4 V | | 60 | | | ns | | TI00 to TI07 input high-level width, low-level width | tπн, tπ∟ | | | | 1/fмск +<br>10 | | | ns | | TO00 to TO07 output | fто | 4.0 V ≤ V <sub>DD</sub> ≤ 5 | .5 V | | | | 12 | MHz | | frequency | | $2.7~V \leq V_{DD} < 4$ | .0 V | | | | 8 | MHz | | | | 1.8 V ≤ V <sub>DD</sub> < 2 | .7 V | | | | 4 | MHz | | PCLBUZ0, or PCLBUZ1 | fPCL | 4.0 V ≤ V <sub>DD</sub> ≤ 5 | .5 V | | | | 16 | MHz | | output frequency | | $2.7~V \leq V_{\text{DD}} < 4$ | .0 V | | | | 8 | MHz | | | | $1.8~V \leq V_{DD} < 2$ | .7 V | | | | 4 | MHz | | INTP0 to INTP5 input high-<br>level width, low-level width | tinth, tintl | | | | 1 | | | μs | | KR0 to KR9 input available width | tkr | | | | 250 | | | ns | | RESET low-level width | trsL | | | | 10 | | | μS | Remark fmck: Timer array unit operation clock frequency (Operation clock to be set by the timer clock select register 0 (TPS0) and the CKS0n bit of timer mode register 0 (TMR0n). n: Channel number (n = 0 to 7)) ### Minimum Instruction Execution Time during Main System Clock Operation ### **AC Timing Test Point** ### **External Main System Clock Timing** ### **TI/TO Timing** ### **Interrupt Request Input Timing** ### **Key Interrupt Input Timing** ### **RESET Input Timing** ### 28.5 Peripheral Functions Characteristics ### **AC Timing Test Point** #### 28.5.1 Serial array unit ### (1) During communication at same potential (UART mode) ### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | | | , , | | | | | | |---------------|--------|------------------------------------------------|------|------------------------------|------|-----------------------------|------| | Parameter | Symbol | Conditions | | HS (high-speed<br>main) Mode | | LS (low-speed<br>main) Mode | | | | | | MIN. | MAX. | MIN. | MAX. | | | Transfer rate | | | | fмск/6 | | fмск/6 | bps | | Note 1 | | Theoretical value of the maximum transfer rate | | 4.0 | | 1.3 | Mbps | | | | $f_{CLK} = f_{MCK}^{Note2}$ | | | | | | Notes 1. Transfer rate in the SNOOZE mode is 4800 bps only. 2. The maximum operating frequencies of the CPU/peripheral hardware clock (fclk) are: HS (high-speed main) mode: 24 MHz (2.7 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V) 16 MHz (2.4 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V) LS (low-speed main) mode: $8 \text{ MHz} (1.8 \text{ V} \leq \text{V}_{DD} \leq 5.5 \text{ V})$ Caution Select the normal input buffer for the RxDq pin and the normal output mode for the TxDq pin by using port input mode register g (PIMg) and port output mode register g (POMg). ### **UART** mode connection diagram (during communication at same potential) ### UART mode bit width (during communication at same potential) (reference) **Remarks 1.** q: UART number (q = 0 to 2), g: PIM, POM number (g = 0, 1) 2. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number, n: Channel number (mn = 00 to 03, 10, 11)) ## (2) During communication at same potential (CSI mode) (master mode, SCK00... internal clock output, corresponding CSI00 only) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 2.7 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | HS (high-spo | , | LS (low-sp | Unit | | |----------------------------------------------------|------------------|--------------------------------|--------------|------|------------|------|----| | | | | MIN. | MAX. | MIN. | MAX. | | | SCK00 cycle time | tkCY1 | tkcy1 ≥ 2/fclk | 83.3 | | 250 | | ns | | SCK00 high-/low- | <b>t</b> кн1, | $4.0~V \leq V_{DD} \leq 5.5~V$ | tkcy1/2-7 | | tkcy1/2-50 | | ns | | level width | t <sub>KL1</sub> | $2.7~V \leq V_{DD} \leq 5.5~V$ | tkcy1/2-10 | | tkcy1/2-50 | | ns | | SI00 setup time | tsıĸı | $4.0~V \leq V_{DD} \leq 5.5~V$ | 23 | | 110 | | ns | | (to SCK00↑) Note 1 | | $2.7~V \leq V_{DD} \leq 5.5~V$ | 33 | | 110 | | ns | | SI00 hold time<br>(from SCK00↑) Note2 | tksi1 | | 10 | | 10 | | ns | | Delay time from<br>SCK00↓ to SO00<br>output Note 3 | tkso1 | C = 20 pF Note 4 | | 10 | | 10 | ns | - **Notes 1.** When DAP00 = 0 and CKP00 = 0, or DAP00 = 1 and CKP00 = 1. The SI00 setup time becomes "to $SCK00\downarrow$ " when DAP00 = 0 and CKP00 = 1, or DAP00 = 1 and CKP00 = 0. - 2. When DAP00 = 0 and CKP00 = 0, or DAP00 = 1 and CKP00 = 1. The SI00 hold time becomes "from SCK00 $\downarrow$ " when DAP00 = 0 and CKP00 = 1, or DAP00 = 1 and CKP00 = 0. - 3. When DAP00 = 0 and CKP00 = 0, or DAP00 = 1 and CKP00 = 1. The delay time to SO00 output becomes "from SCK00↑" when DAP00 = 0 and CKP00 = 1, or DAP00 = 1 and CKP00 = 0. - 4. C is the load capacitance of the SCK00 and SO00 output lines. **Caution** Select the normal input buffer for the SI00 pin and the normal output mode for the SO00 and SCK00 pins by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). Remarks 1. This specification is valid only when CSI00's peripheral I/O redirect function is not used. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register 0 (SPS0) and the CKS00 bit of serial mode register 00 (SMR00).) ## (3) During communication at same potential (CSI mode) (master mode, SCKp... internal clock output) ( $T_A = -40$ to +85°C, 1.8 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V, V<sub>SS</sub> = 0 V) | Parameter | Symbol | Conditions | | | HS (high-speed main) Mode | | eed main)<br>de | Unit | |--------------------------------------------|------------------|---------------------------|--------------------------------|------------|---------------------------|------------|-----------------|------| | | | | | MIN. | MAX. | MIN. | MAX. | | | SCKp cycle time | tkcy1 | tkcy₁ ≥ 4/fclk | $2.7~V \leq V_{DD} \leq 5.5~V$ | 167 | | 500 | | ns | | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | 250 | | 500 | | ns | | | | | $1.8~V \leq V_{DD} \leq 5.5~V$ | _ | | 500 | | ns | | SCKp high-/low-level width | <b>t</b> кн1, | 4.0 V ≤ V <sub>DD</sub> ≤ | 5.5 V | tксү1/2-12 | | tkcy1/2-50 | | ns | | | t <sub>KL1</sub> | $2.7~V \leq V_{DD} \leq$ | 5.5 V | tксү1/2-18 | | tkcy1/2-50 | | ns | | | | 2.4 V ≤ V <sub>DD</sub> ≤ | 5.5 V | tkcy1/2-38 | | tkcy1/2-50 | | ns | | | | 1.8 V ≤ V <sub>DD</sub> ≤ | 5.5 V | - | | tkcy1/2-50 | | ns | | SIp setup time (to SCKp↑) | tsıĸı | 4.0 V ≤ V <sub>DD</sub> ≤ | 5.5 V | 44 | | 110 | | ns | | Note 1 | | $2.7~V \leq V_{DD} \leq$ | 5.5 V | 44 | | 110 | | ns | | | | $2.4~V \leq V_{DD} \leq$ | 5.5 V | 75 | | 110 | | ns | | | | 1.8 V ≤ V <sub>DD</sub> ≤ | 5.5 V | _ | | 110 | | ns | | SIp hold time<br>(from SCKp↑) Note 2 | tksi1 | | | 19 | | 19 | | ns | | Delay time from SCKp↓ to SOp output Note 3 | tkso1 | C = 30 pF Note4 | | | 25 | | 25 | ns | - **Notes 1.** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp setup time becomes "to $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 2. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The Slp hold time becomes "from $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - **3.** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The delay time to SOp output becomes "from SCKp $\uparrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 4. C is the load capacitance of the SCKp and SOp output lines. **Caution** Select the normal input buffer for the SIp pin and the normal output mode for the SOp and SCKp pins by using port input mode register 1 (PIM1) and port output mode registers 0, 1, 4 (POM0, POM1, POM4). - **Remarks 1.** p: CSI number (p = 00, 01, 11, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0, 1, 3: "1, 3" is only for the R5F102 products) - 2. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number (m = 0, 1), n: Channel number (n = 0, 1, 3: "1, 3" is only for the R5F102 products.)) ### (4) During communication at same potential (CSI mode) (slave mode, SCKp... external clock input) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Cond | ditions | HS (high<br>main) l | • | LS (low-sp<br>Mo | | Unit | |----------------------------------|--------------------|--------------------------------------------------------------|--------------------------------|----------------------|----------------|------------------|-----------------|------| | | | | | MIN. | MAX. | MIN. | MAX. | | | SCKp cycle time Note4 | tkcy2 | $4.0~V \leq V_{DD} \leq 5.5~V$ | 20 MHz < fmck | 8/fмск | | - | | ns | | | | | fмcк ≤ 20 MHz | 6/fмск | | 6/fмск | | ns | | | | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$ | 16 MHz < fмск | 8/fмск | | - | | ns | | | | | fмcк ≤ 16 MHz | 6/fмск | | 6/fмск | | ns | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | 6/fмск | | 6/fмск | | ns | | | | | | and 500 | | and 500 | | | | | | $1.8~V \leq V_{DD} \leq 5.5~V$ | | - | | 6/fмск | | ns | | | | | | | | and 750 | | | | SCKp high-/low-level | t <sub>KH2</sub> , | $4.0~V \leq V_{DD} \leq 5.5~V$ | | tkcy2/2-7 | | tксү2/2-7 | | ns | | width tk | t <sub>KL2</sub> | $2.7~V \leq V_{DD} \leq 5.5~V$ | | tkcy2/2-8 | | tксү2/2-8 | | ns | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | tксү2/2-18 | | tксү2/2-18 | | ns | | | | $1.8~V \leq V_{DD} \leq 5.5~V$ | | - | | tксү2/2-18 | | ns | | SIp setup time | tsik2 | $2.7~V \leq V_{\text{DD}} \leq 5.5~V$ | | 1/fмск + | | 1/fмск + | | ns | | (to SCKp↑) Note 1 | | | | 20 | | 30 | | | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | 1/fмск + | | 1/fмск + | | ns | | | | | | 30 | | 30 | | | | | | $1.8 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V}$ | | = | | 1/fмск +<br>30 | | ns | | SIp hold time | t <sub>KSI2</sub> | | | 1/f <sub>MCK</sub> + | | 1/fмск + | | ns | | (from SCKp <sup>↑</sup> ) Note 2 | tivoi2 | | | 31 | | 31 | | | | Delay time from<br>SCKp↓ to | tkso2 | C = 30 pF Note4 | $2.7~V \leq V_{DD} \leq 5.5~V$ | | 2/fмск +<br>44 | | 2/fмск +<br>110 | ns | | SOp output Note 3 | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | 2/fмск +<br>75 | | 2/fмск +<br>110 | ns | | | | | $1.8~V \leq V_{DD} \leq 5.5~V$ | | - | | 2/fмск +<br>110 | ns | - **Notes 1.** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp setup time becomes "to $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 2. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp hold time becomes "from $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 3. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The delay time to SOp output becomes "from SCKp $\uparrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 4. C is the load capacitance of the SOp output lines. - 5. Transfer rate in the SNOOZE mode: MAX. 1 Mbps **Caution** Select the normal input buffer for the SIp and SCKp pins and the normal output mode for the SOp pin by using port input mode register 1 (PIM1) and port output mode registers 0, 1, 4 (POM0, POM1, POM4). ### CSI mode connection diagram (during communication at same potential) ## CSI mode serial transfer timing (during communication at same potential) (When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1.) # CSI mode serial transfer timing (during communication at same potential) (When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0.) (Remarks are listed on the next page.) - **Remarks 1.** p: CSI number (p = 00, 01, 11, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0, 1, 3: "1, 3" is only for the R5F102 products.) - 2. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number (m = 0, 1), n: Channel number (n = 0, 1, 3: "1, 3" is only for the R5F102 products.)) ### (5) During communication at same potential (simplified I<sup>2</sup>C mode) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | HS (high-speed | main) Mode | Unit | |-------------------------------|---------|----------------------------------------------------|---------------------|------------|------| | | | | LS (low-speed | main) Mode | | | | | | MIN. | MAX. | | | SCLr clock frequency | fscL | $1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V},$ | | 400 Note 1 | kHz | | | | $C_b = 100 \text{ pF}, R_b = 3 \text{ k}\Omega$ | | | | | | | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$ | | 300 Note 1 | kHz | | | | $C_b = 100 \text{ pF}, R_b = 5 \text{ k}\Omega$ | | | | | Hold time when SCLr = "L" | tLOW | $1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V},$ | 1150 | | ns | | | | $C_b = 100 \text{ pF}, R_b = 3 \text{ k}\Omega$ | | | | | | | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$ | 1550 | | ns | | | | $C_b = 100 \text{ pF}, R_b = 5 \text{ k}\Omega$ | | | | | Hold time when SCLr = "H" | tніgн | $1.8~V \leq V_{DD} \leq 5.5~V,$ | 1150 | | ns | | | | $C_b = 100 \text{ pF}, R_b = 3 \text{ k}\Omega$ | | | | | | | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$ | 1550 | | ns | | | | $C_b = 100 \text{ pF}, R_b = 5 \text{ k}\Omega$ | | | | | Data setup time (reception) | tsu:dat | $1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V},$ | 1/fмск + 145 Note 2 | | ns | | | | $C_b=100~pF,~R_b=3~k\Omega$ | | | | | | | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$ | 1/fмск + 230 Note 2 | | ns | | | | $C_b = 100 \text{ pF}, R_b = 5 \text{ k}\Omega$ | | | | | Data hold time (transmission) | thd:dat | $1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V},$ | 0 | 355 | ns | | | | $C_b=100~pF,~R_b=3~k\Omega$ | | | | | | | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$ | 0 | 405 | ns | | | | $C_b = 100 \text{ pF}, R_b = 5 \text{ k}\Omega$ | | | | - Notes 1. The value must also be equal to or less than fmck/4. - 2. Set tsu:DAT so that it will not exceed the hold time when SCLr = "L" or SCLr = "H". Caution Select the N-ch open drain output (VDD tolerance) mode for SDAr by using port output mode register h (POMh). (Remarks are listed on the next page.) ### Simplified I<sup>2</sup>C mode connection diagram (during communication at same potential) ### Simplified I<sup>2</sup>C mode serial transfer timing (during communication at same potential) - Remarks 1. Rb $[\Omega]$ :Communication line (SDAr) pull-up resistance Cb [F]: Communication line (SCLr, SDAr) load capacitance - 2. r: IIC number (r = 00, 01, 11, 20), h: = POM number (h = 0, 1, 4, 5) - 3. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number (m = 0, 1), n: Channel number (0, 1, 3)) - 4. Simplified I<sup>2</sup>C mode is supported only by the R5F102 products. ### (6) Communication at different potential (1.8 V, 2.5 V, 3 V) (UART mode) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | | С | onditions | | igh-speed<br>n) Mode | , | ow-speed<br>n) Mode | Unit | |------------|--------|--------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------|----------------------|------|---------------------|------| | | | | | | MIN. | MAX. | MIN. | MAX. | | | Transfer | | Reception | 4.0 V ≤ V <sub>DD</sub> ≤ | 5.5 V, | | fмск/6 | | fмск/6 | bps | | rate Note4 | | | $2.7~V \leq V_b \leq 4$ | I.0 V | | Note1 | | Note1 | | | | | | | Theoretical value of the maximum transfer rate $_{ m Note3}^{ m Note3}$ | | 4.0 | | 1.3 | Mbps | | | | | $2.7 \text{ V} \leq \text{V}_{DD} <$ $2.3 \text{ V} \leq \text{V}_{b} \leq 2$ | | | fmck/6<br>Note1 | | fmck/6<br>Note1 | bps | | | | | | Theoretical value of the maximum transfer rate $f_{MCK} = f_{CLK}^{Note3}$ | | 4.0 | | 1.3 | Mbps | | | | | 1.8 V ≤ V <sub>DD</sub> <<br>1.6 V ≤ V <sub>b</sub> ≤ 2 | 3.3 V, | | fmck/6<br>Notes1, 2 | | fmck/6<br>Notes1, 2 | bps | | | | | | Theoretical value of the maximum transfer rate $f_{MCK} = f_{CLK}^{Note3}$ | | 4.0 | | 1.3 | Mbps | | | | Transmission | 4.0 V ≤ V <sub>DD</sub> ≤ | | | Note4 | | Note4 | bps | | | | | $2.7~V \leq V_b \leq 4$ | I.0 V | | | | | | | | | | | Theoretical value of the maximum transfer rate $C_b = 50$ pF, $R_b = 1.4$ k $\Omega$ , $V_b = 2.7$ V | | 2.8<br>Note5 | | 2.8<br>Note5 | Mbps | | | | | 2.7 V ≤ V <sub>DD</sub> < | , | | Note6 | | Note6 | bps | | | | | $2.3~V \leq V_b \leq 2$ | · · | | | | | | | | | | | Theoretical value of the maximum transfer rate $C_b = 50 \text{ pF}, R_b = 2.7 \text{ k}\Omega, V_b = 2.3 \text{ V}$ | | 1.2<br>Note7 | | 1.2<br>Note7 | Mbps | | | | | 1.8 V ≤ V <sub>DD</sub> < | 3.3 V, | | Notes | | Notes | bps | | | | | $1.6~V \le V_b \le 2$ | 2.0 V | | 2, 8 | | 2, 8 | | | | | | | Theoretical value of the maximum transfer rate $C_b = 50 \text{ pF}, R_b = 5.5 \text{ k}\Omega, V_b = 1.6 \text{ V}$ | | 0.43<br>Note9 | | 0.43<br>Note9 | Mbps | Notes 1. Transfer rate in the SNOOZE mode is 4800 bps only. - 2. Use it with $V_{DD} \ge V_b$ . - 3. The maximum operating frequencies of the CPU/peripheral hardware clock (fclk) are: HS (high-speed main) mode: 24 MHz (2.7 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V) 16 MHz (2.4 V $$\leq$$ V<sub>DD</sub> $\leq$ 5.5 V) LS (low-speed main) mode: $8 \text{ MHz} (1.8 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V})$ 4. The smaller maximum transfer rate derived by using fmck/6 or the following expression is the valid maximum transfer rate. Expression for calculating the transfer rate when 4.0 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V and 2.7 V $\leq$ V<sub>b</sub> $\leq$ 4.0 V $$\label{eq:maximum transfer rate} \text{Maximum transfer rate} = \frac{1}{\{-C_b \times R_b \times \text{In } (1-\frac{2.2}{V_b})\} \times 3} \quad \text{[bps]}$$ Baud rate error (theoretical value) = $$\frac{\frac{1}{\text{Transfer rate} \times 2} - \{-C_b \times R_b \times \ln (1 - \frac{2.2}{V_b})\}}{(\frac{1}{\text{Transfer rate}}) \times \text{Number of transferred bits}} \times 100 \, [\%]$$ <sup>\*</sup> This value is the theoretical value of the relative difference between the transmission and reception sides. - **5.** This value as an example is calculated when the conditions described in the "Conditions" column are met. Refer to **Note 4** above to calculate the maximum transfer rate under conditions of the customer. - **6.** The smaller maximum transfer rate derived by using fmck/6 or the following expression is the valid maximum transfer rate. Expression for calculating the transfer rate when 2.7 V $\leq$ VDD < 4.0 V and 2.3 V $\leq$ Vb $\leq$ 2.7 V Maximum transfer rate = $$\frac{1}{\{-C_b \times R_b \times \ln (1 - \frac{2.0}{V_b})\} \times 3}$$ [bps] $$\text{Baud rate error (theoretical value)} = \frac{\frac{1}{\text{Transfer rate} \times 2} - \{-\text{Cb} \times \text{Rb} \times \text{ln } (1 - \frac{2.0}{\text{Vb}})\}}{\frac{1}{(\text{Transfer rate})} \times \text{Number of transferred bits}} \times 100 \, [\%]$$ - \* This value is the theoretical value of the relative difference between the transmission and reception sides. - **7.** This value as an example is calculated when the conditions described in the "Conditions" column are met. Refer to **Note 6** above to calculate the maximum transfer rate under conditions of the customer. - 8. The smaller maximum transfer rate derived by using fmck/6 or the following expression is the valid maximum transfer rate. Expression for calculating the transfer rate when 1.8 V $\leq$ V<sub>DD</sub> < 3.3 V, 1.6 V $\leq$ V<sub>b</sub> $\leq$ 2.0 V Maximum transfer rate = $$\frac{1}{\{-C_b \times R_b \times \ln (1 - \frac{1.5}{V_b})\} \times 3}$$ [bps] Baud rate error (theoretical value) = $$\frac{\frac{1}{\text{Transfer rate} \times 2} - \{-C_b \times R_b \times \ln(1 - \frac{1.5}{V_b})\}}{\frac{1}{(\text{Transfer rate}) \times \text{Number of transferred bits}}} \times 100 \, [\%]$$ - \* This value is the theoretical value of the relative difference between the transmission and reception sides. - **9.** This value as an example is calculated when the conditions described in the "Conditions" column are met. Refer to **Note 8** above to calculate the maximum transfer rate under conditions of the customer. Caution Select the TTL input buffer for the RxDq pin and the N-ch open drain output (VDD tolerance) mode for the TxDq pin by using port input mode register g (PIMg) and port output mode register g (POMg). For VIH and VIL, see the DC characteristics with TTL input buffer selected. ### **UART** mode connection diagram (during communication at different potential) ### UART mode bit width (during communication at different potential) (reference) - **Remarks 1.** R<sub>b</sub>[ $\Omega$ ]: Communication line (TxDq) pull-up resistance, C<sub>b</sub>[F]: Communication line (TxDq) load capacitance, V<sub>b</sub>[V]: Communication line voltage - 2. q: UART number (q = 0 to 2), g: PIM and POM number (g = 0, 1) - 3. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). - m: Unit number, n: Channel number (mn = 00 to 03, 10, 11)) - **4.** UART0 of the 20- and 24-pin products supports communication at different potential only when the peripheral I/O redirection function is not used. # (7) Communication at different potential (2.5 V, 3 V) (CSI mode) (master mode, SCK00... internal clock output, corresponding CSI00 only) (Ta = -40 to +85°C, 2.7 V $\leq$ VDD $\leq$ 5.5 V, Vss = 0 V) | Parameter | Symbol | | Conditions | HS (higl<br>main) | | LS (low<br>main) | | Unit | |-------------------------------------------------|-------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------|------------------|------|------| | | | | | MIN. | MAX. | MIN. | MAX. | 1 | | SCK00 cycle time | tkcy1 | tkcy1 ≥ 2/fCLK | $ \begin{aligned} &4.0 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V}, \\ &2.7 \text{ V} \leq \text{V}_{b} \leq 4.0 \text{ V}, \\ &C_{b} = 20 \text{ pF}, R_{b} = 1.4 \text{ k}\Omega \end{aligned} $ | 200 | | 1150 | | ns | | | | | $\begin{split} 2.7 \ V &\leq V_{DD} < 4.0 \ V, \\ 2.3 \ V &\leq V_b \leq 2.7 \ V, \\ C_b &= 20 \ pF, \ R_b = 2.7 \ k\Omega \end{split}$ | 300 | | 1150 | | ns | | SCK00 high-level width | tкнı | $4.0 \text{ V} \leq \text{V}_{DD} \leq 5.$ $C_b = 20 \text{ pF}, \text{ Rb} =$ | 5 V, 2.7 V $\leq$ V <sub>b</sub> $\leq$ 4.0 V, = 1.4 k $\Omega$ | tксү1/2 – 50 | | tkcy1/2- | | ns | | | | $2.7~V \leq V_{DD} < 4.0~V,~2.3~V \leq V_b \leq 2.7~V,$ $C_b = 20~pF,~R_b = 2.7~k\Omega$ | | tксу1/2 —<br>120 | | tксү1/2 –<br>120 | | ns | | SCK00 low-level width | t <sub>KL1</sub> | | $0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}, 2.7 \text{ V} \le \text{V}_{b} \le 4.0 \text{ V},$ $b = 20 \text{ pF}, R_{b} = 1.4 \text{ k}\Omega$ | | | tксү1/2 –<br>50 | | ns | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.$ $C_b = 20 \text{ pF}, R_b =$ | 0 V, 2.3 V $\leq$ V <sub>b</sub> $\leq$ 2.7 V, = 2.7 kΩ | tксу1/2 — 10 | | tксү1/2 — 50 | | ns | | SI00 setup time<br>(to SCK00↑) Note 1 | tsıĸ1 | $4.0 \text{ V} \le \text{V}_{DD} \le 5.$ $C_b = 20 \text{ pF}, R_b =$ | 5 V, 2.7 V $\leq$ V <sub>b</sub> $\leq$ 4.0 V, = 1.4 kΩ | 58 | | 479 | | ns | | | | $2.7~V \leq V_{DD} < 4.0~V,~2.3~V \leq V_b \leq 2.7~V,$ $C_b = 20~pF,~R_b = 2.7~k\Omega$ | | 121 | | 479 | | ns | | SI00 hold time<br>(from SCK00↑) Note 1 | tksii | $4.0 \text{ V} \le \text{V}_{DD} \le 5.$ $C_b = 20 \text{ pF}, R_b = 0.$ | 5 V, 2.7 V $\leq$ V <sub>b</sub> $\leq$ 4.0 V,<br>= 1.4 kΩ | 10 | | 10 | | ns | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.$ $C_b = 20 \text{ pF}, R_b =$ | 0 V, 2.3 V $\leq$ V <sub>b</sub> $\leq$ 2.7 V, = 2.7 k $\Omega$ | 10 | | 10 | | ns | | Delay time from SCK00↓<br>to SO00 output Note 1 | tkso1 | $4.0~V \leq V_{DD} \leq 5.$ $C_b = 20~pF,~R_b =$ | 5 V, 2.7 V $\leq$ V <sub>b</sub> $\leq$ 4.0 V, = 1.4 k $\Omega$ | | 60 | | 60 | ns | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.$ $C_b = 20 \text{ pF}, R_b =$ | 0 V, 2.3 V $\leq$ V <sub>b</sub> $\leq$ 2.7 V, = 2.7 k $\Omega$ | | 130 | | 130 | ns | | SI00 setup time<br>(to SCK00↓) Note 2 | tsıĸı | $4.0 \text{ V} \le \text{V}_{DD} \le 5.$ $C_b = 20 \text{ pF}, R_b =$ | 5 V, 2.7 V $\leq$ V <sub>b</sub> $\leq$ 4.0 V, = 1.4 kΩ | 23 | | 110 | | ns | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.$ $C_b = 20 \text{ pF}, R_b =$ | 0 V, 2.3 V $\leq$ V <sub>b</sub> $\leq$ 2.7 V, = 2.7 kΩ | 33 | | 110 | | ns | | SI00 hold time<br>(from SCK00↓) Note 2 | tksi1 | $4.0 \text{ V} \le V_{DD} \le 5.$ $C_b = 20 \text{ pF}, R_b =$ | 5 V, 2.7 V $\leq$ V <sub>b</sub> $\leq$ 4.0 V, = 1.4 k $\Omega$ | 10 | | 10 | | ns | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.$ $C_b = 20 \text{ pF}, R_b =$ | 0 V, 2.3 V $\leq$ V <sub>b</sub> $\leq$ 2.7 V, = 2.7 k $\Omega$ | 10 | | 10 | | ns | | Delay time from SCK00↑ to SO00 output Note 2 | t <sub>KSO1</sub> | $4.0 \text{ V} \le V_{DD} \le 5.$ $C_b = 20 \text{ pF}, R_b =$ | 5 V, 2.7 V $\leq$ V <sub>b</sub> $\leq$ 4.0 V, = 1.4 k $\Omega$ | | 10 | | 10 | ns | | | | · | $0~V,~2.3~V \leq V_b \leq 2.7~V,$ | | 10 | | 10 | ns | (Notes, Caution, and Remarks are listed on the next page.) - Notes 1. When DAP00 = 0 and CKP00 = 0, or DAP00 = 1 and CKP00 = 1 - **2.** When DAP00 = 0 and CKP00 = 1, or DAP00 = 1 and CKP00 = 0. - Caution Select the TTL input buffer for the SI00 pin and the N-ch open drain output (VDD tolerance) mode for the SO00 pin and SCK00 pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. - **Remarks 1.** Rb [ $\Omega$ ]:Communication line (SCK00, SO00) pull-up resistance, Cb [F]: Communication line (SCK00, SO00) load capacitance, Vb [V]: Communication line voltage - fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register 0 (SPS0) and the CKS00 bit of serial mode register 00 (SMR00).) # (8) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (master mode, SCKp... internal clock output) (1/3) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | | Conditions | HS (high-spe<br>Mode | | LS (low-spee<br>Mode | · · | Unit | |-----------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------|------|----------------------|------|------| | | | | | MIN. | MAX. | MIN. | MAX. | | | SCKp cycle time | tkcy1 | tkcy1 ≥ 4/fclk | $4.0~V \leq V_{DD} \leq 5.5~V,$ | 300 | | 1150 | | ns | | | | | $2.7 \ V \le V_b \le 4.0 \ V,$ | | | | | | | | | | $C_b = 30$ pF, $R_b = 1.4$ k $\Omega$ | | | | | | | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V},$ | 500 | | 1150 | | ns | | | | | $2.3~V \leq V_b \leq 2.7~V,$ | | | | | | | | | | $C_b = 30 \text{ pF}, R_b = 2.7 \text{ k}\Omega$ | | | | | | | | | | $1.8 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V},$ | 1150 | | 1150 | | ns | | | | | $1.6~V \leq V_b \leq 2.0~V^{\text{ Note}},$ | | | | | | | | | | $C_b = 30$ pF, $R_b = 5.5$ k $\Omega$ | | | | | | | SCKp high-level width | t <sub>KH1</sub> | $4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V,$ | | tkcy1/2 -75 | | tkcy1/2-75 | | ns | | | | $C_b = 30 \text{ pF}, R_b = 1.4 \text{ k}\Omega$ | | | | | | | | | | $2.7 \text{ V} \leq \text{V}_{DD} <$ | $4.0~V,~2.3~V \leq V_b \leq 2.7~V,$ | tkcy1/2 -170 | | tkcy1/2-170 | | ns | | | | C <sub>b</sub> = 30 pF, R | $k_b = 2.7 \text{ k}\Omega$ | | | | | | | | | 1.8 V ≤ V <sub>DD</sub> < | $3.3~V,~1.6~V \leq V_b \leq 2.0~V$ Note, | tkcy1/2 -458 | | tkcy1/2-458 | | ns | | | | C <sub>b</sub> = 30 pF, R | $k_b = 5.5 \text{ k}\Omega$ | | | | | | | SCKp low-level width | t <sub>KL1</sub> | 4.0 V ≤ V <sub>DD</sub> ≤ | $5.5~V,~2.7~V \leq V_b \leq 4.0~V,$ | tkcy1/2 -12 | | tксү1/2-50 | | ns | | | | C <sub>b</sub> = 30 pF, R | $d_b = 1.4 \text{ k}\Omega$ | | | | | | | | | 2.7 V ≤ V <sub>DD</sub> < | $4.0 \ V, \ 2.3 \ V \leq V_b \leq 2.7 \ V,$ | tkcy1/2 -18 | | tксү1/2-50 | | ns | | | | C <sub>b</sub> = 30 pF, R | $k_b = 2.7 \text{ k}\Omega$ | | | | | | | | | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 3.3 \text{ V}, \ 1.6 \text{ V} \le \text{V}_{\text{b}} \le 2.0 \text{ V}^{\text{Note}},$ | | tkcy1/2 -50 | | tkcy1/2-50 | | ns | | | | C <sub>b</sub> = 30 pF, R | $k_b = 5.5 \text{ k}\Omega$ | | | | | | Note Use it with $V_{DD} \ge V_b$ . - Cautions 1. Select the TTL input buffer for the SIp pin and the N-ch open drain output (VDD tolerance) mode for the SOp pin and SCKp pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. - 2. CSI01 and CSI11 cannot communicate at different potential. - **Remarks 1.** R<sub>b</sub> [ $\Omega$ ]: Communication line (SCKp, SOp) pull-up resistance, C<sub>b</sub> [F]: Communication line (SCKp, SOp) load capacitance, V<sub>b</sub> [V]: Communication line voltage - **2.** p: CSI number (p = 00, 20) # (8) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (master mode, SCKp... internal clock output) (2/3) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | , , | h-speed<br>Mode | ` | v-speed<br>Mode | Unit | |--------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------|------|-----------------|------| | | | | MIN. | MAX. | MIN. | MAX. | | | SIp setup time<br>(to SCKp↑) Note 1 | tsıkı | $ 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, $ $ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega $ | 81 | | 479 | | ns | | | | $2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V,$ $C_b = 30 \; pF, \; R_b = 2.7 \; k\Omega$ | 177 | | 479 | | ns | | | | $ \begin{aligned} &1.8 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V^{\text{Note 2}}, \\ &C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \end{aligned} $ | 479 | | 479 | | ns | | SIp hold time<br>(from SCKp↑) Note 1 | tksi1 | $ 4.0 \; V \leq V_{DD} \leq 5.5 \; V, \; 2.7 \; V \leq V_b \leq 4.0 \; V, $ $ C_b = 30 \; pF, \; R_b = 1.4 \; k\Omega $ | 19 | | 19 | | ns | | | | $2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V,$ $C_b = 30 \; pF, \; R_b = 2.7 \; k\Omega$ | 19 | | 19 | | ns | | | | $ \begin{aligned} &1.8 \; V \leq V_{DD} < 3.3 \; V, \; 1.6 \; V \leq V_b \leq 2.0 \; V^{\text{Note 2}}, \\ &C_b = 30 \; pF, \; R_b = 5.5 \; k\Omega \end{aligned} $ | 19 | | 19 | | ns | | Delay time from SCKp↓ to | tkso1 | $ 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, $ $ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega $ | | 100 | | 100 | ns | | SOp output Note 1 | | $2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V,$ $C_b = 30 \; pF, \; R_b = 2.7 \; k\Omega$ | | 195 | | 195 | ns | | | | $ \begin{aligned} &1.8 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V^{\text{Note 2}}, \\ &C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \end{aligned} $ | | 483 | | 483 | ns | Notes 1. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. 2. Use it with $V_{DD} \ge V_b$ . (Cautions and Remarks are listed on the next page.) # (8) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (master mode, SCKp... internal clock output) (3/3) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | | h-speed<br>Mode | · ` | v-speed<br>Mode | Unit | |--------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------|------|-----------------|------| | | | | MIN. | MAX. | MIN. | MAX. | | | SIp setup time<br>(to SCKp↓) Note 1 | tsıĸı | $ 4.0 \; V \leq V_{DD} \leq 5.5 \; V, \; 2.7 \; V \leq V_b \leq 4.0 \; V, $ $ C_b = 30 \; pF, \; R_b = 1.4 \; k\Omega $ | 44 | | 110 | | ns | | | | $ 2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V, \\ C_b = 30 \; pF, \; R_b = 2.7 \; k\Omega $ | 44 | | 110 | | ns | | | | $ \begin{aligned} &1.8 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_{b} \leq 2.0 \ V^{\text{Note 2}}, \\ &C_{b} = 30 \ pF, \ R_{b} = 5.5 \ k\Omega \end{aligned} $ | 110 | | 110 | | ns | | SIp hold time<br>(from SCKp↓) Note 1 | tksi1 | $ 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, $ $ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega $ | 19 | | 19 | | ns | | | | $ 2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V, $ $ C_b = 30 \; pF, \; R_b = 2.7 \; k\Omega $ | 19 | | 19 | | ns | | | | $ \begin{aligned} &1.8 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_{b} \leq 2.0 \ V^{\text{Note 2}}, \\ &C_{b} = 30 \ pF, \ R_{b} = 5.5 \ k\Omega \end{aligned} $ | 19 | | 19 | | ns | | Delay time from SCKp↑ to | tkso1 | $ 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, $ $ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega $ | | 25 | | 25 | ns | | SOp output Note 1 | | $ 2.7 \; V \leq V_{DD} < 4.0 \; V, 2.3 \; V \leq V_b \leq 2.7 \; V, \\ C_b = 30 \; pF, \; R_b = 2.7 \; k\Omega $ | | 25 | | 25 | ns | | | | $\begin{split} 1.8 \ V & \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V^{\text{Note 2}}, \\ C_b & = 30 \ pF, \ R_b = 5.5 \ k\Omega \end{split}$ | | 25 | | 25 | ns | - **Notes 1.** When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 2. Use it with $V_{DD} \ge V_b$ . - Cautions 1. Select the TTL input buffer for the SIp pin and the N-ch open drain output (VDD tolerance) mode for the SOp pin and SCKp pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. - 2. CSI01 and CSI11 cannot communicate at different potential. - **Remarks 1.** Rb $[\Omega]$ : Communication line (SCKp, SOp) pull-up resistance, Cb [F]: Communication line (SCKp, SOp) load capacitance, Vb [V]: Communication line voltage - 2. p: CSI number (p = 00, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0) ### CSI mode connection diagram (during communication at different potential) # CSI mode serial transfer timing (master mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1) ## CSI mode serial transfer timing (master mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0.) (9) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (slave mode, SCKp... external clock input) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Co | onditions | HS (high-spe | | LS (low-spe | | Unit | |---------------------------------------------------|---------------|-----------------------------------------------------------|--------------------------------------------------------|--------------|----------|--------------|----------|------| | | | | | MIN. | MAX. | MIN. | MAX. | | | SCKp cycle time Note 1 | tkCY2 | $4.0~V \leq V_{DD} \leq 5.5~V,$ | 20 MHz < fмcк ≤ 24 MHz | 12/fмск | | = | | ns | | | | $2.7~V \leq V_b \leq 4.0~V$ | 8 MHz < fмcк ≤ 20 MHz | 10/fмск | | = | | ns | | | | | 4 MHz < fмcк ≤ 8 MHz | 8/fмск | | 16/fмск | | ns | | | | | fmck ≤ 4 MHz | 6/fмск | | 10/fмск | | ns | | | | $2.7 \text{ V} \le V_{DD} < 4.0 \text{ V},$ | 20 MHz < fмcк ≤ 24 MHz | 16/fмск | | - | | ns | | | | $2.3~V \leq V_b \leq 2.7~V$ | 16 MHz < fмcк ≤ 20 MHz | 14/fмск | | - | | ns | | | | | 8 MHz < fмск ≤ 16 MHz | 12/fмск | | - | | ns | | | | | 4 MHz < fмcк ≤ 8 MHz | 8/fмск | | 16/fмск | | ns | | | | | fmck ≤ 4 MHz | 6/fмск | | 10/fмск | | ns | | | | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 3.3 \text{ V},$ | 20 MHz < fмcк ≤ 24 MHz | 36/fмск | | - | | ns | | | | $1.6~V \leq V_b \leq 2.0~V$ | 16 MHz < fмcк ≤ 20 MHz | 32/fмск | | - | | ns | | | | Note 2 | 8 MHz < fмск ≤ 16 MHz | 26/fмск | | - | | ns | | | | | 4 MHz < fмcк ≤ 8 MHz | 16/fмск | | 16/fмск | | ns | | | | | fmck ≤ 4 MHz | 10/fмск | | 10/fмск | | ns | | SCKp high-/low-level | <b>t</b> кн2, | $4.0~V \leq V_{DD} \leq 5.5~V,$ | $2.7~V \leq V_b \leq 4.0~V$ | tkcy2/2 - 12 | | tkcy2/2 - 50 | | ns | | width | <b>t</b> KL2 | $2.7~V \leq V_{\text{DD}} < 4.0~V,$ | $2.3~V \leq V_b \leq 2.7~V$ | tkcy2/2 - 18 | | tkcy2/2 - 50 | | ns | | | | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 3.3 \text{ V},$ | $1.6~V \leq V_b \leq 2.0~V^{\textrm{Note 2}}$ | tkcy2/2 - 50 | | tkcy2/2 - 50 | | ns | | SIp setup time | tsık2 | $4.0~V \leq V_{DD} \leq 5.5~V,$ | $2.7~V \leq V_{DD} \leq 4.0~V$ | 1/fmck + 20 | | 1/fмск + 30 | | ns | | (to SCKp↑) Note 3 | | $2.7~V \leq V_{DD} < 4.0~V,$ | $2.3~V \leq V_b \leq 2.7~V$ | 1/fmck + 20 | | 1/fмск + 30 | | ns | | | | $1.8 \text{ V} \le \text{V}_{\text{DD}} < 3.3 \text{ V},$ | $1.6~V \leq V_{\text{DD}} \leq 2.0~V^{\text{ Note 2}}$ | 1/fmck + 30 | | 1/fмск + 30 | | ns | | SIp hold time<br>(from SCKp <sup>↑</sup> ) Note 4 | tksi2 | | | 1/fмск + 31 | | 1/fмск + 31 | | ns | | Delay time from | tkso2 | $4.0~V \leq V_{DD} \leq 5.5~V,$ | $2.7 \text{ V} \le V_b \le 4.0 \text{ V},$ | | 2/fмск + | | 2/fмск + | ns | | SCKp↓ to SOp | | C <sub>b</sub> = 30 pF, R <sub>b</sub> = 1.4 | kΩ | | 120 | | 573 | | | output Note 5 | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V},$ | $2.3 \text{ V} \le V_b \le 2.7 \text{ V},$ | | 2/fмск + | | 2/fмск + | ns | | | | $C_b = 30 \text{ pF}, R_b = 2.7$ | kΩ | | 214 | | 573 | | | | | $1.8 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V},$ | $1.6~V \leq V_b \leq 2.0~V^{\text{Note 2}},$ | | 2/fмск + | | 2/fмск + | ns | | | | C <sub>b</sub> = 30 pF, R <sub>b</sub> = 5.5 | kΩ | | 573 | | 573 | | Notes 1. Transfer rate in the SNOOZE mode: MAX. 1 Mbps - 2. Use it with $V_{DD} \ge V_b$ . - 3. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp setup time becomes "to $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - **4.** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp hold time becomes "from $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - **5.** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The delay time to SOp output becomes "from SCKp $\uparrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. Cautions 1. Select the TTL input buffer for the SIp and SCKp pins and the N-ch open drain output (VDD tolerance) mode for the SOp pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. 2. CSI01 and CSI11 cannot communicate at different potential. ### CSI mode connection diagram (during communication at different potential) - **Remarks 1.** Rb $[\Omega]$ : Communication line (SOp) pull-up resistance, Cb [F]: Communication line (SOp) load capacitance, Vb [V]: Communication line voltage - 2. p: CSI number (p = 00, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0) - 3. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number, n: Channel number (mn = 00, 10)) # CSI mode serial transfer timing (slave mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1.) # CSI mode serial transfer timing (slave mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0.) **Remark** p: CSI number (p = 00, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0) ### (10) Communication at different potential (1.8 V, 2.5 V, 3 V) (simplified I<sup>2</sup>C mode) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | | h-speed<br>Mode | · · | v-speed<br>Mode | Unit | |----------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|----------------------|-------------------------------------------------|----------------------|------| | | | | MIN. | MAX. | MIN. | MAX. | | | SCLr clock frequency | fscL | $ 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, $ $ C_b = 100 \ pF, \ R_b = 2.8 \ k\Omega $ | | 400 <sup>Note1</sup> | | 300 <sup>Note1</sup> | kHz | | | | $ 2.7 \text{ V} \leq \text{V}_{DD} < 4.0 \text{ V}, \ 2.3 \text{ V} \leq \text{V}_{b} \leq 2.7 \text{ V}, $ $ C_{b} = 100 \text{ pF}, \ R_{b} = 2.7 \text{ k}\Omega $ | | 400 <sup>Note1</sup> | | 300 <sup>Note1</sup> | kHz | | | | $1.8~V \leq V_{DD} < 3.3~V,~1.6~V \leq V_b \leq 2.0~V,^{\text{Note2}}$ $C_b = 100~pF,~R_b = 5.5~k\Omega$ | | 300 <sup>Note1</sup> | | 300 <sup>Note1</sup> | kHz | | Hold time when SCLr = "L" | tLOW | $4.0 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V}, 2.7 \text{ V} \leq \text{V}_{\text{b}} \leq 4.0 \text{ V},$ $C_{\text{b}} = 100 \text{ pF}, R_{\text{b}} = 2.8 \text{ k}\Omega$ | 1150 | | 1550 | | ns | | | | $ 2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V, $ $ C_b = 100 \; pF, \; R_b = 2.7 \; k\Omega $ | 1150 | | 1550 | | ns | | | | | 1550 | | 1550 | | ns | | Hold time when SCLr = "H" | tнідн | $ 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, $ $ C_b = 100 \ pF, \ R_b = 2.8 \ k\Omega $ | 675 | | 610 | | ns | | | | $ 2.7 \ V \leq V_{DD} < 4.0 \ V, \ 2.3 \ V \leq V_b \leq 2.7 \ V, $ $ C_b = 100 \ pF, \ R_b = 2.7 \ k\Omega $ | 600 | | 610 | | ns | | | | | 610 | | 610 | | ns | | Data setup time (reception) | tsu:dat | $4.0~V \leq V_{DD} \leq 5.5~V,~2.7~V \leq V_b \leq 4.0~V,$ $C_b = 100~pF,~R_b = 2.8~k\Omega$ | 1/fмск<br>+ 190<br><sub>Note3</sub> | | 1/fмск<br>+ 190<br><sub>Note3</sub> | | ns | | | | $2.7 \text{ V} \leq V_{DD} < 4.0 \text{ V}, \ 2.3 \text{ V} \leq V_{b} \leq 2.7 \text{ V},$ $C_{b} = 100 \text{ pF}, \ R_{b} = 2.7 \text{ k}\Omega$ | 1/fmck<br>+ 190<br>Note3 | | 1/fмск<br>+ 190<br><sub>Note3</sub> | | ns | | | | $1.8~V \leq V_{DD} < 3.3~V,~1.6~V \leq V_b \leq 2.0~V,^{\text{Note2}}$ $C_b = 100~pF,~R_b = 5.5~k\Omega$ | 1/fmck<br>+ 190<br>Note3 | | 1/f <sub>MCK</sub><br>+ 190<br><sub>Note3</sub> | | ns | | Data hold time<br>(transmission) | thd:dat | $4.0~V \leq V_{DD} \leq 5.5~V,~2.7~V \leq V_b \leq 4.0~V,$ $C_b = 100~pF,~R_b = 2.8~k\Omega$ | 0 | 355 | 0 | 355 | ns | | | | $ 2.7 \text{ V} \leq V_{DD} < 4.0 \text{ V}, \ 2.3 \text{ V} \leq V_b \leq 2.7 \text{ V}, \\ C_b = 100 \text{ pF}, \ R_b = 2.7 \text{ k}\Omega $ | 0 | 355 | 0 | 355 | ns | | | | $ \begin{array}{c} 1.8 \; V \leq V_{DD} < 3.3 \; V, \; 1.6 \; V \leq V_{b} \leq 2.0 \; V, \\ \\ C_{b} = 100 \; pF, \; R_{b} = 5.5 \; k\Omega \end{array} $ | 0 | 405 | 0 | 405 | ns | Notes 1. The value must also be equal to or less than fmck/4. - 2. Use it with $V_{DD} \ge V_b$ . - 3. Set tsu:DAT so that it will not exceed the hold time when SCLr = "L" or SCLr = "H". Cautions 1. Select the TTL input buffer and the N-ch open drain output (VDD tolerance) mode for the SDAr pin and the N-ch open drain output (VDD tolerance) mode for the SCLr pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. 2. IIC01 and IIC11 cannot communicate at different potential. (Remarks are listed on the next page.) ### Simplified I<sup>2</sup>C mode connection diagram (during communication at different potential) ### Simplified I<sup>2</sup>C mode serial transfer timing (during communication at different potential) - **Remarks 1.** Rb $[\Omega]$ : Communication line (SDAr, SCLr) pull-up resistance, Cb [F]: Communication line (SDAr, SCLr) load capacitance, Vb [V]: Communication line voltage - **2.** r: IIC Number (r = 00, 20) - fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). - m: Unit number (m = 0,1), n: Channel number (n = 0) - Simplified I<sup>2</sup>C mode is supported only by the R5F102 products. #### 28.5.2 Serial interface IICA $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | HS | (high-spee | d main) m | node | Unit | |-------------------------------------------------|--------------|--------------------------|--------|------------|-----------|------|------| | | | | LS | (low-spee | d main) m | ode | | | | | | Standa | rd Mode | Fast | Mode | | | | | | MIN. | MAX. | MIN. | MAX. | | | SCLA0 clock frequency | fscL | Fast mode: fclk≥ 3.5 MHz | | | 0 | 400 | kHz | | | | Normal mode: fcLK≥ 1 MHz | 0 | 100 | | | kHz | | Setup time of restart condition | tsu:sta | | 4.7 | | 0.6 | | μS | | Hold time <sup>Note 1</sup> | thd:sta | | 4.0 | | 0.6 | | μS | | Hold time when SCLA0 = "L" | tLOW | | 4.7 | | 1.3 | | μS | | Hold time when SCLA0 = "H" | thigh | | 4.0 | | 0.6 | | μS | | Data setup time (reception) | tsu:dat | | 250 | | 100 | | ns | | Data hold time (transmission) <sup>Note 2</sup> | thd:dat | | 0 | 3.45 | 0 | 0.9 | μS | | Setup time of stop condition | tsu:sto | | 4.0 | | 0.6 | | μS | | Bus-free time | <b>t</b> BUF | | 4.7 | | 1.3 | | μS | Notes 1. The first clock pulse is generated after this period when the start/restart condition is detected. <R> 2. The maximum value (MAX.) of thd:DAT is during normal transfer and a wait state is inserted in the ACK (acknowledge) timing. Caution Only in the 30-pin products, the values in the above table are applied even when bit 2 (PIOR2) in the peripheral I/O redirection register (PIOR) is 1. At this time, the pin characteristics (IoH1, IoL1, VoH1, VoL1) must satisfy the values in the redirect destination. **Remark** The maximum value of Cb (communication line capacitance) and the value of Rb (communication line pull-up resistor) at that time in each mode are as follows. Normal mode: $C_b = 400 \text{ pF}, \text{ Rb} = 2.7 \text{ k}\Omega$ Fast mode: $C_b = 320 \text{ pF}, \text{ Rb} = 1.1 \text{ k}\Omega$ ### IICA serial transfer timing ### 28.6 Analog Characteristics #### 28.6.1 A/D converter characteristics Classification of A/D converter characteristics | Input channel | | Reference Voltage | | |-----------------------------------|------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------| | | Reference voltage (+) = AVREFP<br>Reference voltage (-) = AVREFM | Reference voltage (+) = VDD<br>Reference voltage (-) = Vss | Reference voltage (+) = VBGR<br>Reference voltage (-) = AVREFM | | ANI0 to ANI3 | Refer to 28.6.1 (1). | Refer to 28.6.1 (3). | Refer to 28.6.1 (4). | | ANI16 to ANI22 | Refer to 28.6.1 (2). | | | | Internal reference voltage | Refer to <b>28.6.1 (1)</b> . | | = | | Temperature sensor output voltage | | | | (1) When reference voltage (+) = AVREFP/ANIO (ADREFP1 = 0, ADREFP0 = 1), reference voltage (-) = AVREFM/ANI1 (ADREFM = 1), target pin: ANI2, ANI3, internal reference voltage, and temperature sensor output voltage $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le \text{AV}_{REFP} \le \text{VDD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V}, \text{Reference voltage (+)} = \text{AV}_{REFP}, \text{Reference voltage (-)} = \text{AV}_{REFM} = 0 \text{ V})$ | Parameter | Symbol | Cor | nditions | MIN. | TYP. | MAX. | Unit | |--------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------|--------|-------------------------|--------------|------| | Resolution | RES | | | 8 | | 10 | bit | | Overall error <sup>Note 1</sup> | AINL | 10-bit resolution | | | 1.2 | ±3.5 | LSB | | | | AVREFP = VDD Note 3 | | | 1.2 | ±7.0 Note 4 | LSB | | Conversion time | tconv | 10-bit resolution | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.125 | | 39 | μS | | | | Target pin: ANI2, ANI3 | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.1875 | | 39 | μS | | | | | $1.8~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μS | | | | | | 57 | | 95 | μS | | | | 10-bit resolution | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.375 | | 39 | μS | | | | Target pin: Internal | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.5625 | | 39 | μS | | | reference voltage, and temperature sensor output voltage (HS (high-speed main) mode) | $2.4~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μs | | | Zero-scale error <sup>Notes 1, 2</sup> | EZS | 10-bit resolution AVREFP = VDD Note 3 | | | | ±0.25 | %FSR | | Notes 1.2 | | | | | | ±0.50 Note 4 | %FSR | | Full-scale error <sup>Notes 1, 2</sup> | EFS | 10-bit resolution AVREFP = VDD Note 3 | | | | ±0.25 | %FSR | | Notes | | | | | | ±0.50 Note 4 | %FSR | | Integral linearity error <sup>Note 1</sup> | ILE | 10-bit resolution AVREFP = VDD Note 3 | | | | ±2.5 | LSB | | | | | | | | ±5.0 Note 4 | LSB | | Differential linearity error | DLE | 10-bit resolution | | | | ±1.5 | LSB | | Note 1 | | AVREFP = VDD Note 3 | | | | ±2.0 Note 4 | LSB | | Analog input voltage | VAIN | ANI2, ANI3 | | 0 | | AVREFP | V | | | | Internal reference voltage (2.4 V $\leq$ VDD $\leq$ 5.5 V, HS | e<br>(high-speed main) mode) | | V <sub>BGR</sub> Note 5 | | V | | | | Temperature sensor outp<br>(2.4 V ≤ VDD ≤ 5.5 V, HS | out voltage<br>(high-speed main) mode) | | VTMPS25 Note | 5 | V | (Notes are listed on the next page.) - **Notes 1.** Excludes quantization error ( $\pm 1/2$ LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - **3.** When $AV_{REFP} < V_{DD}$ , the MAX. values are as follows. Overall error: Add $\pm 1.0$ LSB to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. Zero-scale error/Full-scale error: Add $\pm 0.05\%$ FSR to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. Integral linearity error/ Differential linearity error: Add ±0.5 LSB to the MAX. value when AVREFP = VDD. - **4.** Values when the conversion time is set to 57 $\mu$ s (min.) and 95 $\mu$ s (max.). - 5. Refer to 28.6.2 Temperature sensor/internal reference voltage characteristics. ## (2) When reference voltage (+) = AVREFP/ANIO (ADREFP1 = 0, ADREFP0 = 1), reference voltage (-) = AVREFM/ANI1 (ADREFM = 1), target pin: ANI16 to ANI22 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le \text{AV}_{REFP} \le \text{V}_{DD} \le 5.5 \text{ V}, \text{V}_{SS} = 0 \text{ V}, \text{Reference voltage (+)} = \text{AV}_{REFP}, \text{Reference voltage (-)} = \text{AV}_{REFM} = 0 \text{ V})$ | Parameter | Symbol | Conditions | | MIN. | TYP. | MAX. | Unit | |----------------------------------------|--------|-----------------------------------------------------------------------------|--------------------------------|--------|------|-------------------|------| | Resolution | Res | | | 8 | | 10 | bit | | Overall error Note 1 | AINL | 10-bit resolution<br>AV <sub>REFP</sub> = V <sub>DD</sub> Note 3 | | | 1.2 | ±5.0 | LSB | | | | | | | 1.2 | ±8.5 Note 4 | LSB | | Conversion time | tconv | 10-bit resolution Target ANI pin: ANI16 to ANI22 | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.125 | | 39 | μs | | | | | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.1875 | | 39 | μs | | | | | $1.8~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μS | | | | | | 57 | | 95 | μS | | Zero-scale error Notes 1, 2 | EZS | 10-bit resolution AV <sub>REFP</sub> = V <sub>DD</sub> Note 3 | | | | ±0.35 | %FSR | | | | | | | | ±0.60 Note 4 | %FSR | | Full-scale error Notes 1, 2 | EFS | 10-bit resolution<br>AV <sub>REFP</sub> = V <sub>DD</sub> <sup>Note 3</sup> | | | | ±0.35 | %FSR | | | | | | | | ±0.60 Note 4 | %FSR | | Integral linearity error Note 1 | ILE | | | | | ±3.5 | LSB | | | | AV <sub>REFP</sub> = V <sub>DD</sub> Note 3 | | | | ±6.0 Note 4 | LSB | | Differential linearity<br>error Note 1 | DLE | 10-bit resolution<br>AV <sub>REFP</sub> = V <sub>DD</sub> Note 3 | | | | ±2.0 | LSB | | | | | | | | ±2.5 Note 4 | LSB | | Analog input voltage | Vain | ANI16 to ANI22 | | | | AVREFP<br>and VDD | V | - **Notes 1.** Excludes quantization error ( $\pm 1/2$ LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - **3.** When $AV_{REFP} \leq V_{DD}$ , the MAX. values are as follows. Overall error: Add $\pm 4.0$ LSB to the MAX, value when AV<sub>REFP</sub> = V<sub>DD</sub>. Zero-scale error/Full-scale error: Add $\pm 0.20\%$ FSR to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. Integral linearity error/ Differential linearity error: Add ±2.0 LSB to the MAX. value when AVREFP = VDD. **4.** When the conversion time is set to 57 $\mu$ s (min.) and 95 $\mu$ s (max.). (3) When reference voltage (+) = V<sub>DD</sub> (ADREFP1 = 0, ADREFP0 = 0), reference voltage (-) = V<sub>SS</sub> (ADREFM = 0), target pin: ANI0 to ANI3, ANI16 to ANI22, internal reference voltage, and temperature sensor output voltage $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ Reference voltage (+)} = V_{DD}, \text{ Reference voltage (-)} = V_{SS})$ | Parameter | Symbol | Conditions | | MIN. | TYP. | MAX. | Unit | |--------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------|------|-------------------|------| | Resolution | Res | | 8 | | 10 | bit | | | Overall error <sup>Note 1</sup> | AINL | 10-bit resolution | | | 1.2 | ±7.0 | LSB | | | | | | | 1.2 | $\pm 10.5$ Note 3 | LSB | | Conversion time | tconv | 10-bit resolution Target pin: ANI0 to ANI3, ANI16 to ANI22 | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.125 | | 39 | μs | | | | | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.1875 | | 39 | μS | | | | | $1.8~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μS | | | | | | 57 | | 95 | μS | | Conversion time | tconv | 10-bit resolution Target pin: internal reference voltage, and temperature sensor output voltage (HS (high-speed main) mode) | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.375 | | 39 | μS | | | | | $2.7 \text{ V} \leq \text{VDD} \leq 5.5 \text{ V}$ | 3.5625 | | 39 | μS | | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μS | | Zero-scale error <sup>Notes 1, 2</sup> | EZS | 10-bit resolution | | | | ±0.60 | %FSR | | | | | | | | ±0.85 | %FSR | | Full-scale error <sup>Notes 1, 2</sup> | EFS | 10-bit resolution | | | | ±0.60 | %FSR | | | | | | | | ±0.85 | %FSR | | Integral linearity error <sup>Note 1</sup> | ILE | 10-bit resolution | | | | ±4.0 | LSB | | | | | | | | ±6.5 Note 3 | LSB | | Differential linearity error Note 1 | DLE | 10-bit resolution | | | | ±2.0 | LSB | | | | | | | | ±2.5 Note 3 | LSB | | Analog input voltage | Vain | ANI0 to ANI3, ANI16 to ANI22 | | 0 | | V <sub>DD</sub> | V | | | | Internal reference voltage (2.4 V ≤ VDD ≤ 5.5 V, HS (high-speed main) mode) | | V <sub>BGR</sub> Note 4 | | | V | | | | Temperature sensor output voltage (2.4 V $\leq$ VDD $\leq$ 5.5 V, HS (high-speed main) mode) | | V <sub>TMPS25</sub> Note 4 | | | V | Notes 1. Excludes quantization error (±1/2 LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - **3.** When the conversion time is set to 57 $\mu$ s (min.) and 95 $\mu$ s (max.). - 4. Refer to 28.6.2 Temperature sensor/internal reference voltage characteristics. (4) When reference voltage (+) = Internal reference voltage (ADREFP1 = 1, ADREFP0 = 0), reference voltage (-) = AVREFM (ADREFM = 1), target pin: ANIO, ANI2, ANI3, and ANI16 to ANI22 (TA = -40 to +85°C, 2.4 V ≤ VDD ≤ 5.5 V, Vss = 0 V, Reference voltage (+) = VBGR Note 3, Reference voltage (-) = AVREFM Note 4 = 0 V, HS (high-speed main) mode) | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------------------|--------|------------------|------|------|-------------|------| | Resolution | Res | | | 8 | | bit | | Conversion time | tconv | 8-bit resolution | 17 | | 39 | μs | | Zero-scale error <sup>Notes 1, 2</sup> | EZS | 8-bit resolution | | | ±0.60 | %FSR | | Integral linearity error <sup>Note 1</sup> | ILE | 8-bit resolution | | | ±2.0 | LSB | | Differential linearity error Note 1 | DLE | 8-bit resolution | | | ±1.0 | LSB | | Analog input voltage | VAIN | | 0 | | VBGR Note 3 | V | - **Notes 1.** Excludes quantization error ( $\pm 1/2$ LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - 3. Refer to 28.6.2 Temperature sensor/internal reference voltage characteristics. - **4.** When reference voltage (-) = Vss, the MAX. values are as follows. Zero-scale error: Add ±0.35%FSR to the MAX. value when reference voltage (-) = AVREFM. Integral linearity error: Add $\pm 0.5$ LSB to the MAX. value when reference voltage (-) = AVREFM. Differential linearity error: Add ±0.2 LSB to the MAX. value when reference voltage (-) = AVREFM. ### 28.6.2 Temperature sensor/internal reference voltage characteristics (T<sub>A</sub> = -40 to +85°C, 2.4 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V, V<sub>SS</sub> = 0 V, HS (high-speed main) mode | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------|---------------------|-------------------------------------------------------------------|------|------|------|----------| | Temperature sensor output voltage | V <sub>TMPS25</sub> | Setting ADS register = 80H,<br>TA = +25°C | | 1.05 | | <b>V</b> | | Internal reference voltage | V <sub>BGR</sub> | Setting ADS register = 81H | 1.38 | 1.45 | 1.50 | V | | Temperature coefficient | FVTMPS | Temperature sensor output voltage that depends on the temperature | | -3.6 | | mV/°C | | Operation stabilization wait time | tamp | | 5 | | | μS | ### 28.6.3 POR circuit characteristics ## $(T_A = -40 \text{ to } +85^{\circ}\text{C}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------|------------------|------------------------|------|------|------|------| | Detection voltage | V <sub>POR</sub> | Power supply rise time | | 1.51 | 1.55 | V | | | V <sub>PDR</sub> | Power supply fall time | 1.46 | 1.50 | 1.54 | ٧ | | Minimum pulse width Note | T <sub>PW</sub> | | 300 | | | μs | **Note** Minimum time required for a POR reset when V<sub>DD</sub> exceeds below V<sub>PDR</sub>. This is also the minimum time required for a POR reset from when V<sub>DD</sub> exceeds below 0.7 V to when V<sub>DD</sub> exceeds V<sub>PDR</sub> while STOP mode is entered or the main system clock is stopped through setting bit 0 (HIOSTOP) and bit 7 (MSTOP) in the clock operation status control register (CSC). ## 28.6.4 LVD circuit characteristics ## LVD Detection Voltage of Reset Mode and Interrupt Mode $(T_A = -40 \text{ to } +85^{\circ}\text{C}, V_{PDR} \le V_{DD} \le 5.5 \text{ V}, V_{SS} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------|--------------------|------------------------|------|------|------|------| | Detection supply voltage | V <sub>LVD0</sub> | Power supply rise time | 3.98 | 4.06 | 4.14 | ٧ | | | | Power supply fall time | 3.90 | 3.98 | 4.06 | V | | | V <sub>LVD1</sub> | Power supply rise time | 3.68 | 3.75 | 3.82 | ٧ | | | | Power supply fall time | 3.60 | 3.67 | 3.74 | ٧ | | | V <sub>LVD2</sub> | Power supply rise time | 3.07 | 3.13 | 3.19 | ٧ | | | | Power supply fall time | 3.00 | 3.06 | 3.12 | ٧ | | | <b>V</b> LVD3 | Power supply rise time | 2.96 | 3.02 | 3.08 | ٧ | | | | Power supply fall time | 2.90 | 2.96 | 3.02 | ٧ | | | V <sub>LVD4</sub> | Power supply rise time | 2.86 | 2.92 | 2.97 | ٧ | | | | Power supply fall time | 2.80 | 2.86 | 2.91 | ٧ | | | V <sub>LVD5</sub> | Power supply rise time | 2.76 | 2.81 | 2.87 | ٧ | | | | Power supply fall time | 2.70 | 2.75 | 2.81 | ٧ | | | V <sub>LVD6</sub> | Power supply rise time | 2.66 | 2.71 | 2.76 | ٧ | | | | Power supply fall time | 2.60 | 2.65 | 2.70 | ٧ | | | V <sub>LVD7</sub> | Power supply rise time | 2.56 | 2.61 | 2.66 | ٧ | | | | Power supply fall time | 2.50 | 2.55 | 2.60 | ٧ | | | V <sub>LVD8</sub> | Power supply rise time | 2.45 | 2.50 | 2.55 | ٧ | | | | Power supply fall time | 2.40 | 2.45 | 2.50 | ٧ | | | V <sub>LVD9</sub> | Power supply rise time | 2.05 | 2.09 | 2.13 | ٧ | | | | Power supply fall time | 2.00 | 2.04 | 2.08 | ٧ | | | V <sub>LVD10</sub> | Power supply rise time | 1.94 | 1.98 | 2.02 | ٧ | | | | Power supply fall time | 1.90 | 1.94 | 1.98 | ٧ | | | V <sub>LVD11</sub> | Power supply rise time | 1.84 | 1.88 | 1.91 | ٧ | | | | Power supply fall time | 1.80 | 1.84 | 1.87 | ٧ | | Minimum pulse width | tьw | | 300 | | | μS | | Detection delay time | | | | | 300 | μS | ## LVD detection voltage of interrupt & reset mode (T<sub>A</sub> = -40 to +85°C, V<sub>PDR</sub> $\leq$ V<sub>DD</sub> $\leq$ 5.5 V, V<sub>SS</sub> = 0 V) | Parameter | Symbol | | Con | ditions | MIN. | TYP. | MAX. | Unit | |---------------------|--------------------|---------------------|----------------------------|------------------------------|------|------|------|------| | Interrupt and reset | V <sub>LVDB0</sub> | V <sub>POC2</sub> , | VPOC1, VPOC0 = 0, 0, 1, fa | lling reset voltage | 1.80 | 1.84 | 1.87 | V | | mode | V <sub>LVDB1</sub> | | LVIS1, LVIS0 = 1, 0 | Rising reset release voltage | 1.94 | 1.98 | 2.02 | V | | | | | | Falling interrupt voltage | 1.90 | 1.94 | 1.98 | V | | | V <sub>LVDB2</sub> | | LVIS1, LVIS0 = 0, 1 | Rising reset release voltage | 2.05 | 2.09 | 2.13 | V | | | | | | Falling interrupt voltage | 2.00 | 2.04 | 2.08 | V | | | V <sub>LVDB3</sub> | | LVIS1, LVIS0 = 0, 0 | Rising reset release voltage | 3.07 | 3.13 | 3.19 | V | | | | | | Falling interrupt voltage | 3.00 | 3.06 | 3.12 | V | | | V <sub>LVDC0</sub> | V <sub>POC2</sub> , | VPOC1, VPOC0 = 0, 1, 0, fa | lling reset voltage | 2.40 | 2.45 | 2.50 | V | | | V <sub>LVDC1</sub> | | LVIS1, LVIS0 = 1, 0 | Rising reset release voltage | 2.56 | 2.61 | 2.66 | V | | | | | | Falling interrupt voltage | 2.50 | 2.55 | 2.60 | V | | | V <sub>LVDC2</sub> | | LVIS1, LVIS0 = 0, 1 | Rising reset release voltage | 2.66 | 2.71 | 2.76 | V | | | | | | Falling interrupt voltage | 2.60 | 2.65 | 2.70 | V | | | V <sub>LVDC3</sub> | | LVIS1, LVIS0 = 0, 0 | Rising reset release voltage | 3.68 | 3.75 | 3.82 | V | | | | | | Falling interrupt voltage | 3.60 | 3.67 | 3.74 | V | | | V <sub>LVDD0</sub> | V <sub>POC2</sub> , | VPOC1, VPOC1 = 0, 1, 1, fa | lling reset voltage | 2.70 | 2.75 | 2.81 | V | | | V <sub>LVDD1</sub> | | LVIS1, LVIS0 = 1, 0 | Rising reset release voltage | 2.86 | 2.92 | 2.97 | V | | | | | | Falling interrupt voltage | 2.80 | 2.86 | 2.91 | V | | | V <sub>LVDD2</sub> | | LVIS1, LVIS0 = 0, 1 | Rising reset release voltage | 2.96 | 3.02 | 3.08 | V | | | | | | Falling interrupt voltage | 2.90 | 2.96 | 3.02 | V | | | V <sub>LVDD3</sub> | | LVIS1, LVIS0 = 0, 0 | Rising reset release voltage | 3.98 | 4.06 | 4.14 | V | | | | | | Falling interrupt voltage | 3.90 | 3.98 | 4.06 | V | ## 28.6.5 Power supply voltage rising slope characteristics ## $(T_A = -40 \text{ to } +85^{\circ}\text{C}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------|--------|------------|------|------|------|------| | Power supply voltage rising slope | SVDD | | | | 54 | V/ms | **Caution** Make sure to keep the internal reset state by the LVD circuit or an external reset until V<sub>DD</sub> reaches the operating voltage range shown in 28.4 AC Characteristics. ### <R> 28.7 RAM Data Retention Characteristics ## $(T_A = -40 \text{ to } +85^{\circ}\text{C}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |-------------------------------|--------|------------|-----------|------|------|------| | Data retention supply voltage | VDDDR | | 1.46 Note | | 5.5 | V | Note This depends on the POR detection voltage. For a falling voltage, data in RAM are retained until the voltage reaches the level that triggers a POR reset but not once it reaches the level at which a POR reset is generated. ## 28.8 Flash Memory Programming Characteristics $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{ Vss} = 0 \text{ V})$ | > | Parameter Symb | | Conditions | MIN. | TYP. | MAX. | Unit | |---|--------------------------------------------------|-------|----------------------------------------------|---------|-----------|------|-------| | | System clock frequency | fclk | | 1 | | 24 | MHz | | | Code flash memory rewritable times Notes 1, 2, 3 | Cerwr | Retained for 20 years T <sub>A</sub> = 85°C | 1,000 | | | Times | | | Data flash memory rewritable times Notes 1, 2, 3 | | Retained for 1 year T <sub>A</sub> = 25°C | | 1,000,000 | | | | | | | Retained for 5 years T <sub>A</sub> = 85°C | 100,000 | | | | | | | | Retained for 20 years | 10,000 | | | | | | | | T <sub>A</sub> = 85°C | | | | | - **Notes 1.** 1 erase + 1 write after the erase is regarded as 1 rewrite. The retaining years are until next rewrite after the rewrite. - 2. When using flash memory programmer and Renesas Electronics self programming library - **3.** These are the characteristics of the flash memory and the results obtained from reliability testing by Renesas Electronics Corporation. ## 28.9 Dedicated Flash Memory Programmer Communication (UART) $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |---------------|--------|---------------------------|---------|------|-----------|------| | Transfer rate | | During serial programming | 115,200 | | 1,000,000 | bps | ### 28.10 Timing of Entry to Flash Memory Programming Modes $(T_A = -40 \text{ to } +85^{\circ}\text{C}, 1.8 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------------------------------------------------|------|------|------|------| | Time to complete the communication for the initial setting after the external reset is released | tsuinit | POR and LVD reset are released before external reset release | | | 100 | ms | | Time to release the external reset after the TOOL0 pin is set to the low level | tsu | POR and LVD reset are released before external reset release | 10 | | | μs | | Time to hold the TOOL0 pin at the low level after the external reset is released (excluding the processing time of the firmware to control the flash memory) | tho | POR and LVD reset are released before external reset release | 1 | | | ms | - <1> The low level is input to the TOOL0 pin. - <2> The external reset is released (POR and LVD reset must be released before the external reset is released.). - <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: Communication for the initial setting must be completed within 100 ms after the external reset is released during this period. tsu: Time to release the external reset after the TOOL0 pin is set to the low level the: Time to hold the TOOL0 pin at the low level after the external reset is released (excluding the processing time of the firmware to control the flash memory) <R> <R> <R> ## CHAPTER 29 ELECTRICAL SPECIFICATIONS (G: INDUSTRIAL APPLICATIONS TA = -40 to +105°C) - <R> This chapter describes the following electrical specifications. - Target products G: Industrial applications $T_A = -40 \text{ to } +105^{\circ}\text{C}$ R5F102xxGxx - Cautions 1. The RL78 microcontrollers have 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. - 2. The pins mounted depend on the product. Refer to 2.1 Port Functions to 2.2.1 Functions for each product. - 3. Please contact Renesas Electronics sales office for derating of operation under $T_A = +85^{\circ}C$ to $+105^{\circ}C$ . Derating is the systematic reduction of load for the sake of improved reliability. ## Remark When the RL78 microcontroller is used in the range of $T_A = -40$ to +85 °C, see CHAPTER 28 ELECTRICAL SPECIFICATIONS (A: $T_A = -40$ to +85 °C). There are following differences between the products "G: Industrial applications ( $T_A = -40$ to +105°C)" and the products "A: Consumer applications, and D: Industrial applications". | Parameter | Appli | cation | |-------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------| | | A: Consumer applications, D: Industrial applications | G: Industrial applications | | Operating ambient temperature | T <sub>A</sub> = -40 to +85°C | T <sub>A</sub> = -40 to +105°C | | Operating mode | HS (high-speed main) mode: | HS (high-speed main) mode only: | | Operating voltage range | $2.7~V \le V_{DD} \le 5.5~V@1~MHz$ to $24~MHz$ | $2.7~V \le V_{DD} \le 5.5~V @ 1~MHz$ to $24~MHz$ | | | $2.4~V \le V_{DD} \le 5.5~V@1~MHz$ to $16~MHz$ | $2.4~V \le V_{DD} \le 5.5~V @ 1~MHz$ to $16~MHz$ | | | LS (low-speed main) mode: | | | | 1.8 V ≤ V <sub>DD</sub> ≤ 5.5 V@1 MHz to 8 MHz | | | High-speed on-chip oscillator clock | R5F102 products, 1.8 V ≤ V <sub>DD</sub> ≤ 5.5 V: | R5F102 products, 2.4 V $\leq$ V <sub>DD</sub> $\leq$ 5.5 V: | | accuracy | ±1.0%@ T <sub>A</sub> = -20 to +85°C | ±2.0%@ T <sub>A</sub> = +85 to +105°C | | | ±1.5%@ T <sub>A</sub> = -40 to -20°C | ±1.0%@ T <sub>A</sub> = -20 to +85°C | | | R5F103 products, 1.8 V $\leq$ V <sub>DD</sub> $\leq$ 5.5 V: | ±1.5%@ T <sub>A</sub> = -40 to -20°C | | | ±5.0%@ T <sub>A</sub> = -40 to +85°C | | | Serial array unit | UART | UART | | | CSI: fclk/2 (supporting 12 Mbps), fclk/4 | CSI: fcLk/4 | | | Simplified I <sup>2</sup> C communication | Simplified I <sup>2</sup> C communication | | Voltage detector | Rise detection voltage: 1.88 V to 4.06 V | Rise detection voltage: 2.61 V to 4.06 V | | | (12 levels) | (8 levels) | | | Fall detection voltage: 1.84 V to 3.98 V | Fall detection voltage: 2.55 V to 3.98 V | | | (12 levels) | (8 levels) | **Remark** The electrical characteristics of the products G: Industrial applications (T<sub>A</sub> = -40 to +105°C) are different from those of the products "A: Consumer applications, and D: Industrial applications". For details, refer to **29.1** to **29.10**. #### 29.1 Absolute Maximum Ratings Absolute Maximum Ratings (TA = 25°C) | Parameter | Symbols | | Conditions | Ratings | Unit | |-----------------------------------|------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|------| | Supply Voltage | V <sub>DD</sub> | | | -0.5 to + 6.5 | ٧ | | REGC terminal input voltage Note1 | Virego | REGC | | -0.3 to +2.8<br>and -0.3 to V <sub>DD</sub> + 0.3<br>Note 2 | V | | Input Voltage | VII | Other than P60, F | P61 | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 3</sup> | V | | | V <sub>I2</sub> | P60, P61 (N-ch o | pen drain) | -0.3 to 6.5 | V | | Output Voltage | Vo | | | -0.3 to V <sub>DD</sub> + 0.3 <sup>Note 3</sup> | V | | Analog input voltage | Vai | 20, 24-pin produc | ts: ANI0 to ANI3, ANI16 to ANI22 | -0.3 to V <sub>DD</sub> + 0.3 | V | | 30-pin products: ANI0 to A | | | ANI0 to ANI3, ANI16 to ANI19 | and -0.3 to<br>AVREF(+)+0.3 Notes 3, 4 | | | Output current, high | <b>І</b> он1 | Per pin | Other than P20 to P23 | -40 | mA | | | | Total of all pins | All the terminals other than P20 to P23 | -170 | mA | | | | | 20-, 24-pin products: P40 to P42 | -70 | mA | | | | | 30-pin products: P00, P01, P40, P120 | | | | | | | 20-, 24-pin products: P00 to P03 <sup>Note 5</sup> ,<br>P10 to P14<br>30-pin products: P10 to P17, P30, P31,<br>P50, P51, P147 | -100 | mA | | | <b>І</b> он2 | Per pin | P20 to P23 | -0.5 | mA | | | | Total of all pins | | -2 | mA | | Output current, low | lo <sub>L1</sub> | Per pin | Other than P20 to P23 | 40 | mA | | | | Total of all pins | All the terminals other than P20 to P23 | 170 | mA | | | | | 20-, 24-pin products: P40 to P42<br>30-pin products: P00, P01, P40, P120 | 70 | mA | | | | | 20-, 24-pin products: P00 to P03 Note 5,<br>P10 to P14, P60, P61<br>30-pin products: P10 to P17, P30, P31,<br>P50, P51, P60, P61, P147 | 100 | mA | | | lo <sub>L2</sub> | Per pin | P20 to P23 | 1 | mA | | | | Total of all pins | | 5 | mA | | Operating ambient temperature | Та | | • | -40 to +105 | °C | | Storage temperature | Tstg | | | -65 to +150 | °C | - Notes 1. 30-pin product only. - 2. Connect the REGC pin to Vss via a capacitor (0.47 to 1 $\mu$ F). This value determines the absolute maximum rating of the REGC pin. Do not use it with voltage applied. - 3. Must be 6.5 V or lower. - 4. Do not exceed AVREF(+) + 0.3 V in case of A/D conversion target pin. - **5.** 24-pin products only. Caution Product quality may suffer if the absolute maximum rating is exceeded even momentarily for any parameter. That is, the absolute maximum ratings are rated values at which the product is on the verge of suffering physical damage, and therefore the product must be used under conditions that ensure that the absolute maximum ratings are not exceeded. Remarks 1. Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port - **2.** AVREF(+): + side reference voltage of the A/D converter. - 3. Vss: Reference voltage #### 29.2 Oscillator Characteristics #### 29.2.1 X1 oscillator characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Resonator | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------|---------------------|---------------------------------------------------|------|------|------|------| | X1 clock oscillation | Ceramic resonator / | $2.7~V \leq V_{DD} \leq 5.5~V$ | 1.0 | | 20.0 | MHz | | frequency (fx) <sup>Note</sup> | crystal oscillator | $2.4 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$ | 1.0 | | 8.0 | | Note Indicates only permissible oscillator frequency ranges. Refer to AC Characteristics for instruction execution time. Request evaluation by the manufacturer of the oscillator circuit mounted on a board to check the oscillator characteristics. Caution Since the CPU is started by the high-speed on-chip oscillator clock after a reset release, check the X1 clock oscillation stabilization time using the oscillation stabilization time counter status register (OSTC) by the user. Determine the oscillation stabilization time of the OSTC register and the oscillation stabilization time select register (OSTS) after sufficiently evaluating the oscillation stabilization time with the resonator to be used. Remark When using the X1 oscillator, refer to 5.4 System Clock Oscillator. ### 29.2.2 On-chip oscillator characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}, \text{V}_{SS} = 0 \text{ V})$ | 17. 10 10 1100 0, 211 | | , , , , , , , , , , , , , , , , , , , | | | | | | |----------------------------------------------------------|------------|---------------------------------------|---------------------------------------------|------|------|------|------| | Oscillators | Parameters | C | Conditions | MIN. | TYP. | MAX. | Unit | | High-speed on-chip oscillator clock frequency Notes 1, 2 | fін | | | 1 | | 24 | MHz | | High-speed on-chip oscillator | | R5F102 products | T <sub>A</sub> = -20 to +85°C | -1.0 | | +1.0 | % | | clock frequency accuracy | | | $T_A = -40 \text{ to } -20^{\circ}\text{C}$ | -1.5 | | +1.5 | % | | | | | T <sub>A</sub> = +85 to +105°C | -2.0 | | +2.0 | % | | Low-speed on-chip oscillator clock frequency | fı∟ | | | | 15 | | kHz | | Low-speed on-chip oscillator clock frequency accuracy | | | | -15 | | +15 | % | **Notes 1.** High-speed on-chip oscillator frequency is selected by bits 0 to 3 of option byte (000C2H) and bits 0 to 2 of HOCODIV register. 2. This only indicates the oscillator characteristics. Refer to AC Characteristics for instruction execution time. #### 29.3 DC Characteristics #### 29.3.1 Pin characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (1/4) | Parameter | Symbol | Conditions | | MIN. | TYP. | MAX. | Unit | |----------------------------------------|------------------|----------------------------------------------------------------------------------------------|---------------------------------|------|------|----------------|------| | Output current, high <sup>Note 1</sup> | Іон1 | 20-, 24-pin products: Per pin for P00 to P03 <sup>Note 4</sup> , P10 to P14, P40 to P42 | | | | -3.0<br>Note 2 | mA | | | | 30-pin products:<br>Per pin for P00, P01, P10 to P17, P30,<br>P31, P40, P50, P51, P120, P147 | | | | | | | | | 20-, 24-pin products: | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | -9.0 | mA | | | | Total of P40 to P42 | $2.7~V \leq V_{DD} < 4.0~V$ | | | -6.0 | mA | | | | 30-pin products: Total of P00, P01, P40, P120 (When duty $\leq$ 70% Note 3) | 2.4 V ≤ V <sub>DD</sub> < 2.7 V | | | -4.5 | mA | | | | 20-, 24-pin products: | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | -27.0 | mA | | | | Total of P00 to P03 <sup>Note 4</sup> , P10 to P14 | $2.7~V \leq V_{DD} < 4.0~V$ | | | -18.0 | mA | | | | 30-pin products: Total of P10 to P17, P30, P31, P50, P51, P147 (When duty ≤ 70% Note 3) | 2.4 V ≤ V <sub>DD</sub> < 2.7 V | | | -10.0 | mA | | | Iон <sub>2</sub> | Total of all pins (When duty $\leq 70\%^{\text{Note 3}}$ ) | | | | -36.0 | mA | | | | Per pin for P20 to P23 | | | | -0.1 | mA | | | | Total of all pins | | | | -0.4 | mA | - **Notes 1**. value of current at which the device operation is guaranteed even if the current flows from the V<sub>DD</sub> pin to an output pin. - 2. However, do not exceed the total current value. - 3. The output current value under conditions where the duty factor ≤ 70%. If duty factor > 70%: The output current value can be calculated with the following expression (where n represents the duty factor as a percentage). - Total output current of pins = (IoH $\times$ 0.7)/(n $\times$ 0.01) - <Example> Where n = 80% and loh = -10.0 mA Total output current of pins = $(-10.0 \times 0.7)/(80 \times 0.01) \approx -8.7$ mA However, the current that is allowed to flow into one pin does not vary depending on the duty factor. A current higher than the absolute maximum rating must not flow into one pin. 4. 24-pin products only. **Caution** P10 to P12 and P41 for 20-pin products, P01, P10 to P12, and P41 for 24-pin products, and P00, P10 to P15, P17, and P50 for 30-pin products do not output high level in N-ch open-drain mode. **Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. (2/4) | Parameter | Symbol | Conditions | Conditions | | TYP. | MAX. | Unit | |---------------------------|--------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--|------|----------------|------| | Output current, lowNote 1 | lol1 | 20-, 24-pin products: Per pin for P00 to P03 <sup>Note 4</sup> , P10 to P14, P40 to P42 | | | | 8.5<br>Note 2 | mA | | | | 30-pin products:<br>Per pin for P00, P01, P10 to P17, P30,<br>P31, P40, P50, P51, P120, P147 | | | | | | | | | Per pin for P60, P61 | | | | 15.0<br>Note 2 | mA | | | | 20-, 24-pin products: | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | 25.5 | mA | | | | Total of P40 to P42 | $2.7~V \leq V_{\text{DD}} < 4.0~V$ | | | 9.0 | mA | | | | 30-pin products:<br>Total of P00, P01, P40, P120<br>(When duty ≤ 70% Note 3) | $2.4~\textrm{V} \leq \textrm{V}_\textrm{DD} < 2.7~\textrm{V}$ | | | 1.8 | mA | | | | 20-, 24-pin products: | $4.0~V \leq V_{DD} \leq 5.5~V$ | | | 40.0 | mA | | | | Total of P00 to P03 <sup>Note 4</sup> , | $2.7~V \leq V_{DD} < 4.0~V$ | | | 27.0 | mA | | | | P10 to P14, P60, P61 30-pin products: Total of P10 to P17, P30, P31, P50, P51, P60, P61, P147 (When duty ≤ 70% Note 3) | 2.4 V ≤ V <sub>DD</sub> < 2.7 V | | | 5.4 | mA | | _ | | Total of all pins (When duty ≤ 70% Note 3) | | | | 65.5 | mA | | | lol2 | Per pin for P20 to P23 | | | | 0.4 | mA | | | | Total of all pins | | | | 1.6 | mA | Notes 1. Value of current at which the device operation is guaranteed even if the current flows from an output pin to the Vss pin. - 2. However, do not exceed the total current value. - 3. The output current value under conditions where the duty factor $\leq 70\%$ . If duty factor > 70%: The output current value can be calculated with the following expression (where n represents the duty factor as a percentage). - Total output current of pins = $(lol \times 0.7)/(n \times 0.01)$ - <Example> Where n = 80% and lol = 10.0 mA Total output current of pins = $(10.0 \times 0.7)/(80 \times 0.01) \approx 8.7$ mA However, the current that is allowed to flow into one pin does not vary depending on the duty factor. A current higher than the absolute maximum rating must not flow into one pin. 4. 24-pin products only. Remark Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. $(TA = -40 \text{ to } +105^{\circ}C, 2.4 \text{ V} \le \text{Vdd} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (3/4) | Parameter Sym | | Condition | S | MIN. | TYP. | MAX. | Unit | |----------------------|--------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------|-----------------|--------------------|------| | Input voltage, high | V <sub>IH1</sub> | Normal input buffer | <u>- </u> | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | V | | | | 20-, 24-pin products: P00 to P0<br>P40 to P42 | 03 <sup>Note 2</sup> , P10 to P14, | | | | | | | | 30-pin products: P00, P01, P1<br>P40, P50, P51, P120, P147 | 0 to P17, P30, P31, | | | | | | | V <sub>IH2</sub> | TTL input buffer | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ | 2.2 | | V <sub>DD</sub> | ٧ | | | | 20-, 24-pin products: P10, P11 | $3.3 \text{ V} \leq \text{V}_{\text{DD}} < 4.0 \text{ V}$ | 2.0 | | V <sub>DD</sub> | ٧ | | | | 30-pin products: P01, P10,<br>P11, P13 to P17 | 2.4 V ≤ V <sub>DD</sub> < 3.3 V | 1.5 | | V <sub>DD</sub> | V | | | V <sub>IH3</sub> | Normal input buffer P20 to P23 | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | | | V <sub>IH4</sub> | P60, P61 | 0.7V <sub>DD</sub> | | 6.0 | V | | | | V <sub>IH5</sub> | P121, P122, P125 <sup>Note 1</sup> , P137, I | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | V | | | Input voltage, low | V <sub>IL1</sub> | Normal input buffer | | 0 | | 0.2V <sub>DD</sub> | V | | , | | 20-, 24-pin products: P00 to P0<br>P40 to P42 | 03 <sup>Note 2</sup> , P10 to P14, | | | | | | | | 30-pin products: P00, P01, P10<br>P40, P50, P51, P120, P147 | | | | | | | | V <sub>IL2</sub> | TTL input buffer | $4.0~V \leq V_{\text{DD}} \leq 5.5~V$ | 0 | | 0.8 | ٧ | | | | 20-, 24-pin products: P10, P11 | $3.3 \text{ V} \leq \text{V}_{\text{DD}} < 4.0 \text{ V}$ | 0 | | 0.5 | ٧ | | | | 30-pin products: P01, P10,<br>P11, P13 to P17 | 2.4 V ≤ V <sub>DD</sub> < 3.3 V | 0 | | 0.32 | V | | | V <sub>IL3</sub> | P20 to P23 | | 0 | | 0.3V <sub>DD</sub> | ٧ | | | V <sub>IL4</sub> | P60, P61 | | 0 | | 0.3V <sub>DD</sub> | ٧ | | | V <sub>IL5</sub> | P121, P122, P125 <sup>Note 1</sup> , P137, I | EXCLK, RESET | 0 | | 0.2V <sub>DD</sub> | V | | Output voltage, high | V <sub>OH1</sub> | 20-, 24-pin products:<br>P00 to P03 <sup>Note 2</sup> , P10 to P14, | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ Iон1 = -3.0 mA | V <sub>DD</sub> -0.7 | | | V | | | | P40 to P42<br>30-pin products: | $2.7 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ $I_{OH1} = -2.0 \text{ mA}$ | V <sub>DD</sub> -0.6 | | | V | | | P00, P01,<br>P31, P40,<br>P147 | | $2.4 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ $I_{OH1} = -1.5 \text{ mA}$ | V <sub>DD</sub> -0.5 | | | V | | | V <sub>OH2</sub> | P20 to P23 | Іон2 = -100 μΑ | V <sub>DD</sub> -0.5 | | | V | Notes 1. 20, 24-pin products only. 2. 24-pin products only. Caution The maximum value of V<sub>IH</sub> of pins P10 to P12 and P41 for 20-pin products, P01, P10 to P12, and P41 for 24-pin products, and P00, P10 to P15, P17, and P50 for 30-pin products is V<sub>DD</sub> even in N-ch open-drain mode. High level is not output in the N-ch open-drain mode. **Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. $(TA = -40 \text{ to } +105^{\circ}C, 2.4 \text{ V} \le VDD \le 5.5 \text{ V}, Vss = 0 \text{ V})$ (4/4) | Parameter | Symbol | | MIN. | TYP. | MAX. | Unit | | | |-----------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------|------|------|-----|----| | Output voltage, low | V <sub>OL1</sub> | 20-, 24-pin product<br>P00 to P03 <sup>Note</sup> , P10 | | $4.0~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 8.5~mA$ | | | 0.7 | V | | | | 30-pin products: P00, P01,<br>P10 to P17, P30, P31, P40,<br>P50, P51, P120, P147 $\begin{vmatrix} 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 $ | | $2.7~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 3.0~mA$ | | | 0.6 | V | | | | | | $2.7 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V},$ $I_{\text{OL1}} = 1.5 \text{ mA}$ | | | 0.4 | V | | | | | | $2.4~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 0.6~mA$ | | | 0.4 | V | | | V <sub>OL2</sub> | P20 to P23 | | Ιοι2 = 400 μΑ | | | 0.4 | V | | | Vol3 | P60, P61 | | $4.0~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 15.0~mA$ | | | 2.0 | V | | | | | | $4.0 \text{ V} \leq \text{V}_{\text{DD}} \leq 5.5 \text{ V},$ $I_{\text{OL1}} = 5.0 \text{ mA}$ | | | 0.4 | V | | | | | | $2.7~V \leq V_{DD} \leq 5.5~V,$ $I_{OL1} = 3.0~mA$ | | | 0.4 | V | | | | | | $2.4 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$<br>$I_{OL1} = 2.0 \text{ mA}$ | | | 0.4 | V | | Input leakage current, high | Ішн1 | Other than P121,<br>P122 | n P121, V <sub>I</sub> = V <sub>DD</sub> | | | | 1 | μА | | | ILIH2 | P121, P122<br>(X1, X2/EXCLK) | VI = VDD | Input port or external clock input | | | 1 | μА | | | | | | When resonator connected | | | 10 | μΑ | | Input leakage current, low | ILIL1 | Other than P121,<br>P122 | Vı = Vss | | | | -1 | μΑ | | | ILIL2 | P121, P122<br>(X1, X2/EXCLK) | Vı = Vss | Input port or external clock input | | | -1 | μΑ | | | | | | When resonator connected | | | -10 | μΑ | | On-chip pull-up resistance | Ru | 20-, 24-pin product<br>P00 to P03 <sup>Note</sup> , P10<br>P40 to P42, P125, | ) to P14, | V <sub>I</sub> = V <sub>SS</sub> , input port | 10 | 20 | 100 | kΩ | | | | 30-pin products: P0<br>P10 to P17, P30, F<br>P50, P51, P120, P | P31, P40, | | | | | | Note 24-pin products only. Remark Unless specified otherwise, the characteristics of alternate-function pins are the same as those of the port pins. #### 29.3.2 Supply current characteristics ### (1) 20-, 24-pin products $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (1/2) | Parameter | Symbol | | | Conditions | | | MIN. | TYP. | MAX. | Unit | |---------------------------|------------------|------------------------|----------------|----------------------------------------------|-------------------------|-------------------------|------|------|------|------| | Supply | I <sub>DD1</sub> | Operating | HS (High-speed | f⊪ = 24 MHz <sup>Note 3</sup> | Basic | V <sub>DD</sub> = 5.0 V | | 1.5 | | mA | | current <sup>Note 1</sup> | | mode main) mode Note 4 | | operation | V <sub>DD</sub> = 3.0 V | | 1.5 | | | | | | | | | | Normal | V <sub>DD</sub> = 5.0 V | | 3.3 | 5.3 | mA | | | | | | | operation | V <sub>DD</sub> = 3.0 V | | 3.3 | 5.3 | | | | | | | f⊪ = 16 MHz <sup>Note 3</sup> | | V <sub>DD</sub> = 5.0 V | | 2.5 | 3.9 | mA | | | | | | | | V <sub>DD</sub> = 3.0 V | | 2.5 | 3.9 | | | | | | | $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 2.8 | 4.7 | mA | | | | | | $V_{DD} = 5.0 \text{ V}$ | | Resonator connection | | 3.0 | 4.8 | | | | | | | $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 2.8 | 4.7 | mA | | | | | | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 3.0 | 4.8 | | | | | | | $f_{MX} = 10 \text{ MHz}^{Note 2},$ | | Square wave input | | 1.8 | 2.8 | mA | | | | | | $V_{DD} = 5.0 \text{ V}$ | | Resonator connection | | 1.8 | 2.8 | | | | | | | f <sub>MX</sub> = 10 MHz <sup>Note 2</sup> , | | Square wave input | | 1.8 | 2.8 | mA | | | | | | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 1.8 | 2.8 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to VDD or Vss. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing data flash rewrite. - 2. When high-speed on-chip oscillator clock is stopped. - 3. When high-speed system clock is stopped - **4.** Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS(High speed main) mode: $V_{DD} = 2.7 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 24 \text{ MHz}$ $V_{DD} = 2.4 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 16 \text{ MHz}$ - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - **3.** Temperature condition of the TYP. value is $T_A = 25^{\circ}C$ . #### (1) 20-, 24-pin products $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (2/2) | Parameter | Symbol | | | Conditions | | MIN. | TYP. | MAX. | Unit | |---------------------------|-------------------------|------|------------------------------|---------------------------------------------------------------------|-------------------------|------|------|-------|------| | Supply | I <sub>DD2</sub> Note 2 | HALT | HS (High-speed | fin = 24 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 440 | 2230 | μА | | current <sup>Note 1</sup> | | mode | main) mode <sup>Note 6</sup> | | V <sub>DD</sub> = 3.0 V | | 440 | 2230 | | | | | | | fin = 16 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 400 | 1650 | μА | | | | | | | V <sub>DD</sub> = 3.0 V | | 400 | 1650 | | | | | | | f <sub>MX</sub> = 20 MHz <sup>Note 3</sup> , | Square wave input | | 280 | 1900 | μА | | | | | | $V_{DD} = 5.0 \text{ V}$ | Resonator connection | | 450 | 2000 | | | | | | | f <sub>MX</sub> = 20 MHz <sup>Note 3</sup> , | Square wave input | | 280 | 1900 | μА | | | | | VDD | V <sub>DD</sub> = 3.0 V | Resonator connection | | 450 | 2000 | | | | | | | $f_{MX} = 10 \text{ MHz}^{\text{Note 3}},$ $V_{DD} = 5.0 \text{ V}$ | Square wave input | | 190 | 1010 | μА | | | | | | | Resonator connection | | 260 | 1090 | | | | | | | f <sub>MX</sub> = 10 MHz <sup>Note 3</sup> , | Square wave input | | 190 | 1010 | μА | | | | | | V <sub>DD</sub> = 3.0 V | Resonator connection | | 260 | 1090 | | | | I <sub>DD3</sub> Note 5 | STOP | T <sub>A</sub> = -40°C | | | | 0.19 | 0.50 | μА | | | | mode | T <sub>A</sub> = +25°C | | | | 0.24 | 0.50 | | | | | | T <sub>A</sub> = +50°C | | | | 0.32 | 0.80 | | | | | | T <sub>A</sub> = +70°C | | | | 0.48 | 1.20 | | | | | | T <sub>A</sub> = +85°C | | | | 0.74 | 2.20 | | | | | | T <sub>A</sub> = +105°C | | | | 1.50 | 10.20 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to V<sub>DD</sub> or V<sub>SS</sub>. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing during data flash rewrite. - 2. During HALT instruction execution by flash memory. - 3. When high-speed on-chip oscillator clock is stopped. - 4. When high-speed system clock is stopped. - Not including the current flowing into the 12-bit interval timer and watchdog timer. - 6. Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS (High speed main) mode: VDD = 2.7 V to 5.5 V @1 MHz to 24 MHz $V_{DD} = 2.4 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 16 \text{ MHz}$ - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - 3. Except temperature condition of the TYP. value is TA = 25°C, other than STOP mode #### (2) 30-pin products $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (1/2) | Parameter | Symbol | | | Conditions | | | MIN. | TYP. | MAX. | Unit | |---------------------------|------------------|-----------|--------------------------|--------------------------------------------|-----------|-------------------------|------|------|------|------| | Supply | I <sub>DD1</sub> | Operating | HS (High-speed | f <sub>IH</sub> = 24 MHz <sup>Note 3</sup> | Basic | V <sub>DD</sub> = 5.0 V | | 1.5 | | mA | | current <sup>Note 1</sup> | | mode | main) mode <sup>№1</sup> | | operation | V <sub>DD</sub> = 3.0 V | | 1.5 | | | | | | | | | Normal | V <sub>DD</sub> = 5.0 V | | 3.7 | 5.8 | mA | | | | | | | operation | V <sub>DD</sub> = 3.0 V | | 3.7 | 5.8 | | | | | | | f <sub>H</sub> = 16 MHz <sup>Note 3</sup> | | V <sub>DD</sub> = 5.0 V | | 2.7 | 4.2 | mA | | | | | | | | V <sub>DD</sub> = 3.0 V | | 2.7 | 4.2 | | | | | | | $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 3.0 | 4.9 | mA | | | | | | V <sub>DD</sub> = 5.0 V | | Resonator connection | | 3.2 | 5.0 | | | | | | | $f_{MX} = 20 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 3.0 | 4.9 | mA | | | | | | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 3.2 | 5.0 | | | | | | | $f_{MX} = 10 \text{ MHz}^{Note 2},$ | | Square wave input | | 1.9 | 2.9 | mA | | | | | | $V_{DD} = 5.0 \text{ V}$ | | Resonator connection | | 1.9 | 2.9 | | | | | | | $f_{MX} = 10 \text{ MHz}^{\text{Note 2}},$ | | Square wave input | | 1.9 | 2.9 | mA | | | | | | $V_{DD} = 3.0 \text{ V}$ | | Resonator connection | | 1.9 | 2.9 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to VDD or Vss. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing during data flash rewrite. - 2. When high-speed on-chip oscillator clock is stopped. - 3. When high-speed system clock is stopped - **4.** Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS(High speed main) mode: $V_{DD} = 2.7 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 24 \text{ MHz}$ $V_{DD} = 2.4 \text{ V to } 5.5 \text{ V } @ 1 \text{ MHz to } 16 \text{ MHz}$ - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - **3.** Temperature condition of the TYP. value is $T_A = 25^{\circ}C$ . #### (2) 30-pin products $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ (2/2) | Parameter | Symbol | | | Conditions | | MIN. | TYP. | MAX. | Unit | |----------------|-------------------------|----------------------------------------------------------------|-------------------------|----------------------------------------------|-------------------------|------|------|-------|------| | Supply | IDD2 Note 2 | HALT | HS (High-speed | fih = 24 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 440 | 2300 | μA | | current Note 1 | | mode | main) mode Note 6 | | V <sub>DD</sub> = 3.0 V | | 440 | 2300 | | | | | | | fih = 16 MHz <sup>Note 4</sup> | V <sub>DD</sub> = 5.0 V | | 400 | 1700 | μA | | | | | | | V <sub>DD</sub> = 3.0 V | | 400 | 1700 | | | | | | | f <sub>MX</sub> = 20 MHz <sup>Note 3</sup> , | Square wave input | | 280 | 1900 | μA | | | | | | $V_{DD} = 5.0 \text{ V}$ | Resonator connection | | 450 | 2000 | | | | | | VDD | f <sub>MX</sub> = 20 MHz <sup>Note 3</sup> , | Square wave input | | 280 | 1900 | μΑ | | | | | | V <sub>DD</sub> = 3.0 V | Resonator connection | | 450 | 2000 | | | | | | | f <sub>MX</sub> = 10 MHz <sup>Note 3</sup> , | Square wave input | | 190 | 1020 | μA | | | | | | $V_{DD} = 5.0 \text{ V}$ | Resonator connection | | 260 | 1100 | | | | | | | fmx = 10 MHz <sup>Note 3</sup> , | Square wave input | | 190 | 1020 | μΑ | | | | | | V <sub>DD</sub> = 3.0 V | Resonator connection | | 260 | 1100 | | | | IDD3 Note 5 | STOP | T <sub>A</sub> = -40°C | | | | 0.18 | 0.50 | μΑ | | | | mode | T <sub>A</sub> = +25°C | | | | 0.23 | 0.50 | | | | | $T_A = +50^{\circ}C$ $T_A = +70^{\circ}C$ $T_A = +85^{\circ}C$ | | | | 0.30 | 1.10 | | | | | | | | | | 0.46 | 1.90 | | | | | | | T <sub>A</sub> = +85°C | A = +85°C | | | 0.75 | 3.30 | | | | T <sub>A</sub> = +105°C | | T <sub>A</sub> = +105°C | | | | 2.94 | 15.30 | | - Notes 1. Total current flowing into VDD, including the input leakage current flowing when the level of the input pin is fixed to VDD or Vss. The values below the MAX. column include the peripheral operation current. However, not including the current flowing into the A/D converter, LVD circuit, I/O port, and on-chip pull-up/pull-down resistors and the current flowing during data flash rewrite. - 2. During HALT instruction execution by flash memory. - 3. When high-speed on-chip oscillator clock is stopped. - 4. When high-speed system clock is stopped. - 5. Not including the current flowing into the 12-bit interval timer and watchdog timer. - **6.** Relationship between operation voltage width, operation frequency of CPU and operation mode is as follows. HS (High speed main) mode: $V_{DD} = 2.7 \text{ V to } 5.5 \text{ V}$ @1 MHz to 24 MHz $V_{DD} = 2.4 \text{ V to } 5.5 \text{ V}$ @1 MHz to 16 MHz - Remarks 1. fmx: High-speed system clock frequency (X1 clock oscillation frequency or external main system clock frequency) - 2. fin: high-speed on-chip oscillator clock frequency - 3. Except STOP mode, temperature condition of the TYP. value is $T_A = 25$ °C. ## (3) Peripheral functions (Common to all products) ## $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | | Conditions | MIN. | TYP. | MAX. | Unit | |---------------------------------------------------|------------------------|--------------------|-------------------------------------------------------------------------------------|------|------|-------|------| | Low-speed onchip oscillator operating current | IFIL Note 1 | | | | 0.20 | | μΑ | | 12-bit interval timer operating current | ITMKA<br>Notes 1, 2, 3 | | | | 0.02 | | μΑ | | Watchdog timer operating current | WDT<br>Notes 1, 2, 4 | fı∟ = 15 kHz | | | 0.22 | | μΑ | | A/D converter | IADC | When conversion | Normal mode, AVREFP = VDD = 5.0 V | | 1.30 | 1.70 | mA | | operating current | Notes 1, 5 | at maximum speed | Low voltage mode,<br>AV <sub>REFP</sub> = V <sub>DD</sub> = 3.0 V | | 0.50 | 0.70 | mA | | A/D converter reference voltage operating current | ADREF<br>Note 1 | | | | 75.0 | | μΑ | | Temperature sensor operating current | ITMPS<br>Note 1 | | | | 75.0 | | μА | | LVD operating current | ILVD<br>Notes 1, 6 | | | | 0.08 | | μА | | Self-programming operating current | FSP<br>Notes 1, 8 | | | | 2.00 | 12.20 | mA | | BGO operating current | BGO<br>Notes 1, 7 | | | | 2.00 | 12.20 | mA | | SNOOZE operating | Isnoz | ADC operation | The mode is performed Note 9 | | 0.50 | 1.10 | mA | | current | Note 1 | | The A/D conversion operations are performed, Low voltage mode, AVREFP = VDD = 3.0 V | | 1.20 | 2.04 | mA | | | | CSI/UART operation | 1 | | 0.70 | 1.54 | mA | #### Notes 1. Current flowing to the VDD. - 2. When high speed on-chip oscillator and high-speed system clock are stopped. - 3. Current flowing only to the 12-bit interval timer (excluding the operating current of the low-speed on-chip oscillator). The current value of the RL78 microcontrollers is the sum of IDD1, IDD2 or IDD3, and IFIL and ITMKA when the 12-bit interval timer operates. - 4. Current flowing only to the watchdog timer (including the operating current of the low-speed on-chip oscillator). The current value of the RL78 microcontrollers is the sum of IDD1, IDD2 or IDD3 and IWDT when the watchdog timer operates. - **5.** Current flowing only to the A/D converter. The current value of the RL78 microcontrollers is the sum of IDD1 or IDD2 and IADC when the A/D converter operates in an operation mode or the HALT mode. - **6.** Current flowing only to the LVD circuit. The current value of the RL78 microcontrollers is the sum of IDD1, IDD2 or IDD3 and ILVD when the LVD circuit operates. - 7. Current flowing only during data flash rewrite. - 8. Current flowing only during self programming. - 9. For shift time to the SNOOZE mode, see 17.3.3 SNOOZE mode. Remarks 1. fil: Low-speed on-chip oscillator clock frequency 2. Temperature condition of the TYP. value is TA = 25°C ### 29.4 AC Characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Items | Symbol | | Condition | s | MIN. | TYP. | MAX. | Unit | |------------------------------------------------------------|--------------|-------------------------------------|---------------------|------------------------------------|----------------|------|------|------| | Instruction cycle (minimum | Tcy | Main system | HS (High- | $2.7~V \leq V_{DD} \leq 5.5~V$ | 0.04167 | | 1 | μs | | instruction execution time) | | clock (fmain)<br>operation | speed main)<br>mode | $2.4~V \leq V_{\text{DD}} < 2.7~V$ | 0.0625 | | 1 | μs | | | | During self | HS (High- | $2.7~V \leq V_{DD} \leq 5.5~V$ | 0.04167 | | 1 | μS | | | | programming | speed main)<br>mode | $2.4~V \leq V_{DD} < 2.7~V$ | 0.0625 | | 1 | μS | | External main system clock | fex | $2.7 \text{ V} \leq V_{DD} \leq 5.$ | 5 V | | 1.0 | | 20.0 | MHz | | frequency | | $2.4~V \leq V_{DD} < 2$ | .7 V | | 1.0 | | 16.0 | MHz | | External main system clock | texh, texl | $2.7~V \leq V_{\text{DD}} \leq 5$ | .5 V | | 24 | | | ns | | input high-level width, low-<br>level width | | $2.4~V \leq V_{DD} < 2.$ | 7 V | | 30 | | | ns | | TI00 to TI07 input high-level width, low-level width | tπн, tπ∟ | | | | 1/fмск +<br>10 | | | ns | | TO00 to TO07 output | fто | $4.0~V \leq V_{DD} \leq 5$ | .5 V | | | | 12 | MHz | | frequency | | $2.7~V \leq V_{DD} < 4.$ | 0 V | | | | 8 | MHz | | | | $2.4~V \leq V_{DD} < 2$ | .7 V | | | | 4 | MHz | | PCLBUZ0, or PCLBUZ1 | fPCL | $4.0~V \leq V_{DD} \leq 5$ | .5 V | | | | 16 | MHz | | output frequency | | $2.7~V \leq V_{\text{DD}} < 4$ | .0 V | | | | 8 | MHz | | | | $2.4~V \leq V_{DD} < 2$ | .7 V | | | | 4 | MHz | | INTP0 to INTP5 input high-<br>level width, low-level width | tinth, tintl | | | | 1 | | | μs | | KR0 to KR9 input available width | tkr | | | | 250 | | | ns | | RESET low-level width | trsL | | | | 10 | | | μs | Remark fmck: Timer array unit operation clock frequency (Operation clock to be set by the timer clock select register 0 (TPS0) and the CKS0n bit of timer mode register 0 (TMR0n). n: Channel number (n = 0 to 7)) ## Minimum Instruction Execution Time during Main System Clock Operation ### **AC Timing Test Point** ### **External Main System Clock Timing** ## **TI/TO Timing** ## **Interrupt Request Input Timing** ## **Key Interrupt Input Timing** ## **RESET Input Timing** #### 29.5 Peripheral Functions Characteristics ### **AC Timing Test Point** #### 29.5.1 Serial array unit ### (1) During communication at same potential (UART mode) #### $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | _ | | , | , , | | | | |---|--------------|--------|----------------------------------------------------------------------------|---------------------------|---------|------| | | Parameter | Symbol | Conditions | HS (high-speed main) Mode | | Unit | | | | | | MIN. | MAX. | | | Т | ransfer rate | | | | fмск/12 | bps | | N | ote 1 | | Theoretical value of the maximum transfer rate $f_{CLK} = f_{MCK}^{Note2}$ | | 2.0 | Mbps | - Notes 1. Transfer rate in the SNOOZE mode is 4800 bps only. - 2. The maximum operating frequencies of the CPU/peripheral hardware clock (fclk) are: HS (high-speed main) mode: 24 MHz (2.7 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V) 16 MHz (2.4 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V) **Caution** Select the normal input buffer for the RxDq pin and the normal output mode for the TxDq pin by using port input mode register g (PIMg) and port output mode register g (POMg). ## **UART** mode connection diagram (during communication at same potential) #### **UART** mode bit width (during communication at same potential) (reference) **Remarks 1.** q: UART number (q = 0 to 2), g: PIM, POM number (g = 0, 1) 2. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number, n: Channel number (mn = 00 to 03, 10, 11)) ## (2) During communication at same potential (CSI mode) (master mode, SCKp... internal clock output) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, V_{SS} = 0 \text{ V})$ | Parameter | Symbol | Conditions | | HS (high-speed main) Mode | | Unit | | |--------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------|--------------------------------|---------------------------|------|------|--| | | | | | MIN. | MAX. | | | | SCKp cycle time | tkcy1 | tkcy1 ≥ 4/fcLk | $2.7~V \leq V_{DD} \leq 5.5~V$ | 334 | | ns | | | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | 500 | | ns | | | SCKp high-/low-level width | <b>t</b> кн1, | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}$<br>$2.7 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}$ | | tkcy1/2-24 | | ns | | | | t <sub>KL1</sub> | | | tkcy1/2-36 | | ns | | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | tkcy1/2-76 | | ns | | | SIp setup time (to SCKp↑) Note 1 | tsik1 | $4.0 \text{ V} \leq \text{V}_{DD} \leq 5.5 \text{ V}$ | | 66 | | ns | | | | | 2.7 V ≤ V <sub>DD</sub> ≤ 5.5 V | | 66 | | ns | | | | | 2.4 V ≤ V <sub>DD</sub> ≤ 5 | .5 V | 113 | | ns | | | SIp hold time (from SCKp↑) Note 2 | tksi1 | | | 38 | | ns | | | Delay time from SCKp↓ to SOp output Note 3 | tkso1 | C = 30 pF Note4 | | | 50 | ns | | - **Notes 1.** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp setup time becomes "to $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 2. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp hold time becomes "from $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 3. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The delay time to SOp output becomes "from SCKp↑" when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 4. C is the load capacitance of the SCKp and SOp output lines. **Caution** Select the normal input buffer for the SIp pin and the normal output mode for the SOp and SCKp pins by using port input mode register 1 (PIM1) and port output mode registers 0, 1, 4 (POM0, POM1, POM4). Remarks 1. p: CSI number (p = 00, 01, 11, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0, 1, 3) 2. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number (m = 0, 1), n: Channel number (n = 0, 1, 3)) ## (3) During communication at same potential (CSI mode) (slave mode, SCKp... external clock input) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Con | ditions | HS (high-speed main) Mode | | Unit | |---------------------------------------------------|--------------------------------|------------------------------------------------------------|--------------------------------|---------------------------|--------------|------| | | | | | MIN. | MAX. | | | SCKp cycle time Note4 | tkcy2 | tkcy2 $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V}$ | 20 MHz < fmck | 16/fмск | | ns | | | | | fмcк ≤ 20 MHz | 12/fмск | | ns | | | | $2.7~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$ | 16 MHz < fмск | 16/fмск | | ns | | | | | fмcк ≤ 16 MHz | 12/fмск | | ns | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | | 12/fмск | | ns | | | | | | and 1000 | | | | SCKp high-/low-level width | <b>t</b> кн2, | $4.0~V \leq V_{DD} \leq 5.5~V$ | | tксү2/2-14 | | ns | | | t <sub>KL2</sub> | $2.7~V \leq V_{DD} \leq 5.5~V$ | | tксү2/2–16 | | ns | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | tксү2/2-36 | | ns | | SIp setup time (to SCKp↑) | tsik2 | $2.7~V \leq V_{DD} \leq 5.5~V$ | | 1/fмск + 40 | | ns | | Note 1 | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | 1/fмск + 60 | | ns | | Slp hold time<br>(from SCKp <sup>↑</sup> ) Note 2 | t <sub>KSI2</sub> | | | 1/fмск + 62 | | ns | | Delay time from SCKp↓ to | tkso2 | C = 30 pF Note4 | $2.7~V \leq V_{DD} \leq 5.5~V$ | | 2/fмcк + 66 | ns | | SOp output Note 3 | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | | 2/fмcк + 113 | ns | - **Notes 1.** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp setup time becomes "to SCKp↓" when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 2. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp hold time becomes "from $SCKp\downarrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 3. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The delay time to SOp output becomes "from SCKp $\uparrow$ " when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 4. C is the load capacitance of the SOp output lines. - 5. Transfer rate in the SNOOZE mode: MAX. 1 Mbps **Caution** Select the normal input buffer for the SIp and SCKp pins and the normal output mode for the SOp pin by using port input mode register 1 (PIM1) and port output mode registers 0, 1, 4 (POM0, POM1, POM4). ### CSI mode connection diagram (during communication at same potential) # CSI mode serial transfer timing (during communication at same potential) (When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1.) ## CSI mode serial transfer timing (during communication at same potential) (When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0.) **Remarks 1.** p: CSI number (p = 00, 01, 11, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0, 1, 3) 2. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number (m = 0,1), n: Channel number (n = 0, 1, 3)) ### (4) During communication at same potential (simplified I<sup>2</sup>C mode) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | (1A = 10 to 1100 0, 211 t | <u> </u> | 700 = 0 17 | | | | |-------------------------------|----------|---------------------------------------|---------------------------|------------|------| | Parameter | Symbol | Conditions | HS (high-speed main) Mode | | Unit | | | | | MIN. | MAX. | | | SCLr clock frequency | fscL | $C_b = 100 \ pF, \ R_b = 3 \ k\Omega$ | | 100 Note 1 | kHz | | Hold time when SCLr = "L" | tLOW | $C_b=100~pF,~R_b=3~k\Omega$ | 4600 | | ns | | Hold time when SCLr = "H" | thigh | $C_b=100~pF,~R_b=3~k\Omega$ | 4600 | | ns | | Data setup time (reception) | tsu:dat | $C_b=100~pF,~R_b=3~k\Omega$ | 1/fmck + 580 Note 2 | | ns | | Data hold time (transmission) | thd:dat | $C_b=100~pF,~R_b=3~k\Omega$ | 0 | 1420 | ns | - Notes 1. The value must also be equal to or less than fmck/4. - 2. Set tsu:DAT so that it will not exceed the hold time when SCLr = "L" or SCLr = "H". **Caution** Select the N-ch open drain output (V<sub>DD</sub> tolerance) mode for SDAr by using port output mode register h (POMh). ### Simplified I<sup>2</sup>C mode connection diagram (during communication at same potential) ## Simplified I<sup>2</sup>C mode serial transfer timing (during communication at same potential) - **Remarks 1.** R<sub>b</sub> $[\Omega]$ :Communication line (SDAr) pull-up resistance - C<sub>b</sub> [F]: Communication line (SCLr, SDAr) load capacitance - 2. r: IIC number (r = 00, 01, 11, 20), h: = POM number (h = 0, 1, 4, 5) - 3. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). - m: Unit number (m = 0, 1), n: Channel number (0, 1, 3)) ## (5) Communication at different potential (1.8 V, 2.5 V, 3 V) (UART mode) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | | HS (high-speed main)<br>Mode | | Unit | |---------------------|--------|--------------|------------------------------------------------------------------------------------------------------------------------|------------------------------|-------------------|------| | | | | | MIN. | MAX. | | | Transfer rate Note4 | | Reception | $ 4.0 \ V \leq V_{DD} \leq 5.5 \ V, $ $ 2.7 \ V \leq V_b \leq 4.0 \ V $ | | fMCK/12<br>Note 1 | bps | | | | | Theoretical value of the maximum transfer rate fmck = fclk Note 2 | | 2.0 | Mbps | | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V},$<br>$2.3 \text{ V} \le \text{V}_{b} \le 2.7 \text{ V}$ | | fMCK/12<br>Note 1 | bps | | | | | Theoretical value of the maximum transfer rate $f_{MCK} = f_{CLK}^{Note \ 2}$ | | 2.0 | Mbps | | | | | $2.4 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V},$<br>$1.6 \text{ V} \le \text{V}_{b} \le 2.0 \text{ V}$ | | fMCK/12<br>Note 1 | bps | | | | | Theoretical value of the maximum transfer rate $f_{MCK} = f_{CLK}^{Note 2}$ | | 2.0 | Mbps | | | | Transmission | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$<br>$2.7 \text{ V} \le \text{V}_{b} \le 4.0 \text{ V}$ | | Note 3 | bps | | | | | Theoretical value of the maximum transfer rate $C_b = 50 \text{ pF}, R_b = 1.4 \text{ k}\Omega, V_b = 2.7 \text{ V}$ | | 2.0<br>Note 4 | Mbps | | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V},$<br>$2.3 \text{ V} \le \text{V}_{b} \le 2.7 \text{ V},$ | | Note 5 | bps | | | | | Theoretical value of the maximum transfer rate $C_b = 50 \text{ pF}, R_b = 2.7 \text{ k}\Omega, V_b = 2.3 \text{ V}$ | | 1.2<br>Note 6 | Mbps | | | | | $2.4 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V},$<br>$1.6 \text{ V} \le \text{V}_{b} \le 2.0 \text{ V}$ | | Notes<br>2, 7 | bps | | | | | Theoretical value of the maximum transfer rate $C_b = 50 \text{ pF}, R_b = 5.5 \text{ k}\Omega, V_b = 1.6 \text{ V}$ | | 0.43<br>Note 8 | Mbps | Notes 1. Transfer rate in the SNOOZE mode is 4800 bps only. 2. The maximum operating frequencies of the CPU/peripheral hardware clock (fclk) are: HS (high-speed main) mode: 24 MHz (2.7 V $\leq$ VDD $\leq$ 5.5 V) 16 MHz (2.4 V $$\leq$$ V<sub>DD</sub> $\leq$ 5.5 V) 3. The smaller maximum transfer rate derived by using fmck/12 or the following expression is the valid maximum transfer rate. Expression for calculating the transfer rate when 4.0 V $\leq$ VDD $\leq$ 5.5 V and 2.7 V $\leq$ Vb $\leq$ 4.0 V $$\label{eq:maximum transfer rate} \text{Maximum transfer rate} = \frac{1}{\{-C_b \times R_b \times \text{ln } (1 - \frac{2.2}{V_b})\} \times 3} \text{ [bps]}$$ Baud rate error (theoretical value) = $$\frac{\frac{1}{|\text{Transfer rate} \times 2|} - \{-C_b \times R_b \times \ln(1 - \frac{2.2}{|V_b|})\}}{\frac{1}{|\text{Transfer rate}|} \times \text{Number of transferred bits}} \times 100 \, [\%]$$ - \* This value is the theoretical value of the relative difference between the transmission and reception sides. - **4.** This value as an example is calculated when the conditions described in the "Conditions" column are met. Refer to **Note 3** above to calculate the maximum transfer rate under conditions of the customer. - 5. The smaller maximum transfer rate derived by using fmck/12 or the following expression is the valid maximum transfer rate. Expression for calculating the transfer rate when 2.7 V $\leq$ V<sub>DD</sub> < 4.0 V and 2.3 V $\leq$ V<sub>b</sub> $\leq$ 2.7 V $$\label{eq:maximum transfer rate} \text{Maximum transfer rate} = \frac{1}{\left\{-C_b \times R_b \times \ln\left(1-\frac{2.0}{V_b}\right)\right\} \times 3} \text{ [bps]}$$ Baud rate error (theoretical value) = $$\frac{\frac{1}{\text{Transfer rate} \times 2} - \{-C_b \times R_b \times \ln (1 - \frac{2.0}{V_b})\}}{\frac{1}{\text{Transfer rate}}) \times \text{Number of transferred bits}} \times 100 \, [\%]$$ - \* This value is the theoretical value of the relative difference between the transmission and reception sides. - **6.** This value as an example is calculated when the conditions described in the "Conditions" column are met. Refer to **Note 5** above to calculate the maximum transfer rate under conditions of the customer. - 7. The smaller maximum transfer rate derived by using fmck/12 or the following expression is the valid maximum transfer rate. Expression for calculating the transfer rate when 2.4 V $\leq$ VDD < 3.3 V, 1.6 V $\leq$ Vb $\leq$ 2.0 V Maximum transfer rate = $$\frac{1}{\{-C_b \times R_b \times ln (1 - \frac{1.5}{V_b})\} \times 3}$$ [bps] Baud rate error (theoretical value) = $$\frac{\frac{1}{\text{Transfer rate} \times 2} - \{-C_b \times R_b \times \ln(1 - \frac{1.5}{V_b})\}}{\frac{1}{\text{Transfer rate}} \times \text{Number of transferred bits}} \times 100 \, [\%]$$ - \* This value is the theoretical value of the relative difference between the transmission and reception sides. - **8.** This value as an example is calculated when the conditions described in the "Conditions" column are met. Refer to **Note 7** above to calculate the maximum transfer rate under conditions of the customer. Caution Select the TTL input buffer for the RxDq pin and the N-ch open drain output (VDD tolerance) mode for the TxDq pin by using port input mode register g (PIMg) and port output mode register g (POMg). For VIH and VIL, see the DC characteristics with TTL input buffer selected. RxDq ## **UART** mode connection diagram (during communication at different potential) #### **UART** mode bit width (during communication at different potential) (reference) - 2. q: UART number (q = 0 to 2), g: PIM and POM number (g = 0, 1) - 3. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). - m: Unit number, n: Channel number (mn = 00 to 03, 10, 11)) - **4.** UART0 of the 20- and 24-pin products supports communication at different potential only when the peripheral I/O redirection function is not used. # (6) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (master mode, SCKp... internal clock output) (1/3) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Symbol | Conditions | | HS (high-speed | Unit | | |------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | MIN. | MAX. | | | tkcy1 | tkcy1 ≥ 4/fclk | $4.0~V \leq V_{DD} \leq 5.5~V,$ | 600 | | ns | | | | $2.7 \ V \le V_b \le 4.0 \ V,$ | | | | | | | $C_b=30~pF,~R_b=1.4~k\Omega$ | | | | | | | $2.7 \text{ V} \le V_{DD} < 4.0 \text{ V},$ | 1000 | | ns | | | | $2.3 \ V \le V_b \le 2.7 \ V$ | | | | | | | $C_b = 30$ pF, $R_b = 2.7$ k $\Omega$ | | | | | | | $2.4 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V},$ | 2300 | | ns | | | | $1.6 \ V \le V_b \le 2.0 \ V$ | | | | | | | $C_b = 30$ pF, $R_b = 5.5$ k $\Omega$ | | | | | t <sub>KH1</sub> | $4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V,$ | | tkcy1/2 -150 | | ns | | | $C_b = 30 \text{ pF}, R_b = 1.4 \text{ k}\Omega$ | | | | | | | $2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V, \;$ | | tkcy1/2 -340 | | ns | | | $C_b = 30 \text{ pF}, R_b = 2.7 \text{ k}\Omega$ | | | | | | | $2.4 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V}, \ 1.6 \text{ V} \le \text{V}_{b} \le 2.0 \text{ V},$ | | tkcy1/2 -916 | | ns | | | Сь = 30 pF, Rь | = 5.5 kΩ | | | | | t <sub>KL1</sub> | 4.0 V ≤ V <sub>DD</sub> ≤ 5 | 5.5 V, 2.7 V ≤ V <sub>b</sub> ≤ 4.0 V, | tkcy1/2 -24 | | ns | | | Cb = 30 pF, Rb | = 1.4 kΩ | | | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}, 2.3 \text{ V} \le \text{V}_{b} \le 2.7 \text{ V},$ | | tксү1/2 -36 | | ns | | | , | | | | | | | | | tkcy1/2 -100 | | ns | | | | , | | | | | | tкнı | $t_{KH1} \qquad \qquad 4.0 \text{ V} \leq \text{V}_{DD} \leq 5 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.7 \text{ V} \leq \text{V}_{DD} < 4 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.4 \text{ V} \leq \text{V}_{DD} < 3 \\ C_{b} = 30 \text{ pF, Rb} \\ 4.0 \text{ V} \leq \text{V}_{DD} \leq 5 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.7 \text{ V} \leq \text{V}_{DD} < 4 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.4 \text{ V} \leq \text{V}_{DD} < 3 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.4 \text{ V} \leq \text{V}_{DD} < 3 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.4 \text{ V} \leq \text{V}_{DD} < 3 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.4 \text{ V} \leq \text{V}_{DD} < 3 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.4 \text{ V} \leq \text{V}_{DD} < 3 \\ C_{b} = 30 \text{ pF, Rb} \\ 2.4 \text{ V} \leq \text{V}_{DD} < 3 \\ C_{b} = 30 \text{ pF, Rb} pF, Rb$ | $ \begin{array}{c} 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \\ \hline 2.7 \ V \leq V_{DD} < 4.0 \ V, \\ 2.3 \ V \leq V_{DD} < 4.0 \ V, \\ \hline 2.3 \ V \leq V_{DD} < 4.0 \ V, \\ \hline 2.4 \ V \leq V_{DD} < 3.3 \ V, \\ \hline 1.6 \ V \leq V_{DD} < 3.3 \ V, \\ \hline 1.6 \ V \leq V_b \leq 2.0 \ V, \\ \hline C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \\ \hline \end{array} $ $ \begin{array}{c} t_{KH1} \\ \hline t_{KH1} \\ \hline \end{array} \qquad \begin{array}{c} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ \hline C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \\ \hline \hline 2.7 \ V \leq V_{DD} < 4.0 \ V, \ 2.3 \ V \leq V_b \leq 2.7 \ V, \\ \hline C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ \hline \hline 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ \hline \hline C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \\ \hline \end{array} $ $ \begin{array}{c} t_{KL1} \\ \hline \end{array} \qquad \begin{array}{c} t_{KL1} \\ \hline \end{array} \qquad \begin{array}{c} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ \hline C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \\ \hline \end{array} $ | $t_{KCY1} \qquad t_{KCY1} \geq 4/f_{CLK} \qquad 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \qquad 600$ $2.7 \ V \leq V_b \leq 4.0 \ V, \qquad 2.7 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.3 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.3 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.4 \ V \leq V_{DD} < 3.3 \ V, \qquad 2300$ $1.6 \ V \leq V_{DD} < 3.3 \ V, \qquad 1.6 \ V \leq V_{DD} < 3.3 \ V, \qquad 1.6 \ V \leq V_{DD} < 3.5 \ K\Omega$ $2.7 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.7 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.7 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.7 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.7 \ V \leq V_{DD} < 4.0 \ V, \qquad 1000$ $2.7 \ V \leq V_{DD} < 3.3 \ V, \qquad 1.6 \ V \leq V_{D} \leq 2.7 \ V, \qquad 1000$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $2.7 \ V \leq V_{DD} < 3.3 \ V, \qquad 1.6 \ V \leq V_{D} \leq 2.0 \ V, \qquad 1000 \ V_{CD} = 30 \ pF, \ R_b = 5.5 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.4 \ K\Omega$ $1000 \ V_{CD} = 30 \ pF, \ R_b = 1.$ | $t_{KCY1} \qquad t_{KCY1} \geq 4/f_{CLK} \qquad 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \\ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \\ 2.7 \ V \leq V_{DD} < 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \\ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \\ 2.7 \ V \leq V_{DD} < 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \\ 2.7 \ V \leq V_{DD} < 4.0 \ V, \\ 2.3 \ V \leq V_b \leq 2.7 \ V, \\ C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \\ 2.7 \ V \leq V_{DD} < 4.0 \ V, \\ 2.3 \ V \leq V_b \leq 2.7 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \\ 2.7 \ V \leq V_{DD} < 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \\ 2.7 \ V \leq V_{DD} < 4.0 \ V, \ 2.3 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \\ 2.7 \ V \leq V_{DD} < 4.0 \ V, \ 2.3 \ V \leq V_b \leq 2.7 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.7 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b = 30 \ pF, \ R_b = 2.7 \ k\Omega \\ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, \\ C_b =$ | - Cautions 1. Select the TTL input buffer for the SIp pin and the N-ch open drain output (VDD tolerance) mode for the SOp pin and SCKp pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VH and VL, see the DC characteristics with TTL input buffer selected. - 2. CSI01 and CSI11 cannot communicate at different potential. - **Remarks 1.** R<sub>b</sub> [ $\Omega$ ]: Communication line (SCKp, SOp) pull-up resistance, C<sub>b</sub> [F]: Communication line (SCKp, SOp) load capacitance, V<sub>b</sub> [V]: Communication line voltage - **2.** p: CSI number (p = 00, 20) # (6) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (master mode, SCKp... internal clock output) (2/3) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | HS (high-spee | HS (high-speed main) Mode | | | |------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------|----|--| | | | | MIN. | MAX. | | | | Slp setup time (to SCKp <sup>↑</sup> ) | tsıkı | $ \begin{aligned} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \end{aligned} $ | 162 | | ns | | | | | | 354 | | ns | | | | | | 958 | | ns | | | SIp hold time<br>(from SCKp↑) Note | tksii | $ \begin{aligned} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \end{aligned} $ | 38 | | ns | | | | | | 38 | | ns | | | | | | 38 | | ns | | | Delay time from SCKp↓ to SOp output Note | tkso1 | $ \begin{aligned} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \end{aligned} $ | | 200 | ns | | | | | | | 390 | ns | | | | | $ 2.4 \ V \leq V_{DD} < 3.3 \ V, \ 1.6 \ V \leq V_b \leq 2.0 \ V, $ $ C_b = 30 \ pF, \ R_b = 5.5 \ k\Omega $ | | 966 | ns | | **Note** When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. ( $\pmb{\mathsf{Cautions}}$ and $\pmb{\mathsf{Remarks}}$ are listed on the next page.) # (6) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (master mode, SCKp... internal clock output) (3/3) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | HS (high-speed | HS (high-speed main) Mode | | | |------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------|----|--| | | | | MIN. | MAX. | | | | SIp setup time (to SCKp↓) Note | tsıkı | $ \begin{aligned} 4.0 \ V &\leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b &= 30 \ pF, \ R_b = 1.4 \ k\Omega \end{aligned} $ | 88 | | ns | | | | | $\label{eq:continuous} \begin{array}{ c c c c c c c c c c c c c c c c c c c$ | 88 | | ns | | | | | $ \label{eq:continuous} $ | 220 | | ns | | | SIp hold time<br>(from SCKp↓) Note | tksii | $ \begin{aligned} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \end{aligned} $ | 38 | | ns | | | | | $ \begin{cases} 2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V, \\ C_b = 30 \; pF, \; R_b = 2.7 \; k\Omega \end{cases} $ | 38 | | ns | | | | | $ \label{eq:continuous} $ | 38 | | ns | | | Delay time from SCKp↑ to SOp output Note | tkso1 | $ \begin{aligned} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 30 \ pF, \ R_b = 1.4 \ k\Omega \end{aligned} $ | | 50 | ns | | | | | $ \label{eq:continuous} $ | | 50 | ns | | | | | $ \label{eq:continuous} $ | | 50 | ns | | **Note** When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - Cautions 1. Select the TTL input buffer for the SIp pin and the N-ch open drain output (VDD tolerance) mode for the SOp pin and SCKp pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. - 2. CSI01 and CSI11 cannot communicate at different potential. - **Remarks 1.** R<sub>b</sub> [ $\Omega$ ]: Communication line (SCKp, SOp) pull-up resistance, C<sub>b</sub> [F]: Communication line (SCKp, SOp) load capacitance, V<sub>b</sub> [V]: Communication line voltage - 2. p: CSI number (p = 00, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0) ### CSI mode connection diagram (during communication at different potential) # CSI mode serial transfer timing (master mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1) # CSI mode serial transfer timing (master mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0.) **Remark** p: CSI number (p = 00, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0) (7) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (slave mode, SCKp... external clock input) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | | , , , | HS (high-speed main)<br>Mode | | |--------------------------------------|---------------|----------------------------------------------------------------------|------------------------------------------------------------|---------------|------------------------------|----| | | | | | MIN. | MAX. | | | SCKp cycle time Note 1 | tkCY2 | $4.0~V \leq V_{DD} \leq 5.5~V,$ | 20 MHz < fмcк ≤ 24 MHz | 24/fмск | | ns | | | | $2.7~V \leq V_b \leq 4.0~V$ | 8 MHz < fмск ≤ 20 MHz | 20/fмск | | ns | | | | | 4 MHz < fмcк ≤ 8 MHz | 16/fмск | | ns | | | | | fmck ≤ 4 MHz | 12/fмск | | ns | | | | $2.7 \text{ V} \le V_{DD} < 4.0 \text{ V},$ | 20 MHz < fмcк ≤ 24 MHz | 32/fмск | | ns | | | | $2.3~V \leq V_b \leq 2.7~V$ | 16 MHz < fмcк ≤ 20 MHz | 28/fмск | | ns | | | | | 8 MHz < fмск ≤ 16 MHz | 24/fмск | | ns | | | | | 4 MHz < fмcк ≤ 8 MHz | 16/fмск | | ns | | | | | fmck ≤ 4 MHz | 12/fмск | | ns | | | | $2.4 \text{ V} \le \text{V}_{\text{DD}} < 3.3 \text{ V},$ | 20 MHz < fмcк ≤ 24 MHz | 72/fмск | | ns | | | | $1.6~V \leq V_b \leq 2.0~V$ | 16 MHz < fмcк ≤ 20 MHz | 64/fмск | | ns | | | | | 8 MHz < fмск ≤ 16 MHz | 52/fмск | | ns | | | | | 4 MHz < fmck ≤ 8 MHz | 32/fмск | | ns | | | | | fmck ≤ 4 MHz | 20/fмск | | ns | | SCKp high-/low-level | tкн2,<br>tкL2 | $4.0 \text{ V} \le V_{DD} \le 5.5 \text{ V}, 2.0$ | $7~V \leq V_b \leq 4.0~V$ | tkcy2/2 - 24 | | ns | | width | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}, 2.0 \text{ V}$ | $3~V \leq V_b \leq 2.7~V$ | tkcy2/2 - 36 | | ns | | | | $2.4 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V}, 1.0 $ | $6~V \leq V_b \leq 2.0~V$ | tkcy2/2 - 100 | | ns | | SIp setup time | tsik2 | $4.0 \text{ V} \le V_{DD} \le 5.5 \text{ V}, 2.00 \le 5.5 \text{ V}$ | $7~V \leq V_{DD} \leq 4.0~V$ | 1/fmck + 40 | | ns | | (to SCKp↑) Note 2 | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}, 2.0 \text{ V}$ | $3 \text{ V} \leq \text{V}_{\text{b}} \leq 2.7 \text{ V}$ | 1/fmck + 40 | | ns | | | | $2.4 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V}, 1.0 $ | $6~V \leq V_{DD} \leq 2.0~V$ | 1/fmck + 60 | | ns | | SIp hold time<br>(from SCKp↑) Note 3 | tksi2 | | | 1/fmck + 62 | | ns | | Delay time from SCKp↓ to | tkso2 | $4.0 \text{ V} \le V_{DD} \le 5.5 \text{ V}, 2.$ | $7 \text{ V} \leq V_b \leq 4.0 \text{ V},$ | | 2/fмск + | ns | | SOp output Note 4 | | $C_b = 30 \text{ pF}, R_b = 1.4 \text{ k}$ | Ω | | 240 | | | | | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}, 2.0 \text{ V}$ | $3 \text{ V} \leq \text{V}_{\text{b}} \leq 2.7 \text{ V},$ | | 2/fмск + | ns | | | | $C_b = 30 \text{ pF}, R_b = 2.7 \text{ k}$ | Ω | | 428 | | | | | 2.4 V ≤ V <sub>DD</sub> < 3.3 V, 1. | $.6 \text{ V} \leq \text{V}_b \leq 2.0 \text{ V},$ | | 2/fмск + | ns | | | | $C_b = 30 \text{ pF}, R_b = 5.5 \text{ k}$ | $C_b = 30 \text{ pF}, R_b = 5.5 \text{ k}\Omega$ | | 1146 | | Notes 1. Transfer rate in the SNOOZE mode: MAX. 1 Mbps - 2. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp setup time becomes "to $SCKp\downarrow^n$ when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 3. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The SIp hold time becomes "from $SCKp\downarrow^n$ when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - 4. When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1. The delay time to SOp output becomes "from SCKp1" when DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0. - Cautions 1. Select the TTL input buffer for the SIp and SCKp pins and the N-ch open drain output (VDD tolerance) mode for the SOp pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. - 2. CSI01 and CSI11 cannot communicate at different potential. ## CSI mode connection diagram (during communication at different potential) CSI mode serial transfer timing (slave mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 0, or DAPmn = 1 and CKPmn = 1.) **Remarks 1.** R<sub>b</sub> [Ω]: Communication line (SOp) pull-up resistance, C<sub>b</sub> [F]: Communication line (SOp) load capacitance, Vb [V]: Communication line voltage - 2. p: CSI number (p = 00, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0) - 3. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn)) # CSI mode serial transfer timing (slave mode) (during communication at different potential) (When DAPmn = 0 and CKPmn = 1, or DAPmn = 1 and CKPmn = 0.) **Remark** p: CSI number (p = 00, 20), m: Unit number (m = 0, 1), n: Channel number (n = 0) ## (8) Communication at different potential (1.8 V, 2.5 V, 3 V) (simplified I<sup>2</sup>C mode) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | HS (high-sր<br>Mo | • | Unit | |--------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------|------| | | | | MIN. | MAX. | | | SCLr clock frequency | fscL | $ \begin{aligned} 4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ C_b = 100 \ pF, \ R_b = 2.8 \ k\Omega \end{aligned} $ | | 100 <sup>Note1</sup> | kHz | | | | | | 100 <sup>Note1</sup> | kHz | | | | $2.4 \text{ V} \le \text{V}_{DD} < 3.3 \text{ V}, 1.6 \text{ V} \le \text{V}_{b} \le 2.0 \text{ V},$ | | 100 <sup>Note1</sup> | kHz | | Hold time when SCLr = "L" tLow | tLOW | $\begin{aligned} &C_b = 100 \ pF, \ R_b = 5.5 \ k\Omega \\ &4.0 \ V \leq V_{DD} \leq 5.5 \ V, \ 2.7 \ V \leq V_b \leq 4.0 \ V, \\ &C_b = 100 \ pF, \ R_b = 2.8 \ k\Omega \end{aligned}$ | 4600 | | ns | | | | $ 2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V, \\ C_b = 100 \; pF, \; R_b = 2.7 \; k\Omega $ | 4600 | | ns | | | | $2.4~V \leq V_{DD} < 3.3~V,~1.6~V \leq V_b \leq 2.0~V,$ $C_b = 100~pF,~R_b = 5.5~k\Omega$ | 4650 | | ns | | Hold time when SCLr = "H" | thigh | $4.0~V \leq V_{DD} \leq 5.5~V,~2.7~V \leq V_b \leq 4.0~V,$ $C_b = 100~pF,~R_b = 2.8~k\Omega$ | 2700 | | ns | | | | $ 2.7 \; V \leq V_{DD} < 4.0 \; V, \; 2.3 \; V \leq V_b \leq 2.7 \; V, \\ C_b = 100 \; pF, \; R_b = 2.7 \; k\Omega $ | 2400 | | ns | | | | | 1830 | | ns | | Data setup time (reception) | tsu:dat | $ 4.0 \; V \leq V_{DD} \leq 5.5 \; V, \; 2.7 \; V \leq V_b \leq 4.0 \; V, \\ C_b = 100 \; pF, \; R_b = 2.8 \; k\Omega $ | 1/fмск<br>+ 760 Note3 | | ns | | | | | 1/f <sub>MCK</sub><br>+ 760 Note3 | | ns | | | | $2.4~V \leq V_{DD} < 3.3~V,~1.6~V \leq V_b \leq 2.0~V,$ $C_b = 100~pF,~R_b = 5.5~k\Omega$ | 1/f <sub>MCK</sub><br>+ 570 Note3 | | ns | | Data hold time (transmission) | thd:dat | $4.0~V \leq V_{DD} \leq 5.5~V,~2.7~V \leq V_b \leq 4.0~V,$ $C_b = 100~pF,~R_b = 2.8~k\Omega$ | 0 | 1420 | ns | | | | | 0 | 1420 | ns | | | | $\label{eq:continuous} $2.4 \ V \le V_{DD} < 3.3 \ V, \ 1.6 \ V \le V_{b} \le 2.0 \ V,$$$$$$$$C_{b} = 100 \ pF, \ R_{b} = 5.5 \ k\Omega$$$ | 0 | 1215 | ns | **Notes 1.** The value must also be equal to or less than fmck/4. 2. Set tsu:DAT so that it will not exceed the hold time when SCLr = "L" or SCLr = "H". Cautions 1. Select the TTL input buffer and the N-ch open drain output (VDD tolerance) mode for the SDAr pin and the N-ch open drain output (VDD tolerance) mode for the SCLr pin by using port input mode register 1 (PIM1) and port output mode register 1 (POM1). For VIH and VIL, see the DC characteristics with TTL input buffer selected. 2. IIC01 and IIC11 cannot communicate at different potential. (Remarks are listed on the next page.) ## Simplified I<sup>2</sup>C mode connection diagram (during communication at different potential) #### Simplified I<sup>2</sup>C mode serial transfer timing (during communication at different potential) - **Remarks 1.** Rb $[\Omega]$ : Communication line (SDAr, SCLr) pull-up resistance, Cb [F]: Communication line (SDAr, SCLr) load capacitance, Vb [V]: Communication line voltage - **2.** r: IIC Number (r = 00, 20) - 3. fmck: Serial array unit operation clock frequency (Operation clock to be set by the serial clock select register m (SPSm) and the CKSmn bit of serial mode register mn (SMRmn). m: Unit number (m = 0,1), n: Channel number (n = 0) #### 29.5.2 Serial interface IICA $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | HS | (high-spee | ed main) m | node | Unit | |-------------------------------------------------|--------------|--------------------------|--------|---------------|------------|------|------| | | | | Standa | Standard Mode | | Mode | | | | | | MIN. | MAX. | MIN. | MAX. | | | SCLA0 clock frequency | fscL | Fast mode: fclk≥ 3.5 MHz | | | 0 | 400 | kHz | | | | Normal mode: fclk≥ 1 MHz | 0 | 100 | | | kHz | | Setup time of restart condition | tsu:sta | | 4.7 | | 0.6 | | μS | | Hold time <sup>Note 1</sup> | thd:STA | | 4.0 | | 0.6 | | μS | | Hold time when SCLA0 = "L" | tLOW | | 4.7 | | 1.3 | | μS | | Hold time when SCLA0 = "H" | thigh | | 4.0 | | 0.6 | | μS | | Data setup time (reception) | tsu:dat | | 250 | | 100 | | ns | | Data hold time (transmission) <sup>Note 2</sup> | thd:dat | | 0 | 3.45 | 0 | 0.9 | μS | | Setup time of stop condition | tsu:sto | | 4.0 | | 0.6 | | μs | | Bus-free time | <b>t</b> BUF | | 4.7 | | 1.3 | | μS | Notes 1. The first clock pulse is generated after this period when the start/restart condition is detected. <R> 2. The maximum value (MAX.) of thd:dat is during normal transfer and a wait state is inserted in the ACK (acknowledge) timing. Caution Only in the 30-pin products, the values in the above table are applied even when bit 2 (PIOR2) in the peripheral I/O redirection register (PIOR) is 1. At this time, the pin characteristics (IoH1, IoL1, VOH1, VOL1) must satisfy the values in the redirect destination. **Remark** The maximum value of Cb (communication line capacitance) and the value of Rb (communication line pull-up resistor) at that time in each mode are as follows. Normal mode: $C_b = 400 \text{ pF}, \text{ Rb} = 2.7 \text{ k}\Omega$ Fast mode: $C_b = 320 \text{ pF}, \text{ Rb} = 1.1 \text{ k}\Omega$ #### IICA serial transfer timing ## 29.6 Analog Characteristics #### 29.6.1 A/D converter characteristics Classification of A/D converter characteristics | Input channel | | Reference Voltage | | |-----------------------------------|------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------| | | Reference voltage (+) = AVREFP<br>Reference voltage (-) = AVREFM | Reference voltage (+) = VDD<br>Reference voltage (-) = Vss | Reference voltage (+) = VBGR<br>Reference voltage (-) = AVREFM | | ANI0 to ANI3 | Refer to 29.6.1 (1). | Refer to 29.6.1 (3). | Refer to 29.6.1 (4). | | ANI16 to ANI22 | Refer to 29.6.1 (2). | | | | Internal reference voltage | Refer to <b>29.6.1 (1)</b> . | | - | | Temperature sensor output voltage | | | | (1) When reference voltage (+) = AVREFP/ANIO (ADREFP1 = 0, ADREFP0 = 1), reference voltage (-) = AVREFM/ANI1 (ADREFM = 1), target pin: ANI2, ANI3, internal reference voltage, and temperature sensor output voltage $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le \text{AV}_{REFP} \le \text{VDD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V}, \text{Reference voltage (+)} = \text{AV}_{REFP}, \text{Reference voltage (-)} = \text{AV}_{REFM} = 0 \text{ V})$ | Parameter | Symbol | Cor | nditions | MIN. | TYP. | MAX. | Unit | |--------------------------------------------|--------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------|----------------|--------|------| | Resolution | RES | | | 8 | | 10 | bit | | Overall error <sup>Note 1</sup> | AINL | 10-bit resolution AVREFP = VDD Note 3 | | | 1.2 | ±3.5 | LSB | | Conversion time | tconv | 10-bit resolution | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.125 | | 39 | μS | | | | Target pin: ANI2, ANI3 | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.1875 | | 39 | μS | | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μS | | | | 10-bit resolution | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.375 | | 39 | μS | | | | Target pin: Internal | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.5625 | | 39 | μS | | | | reference voltage, and<br>temperature sensor<br>output voltage<br>(HS (high-speed main)<br>mode) | $2.4~V \leq V \text{DD} \leq 5.5~V$ | 17 | | 39 | μs | | Zero-scale error <sup>Notes 1, 2</sup> | EZS | 10-bit resolution AVREFP = VDD Note 3 | | | | ±0.25 | %FSR | | Full-scale error <sup>Notes 1, 2</sup> | EFS | 10-bit resolution AVREFP = VDD Note 3 | | | | ±0.25 | %FSR | | Integral linearity error <sup>Note 1</sup> | ILE | 10-bit resolution AVREFP = VDD Note 3 | | | | ±2.5 | LSB | | Differential linearity error | DLE | 10-bit resolution<br>AVREFP = VDD Note 3 | | | | ±1.5 | LSB | | Analog input voltage | Vain | ANI2, ANI3 | | 0 | | AVREFP | V | | | | Internal reference voltage (HS (high-speed main) m | | V <sub>BGR</sub> Note 4 | | | V | | | | | Temperature sensor output voltage (HS (high-speed main) mode) | | VTMPS25 Note 4 | ı | V | (Notes are listed on the next page.) - **Notes 1.** Excludes quantization error ( $\pm 1/2$ LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - **3.** When $AV_{REFP} < V_{DD}$ , the MAX. values are as follows. Overall error: Add $\pm 1.0$ LSB to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. Zero-scale error/Full-scale error: Add $\pm 0.05\%$ FSR to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. Integral linearity error/ Differential linearity error: Add $\pm 0.5$ LSB to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. 4. Refer to 29.6.2 Temperature sensor/internal reference voltage characteristics. # (2) When reference voltage (+) = AVREFP/ANIO (ADREFP1 = 0, ADREFP0 = 1), reference voltage (-) = AVREFM/ANI1 (ADREFM = 1), target pin: ANI16 to ANI22 $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le \text{AV}_{REFP} \le \text{V}_{DD} \le 5.5 \text{ V}, \text{V}_{SS} = 0 \text{ V}, \text{Reference voltage (+)} = \text{AV}_{REFP}, \text{Reference voltage (-)} = \text{AV}_{REFM} = 0 \text{ V})$ | Parameter | Symbol | Conditio | ns | MIN. | TYP. | MAX. | Unit | |----------------------------------------|--------|-----------------------------------------------------------------------------|--------------------------------|--------|------|-------------------|------| | Resolution | RES | | | 8 | | 10 | bit | | Overall error Note 1 | AINL | 10-bit resolution<br>AV <sub>REFP</sub> = V <sub>DD</sub> Note 3 | | 1.2 | ±5.0 | LSB | | | Conversion time | tconv | 10-bit resolution | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.125 | | 39 | μS | | | | Target ANI pin: ANI16 to ANI22 | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.1875 | | 39 | μS | | | | $2.4~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μS | | | Zero-scale error Notes 1, 2 | EZS | 10-bit resolution<br>AV <sub>REFP</sub> = V <sub>DD</sub> <sup>Note 3</sup> | | | | ±0.35 | %FSR | | Full-scale error Notes 1, 2 | EFS | 10-bit resolution AVREFP = VDD Note 3 | | | | | %FSR | | Integral linearity error Note 1 | ILE | 10-bit resolution AVREFP = VDD Note 3 | | | | ±3.5 | LSB | | Differential linearity<br>error Note 1 | DLE | 10-bit resolution AVREFP = VDD Note 3 | | | | ±2.0 | LSB | | Analog input voltage | Vain | ANI16 to ANI22 | | 0 | | AVREFP<br>and VDD | V | #### **Notes 1.** Excludes quantization error ( $\pm 1/2$ LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - **3.** When $AV_{REFP} \leq V_{DD}$ , the MAX. values are as follows. Overall error: Add $\pm 4.0$ LSB to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. Zero-scale error/Full-scale error: Add $\pm 0.20\%$ FSR to the MAX. value when AV<sub>REFP</sub> = V<sub>DD</sub>. Integral linearity error/ Differential linearity error: Add ±2.0 LSB to the MAX. value when AVREFP = VDD. (3) When reference voltage (+) = V<sub>DD</sub> (ADREFP1 = 0, ADREFP0 = 0), reference voltage (-) = V<sub>SS</sub> (ADREFM = 0), target pin: ANI0 to ANI3, ANI16 to ANI22, internal reference voltage, and temperature sensor output voltage $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V}, \text{Reference voltage (+)} = V_{DD}, \text{ Reference voltage (-)} = V_{SS})$ | Parameter | Symbol | Condition | ns | MIN. | TYP. | MAX. | Unit | |--------------------------------------------|--------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------|----------------------------|------|-----------------|------| | Resolution | Res | | | 8 | | 10 | bit | | Overall error <sup>Note 1</sup> | AINL | 10-bit resolution | | | 1.2 | ±7.0 | LSB | | Conversion time | tconv | 10-bit resolution | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.125 | | 39 | μs | | | | Target pin: ANI0 to ANI3,<br>ANI16 to ANI22 | $2.7~V \leq V_{DD} \leq 5.5~V$ | 3.1875 | | 39 | μS | | | | ANI16 to ANI22 | $2.4~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μs | | Conversion time | tconv | 10-bit resolution | $3.6~V \leq V_{DD} \leq 5.5~V$ | 2.375 | | 39 | μs | | | | Target pin: internal reference | $2.7 \text{ V} \leq \text{VDD} \leq 5.5 \text{ V}$ | 3.5625 | | 39 | μs | | | | voltage, and temperature<br>sensor output voltage (HS<br>(high-speed main) mode) | $2.4~V \leq V_{DD} \leq 5.5~V$ | 17 | | 39 | μS | | Zero-scale error <sup>Notes 1, 2</sup> | EZS | 10-bit resolution | <u>I</u> | | | ±0.60 | %FSR | | Full-scale error <sup>Notes 1, 2</sup> | EFS | 10-bit resolution | | | | ±0.60 | %FSR | | Integral linearity error <sup>Note 1</sup> | ILE | 10-bit resolution | | | | ±4.0 | LSB | | Differential linearity error Note 1 | DLE | 10-bit resolution | | | | ±2.0 | LSB | | Analog input voltage | Vain | ANI0 to ANI3, ANI16 to ANI2 | 2 | 0 | | V <sub>DD</sub> | ٧ | | | Internal reference voltage (HS (high-speed main) mode) | | 1 | V <sub>BGR</sub> Note 3 | | | V | | | | Temperature sensor output voltage (HS (high-speed main) mode) | | V <sub>TMPS25</sub> Note 3 | | | V | Notes 1. Excludes quantization error ( $\pm 1/2$ LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - 3. Refer to 29.6.2 Temperature sensor/internal reference voltage characteristics. (4) When reference voltage (+) = Internal reference voltage (ADREFP1 = 1, ADREFP0 = 0), reference voltage (-) = AVREFM (ADREFM = 1), target pin: ANI0, ANI2, ANI3, and ANI16 to ANI22 (TA = -40 to +105°C, 2.4 V $\leq$ VDD $\leq$ 5.5 V, Vss = 0 V, Reference voltage (+) = VBGR Note 3, Reference voltage (-) = AVREFM Note 4 = 0 V, HS (high-speed main) mode) | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------------------|--------|------------------|------|------|-------------------------|------| | Resolution | Res | | 8 | | | bit | | Conversion time | tconv | 8-bit resolution | 17 | | 39 | μs | | Zero-scale error <sup>Notes 1, 2</sup> | EZS | 8-bit resolution | | | ±0.60 | %FSR | | Integral linearity error <sup>Note 1</sup> | ILE | 8-bit resolution | | | ±2.0 | LSB | | Differential linearity error Note 1 | DLE | 8-bit resolution | | | ±1.0 | LSB | | Analog input voltage | VAIN | | 0 | | V <sub>BGR</sub> Note 3 | V | - **Notes 1.** Excludes quantization error ( $\pm 1/2$ LSB). - 2. This value is indicated as a ratio (%FSR) to the full-scale value. - 3. Refer to 29.6.2 Temperature sensor/internal reference voltage characteristics. - 4. When reference voltage (-) = Vss, the MAX. values are as follows. Zero-scale error: Add ±0.35%FSR to the MAX. value when reference voltage (-) = AVREFM. Integral linearity error: Add ±0.5 LSB to the MAX. value when reference voltage (-) = AVREFM. Differential linearity error: Add ±0.2 LSB to the MAX. value when reference voltage (-) = AVREFM. #### 29.6.2 Temperature sensor/internal reference voltage characteristics (T<sub>A</sub> = -40 to +105°C, 2.4 V $\leq$ V<sub>DD</sub> $\leq$ 5.5 V, V<sub>SS</sub> = 0 V, HS (high-speed main) mode | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------|---------------------|-------------------------------------------------------------------|------|------|------|-------| | Temperature sensor output voltage | V <sub>TMPS25</sub> | Setting ADS register = 80H,<br>TA = +25°C | | 1.05 | | V | | Internal reference voltage | V <sub>BGR</sub> | Setting ADS register = 81H | 1.38 | 1.45 | 1.50 | V | | Temperature coefficient | Fvтмps | Temperature sensor output voltage that depends on the temperature | | -3.6 | | mV/°C | | Operation stabilization wait time | tamp | | 5 | | | μS | #### 29.6.3 POR circuit characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------|------------------|------------------------|------|------|------|------| | Detection voltage | VPOR | Power supply rise time | 1.45 | 1.51 | 1.57 | V | | | V <sub>PDR</sub> | Power supply fall time | 1.44 | 1.50 | 1.56 | ٧ | | Minimum pulse width Note | T <sub>PW</sub> | | 300 | | | μs | **Note** Minimum time required for a POR reset when V<sub>DD</sub> exceeds below V<sub>PDR</sub>. This is also the minimum time required for a POR reset from when V<sub>DD</sub> exceeds below 0.7 V to when V<sub>DD</sub> exceeds V<sub>PDR</sub> while STOP mode is entered or the main system clock is stopped through setting bit 0 (HIOSTOP) and bit 7 (MSTOP) in the clock operation status control register (CSC). ## 29.6.4 LVD circuit characteristics ## LVD Detection Voltage of Reset Mode and Interrupt Mode (Ta = -40 to +105°C, VPDR $\leq$ VDD $\leq$ 5.5 V, Vss = 0 V) | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------|-------------------|------------------------|------|------|------|------| | Detection supply voltage | V <sub>LVD0</sub> | Power supply rise time | 3.90 | 4.06 | 4.22 | ٧ | | | | Power supply fall time | 3.83 | 3.98 | 4.13 | V | | | V <sub>LVD1</sub> | Power supply rise time | 3.60 | 3.75 | 3.90 | ٧ | | | | Power supply fall time | 3.53 | 3.67 | 3.81 | ٧ | | | V <sub>LVD2</sub> | Power supply rise time | 3.01 | 3.13 | 3.25 | V | | | | Power supply fall time | 2.94 | 3.06 | 3.18 | V | | | V <sub>LVD3</sub> | Power supply rise time | 2.90 | 3.02 | 3.14 | V | | | | Power supply fall time | 2.85 | 2.96 | 3.07 | ٧ | | | V <sub>LVD4</sub> | Power supply rise time | 2.81 | 2.92 | 3.03 | V | | | | Power supply fall time | 2.75 | 2.86 | 2.97 | V | | | V <sub>LVD5</sub> | Power supply rise time | 2.70 | 2.81 | 2.92 | V | | | | Power supply fall time | 2.64 | 2.75 | 2.86 | V | | | V <sub>LVD6</sub> | Power supply rise time | 2.61 | 2.71 | 2.81 | V | | | | Power supply fall time | 2.55 | 2.65 | 2.75 | V | | | V <sub>LVD7</sub> | Power supply rise time | 2.51 | 2.61 | 2.71 | ٧ | | | | Power supply fall time | 2.45 | 2.55 | 2.65 | V | | Minimum pulse width | tıw | | 300 | | | μS | | Detection delay time | | | | | 300 | μS | ## LVD detection voltage of interrupt & reset mode $(T_A = -40 \text{ to } +105^{\circ}\text{C}, V_{PDR} \le V_{DD} \le 5.5 \text{ V}, V_{SS} = 0 \text{ V})$ | Parameter | Symbol | | Cond | itions | MIN. | TYP. | MAX. | Unit | |---------------------|--------------------|---------------------|-------------------------------|------------------------------|------|------|------|------| | Interrupt and reset | V <sub>LVDD0</sub> | V <sub>POC2</sub> , | VPOC1, VPOC1 = 0, 1, 1, falli | 2.64 | 2.75 | 2.86 | V | | | mode | V <sub>LVDD1</sub> | | LVIS1, LVIS0 = 1, 0 | Rising reset release voltage | 2.81 | 2.92 | 3.03 | V | | | | | | Falling interrupt voltage | 2.75 | 2.86 | 2.97 | V | | | V <sub>LVDD2</sub> | | LVIS1, LVIS0 = 0, 1 | Rising reset release voltage | 2.90 | 3.02 | 3.14 | V | | | | | | Falling interrupt voltage | 2.85 | 2.96 | 3.07 | V | | | V <sub>LVDD3</sub> | | LVIS1, LVIS0 = 0, 0 | Rising reset release voltage | 3.90 | 4.06 | 4.22 | V | | | | | | Falling interrupt voltage | 3.83 | 3.98 | 4.13 | V | #### 29.6.5 Power supply voltage rising slope characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------|--------|------------|------|------|------|------| | Power supply voltage rising slope | SVDD | | | | 54 | V/ms | **Caution** Make sure to keep the internal reset state by the LVD circuit or an external reset until V<sub>DD</sub> reaches the operating voltage range shown in 29.4 AC Characteristics. ## <R>> 29.7 RAM Data Retention Characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, \text{ Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |-------------------------------|--------|------------|-----------|------|------|------| | Data retention supply voltage | VDDDR | | 1.44 Note | | 5.5 | V | Note This depends on the POR detection voltage. For a falling voltage, data in RAM are retained until the voltage reaches the level that triggers a POR reset but not once it reaches the level at which a POR reset is generated. #### 29.8 Flash Memory Programming Characteristics $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | | (1H = 10 to 1100 0, 211 1 2 1 | | 1, 100 0 1/ | | | | | |---------|------------------------------------|--------|-----------------------------------------------------|---------|-----------|------|-------| | _ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | | <r></r> | System clock frequency | fclk | | 1 | | 24 | MHz | | | Code flash memory rewritable times | Cerwr | Retained for 20 years TA = 85°C Notes 4 | 1,000 | | | Times | | | Data flash memory rewritable times | | Retained for 1 year TA = 25°C Notes 4 | | 1,000,000 | | | | | | | Retained for 5 years T <sub>A</sub> = 85°C Notes 4 | 100,000 | | | | | | | | Retained for 20 years TA = 85°C Notes 4 | 10,000 | | | | - **Notes 1.** 1 erase + 1 write after the erase is regarded as 1 rewrite. The retaining years are until next rewrite after the rewrite. - 2. When using flash memory programmer and Renesas Electronics self programming library - 3. These are the characteristics of the flash memory and the results obtained from reliability testing by Renesas Electronics Corporation. - 4. This temperature is the average value at which data are retained. #### 29.9 Dedicated Flash Memory Programmer Communication (UART) $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |---------------|--------|---------------------------|---------|------|-----------|------| | Transfer rate | | During serial programming | 115,200 | | 1,000,000 | bps | #### 29.10 Timing of Entry to Flash Memory Programming Modes $(T_A = -40 \text{ to } +105^{\circ}\text{C}, 2.4 \text{ V} \le V_{DD} \le 5.5 \text{ V}, \text{Vss} = 0 \text{ V})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |-------------------------------------------------------------------------------------------------|---------|--------------------------------------------------------|------|------|------|------| | Time to complete the communication for the initial setting after the external reset is released | tsuinit | POR and LVD reset are released before external release | | | 100 | ms | | Time to release the external reset after the TOOL0 pin is set to the low level | tsu | POR and LVD reset are released before external release | 10 | | | μS | | Time to hold the TOOL0 pin at the low level after the external reset is released | tно | POR and LVD reset are released before external release | 1 | | | ms | | (excluding the processing time of the firmware to control the flash memory) | | | | | | | - <1> The low level is input to the TOOL0 pin. - <2> The external reset is released (POR and LVD reset must be released before the external reset is released.). - <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: Communication for the initial setting must be completed within 100 ms after the external reset is released during this period. tsu: Time to release the external reset after the TOOL0 pin is set to the low level thd: Time to hold the TOOL0 pin at the low level after the external reset is released (excluding the processing time of the firmware to control the flash memory) <R> #### **CHAPTER 30 PACKAGE DRAWINGS** ## 30.1 20-pin products R5F1026AASP, R5F10269ASP, R5F10268ASP, R5F10267ASP, R5F10266ASP R5F1036AASP, R5F10369ASP, R5F10368ASP, R5F10367ASP, R5F10366ASP R5F1026ADSP, R5F10269DSP, R5F10268DSP, R5F10267DSP, R5F10366DSP R5F1036ADSP, R5F10369DSP, R5F10368DSP, R5F10367DSP, R5F10266GSP R5F1026AGSP, R5F10269GSP, R5F10268GSP, R5F10267GSP, R5F10266GSP | JEITA Package Code | RENESAS Code | Previous Code | MASS (TYP.) [g] | |------------------------|--------------|----------------|-----------------| | P-LSSOP20-4.4x6.5-0.65 | PLSP0020JB-A | P20MA-65-NAA-1 | 0.1 | #### NOTE - 1. Dimensions "X1" and "X2" do not include mold flash. - 2.Dimension "¾3" does not include trim offset. | | (UNIT:mm) | |----------|--------------------------| | ITEM | DIMENSIONS | | D | 6.50±0.10 | | E | 4.40±0.10 | | HE | 6.40±0.20 | | Α | 1.45 MAX. | | A1 | 0.10±0.10 | | A2 | 1.15 | | е | 0.65±0.12 | | bp | $0.22 + 0.10 \\ -0.05$ | | С | $0.15 \pm 0.05 \\ -0.02$ | | L | 0.50±0.20 | | У | 0.10 | | $\theta$ | 0° to 10° | | | | ©2012 Renesas Electronics Corporation. All rights reserved. <R> ## 30.2 24-pin products R5F1027AANA, R5F10279ANA, R5F10278ANA, R5F10277ANA R5F1037AANA, R5F10379ANA, R5F10378ANA, R5F10377ANA R5F1027ADNA, R5F10279DNA, R5F10278DNA, R5F10277DNA R5F1037ADNA, R5F10379DNA, R5F10378DNA, R5F10377DNA R5F1027AGNA, R5F10279GNA, R5F10278GNA, R5F10277GNA | JEITA Package Code | RENESAS Code | Previous Code | MASS (TYP.) [g] | |--------------------|--------------|----------------|-----------------| | P-HWQFN24-4x4-0.50 | PWQN0024KE-A | P24K8-50-CAB-1 | 0.04 | ©2012 Renesas Electronics Corporation. All rights reserved. <R> ## 30.3 30-pin products R5F102AAASP, R5F102A9ASP, R5F102A8ASP, R5F102A7ASP R5F103AAASP, R5F103A9ASP, R5F103A8ASP, R5F103A7ASP R5F102AADSP, R5F102A9DSP, R5F102A8DSP, R5F102A7DSP R5F103AADSP, R5F103A9DSP, R5F103A8DSP, R5F103A7DSP R5F102AAGSP, R5F102A9GSP, R5F102A8GSP, R5F102A7GSP | JEITA Package Code | RENESAS Code | Previous Code | MASS (TYP.) [g] | |---------------------|--------------|----------------|-----------------| | P-LSSOP30-0300-0.65 | PLSP0030JB-B | S30MC-65-5A4-3 | 0.18 | ## NOTE Each lead centerline is located within 0.13 mm of its true position (T.P.) at maximum material condition. | ITEM | MILLIMETERS | |------|------------------------| | Α | 9.85±0.15 | | В | 0.45 MAX. | | С | 0.65 (T.P.) | | D | $0.24^{+0.08}_{-0.07}$ | | Е | 0.1±0.05 | | F | 1.3±0.1 | | G | 1.2 | | Н | 8.1±0.2 | | ı | 6.1±0.2 | | J | 1.0±0.2 | | K | 0.17±0.03 | | L | 0.5 | | М | 0.13 | | N | 0.10 | | Р | 3°+5° | | Т | 0.25 | | U | 0.6±0.15 | | | | ©2012 Renesas Electronics Corporation. All rights reserved. #### APPENDIX A REVISION HISTORY ## A.1 Major Revisions in This Edition (1/4) | CHAPTER 1 OUTLINE Define Modification of Figure 1-1 Part Number, Memory Size, and Package of RL78/G12 Define Modification of Table 1-1 List of Ordering Part Numbers Addition of product name (RL78/G12) and description (Top View) in 1.4.1 20-pin products Define Addition of product name (RL78/G12) and description (Top View) in 1.4.2 24-pin products Define Addition of product name (RL78/G12) and description (Top View) in 1.4.3 30-pin products Define Modification of description in 1.7 Outline of Functions CHAPTER 2 PIN FUNCTIONS Define Modification of pin type of P125 in 2.1.1 20-pin products Define Modification of pin type of P125 in 2.1.2 24-pin products Define Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) Define Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 Define Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 Define Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 8-1-1 Define Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 Define Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-3-1 Define Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-1 Define Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-1 Define Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 Define Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 Define Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE Define Addition of note 1 in Figure 3-2 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x = 2 or 3) | (d) | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| | D.7 Modification of Table 1-1 List of Ordering Part Numbers D.8 Addition of product name (RL78/G12) and description (Top View) in 1.4.1 20-pin products D.9 Addition of product name (RL78/G12) and description (Top View) in 1.4.2 24-pin products D.10 Addition of product name (RL78/G12) and description (Top View) in 1.4.3 30-pin products D.15 Modification of description in 1.7 Outline of Functions CHAPTER 2 PIN FUNCTIONS D.18 Modification of pin type of P125 in 2.1.1 20-pin products D.19 Modification of pin type of P125 in 2.1.2 24-pin products D.24 Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) D.27 Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 D.30 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-1-2 D.32 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 D.33 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 D.34 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-1-2 D.35 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 D.36 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.39 Addition of caution in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x D.40 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x = 2 or 3) D.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | | | Addition of product name (RL78/G12) and description (Top View) in 1.4.1 20-pin products Addition of product name (RL78/G12) and description (Top View) in 1.4.2 24-pin products Addition of product name (RL78/G12) and description (Top View) in 1.4.3 30-pin products Addition of product name (RL78/G12) and description (Top View) in 1.4.3 30-pin products Modification of description in 1.7 Outline of Functions CHAPTER 2 PIN FUNCTIONS D.18 Modification of pin type of P125 in 2.1.1 20-pin products D.19 Modification of pin type of P125 in 2.1.2 24-pin products D.24 Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) D.27 Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 D.30 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 D.32 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 8-1-1 D.33 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 D.34 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 D.35 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 D.36 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of cautions 1 in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.38 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.39 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.30 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | (d) | | Addition of product name (RL78/G12) and description (Top View) in 1.4.2 24-pin products Addition of product name (RL78/G12) and description (Top View) in 1.4.3 30-pin products Modification of description in 1.7 Outline of Functions CHAPTER 2 PIN FUNCTIONS Modification of pin type of P125 in 2.1.1 20-pin products D.19 Modification of pin type of P125 in 2.1.2 24-pin products D.24 Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) D.27 Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 D.30 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 D.32 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 8-1-1 D.33 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 D.34 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 D.35 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 D.36 Addition of caution in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) D.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | (d) | | Addition of product name (RL78/G12) and description (Top View) in 1.4.3 30-pin products Modification of description in 1.7 Outline of Functions CHAPTER 2 PIN FUNCTIONS D.18 Modification of pin type of P125 in 2.1.1 20-pin products D.19 Modification of pin type of P125 in 2.1.2 24-pin products D.24 Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) D.27 Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 D.30 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 D.32 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 D.33 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 D.34 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-3-1 D.35 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-1 D.36 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (specific processes) | (d) | | CHAPTER 2 PIN FUNCTIONS D.18 Modification of pin type of P125 in 2.1.1 20-pin products D.19 Modification of pin type of P125 in 2.1.2 24-pin products D.24 Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) D.27 Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 D.30 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 D.32 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 D.33 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 D.34 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 D.35 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-1 D.36 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (specific points). | (d) | | CHAPTER 2 PIN FUNCTIONS p.18 Modification of pin type of P125 in 2.1.1 20-pin products p.19 Modification of pin type of P125 in 2.1.2 24-pin products p.24 Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) p.27 Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 p.30 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 p.32 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 p.33 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 p.34 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 p.35 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 p.36 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 p.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE p.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x p.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (s | (d) | | Modification of pin type of P125 in 2.1.1 20-pin products Modification of pin type of P125 in 2.1.2 24-pin products Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | (c) | | Modification of pin type of P125 in 2.1.2 24-pin products D.24 Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) D.27 Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 D.30 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 D.32 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 D.33 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 D.34 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 D.35 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 D.36 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 D.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | | | Modification of description in Table 2-3 Connection of Unused Pins (30-pin products) Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | (a) | | Addition of Figure 2-4 Pin Block Diagram for Pin Type 3-1-1 Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | (a) | | Addition of caution in Figure 2-7 Pin Block Diagram for Pin Type 7-1-2 Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | (a) | | Addition of caution in Figure 2-9 Pin Block Diagram for Pin Type 7-3-2 Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | Addition of caution in Figure 2-10 Pin Block Diagram for Pin Type 8-1-1 Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) D.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | Addition of cautions 1 and 2 in Figure 2-11 Pin Block Diagram for Pin Type 8-1-2 Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | Addition of caution in Figure 2-12 Pin Block Diagram for Pin Type 8-3-1 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE D.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) D.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | p.36 Addition of cautions 1 and 2 in Figure 2-13 Pin Block Diagram for Pin Type 8-3-2 p.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE p.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) p.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | p.37 Addition of caution in Figure 2-14 Pin Block Diagram for Pin Type 12-1-1 CHAPTER 3 CPU ARCHITECTURE p.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) p.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | CHAPTER 3 CPU ARCHITECTURE p.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x. (x = 2 or 3) p.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | p.40 Modification of note 1 in Figure 3-2 Memory Map for the R5F10x67, and R5F10x77, and R5F10x (x = 2 or 3) p.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x) | (c) | | (x = 2 or 3) Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | | | p.41 Modification of note 1 in Figure 3-3 Memory Map for the R5F10x68, R5F10x78, and R5F10xA8 (x | A7 (c) | | | | | 2 or 3) | x = (c) | | p.42 Modification of note 1 in Figure 3-4 Memory Map for the R5F10x69, R5F10x79, and R5F10xA9 (x 2 or 3) | x = (c) | | p.43 Modification of note 1 in Figure 3-5 Memory Map for the R5F10x6A, R5F10x7A (x = 2 or 3) | (c) | | p.44 Modification of note 1 in Figure 3-6 Memory Map for the R5F10xAA (x = 2 or 3) | (c) | | p.47 Modification of vector table addresses in Table 3-3 Vector Table (20-, 24-pin products) | (a) | | p.48 Modification of vector table addresses in Table 3-4 Vector Table (30-pin products) | (a) | | p.55 Modification of addresses in 3.2.1 Control registers | (a) | | CHAPTER 5 CLOCK GENERATOR | (4) | | p.115 Modification of description in 5.1 Functions of Clock Generator | (c) | | p.121 Modification of caution 5 in Figure 5-4 Format of Clock Operation Status Control Register (CSC) | (c) | | p.136 Addition of Note in 5.6.2 Example of setting X1 oscillation clock | (c) | | p.140 Modification of description in Table 5-4 Changing CPU Clock | (c) | | p.141 Modification of description in 5.6.6 Conditions before clock oscillation is stopped | (c) | | p.143 Addition of note 4 and remark 2 in 5.7 Resonator and Oscillator Constants | (c) | - (a): Error correction, (b): Addition/change of specifications, (c): Addition/change of description or note, - (d): Addition/change of package, part number, or management division, (e): Addition/change of related documents (2/4) | Page | Description | Classification | |-----------|------------------------------------------------------------------------------------------------------------|----------------| | CHAPTER ( | 5 TIMER ARRAY UNIT | | | p.157 | Modification of description in 6.2.2 Timer data register 0n (TDR0n) | (c) | | p.163 | Modification of description in Figure 6-9 Format of Timer Mode Register 0n (TMR0n) (1/4) | (c) | | p.171 | Addition of caution in Figure 6-14 Format of Timer Input Select register 0 (TIS0) | (c) | | p.180 | Modification of description in 6.4.2 Basic rules of 8-bit timer operation function (Only Channels 1 and 3) | (c) | | p.204 | Modification of description in 6.8.2 Operation as external event counter | (c) | | p.221 | Modification of description in Figure 6-57 Operation Procedure When Input Signal High-/Low-Level | (c) | | | Width Measurement Function Is Used | | | CHAPTER ' | 10 A/D CONVERTER | | | p.305 | Modification of description in Figure 10-29 Setting up Software Trigger Mode | (c) | | p.306 | Modification of description in Figure 10-30 Setting up Hardware Trigger No-Wait Mode | (c) | | p.307 | Modification of description in Figure 10-31 Setting up Hardware Trigger Wait Mode | (c) | | p.308 | Modification of description in Figure 10-32 Setup when Temperature Sensor Output Voltage/Internal | (c) | | | Reference Voltage is Selected | | | p.308 | Modification of description in Figure 10-33 Setting up Test Mode | (c) | | p.313 | Modification of description in Figure 10-37 Flowchart for Setting Up SNOOZE Mode | (c) | | p.316 | Modification of description in 10.10 Cautions for A/D Converter | (c) | | CHAPTER ' | 11 SERIAL ARRAY UNIT | | | p.328 | Modification of note 2 in 11.2.2 Lower 8/9 bits of the serial data register mn (SDRmn) | (c) | | p.338 | Modification of caution 4 in Figure 11-10 Format of Serial Data Register mn (SDRmn) | (c) | | p.346 | Modification of bit 10 of SO0, note 2, and caution in Figure 11-17 Format of Serial Output Register m | (b) | | | (SOm) | | | p.348 | Modification of pin name in Figure 11-19 Examples of Reverse Transmit Data | (a) | | p.405 | Modification of description in 11.5.7 SNOOZE mode function | (c) | | p.405 | Modification of Figure 11-71 Timing Chart of SNOOZE Mode Operation (once startup) (Type 1: DAP00 | (b) | | | = 0, CKP00 = 0) | | | p.406 | Modification of Figure 11-72 Flowchart of SNOOZE Mode Operation (once startup) | (c) | | p.407 | Modification of Figure 11-73 Timing Chart of SNOOZE Mode Operation (continuous startup) (Type 1: | (b) | | | DAP00 = 0, CKP00 = 0), and modification of note | | | p.408 | Modification of Figure 11-74 Flowchart of SNOOZE Mode Operation (continuous startup) | (c) | | p.410 | Modification of description in Table 11-2 Selection of Operation Clock For 3-Wire Serial I/O | (c) | | p.427 | Modification of Figure 11-87 Procedure for Resuming UART Reception | (c) | | p.430 | Modification of description and addition of caution 5 in 11.6.3 SNOOZE mode function | (c) | | p.432 | Modification of Figure 11-90 Timing Chart of SNOOZE Mode Operation (EOC01 = 0, SSEC0 = 0/1) | (b) | | p.433 | Modification of Figure 11-91 Timing Chart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 0), and | (b) | | | addition of note | | | p.434 | Modification of Figure 11-92 Flowchart of SNOOZE Mode Operation (EOC01 = 0, SSEC0 = 0/1 or | (c) | | | EOC01 = 1, SSEC0 = 0) | | | p.435 | Modification of Figure 11-93 Timing Chart of SNOOZE Mode Operation (EOC01 = 1, SSEC0 = 1: Error | (c) | | | interrupt (INTSRE0) generation is stopped) | | | p.439 | Modification of description in Table 11-4 Selection of Operation Clock For UART | (c) | - (a): Error correction, (b): Addition/change of specifications, (c): Addition/change of description or note, - (d): Addition/change of package, part number, or management division, (e): Addition/change of related documents (3/4) | Page | Description | Classification | |------------|------------------------------------------------------------------------------------------------------------------------------------------|----------------| | | SERIAL INTERFACE IICA | 0.000000 | | p.477 | Modification of description in 12.3.6 IICA low-level width setting register 0 (IICWL0) | (c) | | p.480 | Modification of remark 2 in 12.4.2 Setting transfer clock by using IICWL0 and IICWH0 registers | (c) | | p.493 | Modification of description in 12.5.13 Wakeup function | (c) | | p.495 | Modification of description, formula, and remark in 12.5.14 Communication reservation | (c) | | p.497 | Modification of note 1 and remark in Figure 12-27 Communication Reservation Protocol | (c) | | p.501 | Addition of description in Figure 12-28 Master Operation in Single-Master System | (c) | | p.502 | Addition of description in Figure 12-29 Master Operation in Multi-Master System (1/3) | (c) | | p.503 | Modification of Figure 12-29 Master Operation in Multi-Master System (2/3), and modification of remark | (c) | | p.506 | Addition of description in Figure 12-30 Slave Operation Flowchart (1) | (c) | | CHAPTER 14 | DMA CONTROLLER | | | p.575 | Modification of description in 14.6 Cautions on Using DMA Controller | (c) | | CHAPTER 15 | INTERRUPT FUNCTIONS | | | p.579 | Modification of vector table addresses in Table 15-1 Interrupt Source List (20-, 24-pin products) (1/2) | (a) | | p.580 | Modification of vector table addresses in Table 15-1 Interrupt Source List (20-, 24-pin products) (2/2) | (a) | | p.581 | Modification of vector table addresses in Table 15-2 Interrupt Source List (30-pin products) (1/2) | (a) | | p.582 | Modification of vector table addresses in Table 15-2 Interrupt Source List (30-pin products) (2/2) | (a) | | CHAPTER 17 | STANDBY FUNCTION | • | | p.618 | Modification of description in Table 17-1 Operating Statuses in HALT Mode | (c) | | p.627 | Modification of description in Table 17-3 Operating Statuses in SNOOZE Mode | (c) | | CHAPTER 18 | RESET FUNCTION | • | | p.629 | Modification of addresses (00000H and 00001H) | (a) | | p.634 | Modification of address (00000H, 00001H) in Table 18-2 State of Hardware After Receiving a Reset Signal | (a) | | p.635 | Modification of value after reset in Figure 18-4 Format of Reset Control Flag Register (RESF) | (c) | | p.637 | Addition of description in Figure 18-5 Procedure for Checking Reset Source | (c) | | p.641 | Modification of note 3 in Figure 19-2 Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector (2/3) | (c) | | CHAPTER 20 | VOLTAGE DETECTOR | | | p.643 | Modification of description in 20.1 Functions of Voltage Detector | (c) | | p.651 | Modification of description in 20.4.2 When used as interrupt mode | (c) | | CHAPTER 23 | OPTION BYTE | | | p.677 | Modification of description in 23.1.1 User option byte (000C0H to 000C2H) | (c) | | p.682 | Modification of Figure 23-3 Format of Option Byte (000C2H) | (c) | | CHAPTER 24 | FLASH MEMORYE | | | p.685 | Modification of remark 1 in 24.6 Self-Programming | (a) | | CHAPTER 25 | ON-CHIP DEBUG FUNCTION | | | p.707 | Addition of note in Table 25-1 On-Chip Debug Security ID | (c) | | CHAPTER 27 | INSTRUCTION SET | , , | | p.713 | Modification of description in Table 27-1 Operand Identifiers and Specification Methods | (c) | | p.714 | Modification of description in Table 27-2 Symbols in "Operation" Column | (c) | - (a): Error correction, (b): Addition/change of specifications, (c): Addition/change of description or note, - (d): Addition/change of package, part number, or management division, (e): Addition/change of related documents (4/4) | | | ( 1/ 1) | |--------------|----------------------------------------------------------------------------------------------------|----------------| | Page | Description | Classification | | CHAPTER 28 | ELECTRICAL SPECIFICATIONS (T <sub>A</sub> = -40 to +85 °C) | | | p.733 | Modification of description, and addition of target products | (c) | | p.769 | Modification of note 2 in 28.5.2 Serial interface IICA | (c) | | p.777 | Modification of title and note, and addition of caution in 28.7 RAM Data Retention Characteristics | (b) | | p.777 | Modification of conditions in 28.8 Flash Memory Programming Characteristics | (b) | | CHAPTER 29 | ELECTRICAL SPECIFICATIONS (G: INDUSTRIAL APPLICATIONS T <sub>A</sub> = -40 to +105 °C) | | | p.779 | Modification of description, and addition of target products and remark | (c) | | p.811 | Modification of note 2 in 29.5.2 Serial interface IICA | (c) | | p.819 | Modification of title and note in 29.7 RAM Data Retention Characteristics | (b) | | p.819 | Modification of conditions in 29.8 Flash Memory Programming Characteristics | (b) | | CHAPTER 30 | PACKAGE DRAWINGS | | | p.821 to 823 | Addition of package name | (d) | - (a): Error correction, (b): Addition/change of specifications, (c): Addition/change of description or note, - (d): Addition/change of package, part number, or management division, (e): Addition/change of related documents ## A.2 Revision History of Preceding Editions Here is the revision history of the preceding editions. Chapter indicates the chapter of each edition. (1/17) | Edition | Description | Chapter | |---------|-------------------------------------------------------------------------------------------------|----------------| | 2.00 | Modification of 1.2 Features | CHAPTER 1 | | | Modification of 1.3 List of Part Numbers | OUTLINE | | | Modification of Table 1-1 List of Ordering Part Numbers, Note, and Caution | | | | Modification of package name in 1.4.1 to 1.4.3 | | | | Modification of tables in 1.7 Outline of Functions | | | | Modification of description in 2.1 Port Functions | CHAPTER 2 | | | Modification of tables, Notes, and Remark in 2. 1. 1 to 2. 1. 3 | PIN FUNCTIONS | | | Modification of Figures 2-1 to 2-13 in 2.4 Block Diagrams of Pins | | | | Modification of Notes of Figures 3-1 to 3-6 in 3.1 Memory Space | CHAPTER 3 | | | Modification of Caution 2 in 3.1.3 Internal data memory space | CPU | | | Integration of figures in 3.1.6 Data memory addressing into Figure 3-8 | ARCHITECTURE | | | Error correction and modification of Caution 3 in (3) Stack pointer (SP) | | | | Error correction in 3.2.3 ES and CS registers | | | | Modification of description in Table 3-6 and Note 1 | | | | Modification of description in Table 3-7 and Notes 2 and 3 | | | | Modification of description of Table 4-1 in 4.2 Port Configuration | CHAPTER 4 | | | Modification of Caution in Figure 4-1 | PORT FUNCTIONS | | | Modification of Caution in Figure 4-2 | | | | Modification of description in 4.3.3 Pull-up resistor option registers (PUxx) | | | | Modification of Caution in Figure 4-3 | 7 | | | Modification of Caution in 4.3.4 Port input mode register (PIMx) | | | | Modification of Caution in 4.3.5 Port output mode registers (POMx) | | | | Modification of Caution in Figure 4-5 | | | | Modification of Cautions 1 and 3 in 4.3.6 Port mode control registers (PMCxx) | | | | Modification of Note 3 in Figure 4-8 | | | | Modification of description in 4.5 Register Settings When Using Alternate Function | | | | Modification of description in Table 4-7 | | | | Modification of description in Table 4-8 | | | | Modification of description in 5.1 Functions of Clock Generator | CHAPTER 5 | | | Modification of Figure 5-1 | CLOCK | | | Modification of description in 5.3.1 Clock operation mode control register (CMC) | GENERATOR | | | Modification of Notes 3 and 4 in Figure 5-2 | | | | Modification of Caution in Figure 5-3 | | | | Modification of description in Table 5-2 | | | | Modification of description in Figure 5-5 | | | | Modification of description in 5.3.5 Oscillation stabilization time select register (OSTS) | | | | Modification of Figure 5-6 | | | | Modification of description of Figure 5-7 (1/2) and Caution | | | | Modification of description of Figure 5-7 (2/2) and Caution | | | | Modification of description in 5.3.7 Operation speed mode control register (OSMC) | | | | Modification of description in 5.3.8 High-speed on-chip oscillator frequency selection register | | | | (HOCODIV) | | | | Modification of Figure 5-9 | | | | Modification of Figure 5-10, Note, and Remarks 1 and 2 | | | Edition | Description | (2/17)<br>Chapter | |---------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2.00 | Modification of description in 5.4.2 High-speed on-chip oscillator and 5.4.3 Low-speed on-chip | CHAPTER 5 | | 2.00 | oscillator | CLOCK | | | Modification of Figure 5-13 | GENERATOR | | | Modification of description in 5.6.1 Example of setting high-speed on-chip oscillator | 1 | | | Modification of description in 5.6.2 Example of setting X1 oscillation clock | - | | | Modification of Figure 5-14 | 1 | | | Modification of description in Table 5-3 (2/3) | 1 | | | Modification of description in 5.7 Resonator and Oscillator Constants and addition of Note 3 | 1 | | | Addition of description to the beginning of the chapter | CHAPTER 6 | | | Modification of 6.1.1 Independent channel operation function (4) Divider and addition of Note | TIMER ARRAY UNIT | | | Modification of figure of (1) One-shot pulse output in 6.1.2 Simultaneous channel operation | - THE PROPERTY OF | | | function | | | | Addition of Note to Table 6-1 | - | | | | - | | | Modification of Table 6-2 | - | | | Modification of Figure 6-1 | 1 | | | Modification of Figure 6-2 | - | | | Modification of Figure 6-3 (a), (b), (c), (d), (e), and (f) | _ | | | Addition of 6.2.1 Timer/counter register 0n (TCR0n) | _ | | | Addition of 6.2.2 Timer data register 0n (TDR0n) | _ | | | Modification of 6.3 Registers Controlling Timer Array Unit and addition of Caution | | | | Modification of Caution 1 in Figure 6-7 and addition of Note | _ | | | Modification of description in 6.3.2 Timer clock select register 0 (TPS0) | = | | | Modification of Figure 6-8 | = | | | Modification of Figure 6-9 (4/4) and addition of Note 1 | | | | Modification of Figure 6-15 | | | | Modification of description in 6.3.10 Timer output register 0 (TO0) | | | | Modification of description in 6.3.13 Noise filter enable register 1 (NFEN1) | | | | Modification of description in 6.3.14 Registers controlling port functions of pins to be used for timer | | | | 1/0 | | | | Modification of Figure 6-24 | | | | Modification of Figure 6-25 | | | | Modification of Figure 6-26 | | | | Addition of 6.7 Timer Input (TI0n) Control | | | | Modification of Figure 6-40 | | | | Modification of Figure 6-41 | | | | Modification of Figure 6-44 | ] | | | Modification of Figure 6-45 | | | | Modification of Figure 6-49 | | | | Modification of Note in Figure 6-50 | 1 | | | Modification of Figure 6-53 | 1 | | | Modification of Figure 6-57 | 1 | | | Modification of Figure 6-60 | 1 | | | Modification of Figure 6-61 | 1 | | | Modification of Figure 6-64 | 1 | | 1 | Modification of Figure 6-66 | 1 | | | Modification of Figure 6-69 | 1 | | | Modification of Figure 6-69 Modification of Figure 6-70 | - | | | Modification of Figure 6-70 Modification of description in 6.9.3 Operation as multiple PWM output function | 1 | | | · | 1 | | | Modification of Figure 6-74 | - | | | Modification of description in 6.10.1 Cautions When Using Timer output | OLIADTED 7 | | | Modification of description in Figure 7-1 Modification of Caution 1 in Figure 7-2 | CHAPTER 7 | | | | 12-BIT INTERVAL | | □ d:+: - ·- | Description | (3/17) | |-------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | Edition | Description Modification of description in 7.4.2 Start of count apprecian and as antests LIALT/STOR mode of the | Chapter<br>CHAPTER 7 | | 2.00 | Modification of description in 7.4.2 Start of count operation and re-enter to HALT/STOP mode after returned from HALT/STOP mode | _ | | | Teturned from HALT/STOP mode | 12-BIT INTERVAL<br>TIMER | | | Addition of description to the beginning of the chapter | CHAPTER 8 CLOCK | | | Addition of description of 8.1 Functions of Clock Output/Buzzer Output Controller | OUTPUT/BUZZER | | | Modification of description in 8.3 Registers Controlling Clock Output/Buzzer Output Controller | OUTPUT | | | Addition of Note 1 to and modification of Note 2 in Figure 8-2 | CONTROLLER | | | Modification of title of 8.3.2 to Registers controlling port functions of pins to be used for clock or | | | | buzzer output | | | | Modification of description in 8.4.1 Operation as output pin | | | | Modification of title of Figure 8-3 to Timing of Outputting Clock from PCLBUZn Pin | | | | Addition of 8.5 Cautions of Clock Output/Buzzer Output Controller | | | | Modification of description in 9.1 Functions of Watchdog Timer | CHAPTER 9 | | | Modification of Table 9-1 | WATCHDOG TIMER | | | | WATCHDOG HIVER | | | Modification of Figure 9-1 | | | | Modification of Caution 2 in 9.4.1 Controlling operation of watchdog timer | CHARTER 40 A/D | | | Modification of description in 10.1 Function of A/D Converter | CHAPTER 10 A/D<br>CONVERTER | | | Addition of description of Figure 10-1 | CONVERTER | | | Modification of description in 10.3 Registers Controlling A/D Converter | | | | Modification of Caution 1 in Figure 10-2 | | | | Modification of description of ADCS bit in Figure 10-3 | | | | Modification of Table 10-3, Note, and Caution 1 | | | | Modification of Table 10-3, Note 3, and Caution 1 | | | | Modification of Table 10-3, Note 1, and Caution 1 | | | | Modification of Table 10-3, Note 1, and Caution 1 | | | | Modification of Caution 2 in Figure 10-6 | | | | Modification of description in Figure 10-7 | | | | Modification of Cautions 2 and 3 in Figure 10-13 | | | | Modification of description in Figure 10-15 | | | | Modification of Figure 10-37 | CHAPTER 11 | | | Modification of description in 11.1.1 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) | SERIAL ARRAY | | | Modification of Table 11-1 | UNIT | | | Modification of Figure 11-1 | | | | Modification of Figure 11-2 | | | | Modification of Figure 11-3 | | | | Addition of 11.2.1 Shift register | | | | Addition of 11.2.2 Lower 8/9 bits of the serial data register mn (SDRmn) | | | | Modification of Note and Caution 1 in Figure 11-6 | | | | Modification of description in Figure 11-7 and Note | | | | Modification of Caution in Figure 11-8 (1/2) and (2/2) | | | | Modification of description and Caution in Figure 11-9 (1/2) and (2/2) | | | | Modification of description in 11.3.5 Serial data register mn (SDRmn) | | | | Modification of Figure 11-10 | | | | Modification of Remarks in Figure 11-11 | | | | Modification of Caution in Figure 11-12 (1/2) | | | | Modification of Cautions 1 and 2 in Figure 11-12 (2/2) | | | | Modification of Caution 1 in Figure 11-13 | | | | Modification of Caution in Figure 11-14 | | | | Modification of Caution in Figure 11-16 | | | | Modification of description in 11.3.12 Serial output register m (SOm) | | | | Modification of Caution in Figure 11-17 | | | | Modification of Caution in Figure 11-18 | | | | | | | | Addition of Figure 11-19 | | | Edition | Description | (4/17<br>Chapter | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | 2.00 | Modification of Caution in 11.3.14 Serial standby control register 0 (SSC0) | CHAPTER 11 | | | Modification of Figure 11-20 | SERIAL ARRAY | | | Addition of Figure 11-21 | UNIT | | | Modification of description in 11.3.15 Noise filter enable register 0 (NFEN0) | | | | Modification of Caution in Figure 11-22 | | | | Modification of description in 11.3.16 Registers controlling port functions of serial input/output pins | | | | Modification of description of 11.5 Operation of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) | | | | Communication and Note | | | | Modification of description in 11.5.1 Master transmission and addition of Remark | 1 | | | Modification of Figures 11-28 to 11-32 | | | | Modification of description in 11.5.2 Master reception and addition of Remark | - | | | · | | | | Modification of Figures 11-35 to 11-37, 11-39, and 11-40 | | | | Modification of description in 11.5.3 Master transmission/reception and addition of Remark | + | | | Modification of Figures 11-43, 11-45, 11-47, and 11-48 | + | | | Modification of description in 11.5.4 Slave transmission, Notes 1 and 2, and Remark 2 | _ | | | Modification of Figures 11-49 and 11-51 to 11-56 | _ | | | Modification of description in 11.5.5 Slave reception and Notes 1 and 2 | | | | Modification of Figures 11-57 to 11-59, 11-61, and 11-62 | | | | Modification of description in 11.5.6 Slave transmission/reception and Notes 1 and 2 | | | | Modification of Figures 11-65 and 11-67 to 11-70 | | | | Modification of description in 11.5.7 SNOOZE mode function | | | | Modification of Figures 11-71 to 11-74 | | | | Modification of description in 11.6 Operation of UART (UART0 to UART2) Communication and | | | | addition of Note 1 | | | | Modification of description in 11.6.1 UART transmission and addition of Notes 1 and 2 | | | | Modification of Figures 11-77 to 11-83 | | | | Modification of description in 11.6.2 UART reception and addition of Notes 1 and 2 | | | | Modification of Figure 11-86, 11-88, and 11-89 | | | | Modification of description in 11.6.3 SNOOZE mode function and addition of Cautions 2 to 4 | | | | Modification of Table 11-3 | | | | Modification of description in 11. 6. 3 (1) and Figure 11-90 | | | | Modification of description in 11. 6. 3 (2) and Figure 11-91 | | | | Modification of Figure 11-92 | | | | Modification of description in 11. 6. 3 (3) and Figure 11-93 | | | | Modification of Figure 11-94 | | | | Modification of description in 11.7 Operation of Simplified I2C (IIC00, IIC01, IIC11, IIC20) | | | | Communication | | | | Modification of description in 11.7.1 Address field transmission and Notes 1 and 2 | | | | Modification of description in 11.7.2 Data transmission and Notes 1 and 2 | | | | Modification of description in 11.7.3 Data reception and Notes 1 and 2 | | | | Modification of Figure 11-107 | | | | Modification of Figure 11-109 | | | | Modification of Figure 11-110 | 1 | | | Modification of Figure 12-1 | CHAPTER 12 | | | Modification of Figure 12-5 | SERIAL INTERFACE | | | Modification of Figure 12-6 (3/4) and (4/4) | IICA | | | Modification of Figure 12-9 (3/4) and (4/4) Modification of Figure 12-9 (2/2) | 1 | | | - | 1 | | | Modification of description in 12.3.6 IICA low-level width setting register 0 (IICWL0) | - | | | Modification of description in 12.3.7 IICA high-level width setting register 0 (IICWH0) Modification of description in 12.4.2 Setting transfer clock by using IICWL0 and IICWH0 registers | 4 | (5/17) | Edition | Description | Chapter | |---------|--------------------------------------------------------------------------------------------------------------|-----------------------------------| | 2.00 | Modification of Figures 12-22 and 12-23 | CHAPTER 12 | | | Modification of Figure 12-24 | SERIAL INTERFACE | | | Modification of description in 12.5.14 Communication reservation (1) | IICA | | | Modification of Note 1 in Figure 12-27 | | | | Modification of description in 12.5.14 Communication reservation (2) | | | | Modification of description in 12.5.15 Cautions | | | | Modification of Figure 12-28 | | | | Modification of Figure 12-29 | | | | Modification of Figure 12-30 | | | | Modification of Figure 13-1 and addition of Remark | CHAPTER 13 | | | Addition of 13.2.1 Multiplication/division data register A (MDAH, MDAL) to 13.2.3 | MULTIPLIER AND | | | Multiplication/division data register C (MDCL, MDCH) | DIVIDER/MULTIPLY ACCUMULATOR | | | Modification of Table 13-2 to Table 13-4 | | | | Modification of 13.3.1 Multiplication/division control register (MDUC) and Figure 13-5 | | | | Modification of description in 13.4.1 Multiplication (unsigned) operation to 13.4.5 Division operation | | | | Modification of Figure 13-9 | | | | Modification of description in 14.1 Functions of DMA Controller | CHAPTER 14 DMA | | | Modification of Figure 14-9 | CONTROLLER | | | Modification of rigure 14-9 Modification of description in 14.6 (4) DMA pending forwarding | OONTHOLLEN | | | Modification of description in 14.6 (6) Operation if instructions for accessing the data flash area | | | | · | CHARTER 15 | | | Modification of Figure 15-11 | CHAPTER 15 | | | Modification of Figure 15-12 | INTERRUPT<br>FUNCTIONS | | | Modification of description in Table 15-6 | | | | Addition of description to the beginning of the chapter | CHAPTER 16 KEY INTERRUPT FUNCTION | | | Modification of Table 16-1 | | | | Modification of Table 16-2 | | | | Modification of Figure 16-1 | | | | Modification of Figure 16-2 | | | | Modification of Cautions 1 and 2 in Figure 16-3 | | | | Modification of description in 16.3.3 Key return flag register (KRF) and Caution in Figure 16-4 | | | | Modification of description in 16.3.4 Port mode registers 0, 4, 6 (PM0, PM4, PM6) and Figure 16-5 | | | | Addition of description of 16.4 Key Interrupt Operation | | | | Modification of Caution in 17.3.1 HALT mode | CHAPTER 17 | | | Modification of Caution in 17.3.2 STOP mode | STANDBY | | | Modification of Note 2 in Figure 17-3 (1) | FUNCTION | | | Modification of Notes 1 and 2, Caution, and Remarks 1 and 2 in Figure 17-3 (3) | | | | Modification of description in 17.3.3 SNOOZE mode (2) and (3) | | | | Modification of description in 18.1 Timing of Reset Operation | CHAPTER 18 | | | Addition of Note to Table 18-1 | RESET FUNCTION | | | Modification of Remark in Table 18-2 | | | | Modification of Caution 2 in Figure 18-4 | | | | Modification of Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on-reset | CHAPTER 19 | | | Circuit (1) When the external reset input via RESET pin is used | POWER-ON-RESE | | | Addition of description of Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on- | | | | reset Circuit (3) LVD reset mode (2) LVD interrupt & reset mode (option byte 000C1H/LVIMDS1, LVIMDS0 = 1, 0) | | | | Modification of Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on-reset | | | | Circuit (3) LVD reset mode (option byte 000C1H/LVIMDS1, LVIMDS0 = 1, 1) | | | | Modification of description in 20.1 Functions of Voltage Detector | CHAPTER 20 | | | Modification of Figure 20-1 | VOLTAGE | | | Modification of Figure 20-2 | DETECTOR | (6/17) | Edition | Description | (6/17)<br>Chapter | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 2.00 | Modification of Cautions 1 and 2 and Note 2 in Figure 20-3 | CHAPTER 20 | | 2.00 | Modification of Caution 2 in Figure 20-4 and addition of Remarks 2 and 3 | VOLTAGE | | | Modification of description in 20.4.1 When used as reset mode | DETECTOR | | | Modification of Figure 20-5 | | | | Modification of description in 20.4.2 When used as interrupt mode | | | | Modification of Figure 20-6 and Note 2 | | | | Modification of description in 20.4.3 When used as interrupt and reset mode | | | | Modification of description in Figure 20-7 (1/2) | | | | Modification of description in Figure 20-7 (1/2) | - | | | Modification of description in Figure 20-7 (2/2) Modification of description in Figure 20-8 | | | | | - | | | Modification of item (1) in 20.5 Cautions for Voltage Detector | - | | | Addition of Figure 20-10 | | | | Modification of description of items (3) and (4) in 20.5 Cautions for Voltage Detector | | | | Modification of description of items (6) and (7) and Remark in 21.1 Overview of Safety Functions | CHAPTER 21 | | | Modification of Caution and Remarks 2 and 4 in Figure 21-4 | SAFETY | | | Modification of Figure 21-5 | FUNCTIONS | | | Modification of description in 21.3.7 A/D test function | | | | Modification of description in 21.3.7.2 Analog input channel specification register (ADS) | | | | Modification of Cautions 2 to 4 and 9 in 21.3.7.2 Analog input channel specification register (ADS) | | | | Addition of Caution to 23.1 Functions of Option Bytes | CHAPTER 23 | | | Modification of description in 23.1.1 User option byte (000C0H to 000C2H) and addition of Caution | OPTION BYTE | | | Modification of Figure 23-2 and addition of Remarks 2 and 3 | | | | Modification of Figure 23-3 and addition of Caution 1 | | | | Modification of description in 23.4 Setting of Option Byte and Caution | | | | Modification of description in 24.3.1 P40/TOOL0 pin and Remark 1 | CHAPTER 24 FLASH | | | Addition of Table 24-5. Programming Modes and Voltages at Which Data Can Be Written, Erased, | MEMORY | | | or Verified | | | | Modification of description in Table 24-10 | | | | Modification of description in 24.7 Security Settings | | | | Modification of description in 24.8 Data Flash | | | | Modification of title of 25.1 to Connecting E1 On-chip Debugging Emulator | CHAPTER 25 ON- | | | Modification of Figure 25-1 to Figure 25-3 | CHIP DEBUG | | | The second secon | FUNCTION | | | Addition of 26.2.1 BCD correction result register (BCDADJ) | CHAPTER 26 BCD | | | , , , , , , , , , , , , , , , , , , , | CORRECTION | | | | CIRCUIT | | | Modification of Note 2 in Table 27-5 (1/17) | CHAPTER 27 | | | Modification of Note 2 in Table 27-5 (2/17) | INSTRUCTION SET | | | Modification of Note 2 in Table 27-5 (3/17) | | | | Modification of Note 2 in Table 27-5 (4/17) | | | | Modification of Note 2 in Table 27-5 (5/17) | | | | Modification of Note 2 in Table 27-5 (6/17) | - | | | | | | | Modification of Note 2 in Table 27-7 (7/17) | 1 | | | Modification of Note 2 in Table 27-5 (8/17) | 1 | | | Modification of Note 2 in Table 27-5 (9/17) | - | | | Modification of Note 2 in Table 27-5 (10/17) | - | | | Modification of Note 2 in Table 27-5 (11/17) | - | | | Modification of Note 2 in Table 27-5 (12/17) | | | | Modification of Note 2 in Table 27-5 (13/17) | | | | Modification of Note 2 in Table 27-5 (14/17) | | | | Modification of Note 2 in Table 27-5 (15/17) | | | Edition | Description | (7/17) | |---------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------| | | Description Medification of Note 2 in Table 27.5 (16/17) | CHARTER 27 | | 2.00 | Modification of Note 2 in Table 27-5 (16/17) | CHAPTER 27 | | | Modification of Note 2 in Table 27-5 (17/17) | INSTRUCTION SET | | | Modification of description of table in 28.1 Absolute Maximum Ratings (TA = 25° C) | CHAPTER 28 | | | Modification of table, Note, and Caution in 28.2.1 X1 oscillator characteristics | ELECTRICAL | | | Modification of table in 28.2.2 On-chip oscillator characteristics | SPECIFICATIONS | | | Modification of Note 3 in 28.3.1 Pin characteristics (1/4) | (A, D: TA = -40 to) | | | Modification of Note 3 in 28.3.1 Pin characteristics (2/4) | +85°C) | | | Modification of Notes 1 and 2 in (1) 20-, 24-pin products (1/2) | | | | Modification of Notes 1 and 3 in (1) 20-, 24-pin products (2/2) | | | | Modification of Notes 1 and 2 in (2) 30-pin products (1/2) | | | | Modification of Notes 1 and 3 in (2) 30-pin products (2/2) | | | | Modification of (3) Peripheral functions (Common to all products) | | | | Modification of table in 28.4 AC Characteristics | | | | Addition of Minimum Instruction Execution Time during Main System Clock Operation | | | | Modification of figures of AC Timing Test Point and External Main System Clock Timing | | | | Modification of figure of AC Timing Test Point | | | | Modification of description and Note 2 in (1) During communication at same potential (UART | | | | mode) | | | | Modification of description in (2) During communication at same potential (CSI mode) | | | | Modification of description in (3) During communication at same potential (CSI mode) | | | | Modification of description in (4) During communication at same potential (CSI mode) | | | | Modification of table and Note 2 in (5) During communication at same potential (simplified I2C | | | | mode) | | | | Modification of table and Notes 1 to 9 in (6) Communication at different potential (1.8 V, 2.5 V, 3 V) (UART mode) | | | | Modification of Remarks 1 to 3 in (6) Communication at different potential (1.8 V, 2.5 V, 3 V) (UART mode) | | | | Modification of table in (7) Communication at different potential (2.5 V, 3 V) (CSI mode) | | | | Modification of Caution in (7) Communication at different potential (2.5 V, 3 V) (CSI mode) | | | | Modification of table in (8) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (1/3) | | | | Modification of table and Notes 1 and 2 in (8) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) (2/3) | | | | Modification of table, Note 1, and Caution 1 in (8) Communication at different potential (1.8 V, 2.5 | | | | V, 3 V) (CSI mode) (3/3) | | | | Modification of table in (9) Communication at different potential (1.8 V, 2.5 V, 3 V) (CSI mode) | | | | Modification of table, Note 1, and Caution 1 in (10) Communication at different potential (1.8 V, 2.5 V, 3 V) (simplified I2C mode) | | | | Modification of Remark in 28.5.2 Serial interface IICA | | | | Addition of table to 28.6.1 A/D converter characteristics | | | | Modification of description in 28.6.1 (1) | | | | Modification of Notes 3 to 5 in 28.6.1 (1) | | | | Modification of description and Notes 2 to 4 in 28. 6. 1 (2) | | | | Modification of description and Notes 3 and 4 in 28. 6. 1 (3) | | | | Modification of description and Notes 3 and 4 in 28. 6. 1 (4) | | | | Modification of table in 28.6.2 Temperature sensor/internal reference voltage characteristics | | | | Modification of table and Note in 28.6.3 POR circuit characteristics | | | | Modification of table and Note in 26.6.3 FOR circuit characteristics | | | | | | | | Modification of table of LVD detection voltage of interrupt & reset mode | | | | Modification of number and title to 28.6.5 Power supply voltage rising slope characteristics | | | | Modification of table, figure, and Remark in 28.10 Timing of Entry to Flash Memory Programming | | | | Modes | | (8/17) | Edition | Description | (8/17<br>Chapter | |---------|---------------------------------------------------------------------------------------------------------------|---------------------------------------| | | | | | 2.00 | Addition of products of industrial applications (G: TA = -40 to +105°C) | CHAPTER 29<br>ELECTRICAL | | | | SPECIFICATIONS | | | | (G: TA = - 40 to | | | | (G: TA = - 40 to<br>+105°C) | | | Addition of products of industrial applications (C. TA 40 to 105°C) | , , , , , , , , , , , , , , , , , , , | | | Addition of products of industrial applications (G: TA = -40 to +105°C) | CHAPTER 30 | | | | PACKAGE<br>DRAWINGS | | 1.10 | Deletion of overbars for SCK(serial clock signal) | Throughout | | | Titles of register description headlined | | | | Addition of 1.1 Differences between R5F102 and R5F103 | CHAPTER 1 | | | Modification of description and Notes 1 to 3 and addition of Caution in 1.7 Outline of Functions | OUTLINE | | | Modification of Note 1 and Caution 1 and addition of Cautions 2 and 3 in Figure 3-1. Memory Map | CHAPTER 3 CPU | | | Modification of Caution in Figure 3-2 to 3-6. Memory Maps | ARCHITECTURE | | | Modification of description and Cautions 1 and 2 and addition of Caution 3 in 3.1.3 Internal data | ALIGHME | | | memory space | | | | Modification of Note 1 and Caution 1 and addition of Cautions 2 and 3 in Figure 3-8. | <b>-</b> | | | Correspondence Between Data Memory and Addressing | | | | Modification of Caution in Figure 3-9 to Figure 3-13. Correspondence Between Data Memory and Addressing | - | | | Modification of Caution 3 and addition of Caution 4 in 3.2.1 (3) Stack pointer (SP) | - | | | Modification of Caution 2 and addition of Caution 3 in 3.2.2 General-purpose registers | 1 | | | Modification of Figure 3-27 and Figure 3-28 | 1 | | | Modification of Figure 3-21 to Figure 3-41 | | | | | - | | | Addition of Figure 3-42 to Figure 3-47 | CHARTER 5 CLOCK | | | Modification of Cautions 1 to 3 in 5.3.8 High-speed on-chip oscillator frequency selection register (HOCODIV) | CHAPTER 5 CLOCK<br>GENERATOR | | | Addition of 5.7 Resonator and Oscillator Constants | | | | Modification of description in (2) Timer data register 0n (TDR0n) | CHAPTER 6 TIMER<br>ARRAY UNIT | | | Modification of Caution 1 and addition of Caution 2 in 10.3.2 A/D converter mode register 0 (ADM0) | CHAPTER 10 A/D<br>CONVERTER | | | Modification of Caution 1 and LV1 in Tables 10-3 A/D Conversion Time Selection (2/4) and (4/4) | = | | | Modification of description and deletion of Note in Table 18-1. Operation Statuses During Reset | CHAPTER 18 | | | Period | RESET FUNCTION | | | Modification of Caution 2 in 18.1.1 Reset Control Flag Register (RESF) | | | | Modification of Note 3 in Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on- | CHAPTER 19 | | | reset Circuit and Voltage Detector (1/3) | POWERON-RESET | | | Modification of Note 4 in Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on- | CIRCUIT | | | reset Circuit and Voltage Detector (2/3) | | | | Addition of Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on-reset Circuit | | | | and Voltage Detector (3/3) | | | | Modification of 21.1 (2) RAM parity error detection function | CHAPTER 21 | | | Modification of Caution in 21.3.2 RAM parity error detection function | SAFETY<br>FUNCTIONS | | | Modification of description and addition of Cautions 1 and 2 in 24.4.1 Data flash overview | CHAPTER 24 FLASH | | | Modification of description in 24.6 Security Settings | MEMORY | | | Deletion of (2) Self programming in Table 24-12. Security Setting in Each Programming Mode | | | | Modification of Cautions in 24.7 Flash Memory Programming by Self-Programming | | | | Modification of description in 24.7.1 Flash shield window function | | | | Modification of description in Table 24-14. Setting and changing of the flash shield window | 1 | | | function and relations with commands | | | Edition | Description | (9/17) | |---------|-------------------------------------------------------------------------------------------------------------------------|---------------------------| | Edition | Description Modification of description in 20.9 Floor Margary Programming Characteristics | Chapter<br>CHAPTER 28 | | 1.10 | Modification of description in 28.8 Flash Memory Programming Characteristics | | | | | ELECTRICAL | | 1.00 | Addition of products of industrial application | SPECIFICATIONS Throughout | | 1.00 | Addition of products of industrial application | Throughout | | | Renamed interval timer (unit) to 12-bit interval timer Addition of pin name of the peripheral I/O redirection function | _ | | | Modification of reset processing time | - | | | Deletion of LIN communication function | - | | | Renamed VLVI, VLVIH, VLVIL to VLVD, VLVDH, VLVDL (LVD detection voltage) | | | | Renamed RAMTOP to RPE, renamed ITIF, ITMK, ITKAPR0, ITKAPR1 to TMKAIF, TMKAMK, | | | | | | | | TMKAPR0, TMKAPR1 (interrupt source, flag) | CHAPTER 1 | | | Addition of description to 1.1 Features | OUTLINE | | | Modification of description in 1.2 Ordering Information | OUTLINE | | | Addition of Figure 1-1. Part Number, Memory Size, and Package of RL78/G12 | | | | Addition and Modification of description in 1.6 Outline of Functions | OLIABTED A DIN | | | Modification of description in 2.1 Port Function | CHAPTER 2 PIN | | | Modification of description in 2.2 Functions other than port pins (Deletion of description of port function) | FUNCTIONS | | | Modification of description in 2.3 Pin I/O Circuits and Recommended Connection of Unused Pins | | | | Addition of remark to Table 3-1. Correspondence Between Address Values and Block | CHAPTER 3 CPU | | | Numbers in Flash Memory | ARCHITECTURE | | | Addition of product in Table 3-2. Internal ROM Capacity | 1 | | | Addition of INTFL to Table 3-3. Vector Table (20-, 24-pin products) | <del>-</del> | | | Modification of description in 3.1.2 Mirror area | <del>-</del> | | | Addition of description to Caution in Table 3-5. Internal RAM Capacity | - | | | Modification of Figure 3-23. Outline of Table Indirect Addressing | - | | | Addition of setting of registers when using port xx to Table 4-2 to 4-4, 4-6 to 4-12, 4-14 to 4-20 | CHAPTER 4 PORT | | | Modification of block diagrams for Pxxx | FUNCTIONS | | | Addition of description to (3) Port 2 | <del>-</del> | | | Addition of description to (4) Port 4 | 1 | | | Addition of Note to (6) Port 12 | 1 | | | Addition of description to (3) Port 2 | <del>-</del> | | | Addition of description to (2) Port register (Pxx) | = | | | Addition of description to (3) Pull-up resistor option registers (PUxx) | <del>-</del> | | | Modification of description in Figure 4-37. Format of Port Output Mode Register | = | | | Addition of Caution to Figure 4-38. Format of Port Mode Control Register | <del>-</del> | | | Addition of description to (8) Peripheral I/O redirection register (PIOR) | <del>-</del> | | | Addition of description to 4.4.1 Writing to I/O port, and 4.4.3 Operations on I/O port | - | | | Addition of description to 4.4.4 Connecting to external device with different potential (1.8 V, 2.5 V, 3 V) | 1 | | | Addition of description to 4.5 Settings of Port Mode Register, and Output Latch When Using | 1 | | | Alternate Function | | | | Addition of 4.6.2 Notes on specifying the pin settings | 1 | | | Addition of description to 5.1 (1) <2> High-speed on-chip oscillator | CHAPTER 5 CLOCK | | | Addition of Caution to Figure 5-2. Format of Clock Operation Mode Control Register (CMC) | GENERATOR | | | Modification of Figure 5-1. Block Diagram of Clock Generator | ] | | | Modification of description in Table 5-2. Condition Before Stopping Clock Oscillation and Flag | 1 | | ı | Setting | | | | Deletion of Note to Figure 5-7. Format of Peripheral Enable Register 0 (PER0) (1/2) | 1 | | 1 | Addition of description to (7) Operation speed mode control register (OSMC) | 1 | | | Modification of Caution 3 to Figure 5-9 Format of High-Speed On-Chip Oscillator Frequency | 1 | | | Selection Register (HOCODIV) | | (10/17) | Edition | Description | (10/17)<br>Chapter | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------| | 1.00 | Modification of description in Figure 5-13. Clock Generator Operation When Power Supply | Chapter CHAPTER 5 CLOCK GENERATOR | | 1.00 | Voltage Is Turned On (When voltage detector (LVD) is used) | | | | Addition of description to 5.6.2 Example of setting X1 oscillation clock | GENERATOR | | | Addition of description to 5:0.2 Example of setting X1 oscillation clock Addition of description to Figure 5-14. CPU Clock Status Transition Diagram | | | | Addition of description to (2) CPU operating with high-speed system clock (C) after reset release (A) | | | | | | | | Modification and deletion of description in Table 5-4. Changing CPU Clock | | | | Modification of description in Table 5-5. Maximum Number of Clocks Required for f <sub>IH</sub> ↔ f <sub>MX</sub> , and | | | | Table 5-6. Conditions Before the Clock Oscillation Is Stopped and Flag Settings | CHARTER C TIMER | | | Addition of Figure to (7) Delay counter | CHAPTER 6 TIMER | | | Addition of description to Figure 6-2. Entire Configuration of Timer Array Unit (30-pin products) | ARRAY UNIT | | | Addition of Figure 6-3. Internal Block Diagram of Channel of Timer Array Unit | | | | Addition of description to (1) Timer/counter register 0n (TCR0n) | | | | Addition of description to (2) Timer data register 0n (TDR0n) | | | | Modification of description and addition of caution to Figure 6-8. Format of Timer | | | | Clock Select register 0 (TPS0) | | | | Modification of description in Table 6-4. Interval Times Available for Operation Clock CKS02 or | | | | CKS03, and addition of Caution in (3) Timer mode register 0n (TMR0n) | | | | Modification of Figure 6-9. Format of Timer Mode Register 0n (TMR0n) | | | | Addition of description to (5) Timer channel enable status register 0 (TE0) | | | | Modification of Figure 6-12. Format of Timer Channel Start register 0 (TS0) | | | | Addition of description to Figure 6-13. Format of Timer Channel Stop register 0 (TT0) | | | | Addition of description to (8) Timer input select register 0 (TIS0) | | | | Modification of description to Figure 6-15. Format of Timer Output Enable register 0 (TOE0) | | | | Addition of description to (14) Port mode registers 0, 1, 3, or 4 (PM0, PM1, PM3, or PM4) | | | | Addition of description to 6.4.1 Basic Rules of Simultaneous Channel Operation Function | | | | Addition of description to 6.5.1 Count clock (f <sub>TCIK</sub> ) | | | | Modification of description to Table 6-6. Operations from Count Operation Enabled State to Timer | • | | | count Register 0n (TCR0n) Count Start | | | | Addition of title to 6.5.3 Operation of counter | | | | Modification of Figure 6-27. Operation Timing (In Capture & One-count Mode: High-level Width | - | | | Measurement) | | | | Addition of description to 6.6.2 TO0n Pin Output Setting | | | | Modification of description to Figure 6-39, 43, 51, 55, 59, 64, 69, 74 Example of Set Contents of Registers | | | | Modification of Figure 6-41, 45, 49, 53, 61 | | | | Addition of 6.9 Cautions When Using Timer Array Unit | | | | Addition of description to (2) Operation speed mode control register (OSMC) | CHAPTER 7 | | | Addition of Caution to Figure 7-4. Format of Interval Timer Control Register (ITMC) | INTERVAL TIMER | | | Modification of Figure 7-5. 12-Bit Interval Timer Operation Timing | | | | Modification of Figure 8-1. Block Diagram of Clock Output/Buzzer Output Controller | CHAPTER 8 CLOCK | | | · · · · · · · · · · · · · · · · · · · | OUTPUT/BUZZER | | | Modification of Figure 8-2. Format of Clock Output Select Register n (CKSn) | OUTPUT | | | Addition of description to (2) Port mode register 1, 3 (PM1, PM3) | CONTROLLER | | | Addition of Caution to 8.4.1 Operation as output pin | | | | Modification of description to 9.1 Functions of Watchdog Timer, 9.4.4 Setting watchdog timer | CHAPTER 9 | | | interval interrupt | WATCHDOG TIMER | | | Modification of Figure 10-1. Block Diagram of A/D Converter | CHAPTER 10 A/D | | | Modification of description to (3) A/D voltage comparator | CONVERTER | | | Addition of Caution to Figure 10-3. Format of A/D Converter Mode Register 0 (ADM0) | | | | Modification of description to Figure 10-4. Timing Chart When A/D Voltage Comparator Is Used | | (11/17) | Edition | Description | (11/17)<br>Chapter | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 1.00 | Addition of description to Table 10-3. A/D Conversion Time Selection | CHAPTER 10 A/D | | 1.00 | Modification of Caution to Figure 10-6. Format of A/D Converter Mode Register 1 (ADM1) | CONVERTER | | | Addition of description to Figure 10-7. Format of A/D Converter Mode Register 2 (ADM2) | 00 | | | Addition of description to Figure 10-11. Format of Analog Input Channel Specification Register | | | | (ADS) | | | | Addition of description and Caution to (10) A/D test register (ADTES), (11) A/D port configuration | | | | register (ADPC), (12) Port mode control registers 0, 1, 4, 12, and 14 (PMC0, PMC1, PMC4, | | | | PMC12, and PMC14), and (13) Port mode registers 0, 1, 2, 4, 12, and 14 (PM0, PM1, PM2, PM4, PM12 and PM14) | | | | Addition of Note to 10.4 A/D Converter Conversion Operations | | | | Modification of Figure 10-32. Setting up Software Trigger Mode to Figure 10-36. Setting up Test Trigger Mode | | | | Addition of description to 10.8 SNOOZE mode function | | | | Addition and modification of description to 10.10 Cautions for A/D Converter | | | İ | Change the value to Table 10-6. Resistance and Capacitance Values of Equivalent Circuit | | | | (Reference Values) | | | | Addition of description to CHAPTER 11 SERIAL ARRAY UNIT | CHAPTER 11 | | | Addition of description to 11.1.2 UART (UART0 to UART2) | SERIAL ARRAY | | | Modification of Figure 11-1 to 11-3. Block Diagram of Serial Array Unit 0 (20- or 24-pin products) | UNIT | | | Modification of Caution to Figure 11-6. Format of Peripheral Enable Register 0 (PER0) | | | | Modification of frequency to Figure 11-7. Format of Serial Clock Select Register m (SPSm) | | | | Addition of description for Note to Figure 11-9. Format of Serial Communication Operation Setting | | | | Register mn (SCRmn) | | | | Addition of description to Figure 11-10. Format of Serial Data Register mn (SDRmn) | | | | Addition of description to Figure 11-12. Format of Serial Status Register mn (SSRmn) (2/2) | | | | Addition and modification of Note and Caution to Figure 11-13. Format of Serial Channel Start Register m (SSm) | | | | Addition and modification of Note to Figure 11-14. Format of Serial Channel Stop Register m | | | | (STm), Figure 11-15. Format of Serial Channel Enable Status Register m (SEm) | | | | Addition of description to Figure 11-16. Format of Serial Output Enable Register m (SOEm) and | | | | Figure 11-17. Format of Serial Output Register m (SOm) | | | | Addition of description to (13) Serial output level register m (SOLm) | | | | Modification of description to Figure 11-19. Format of Serial Standby Control Register 0 (SSC0) | | | | Addition of description to (18) Port mode registers 0, 1, 3 to 6 (PM0, PM1, PM3 to PM6) | | | | Addition of description to Figure 11-25. Each Register Setting When Stopping Operation by Channels | | | | Modification of description to 11.5.1 Master transmission, 11.5.2 Master reception, 11.5.3 Master transmission/reception | | | | Modification of description to Figure 11-26, 34, 42, 50, 58, 64, 77, 85, 99, 103, 106 (Example of Contents of Registers) | | | | Modification of description to Figure 11-28, 29, 31, 33, 36, 37, 39, 41, 44, 45, 47, 49, 52, 53, 55, 57, 60, 61, 63, 66, 69, 71, 73, 75, 79, 80, 82, 84, 86, 87, 88, 90, 93, 95, 100, 102, 105, 108 (flow chart) | | | | Addition of description of notes to 11.5.4 Slave transmission, 11.5.5 Slave reception, 11.5.6 Slave transmission/reception | | | | Addition of Caution to 11.5.7 SNOOZE mode function (only CSI00), 11.6.3 SNOOZE mode function (only UART0 reception) | | | | Addition of Caution to 11.6 Operation of UART (UART0 to UART2) Communication | | | | Modification of description to 11.7.1 Address field transmission, 11.7.2 Data transmission, 11.7.3 Data reception | | | | Addition of Caution to 11.7.5 Calculating transfer rate | | | | Modification of description for example of setting IIC transfer rate | | (12/17) | Edition | Description | Chapter | |---------|-------------------------------------------------------------------------------------------------------|------------------------------| | 1.00 | Modification of description to Figure 12-6. Format of IICA Control Register 00 (IICCTL00) | CHAPTER 12 | | | Addition of description to Figure 12-7. Format of IICA Status Register 0 (IICS0) | SERIAL INTERFACE | | | Modification of Figure 12-28, 29, 30 | IICA | | | Modification of Figure 13-1. Block Diagram of Multiplier and Divider/Multiply-Accumulator | CHAPTER 13 | | | Modification of value to Figure 13-6. Timing Diagram of Multiplication (Unsigned) Operation (2 × 3 | MULTIPLIER AND | | | = 6) | DIVIDER/MULTIPLY ACCUMULATOR | | | Addition of description to 13.4.5 Division operation | | | | Addition of description | CHAPTER 15 | | | Addition of description to Table 15-1 and 15-2. Interrupt Source List | INTERRUPT | | | Addition of INTFL to Table 15-3 and 15-4. Flags Corresponding to Interrupt Request Sources | FUNCTION | | | | - | | | Modification of description to Table 15-5. Time from Generation of Maskable Interrupt Until | | | | Servicing Medification of Figure 45 40 John with Bourset Asking and Asking and Timing (Maximum Time) | + | | | Modification of Figure 15-12. Interrupt Request Acknowledgment Timing (Maximum Time) | | | | Modification of Table 15-6. Relationship Between Interrupt Requests Enabled for Multiple | | | | Interrupt Servicing During Interrupt Servicing | | | | Addition and modification of description to Though out | CHAPTER 16 KEY | | | | INTERRUPT | | | | FUNCTION | | | Modification of Caution to (3) SNOOZE mode | CHAPTER 17 | | | Modification of description to Table 17-1. Operating Statuses in HALT Mode | STANDBY | | | Addition and modification of release to standby function, wait time for SNOOZE status | FUNCTION | | | Addition of description to Table 18-1. Operation Statuses During Reset Period | CHAPTER 18 | | | Addition of description to Table 18-2. Hardware Statuses After Reset Acknowledgment | RESET FUNCTION | | | Addition of Note to Table 18-2. Hardware Statuses After Reset Acknowledgment | | | | Addition and modification of 19.1 Functions of Power-on-reset Circuit, 19.3 Operation of Power- | CHAPTER 19 | | | on-reset Circuit | POWERON-RESET | | | | CIRCUIT | | | Modification of Figure 20-1. Block Diagram of Voltage Detector | CHAPTER 20 | | | Modification of description to Figure 20-2. Format of Voltage Detection Register (LVIM) | VOLTAGE | | | Addition of description to Figure 20-3. Format of Voltage Detection Level Select Register (LVIS) | DETECTOR | | | Addition of Caution to Table 20-1. LVD Operation Mode and Detection Voltage Settings for User | | | | Option Byte (000C1H) | | | | Modification of Figure 20-4, 20-5, 20-6 | | | | Addition of description to Figure 20-7, 20-8 | | | | Addition of description to 21.3.1 CRC operation function (general-purpose CRC) | CHAPTER 21 | | | Addition of description to Figure 21-3. CRC Operation Function (General-Purpose CRC) | SAFETY | | | Addition of description to Figure 21-5. Format of Invalid Memory Access Detection Control | FUNCTIONS | | | Register (IAWCTL) | | | | Modification of Figure 21-7. Invalid access detection area | | | | Addition of description to 21.3.7 A/D test function | | | | Addition of Figure (moved from description of CHAPTER 2 PIN FUNCTIONS of the previous | CHAPTER 22 | | | edition) | REGULATOR | | | Addition of description to (2) 000C1H | CHAPTER 23 | | | Addition of description to Figure 23-1. Format of User Option Byte (000C0H) | OPTION BYTE | | | Modification and addition of Caution to Figure 23-1. Format of User Option Byte (000C011) | 55,1,5,1,2 | | | | CHAPTER 24 FLASH | | | Deletion of description to 24.1.1 Programming environment | = | | | Addition of description to 24.2 Writing to Flash Memory by Using External Device (that | MEMORY | | | Incorporates UART) | | | | Addition of description to Figure 24-8. Setting of Flash Memory Programming Mode | | | | Addition of description to Table 24-5, Table 24-13. Programming Modes and Voltages at Which | | | | Data Can Be Written, Erased, or Verified | | (13/17) | Edition | Description | Chapter | |---------|---------------------------------------------------------------------------------------------------------------------|------------------------------| | 1.00 | Modification of description to Table 24-10. Example of Signature Data | CHAPTER 24 FLASH | | | Addition of description to 24.6 Security Settings | MEMORY | | | Addition of Figure 25-3. Connection Example of E1 On-chip Debugging Emulator and RL78/G12 | CHAPTER 25 ON- | | | (30-pin products) | CHIP DEBUG | | | Modification of description to Figure 25-4. Memory Spaces Where Debug Monitor Programs Are | FUNCTION | | | Allocated | | | | Modification of flag status | CHAPTER 27 | | | | INSTRUCTION SET | | | Deletion of target, and public release | CHAPTER 28 | | | | ELECTRICAL | | 0.00 | Deletion (Leaves to Livering and Language A. O. (TEMPOALO) | SPECIFICATIONS | | 0.03 | Deletion of temperature trimming registers 0 to 3 (TEMPCAL0 to TEMPCAL3) | Throughout | | | Addition of description to 1.1 Features | CHAPTER 1 | | | Addition of description to 1.6 Outline of Functions | OUTLINE | | | Change of description for 2.1.4 Pins for each product (pins other than port pins) | CHAPTER 2 PIN | | | Addition of 2.2 Description of Pin Functions | FUNCTIONS | | | Addition of note in Figures 3-3 to 3-5 Memory Map, Correspondence Between Data Memory and | CHAPTER 3 CPU | | | Addressing | ARCHITECTURE | | | Addition of description to 3.1.2 Mirror area | | | | Addition of caution 2 to 3.2.2 General-purpose registers | | | | Change of description in Table 3-7. Extended SFR (2nd SFR) List (2/5) | | | | Addition of description to 3.4.3 Direct addressing | | | | Change of Table 4-5. PMxx, Pxx, PUxx, PIMx, POMx, PMCxx Registers and the Bits (30-pin | CHAPTER 4 PORT | | | Products) and notation in Figure 4-32. Format of Pull-up Resistor Option Register | FUNCTIONS | | | Addition of 4.4 Port Function Operations | | | | Change of setting value in Table 4-6. Settings of Port Mode Register and Output Latch When | | | | Using Alternate Function and Table 4-9. Settings of Port Mode Register and Output Latch When | | | | Using Alternate Function (30-pin products) | OLIADTED F OLOOK | | | Addition of value to 5.1 (1) <2> High-speed on-chip oscillator (HOCO) | CHAPTER 5 CLOCK<br>GENERATOR | | | Change of Figure 5-1. Block Diagram of Clock Generator | | | | Addition of description to 5.3 (2) System clock control register (CKC) | | | | Change of value in Figure 5-4. Format of Clock Operation Status Control Register (CSC) | | | | Change of description in 5.3 (4) Oscillation stabilization time counter status register (OSTC) | | | | Addition of value to Figure 5-6. Format of Oscillation Stabilization Time Select Register (OSTS) | | | | Addition of description to 5.3 (6) Peripheral enable register 0 (PER0) | | | | Addition of description to 5.3 (9) High-speed on-chip oscillator trimming register (HIOTRM) | | | | Addition of note 3 to Figure 5-13. Clock Generator Operation When Power Supply Voltage Is | | | | Turned On | | | | Addition of 5.6.1 Example of setting high-speed on-chip oscillator | | | | Addition of description to 5.6.2 Example of setting X1 oscillation clock | | | | Addition of description to 5.6.3 CPU clock status transition diagram | | | | Addition of X1 clock to Table 5-4. Changing CPU Clock | | | | Addition of description to 5.6.5 Time required for switchover of CPU clock and main system clock | | | | Change of description in Table 5-6. Conditions Before the Clock Oscillation Is Stopped and Flag | | | | Settings | CHARTER C TIMER | | | Addition of 6.1.3 8-bit timer operation function (channels 1 and 3 only) | CHAPTER 6 TIMER | | | Addition of description of caution 1 to Figure 6-7. Format of Peripheral Enable Register 0 (PER0) | ARRAY UNIT | | | Addition of remark to Figure 6-8. Format of Timer Clock Select register 0 (TPS0) | | | | Addition of address and change of description of note 2 in Figure 6-9. Format of Timer Mode Register 0n (TMR0n) | | | | Addition of address to Figure 6-10. Format of Timer Status Register 0n (TSR0n) | 1 | | | Addition of 30-pin products to Figure 6-11. Format of Timer Channel Enable Status register 0 | 1 | | | (TE0) to Figure 6-13. Format of Timer Channel Stop register 0 (TT0), and Figure 6-15. Format of | | | | 1 (1 = 5) to 1 agains 5 To 1 of mar or fillion of the frequency to grow of (1 To), and 1 iguit 5 To 1 of filliat of | | (14/17) | Edition | Description | Chapter | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 0.03 | Change of description in Figure 6-17. Format of Timer Output Level register 0 (TOL0) | CHAPTER 6 TIMER ARRAY UNIT | | | Addition of description to 6.4.1 Basic Rules of Simultaneous Channel Operation Function | | | | Addition of 6.5 Operation Timing of Counter | | | | Change of description in 6.6.1 TO0n pin output circuit configuration and 6.6.2 TO0n Pin Output | | | | Setting | | | | Addition of 6.6.3 Cautions on Channel Output Operation | | | | Addition of 6.6.4 Collective manipulation of TO0n bit | | | | Addition of 6.6.5 Timer Interrupt and TO0n Pin Output at Operation Start | | | | Addition of 6.7 Independent Channel Operation Function of Timer Array Unit | | | | Addition of 6.8 Simultaneous Channel Operation Function of Timer Array Unit | | | | Change of description and addition of caution to Figure 7-2. Format of Peripheral Enable | CHAPTER 7 | | | Register 0 (PER0) | INTERVAL TIMER | | | Addition of caution to Figure 7-4. Format of Interval Timer Control Register (ITMC) | | | | Change of Figure 8-1. Block Diagram of Clock Output/Buzzer Output Controller | CHAPTER 8 CLOCK | | | Addition of frequency to Figure 8-2. Format of Clock Output Select Register n (CKSn) | OUTPUT/BUZZER | | | | OUTPUT | | | | CONTROLLER | | | Change of values in 9.4.3 Setting window open period of watchdog timer | CHAPTER 9 | | | | WATCHDOG TIMER | | | Change of internal reference voltage | CHAPTER 10 A/D | | | Change of Figure 10-1. Block Diagram of A/D Converter | CONVERTER | | | Addition of caution to Table 10-1. Settings of ADCS and ADCE Bits | CHAPTER 11 SERIAL | | | Change of description in Table 10-2. Setting and Clearing Conditions for ADCS Bit | | | | Addition of frequency to Table 10-3. A/D Conversion Time Selection | | | | Change of Figure 10-6. Format of A/D Converter Mode Register 1 (ADM1) | | | | Change of bit name in Figure 10-7. Format of A/D Converter Mode Register 2 (ADM2) | | | | Change of caution 5 in Figure 10-11. Format of Analog Input Channel Specification Register (ADS) | | | | Change of description of note 2 in 10.8 SNOOZE mode function | | | | Addition of 10.10 Cautions for A/D Converter | | | | Addition of description to CHAPTER 11 SERIAL ARRAY UNIT | | | | Addition of description to 11.1.1 3-wire serial I/O (CSI00, CSI01, CSI11, CSI20) | ARRAYUNIT | | | Addition of description to 11.1.2 UART (UART0 to UART2) | Annai onii | | | Addition of description to 11.1.2 GATT (GATTO to GATT2) Addition of description to 11.1.3 Simplified I <sup>2</sup> C (IIC00, IIC01, IIC11, IIC20) | | | | | | | | Addition of SSC1 to Figure 11-3. Block Diagram of Serial Array Unit 1 (30-pin products) Addition of value to Figure 11-7. Format of Serial Clock Select Register m (SPSm) | | | | • , , | | | | Change of address in Figure 11-10. Format of Serial Data Register mn (SDRmn) | | | | Addition of description to 11.3 (14) Serial standby control register m (SSCm) | | | | Addition of description to 11.3 (16) Noise filter enable register 0 (NFEN0) | | | | Addition of description to 11.5 Operation of 3-Wire Serial I/O (CSI00, CSI01, CSI11, CSI20) | | | | Communication Change of value in (a) Social communication are exting a string a social and a string and (COR) and (COR) at Figure 2. | | | | Change of value in (c) Serial communication operation setting register mn (SCRmn) of Figure | | | | 11-86 Channe of value of various d. in 11 C.4 (1) Poud vata calculation averageing | | | | Change of value of remark 1 in 11.6.4 (1) Baud rate calculation expression | CHARTER 40 | | | Change of description and addition of caution to Figure 12-9. Format of IICA Control Register 01 | CHAPTER 12 | | | (IICCTL01) Addition of description to 19.3 (6) IICA law level width potting register 0 (IICM/ 0) | SERIAL INTERFACE | | | Addition of description to 12.3 (6) IICA low-level width setting register 0 (IICWL0) | | | | Change of description in Figure 12-32. Example of Master to Slave | | | | Communication and Figure 12-33. Example of Slave to Master Communication | 0 | | | Change of value in Figure 13-6. Timing Diagram of Multiplication (Unsigned) Operation (2 × 3 = 6) | CHAPTER 13 | | | Addition of description to 13.4.3 Multiply-accumulation (unsigned) operation | MULTIPLIER AND | | | | DIVIDER/MULTIPLY | | | | ACCUMULATOR | (15/17) | Edition | Description | Chapter | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | 0.03 | Addition of description to 13.4.4 Multiply-accumulation (signed) operation | CHAPTER 13 | | 0.03 | Change of Figure 13-9. Timing Diagram of Multiply-Accumulation (signed) Operation | MULTIPLIER AND<br>DIVIDER/MULTIPLY<br>ACCUMULATOR | | | Change of description in 14.2 (2) DMA RAM address register n (DRAn) | CHAPTER 14 DMA<br>CONTROLLER | | | Addition of description to Figure 14-4. Format of DMA Mode Control Register n (DMCn) | | | | Addition of 14.5 Example of Setting of DMA Controller | | | | Addition of 14.6 Cautions on Using DMA Controller | | | | Addition of 30-pin products to Figure 15-8. Format of External Interrupt Rising Edge Enable Register (EGP0) and External Interrupt Falling Edge Enable Register (EGN0) | CHAPTER 15<br>INTERRUPT<br>FUNCTION | | | Addition of value to Figure 17-2. Format of Oscillation Stabilization Time Select Register (OSTS) | CHAPTER 17<br>STANDBY<br>FUNCTION | | | Addition of description to Table 17-1. Operating Statuses in HALT Mode to Table 17-3. Operating Statuses in SNOOZE Mode | | | | Addition of note in Figure 17-3. HALT Mode Release by Interrupt Request Generation to Figure 17-6. STOP Mode Release by Reset | | | | Change of value and hardware name in Table 18-2. Hardware Statuses After Reset Acknowledgment | CHAPTER 18 RESET | | | Addition of name and value of note 2 to Table 18-2. Hardware Statuses After Reset Acknowledgment (3/3) | FUNCTION | | | Addition of note to Figure 19-2. Timing of Generation of Internal Reset Signal by Power-on-reset Circuit and Voltage Detector | CHAPTER 19<br>POWERON-RESET | | | Change of value in Figure 19-3. Example of Software Processing After Reset Release | CIRCUIT | | | Deletion of description of (c) Interrupt mode (option byte LVIMDS1, LVIMDS0 = 0, 1) | CHAPTER 20 | | | Addition of note to Figure 20-2. Format of Voltage Detection Register (LVIM) | VOLTAGE | | | Change of note 1 to Figure 20-3. Format of Voltage Detection Level Select Register (LVIS) | DETECTOR | | | Change of Table 20-1. LVD Operation Mode and Detection Voltage Settings for User Option Byte (000C1H) | | | | Change of description in 20.4.1 When used as reset mode to 20.4.3 When used as interrupt and reset mode | | | | Change of Figure 20-4. Timing of Voltage Detector Internal Reset Signal Generation (Option | | | | Byte LVIMDS1, LVIMDS0 = 1, 1) to Figure 20-6. Timing of Voltage Detector Reset Signal and | | | | Interrupt Signal Generation (Option Byte LVIMDS1, LVIMDS0 = 1, 0) | | | | Change of Figure 20-8. Delay from the time LVD reset source is generated until the time LVD reset has been generated or released | | | | Change of all | CHAPTER 21<br>SAFETY FUNCTION | | | Change of Table 22-1. Regulator Output Voltage Conditions | CHAPTER 22<br>REGULATOR | | | Deletion of description of 23.1.1 (2) 000C1H | CHAPTER 23 | | | Change of description in Figure 23-2. Format of User Option Byte (000C1H) and Figure 23-3. Format of Option Byte (000C2H) | OPTION BYTE | | | Change of setting value in 23.4 Setting of Option Byte | | | | Addition of description to 24.1.2 Communication mode | CHAPTER 24 FLASH<br>MEMORY | | | Change of description in Table 24-2. Pin Connection | | | | Change of description in 24.2.2 Communication mode | | | | Addition of description to 24.4.1 Data flash overview | | | | Change of description in 24.5.2 Flash memory programming mode | | | | Addition of 24.5.5 Description of signature data | | | | , , | | | | Change of description in (2) Self programming of Table 24-12. Security Setting in Each | | | | Programming Mode | | | | Addition of description to 24.7.1 Flash shield window function | | | | Change of description in Figure 24-14. Setting and changing of the flash shield window function | | | | and relations with commands Change of Figure 25-1. Connection Example of E1 On-chip Debugging Emulator and RL78/G12 | CHAPTER 25 ON- | | | | CHIP DEBUG<br>FUNCTION | (16/17) | Edition | Description | (16/17)<br>Chapter | |---------|---------------------------------------------------------------------------------------------------------|------------------------------| | 0.03 | Addition of Figure 25-2. Connection Example of E1 On-chip Debugging Emulator and RL78/G12 | CHAPTER 25 ON- | | | (When using to the alternative function of RESET pin) | CHAPTER 25 ON- | | | Change of description in Figure 25-3. Memory Spaces Where Debug Monitor Programs Are | FUNCTION | | | Allocated | | | | Addition of description to Table 27-1. Operand Identifiers and Specification Methods | CHAPTER 27 | | | Tradition of decomption to Table 27 1. Operand techniness and opcompation methods | INSTRUCTION SET | | | Addition of value to 28.3.2 On-chip oscillator characteristics | CHAPTER 28 | | | Change of 28.4.1 Pin characteristics | ELECTRICAL | | | Addition of value to 28.4.2 Supply current characteristics | SPECIFICATIONS (target) | | | Change of value in 28.5.1 Basic operation | | | | Change of value in 28.6.1 Serial array unit | | | | Addition of value to 28.7.1 A/D converter characteristics | | | | Addition of value to 28.7.2 Temperature sensor characteristics and 28.7.3 POR circuit | | | | characteristics | | | | Deletion of value of LVD detection voltage of interrupt & reset mode | - | | | Change of value in 28.8 Data Memory STOP Mode Low Supply Voltage Data Retention | - | | | Characteristics | | | | Addition of all | CHAPTER 29 | | | Addition of all | | | | | PACKAGE<br>DRAWINGS | | 0.00 | Addition of the 20 pin product | | | 0.02 | Addition of the 30-pin product | Through out | | | Modification of the names "internal high-speed oscillator circuit" and "internal low speed | | | | oscillator circuit" to "high-speed on-chip oscillator (HOCO)" and "low-speed on-chip oscillator (LOCO)" | | | | | CHAPTER & CRIT | | | Addition of cautions in Figures 3-1 through 3-6 Memory maps and Figure 3-8 through 3-13 | CHAPTER 3 CPU | | | Correspondences between data memory and addressing | ARCHITECTURE | | | Modification of reset values of P13 in Table 3-6 SFR list | | | | Addition of high-speed on-chip oscillator frequency selecting register (HOCODIV) to Table 3-7 | | | | Extended SFR (2ndSFR) list | | | | Modification of description method of operand | CHARTER 4 DODT | | | Addition of Cautions 1 through 3 in 4.2.1 20-, 24-pin product (2) Port 1 | CHAPTER 4 PORT | | | Addition of Caution 2 in 4.2.1 20-, 24-pin product (4) Port 4 | FUNCTIONS | | | Addition of Caution in 4.2.1 20-, 24-pin product (5) Port 6 | 01145775 - 010014 | | | Addition of the high-speed on-chip oscillator frequency selection register (HOCODIV) in control | CHAPTER 5 CLOCK<br>GENERATOR | | | registers | | | | Deletion of LV (low-voltage main) mode in 5.6.1 Example of setting high-speed on-chip | | | | Oscillator | | | | Modification of voltages in Figure 5-14 CPU clock status transition diagram | OLIA DTED A TIMED | | | Addition of description of alternate ports in 6.2 Timer array unit configuration | CHAPTER 6 TIMER | | | Madiffestion in Figure 44.40 Females (Opinish Bata Basistanana (OBB as) | ARRAY UNIT | | | Modification in Figure 11-10 Format of Serial Data Register mn (SDRmn) | CHAPTER 11 SERIAL | | | Deletion of values in Caution 2 in Figure 11-10 Format of Serial Data Register mn (SDRmn) and | ARRAY UNIT | | | Caution in 11.6.4 Calculating baud rate | OLIADTED 40 OFFICE | | | Addition of description in cautions in 12.4.2 Setting transfer clock by using the IICWL0 and | CHAPTER 12 SERIAL | | | IICWH0 registers | INTERFACE IICA | | | Addition of setting values in Figure 15-6 Format of Priority Specification Flag Registers (PR00L, | CHAPTER 15 INTERRUPT | | | PR00H, PR01L, PR10L, PR10H, PR11L) (20-, 24-pin product) | | | | | FUNCTIONS | | | Addition of Cautions 2 and 3 in Figure 18-5 Format of Reset Control Flag Register (RESF) | CHAPTER 18 RESET | | | | FUNCTION | (17/17) | | (17/1 | | | |---------|--------------------------------------------------------------------------------------------------|-------------------|--| | Edition | Description | Chapter | | | 0.02 | Modification of voltage in Figure 19-2 Timing of Generation of Internal Reset Signal by Power- | CHAPTER 19 | | | | on-reset Circuit and Voltage Detector | POWERON-RESET | | | | | CIRCUIT | | | | Deletion of description in 20.1 Function of Voltage Detector | CHAPTER 20 | | | | Modification in Figure 20-5 Timing of Interrupt Signal Generation | VOLTAGE | | | | | DETECTOR | | | | Addition of Caution 2 in Figure 21-4 Format of RAM Parity Error Control Register | CHAPTER 21 SAFETY | | | | (RPECTL) | FUNCTIONS | | | | Deletion of the description of boot swap | CHAPTER 23 OPTION | | | | | BYTE | | | | Modification of description in Table 24-1 Wiring Between RL78/G12 and Dedicated Flash | CHAPTER 24 FLASH | | | | Memory Programmer and Table 24-2 Pin Connection | MEMORY | | | | Modification of description in Notes of 24.1.2 Communication Mode | | | | | Addition of description in 24.3.1 TOOL0 pin | | | | | Modification of description in 24.4.1 Data flash overview | | | | | Modification in Figure 24-8 Setting of Flash Memory Programming Mode | | | | | Modification in Table 24-7 Flash Memory Control Commands | | | | | Addition of Caution 2 in 24.7 Flash Memory Programming by Self-Programming | | | | | Addition of 24.7.1 Flash shield window function | | | | | Modification of values of Absolute Maximum Ratings | CHAPTER 28 | | | | Modification of values of On-chip Oscillator Characteristics | ELECTRICAL | | | | Modification of values in 28.4 DC Characteristics | SPECIFICATIONS | | | | Modification of values in 28.6.1 Serial array unit | (TARGET) | | | | Addition of Caution in 28.6.1 Serial array unit | | | | | Addition of description in Caution of 28.6.1 Serial array unit | | | | | Addition and deletion of values in 28.7 Analog Characteristics, and modification of the value in | | | | | the same section | | | | | Modification in 28.9 Flash Memory Programming Characteristics | | | | | Modification in 28.10 Timing Specs for Switching Modes and of the unit | | | RL78/G12 User's Manual: Hardware Publication Date: Rev.2.10 Mar 25, 2016 Published by: Renesas Electronics Corporation #### **SALES OFFICES** Renesas Electronics Corporation http://www.renesas.com Refer to "http://www.renesas.com/" for the latest and detailed information. Renesas Electronics America Inc. 2801 Scott Boulevard Santa Clara, CA 95050-2549, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130 Renesas Electronics Canada Limited 9251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 9T3 Tel: +1-905-237-2004 Renesas Electronics Europe Limited Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K Tel: +44-1628-585-100, Fax: +44-1628-585-900 Renesas Electronics Europe GmbH Arcadiastrasse 10, 40472 Düsseldorf, Germany Tel: +49-211-6503-0, Fax: +49-211-6503-1327 Renesas Electronics (China) Co., Ltd. Room 1709, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100191, P.R.China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679 Renesas Electronics (Shanghai) Co., Ltd. Unit 301, Tower A, Central Towers, 555 Langao Road, Putuo District, Shanghai, P. R. China 200333 Tel: +86-21-2226-0888, Fax: +86-21-2226-0999 Renesas Electronics Hong Kong Limited Unit 1601-1611, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: +852-2265-6688, Fax: +852 2886-9022 Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei 10543, Taiwan Tel: +886-2-8175-9600, Fax: +886 2-8175-9670 Renesas Electronics Singapore Pte. Ltd. 80 Bendemeer Road, Unit #06-02 Hyflux Innovation Centre, Singapore 339949 Tel: +65-6213-0200, Fax: +65-6213-0300 Renesas Electronics Malaysia Sdn.Bhd. Unit 1207, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tel: +60-3-7955-9390, Fax: +60-3-7955-9510 Renesas Electronics India Pvt. Ltd. No.777C, 100 Feet Road, HAL II Stage, Indiranagar, Bangalore, India Tel: +91-80-67208700, Fax: +91-80-67208777 Renesas Electronics Korea Co., Ltd. 12F., 234 Teheran-ro, Gangnam-Gu, Seoul, 135-080, Korea Tel: +82-2-558-3737, Fax: +82-2-558-5141 © 2016 Renesas Electronics Corporation. All rights reserved. ## RL78/G12