# M16C/65C Group User's Manual: Hardware RENESAS MCU M16C Family / M16C/60 Series All information contained in these materials, including products and product specifications, represents information on the product at the time of publication and is subject to change by Renesas Electronics Corp. without notice. Please review the latest information published by Renesas Electronics Corp. through various means, including the Renesas Electronics Corp. website (http://www.renesas.com). #### Notice - Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information. - Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein. - 3. Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others. - 4. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from such alteration, modification, copy or otherwise misappropriation of Renesas Electronics product. - 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots etc. - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; and safety equipment etc. Renesas Electronics products are neither intended nor authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems, surgical implantations etc.), or may cause serious property damages (nuclear reactor control systems, military equipment etc.). You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application for which it is not intended. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for which the product is not intended by Renesas Electronics. - 6. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges. - 7. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or systems manufactured by you. - 8. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations. - 9. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You should not use Renesas Electronics products or technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. When exporting the Renesas Electronics products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. - 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, who distributes, disposes of, or otherwise places the product with a third party, to notify such third party in advance of the contents and conditions set forth in this document, Renesas Electronics assumes no responsibility for any losses incurred by you or third parties as a result of unauthorized use of Renesas Electronics products. - 11. This document may not be reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics. - 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries. - (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries. - (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics. ## General Precautions in the Handling of MPU/MCU Products The following usage notes are applicable to all MPU/MCU products from Renesas. For detailed usage notes on the products covered by this manual, refer to the relevant sections of the manual. If the descriptions under General Precautions in the Handling of MPU/MCU Products and in the body of the manual differ from each other, the description in the body of the manual takes precedence. ## 1. Handling of Unused Pins Handle unused pins in accord with the directions given under Handling of Unused Pins in the manual. The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual. #### 2. Processing at Power-on The state of the product is undefined at the moment when power is supplied. The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied. In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed. In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified. #### 3. Prohibition of Access to Reserved Addresses Access to reserved addresses is prohibited. The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed. #### 4. Clock Signals After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized. — When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable. ### 5. Differences between Products Before changing from one product to another, i.e. to one with a different part number, confirm that the change will not lead to problems. — The characteristics of MPU/MCU in the same group but having different part numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different part numbers, implement a system-evaluation test for each of the products. ## **About This Manual** ## 1. Purpose and Target User This manual is designed to be read primarily by application developers who have an understanding of this microcomputer (MCU) including its hardware functions and electrical characteristics. The user should have a basic understanding of electric circuits, logic circuits and, MCUs. This manual consists of six main categories: Overview, CPU, System Control, Peripherals, Electrical Characteristics, and Usage Notes. Carefully read all notes in this document prior to use. Notes are found throughout each chapter, at the end of each chapter, and in the dedicated Usage Notes chapter. The Revision History at the end of this manual summarizes primary modifications and additions to the previous versions. For details, please refer to the relative chapters or sections of this manual. The M16C/65C Group includes the documents listed below. Verify this manual is the latest version by visiting the Renesas Electronics website. | Type of Document | Contents | Document Name | Document Number | |-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------------------| | Datasheet | Overview of Hardware and Electrical Characteristics | M16C/65C Group<br>Datasheet | R01DS0015EJ0110 | | User's Manual:<br>Hardware | Specifications and detailed descriptions of: -pin layout -memory map -peripherals -electrical characteristics -timing characteristics Refer to the Application Manual for peripheral usage. | M16C/65C Group<br>User's Manual:<br>Hardware | This publication | | User's Manual:<br>Software/Software<br>Manual | Descriptions of instruction set | M16C/60, M16C/20,<br>M16C/Tiny Series<br>Software Manual | REJ09B0137 | | Application Note | -Usages -Applications -Sample programs -Programming technics using Assembly language or C programming language | Available on the Renewebsite. | esas Electronics | | Renesas Technical<br>Update | Bulletins on product specifications, documents, etc. | | | ## 2. Numbers and Symbols The following explains the denotations used in this manual for registers, bits, pins and various numbers. (1) Registers, bits, and pins Registers, bits, and pins are indicated by symbols. Each symbol has a register/bit/pin identifier after the symbol. Example: PM03 bit in the PM0 register P3\_5 pin, VCC pin (2) Numbers A binary number has the suffix "b" except for a 1-bit value. A hexadecimal number has the suffix "h". A decimal number has no suffix. Example: Binary notation: 11b Hexadecimal notation: EFA0h Decimal notation: 1234 ## 3. Registers The following illustration describes registers used throughout this manual. #### Notes: - 1. Blank box: Set this bit to 0 or 1 according to the function. - 0: Set this bit to 0. - 1: Set this bit to 1. - X: Nothing is assigned to this bit. - 2. RW: Read and write - RO: Read only - WO: Write only (the read value is undefined) - —: Not applicable - 3. Reserved bit: This bit field is reserved. Set this bit to a specified value. For RW bits, the written value is read unless otherwise noted. 4 - No register bit(s): No register bit(s) is/are assigned to this field. If necessary, set to 0 for possible future implementation. - Do not use this combination: Proper operation is not guaranteed when this value is set. - Functions vary with operating modes: Functions vary with peripheral operating modes. Refer to register illustrations of the respective mode. ## 4. Abbreviations and Acronyms The following acronyms and terms are used throughout this manual. | Abbreviation/Acronym | Meaning | |----------------------|----------------------------------------------| | ACIA | Asynchronous Communication Interface Adapter | | bps | bits per second | | CRC | Cyclic Redundancy Check | | DMA | Direct Memory Access | | DMAC | Direct Memory Access Controller | | GSM | Global System for Mobile Communications | | Hi-Z | High Impedance | | IEBus | Inter Equipment Bus | | I/O | Input/Output | | IrDA | Infrared Data Association | | LSB | Least Significant Bit | | MSB | Most Significant Bit | | NC | Non-Connection | | PLL | Phase Locked Loop | | PWM | Pulse Width Modulation | | SIM | Subscriber Identity Module | | UART | Universal Asynchronous Receiver/Transmitter | | VCO | Voltage Controlled Oscillator | # **Table of Contents** | Qι | ıick Ref | ference | B-1 | |----|-------------------------------------|------------------------------------------------------------|-----| | 1. | Over | rview | 1 | | | 1.1 | Features | 1 | | | 1.1.1 | Applications | 1 | | | 1.2 | Specifications | 2 | | | 1.3 | Product List | 6 | | | 1.4 | Block Diagram | 8 | | | 1.5 | Pin Assignments | 10 | | | 1.6 | Pin Functions | 18 | | 2. | Cent | tral Processing Unit (CPU) | 24 | | | 2.1 | Data Registers (R0, R1, R2, and R3) | 25 | | | 2.2 | Address Registers (A0 and A1) | 25 | | | 2.3 | Frame Base Register (FB) | 25 | | | 2.4 | Interrupt Table Register (INTB) | 25 | | | 2.5 | Program Counter (PC) | 25 | | | 2.6 | User Stack Pointer (USP) and Interrupt Stack Pointer (ISP) | 25 | | | 2.7 | Static Base Register (SB) | 25 | | | 2.8 | Flag Register (FLG) | 25 | | | 2.8.1 | Carry Flag (C Flag) | 25 | | | 2.8.2 | Debug Flag (D Flag) | 25 | | | 2.8.3 | Zero Flag (Z Flag) | 25 | | | 2.8.4 | Sign Flag (S Flag) | 25 | | | 2.8.5 | Register Bank Select Flag (B Flag) | 25 | | | 2.8.6 | Overflow Flag (O Flag) | 25 | | | 2.8.7 | 7 Interrupt Enable Flag (I Flag) | 26 | | | 2.8.8 | Stack Pointer Select Flag (U Flag) | 26 | | | 2.8.9 | Processor Interrupt Priority Level (IPL) | 26 | | | 2.8.1 | 10 Reserved Areas | 26 | | 3. | Addr | ress Space | 27 | | | 3.1 | Address Space | 27 | | | 3.2 | Memory Map | 28 | | | 3.3 | Accessible Area in Each Mode | 29 | | 4. | . Special Function Registers (SFRs) | | | | | 4.1 | SFRs | 30 | | | 4.2 | Notes on SFRs | 48 | | | 4.2.1 | Register Settings | 48 | | 5. | Prote | ection | 50 | | | E 1 | Introduction | 50 | | | 5.2 | Register | 50 | |----|-------|------------------------------------------------------|----| | | 5.2.1 | 1 Protect Register (PRCR) | 50 | | | 5.3 | Notes on Protection | 52 | | 6. | Rese | ets | 53 | | | 6.1 | Introduction | 53 | | | 6.2 | Registers | 55 | | | 6.2.1 | Processor Mode Register 0 (PM0) | 56 | | | 6.2.2 | Reset Source Determine Register (RSTFR) | 57 | | | 6.3 | Optional Function Select Area | 58 | | | 6.3.1 | Optional Function Select Address 1 (OFS1) | 58 | | | 6.4 | Operations | 60 | | | 6.4.1 | 1 Status after Reset | 60 | | | 6.4.2 | 2 Hardware Reset | 63 | | | 6.4.3 | Power-On Reset Function | 64 | | | 6.4.4 | 4 Voltage Monitor 0 Reset | 65 | | | 6.4.5 | 5 Voltage Monitor 1 Reset | 65 | | | 6.4.6 | 6 Voltage Monitor 2 Reset | 65 | | | 6.4.7 | 7 Oscillator Stop Detect Reset | 66 | | | 6.4.8 | 8 Watchdog Timer Reset | 66 | | | 6.4.9 | 9 Software Reset | 66 | | | 6.4.1 | 10 Cold/Warm Start Discrimination | 67 | | | 6.5 | Notes on Resets | 68 | | | 6.5.1 | Power Supply Rising Gradient | 68 | | | 6.5.2 | Power-On Reset | 68 | | | 6.5.3 | OSDR Bit (Oscillation Stop Detect Reset Detect Flag) | 69 | | 7. | Volta | age Detector | 70 | | | 7.1 | Introduction | 70 | | | 7.2 | Registers | 72 | | | 7.2.1 | 1 Voltage Detector 2 Flag Register (VCR1) | 73 | | | 7.2.2 | Voltage Detector Operation Enable Register (VCR2) | 74 | | | 7.2.3 | Voltage Monitor Function Select Register (VWCE) | 75 | | | 7.2.4 | Voltage Detector 1 Level Select Register (VD1LS) | 76 | | | 7.2.5 | Voltage Monitor 0 Control Register (VW0C) | 77 | | | 7.2.6 | Voltage Monitor 1 Control Register (VW1C) | 78 | | | 7.2.7 | 7 Voltage Monitor 2 Control Register (VW2C) | 80 | | | 7.3 | Optional Function Select Area | 82 | | | 7.3.1 | Optional Function Select Address 1 (OFS1) | 82 | | | 7.4 | Operations | 83 | | | 7.4.1 | 1 Digital Filter | 83 | | | 742 | 2 Voltage Detector 0 | 84 | | | 7.4.3 | Voltage Detector 1 | 86 | |----|-------|--------------------------------------------------------------------------------|-----| | | 7.4.4 | Voltage Detector 2 | 89 | | | 7.5 | Interrupts | 92 | | 8. | Cloc | k Generator | 93 | | | 8.1 | Introduction | 93 | | | 8.2 | Registers | 95 | | | 8.2.1 | Processor Mode Register 0 (PM0) | 96 | | | 8.2.2 | System Clock Control Register 0 (CM0) | 97 | | | 8.2.3 | System Clock Control Register 1 (CM1) | 99 | | | 8.2.4 | Oscillation Stop Detection Register (CM2) | 101 | | | 8.2.5 | Peripheral Clock Select Register (PCLKR) | 103 | | | 8.2.6 | Peripheral Clock Stop Register 1 (PCLKSTP1) | 103 | | | 8.2.7 | PLL Control Register 0 (PLC0) | 105 | | | 8.2.8 | Processor Mode Register 2 (PM2) | 106 | | | 8.2.9 | 40 MHz On-Chip Oscillator Control Register 0 (FRA0) | 107 | | | 8.3 | Clocks Generated by Clock Generators | 108 | | | 8.3.1 | Main Clock | 108 | | | 8.3.2 | PLL Clock | 109 | | | 8.3.3 | fOCO40M | 110 | | | 8.3.4 | fOCO-F | 110 | | | 8.3.5 | 125 kHz On-Chip Oscillator Clock (fOCO-S) | 110 | | | 8.3.6 | Sub Clock (fC) | 111 | | | 8.4 | CPU Clock and Peripheral Function Clocks | 112 | | | 8.4.1 | CPU Clock and BCLK | 112 | | | 8.4.2 | Peripheral Function Clocks (f1, fOCO40M, fOCO-F, fOCO-S, fC32, fC, Main Clock) | 112 | | | 8.5 | Clock Output Function | 114 | | | 8.6 | System Clock Protection Function | 114 | | | 8.7 | Oscillator Stop/Restart Detect Function | 115 | | | 8.7.1 | Operation When CM27 Bit is 0 (Oscillator Stop Detect Reset) | 115 | | | 8.7.2 | Operation When CM27 Bit is 1 (Oscillator Stop/Restart Detect Interrupt) | 116 | | | 8.7.3 | Using the Oscillator Stop/Restart Detect Function | 117 | | | 8.8 | Interrupt | 117 | | | 8.9 | Notes on Clock Generator | 118 | | | 8.9.1 | Oscillator Using a Crystal or a Ceramic Resonator | 118 | | | 8.9.2 | Noise Countermeasure | 119 | | | 8.9.3 | CPU Clock | 120 | | | 8.9.4 | Oscillator Stop/Restart Detect Function | 120 | | | 8.9.5 | PLL Frequency Synthesizer | 121 | | 9. | Pow | er Control | 122 | | | 9.1 | Introduction | 122 | | | 9.2 | Registers | 122 | |-----|-------|-------------------------------------------|-----| | | 9.2.1 | Flash Memory Control Register 0 (FMR0) | 123 | | | 9.2.2 | Flash Memory Control Register 2 (FMR2) | 124 | | | 9.3 | Clock | 126 | | | 9.3.1 | Normal Operating Mode | 126 | | | 9.3.2 | Clock Mode Transition Procedure | 130 | | | 9.3.3 | Wait Mode | 134 | | | 9.3.4 | Stop Mode | 136 | | | 9.4 | Power Control in Flash Memory | 138 | | | 9.4.1 | Stopping Flash Memory | 138 | | | 9.4.2 | Reading Flash Memory | 139 | | | 9.5 | Reducing Power Consumption | 141 | | | 9.5.1 | Ports | 141 | | | 9.5.2 | A/D Converter | 141 | | | 9.5.3 | D/A Converter | 141 | | | 9.5.4 | Stopping Peripheral Functions | 141 | | | 9.5.5 | 3 1 7 | | | | 9.6 | Notes on Power Control | 142 | | | 9.6.1 | CPU Clock | | | | 9.6.2 | Wait Mode | 142 | | | 9.6.3 | • | | | | 9.6.4 | • | | | | 9.6.5 | Slow Read Mode | 143 | | 10. | Proc | essor Mode | 144 | | | 10.1 | Introduction | 144 | | | 10.2 | Registers | 145 | | | 10.2. | 1 Processor Mode Register 0 (PM0) | 145 | | | 10.2. | Processor Mode Register 1 (PM1) | 146 | | | 10.2. | 3 Program 2 Area Control Register (PRG2C) | 148 | | | 10.3 | Operations | 149 | | | 10.3. | 1 Processor Mode Settings | 149 | | 11. | Bus. | | 151 | | | 11.1 | Introduction | | | | 11.2 | Registers | | | | 11.2. | · | | | | 11.2. | | | | | 11.2. | | | | | 11.2. | | | | | 11.3 | Operations | | | | 11.3. | · | | | | 11.3.2 | Internal Bus | 157 | |-----|---------|-------------------------------------------------------|-----| | | 11.3.3 | External Bus | 158 | | | 11.3.4 | External Bus Mode | 158 | | | 11.3.5 | External Bus Control | 159 | | 1′ | 1.4 No | ites on Bus | 171 | | | 11.4.1 | Reading Data Flash | 171 | | | 11.4.2 | External Bus | 171 | | | 11.4.3 | External Access Immediately after Writing to the SFRs | 171 | | | 11.4.4 | Wait and RDY | 171 | | | 11.4.5 | HOLD | 171 | | 12. | Memory | / Space Expansion Function | 172 | | 12 | 2.1 Int | roduction | 172 | | 12 | 2.2 Re | gisters | 172 | | | 12.2.1 | Data Bank Register (DBR) | 173 | | 12 | 2.3 Op | perations | 174 | | | 12.3.1 | 1-MB Mode | 174 | | | 12.3.2 | 4-MB Mode | 176 | | 13. | Progran | mmable I/O Ports | 183 | | | Ŭ | roduction | | | 13 | 3.2 I/O | Ports and Pins | 184 | | 13 | 3.3 Re | gisters | 196 | | | 13.3.1 | Pull-Up Control Register 0 (PUR0) | 197 | | | 13.3.2 | Pull-Up Control Register 1 (PUR1) | 198 | | | 13.3.3 | Pull-Up Control Register 2 (PUR2) | 199 | | | 13.3.4 | Pull-Up Control Register 3 (PUR3) | 200 | | | 13.3.5 | Port Control Register (PCR) | 201 | | | 13.3.6 | Port Pi Register (Pi) (i = 0 to 14) | 202 | | | 13.3.7 | Port Pi Direction Register (PDi) (i = 0 to 14) | 203 | | | 13.3.8 | NMI/SD Digital Filter Register (NMIDF) | 204 | | 13 | 3.4 Pe | ripheral Function I/O | 205 | | | 13.4.1 | Peripheral Function I/O and Port Direction Bits | 205 | | | 13.4.2 | Priority Level of Peripheral Function I/O | 205 | | | 13.4.3 | NMI/SD Digital Filter | 206 | | | 13.4.4 | CNVSS Pin | 206 | | 13 | 3.5 Un | assigned Pin Handling | 207 | | 13 | 3.6 No | tes on Programmable I/O Ports | | | | 13.6.1 | Influence of SD | | | | 13.6.2 | Influence of SI/O3 and SI/O4 | 209 | | | 1363 | 100-Pin Packago | 200 | | 14. | Inte | rrupts | S | 210 | |--------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | | 14.1 | Intro | oduction | 210 | | 14.2 I | | Reg | isters | .211 | | | 14.2 | 2.1 | Processor Mode Register 2 (PM2) | 213 | | | 14.2 | 2.2 | Interrupt Control Register 1 (TB5IC, TB4IC/U1BCNIC, TB3IC/U0BCNIC, BCNIC, DM0IC to DM3IC, KUPIC, ADIC, S0TIC to S2TIC, S0RIC to S2RIC, TA0IC to TA4IC, TB0IC to TB2IC, U5BCNIC/CEC1IC S5TIC/CEC2IC, S5RIC to S7RIC, U6BCNIC/RTCTIC, S6TIC/RTCCIC, U7BCNIC/PMC0IC, S7TIC/PMC1IC, IICIC, SCLDAIC) | • | | | 14.2 | 2.3 | Interrupt Control Register 2 (INT7IC, INT6IC, INT3IC, S4IC/INT5IC, S3IC/INT4IC, INT0IC to INT2IC) | . 215 | | | 14.2 | 2.4 | Interrupt Source Select Register 3 (IFSR3A) | 216 | | | 14.2 | 2.5 | Interrupt Source Select Register 2 (IFSR2A) | 217 | | | 14.2 | 2.6 | Interrupt Source Select Register (IFSR) | 218 | | | 14.2 | 2.7 | Address Match Interrupt Enable Register (AIER) | 219 | | | 14.2 | 2.8 | Address Match Interrupt Enable Register 2 (AIER2) | 219 | | | 14.2 | 2.9 | Address Match Interrupt Register i (RMADi) (i = 0 to 3) | 220 | | | 14.2 | 2.10 | Port Control Register (PCR) | 221 | | | 14.2 | 2.11 | NMI/SD Digital Filter Register (NMIDF) | 222 | | | 14.3 | Туре | es of Interrupts | 223 | | | 14.4 | Soft | ware Interrupts | 224 | | | 14.4 | 1.1 | Undefined Instruction Interrupt | 224 | | | 14.4 | 1.2 | Overflow Interrupt | 224 | | | 14.4 | 1.3 | BRK Interrupt | 224 | | | 14.4 | 1.4 | INT Instruction Interrupt | 224 | | | 14.5 | Hard | dware Interrupts | 225 | | | 14.5 | 5.1 | Special Interrupts | 225 | | | 14.5 | 5.2 | Peripheral Function Interrupts | . 225 | | | 14.6 | Inter | rrupts and Interrupt Vectors | 226 | | | 14.6 | S.1 | Fixed Vector Tables | 226 | | | 14.6 | 6.2 | Relocatable Vector Tables | 227 | | | 14.7 | Inter | rrupt Control | 229 | | | 14.7 | 7.1 | Maskable Interrupt Control | 229 | | | 14.7 | 7.2 | Interrupt Sequence | 230 | | | 14.7 | 7.3 | Interrupt Response Time | 231 | | | 14.7 | 7.4 | Variation of IPL When Interrupt Request is Accepted | 231 | | | 14.7 | 7.5 | Saving Registers | 232 | | | 14.7 | 7.6 | Returning from an Interrupt Routine | 233 | | | 14.7 | 7.7 | Interrupt Priority | 233 | | | 14.7 | 7.8 | Interrupt Priority Level Select Circuit | 233 | | | 14.7 | 7.9 | Multiple Interrupts | 235 | | | 14 8 | ĪNT | Interrupt | 235 | | | 14.9 | NMI | Interrupt | 236 | |----|--------|-------|-------------------------------------------------------|-----| | | 14.10 | Key | Input Interrupt | 236 | | | 14.11 | Add | ress Match Interrupt | 237 | | | 14.12 | Non | -Maskable Interrupt Source Discrimination | 238 | | | 14.13 | Note | es on Interrupts | 239 | | | 14.13 | 3.1 | Reading Address 00000h | 239 | | | 14.13 | 3.2 | SP Setting | 239 | | | 14.13 | 3.3 | NMI Interrupt | 239 | | | 14.13 | 3.4 | Changing an Interrupt Source | 240 | | | 14.13 | 3.5 | Rewriting the Interrupt Control Register | 241 | | | 14.13 | 3.6 | Instruction to Rewrite the Interrupt Control Register | 241 | | | 14.13 | 3.7 | INT Interrupt | 242 | | 15 | . Watc | :hdo | g Timer | 243 | | | | | duction | | | | 15.2 | | isters | | | | 15.2. | · | Voltage Monitor 2 Control Register (VW2C) | | | | 15.2. | | Count Source Protection Mode Register (CSPR) | | | | 15.2. | | Watchdog Timer Refresh Register (WDTR) | | | | 15.2. | | Watchdog Timer Start Register (WDTS) | | | | 15.2. | | Watchdog Timer Control Register (WDC) | | | | 15.3 | | onal Function Select Area | | | | 15.3. | - | Optional Function Select Address 1 (OFS1) | | | | 15.4 | | rations | | | | 15.4. | • | Count Source Protection Mode Disabled | | | | 15.4. | | Count Source Protection Mode Enabled | | | | 15.5 | Inter | rupts | | | | 15.6 | | es on the Watchdog Timer | | | | | | | | | 16 | | | | | | | 16.1 | | duction | | | | 16.2 | · | isters | | | | 16.2. | | DMAi Source Pointer (SARi) (i = 0 to 3) | | | | 16.2. | | DMAi Destination Pointer (DARi) (i = 0 to 3) | | | | 16.2. | | DMAi Transfer Counter (TCRi) (i = 0 to 3) | | | | 16.2. | | DMAi Control Register (DMiCON) (i = 0 to 3) | | | | 16.2. | | DMAi Source Select Register (DMiSL) (i = 0 to 3) | | | | 16.3 | • | rations | | | | 16.3. | | DMA Enabled | | | | 16.3. | | DMA Request | | | | 16.3. | | Transfer Cycles | | | | 16.3. | 4 | DMAC Transfer Cycles | 265 | | | 16.3.5 | Single Transfer Mode | 266 | |-----------|-----------|-----------------------------------------------------------------------|-----| | 16.3.6 | | Repeat Transfer Mode | 267 | | | 16.3.7 | Channel Priority and DMA Transfer Timing | 268 | | 16.4 Inte | | errupts | 269 | | 16.5 Not | | tes on DMAC | 270 | | | 16.5.1 | Write to the DMAE Bit in the DMiCON Register (i = 0 to 3) | 270 | | | 16.5.2 | Changing the DMA Request Source | 270 | | 17 | . Timer A | | 271 | | | 17.1 Intr | oduction | 271 | | | 17.2 Re | gisters | 274 | | | 17.2.1 | Peripheral Clock Select Register (PCLKR) | 275 | | | 17.2.2 | Clock Prescaler Reset Flag (CPSRF) | 275 | | | 17.2.3 | Peripheral Clock Stop Register 1 (PCLKSTP1) | 276 | | | 17.2.4 | Timer AB Division Control Register 0 (TCKDIVC0) | 277 | | | 17.2.5 | Timer A Count Source Select Register i (TACSi) (i = 0 to 2) | 278 | | | 17.2.6 | 16-bit Pulse Width Modulation Mode Function Select Register (PWMFS) | 279 | | | 17.2.7 | Timer A Waveform Output Function Select Register (TAPOFS) | 280 | | | 17.2.8 | Timer A Output Waveform Change Enable Register (TAOW) | 281 | | | 17.2.9 | Timer Ai Register (TAi) (i = 0 to 4) | 282 | | | 17.2.10 | Timer Ai-1 Register (TAi1) (i = 1, 2, 4) | 283 | | | 17.2.11 | Count Start Flag (TABSR) | 283 | | | 17.2.12 | One-Shot Start Flag (ONSF) | 284 | | | 17.2.13 | Trigger Select Register (TRGSR) | 285 | | | 17.2.14 | Increment/Decrement Flag (UDF) | 286 | | | 17.2.15 | Timer Ai Mode Register (TAiMR) (i = 0 to 4) | 287 | | | 17.3 Op | erations | 288 | | | 17.3.1 | Common Operations | 288 | | | 17.3.2 | Timer Mode | 290 | | | 17.3.3 | Event Counter Mode (When Not Using Two-Phase Pulse Signal Processing) | 294 | | | 17.3.4 | Event Counter Mode (When Processing Two-Phase Pulse Signal) | 298 | | | 17.3.5 | One-Shot Timer Mode | 303 | | | 17.3.6 | Pulse Width Modulation (PWM) Mode | 307 | | | 17.3.7 | Programmable Output Mode (Timers A1, A2, and A4) | 312 | | | 17.4 Inte | errupts | 316 | | | 17.5 No | tes on Timer A | 317 | | | 17.5.1 | Common Notes on Multiple Modes | 317 | | | 17.5.2 | Timer A (Timer Mode) | | | | 17.5.3 | Timer A (Event Counter Mode) | 318 | | | 17.5.4 | Timer A (One-Shot Timer Mode) | | | | 17.5.5 | Timer A (Pulse Width Modulation Mode) | 319 | | | 17.5.6 | Timer A (Programmable Output Mode) | 320 | |-----|---------|------------------------------------------------------------------------------------------|-----| | 18. | Timer | В | 321 | | | 18.1 Ir | ntroduction | 321 | | | 18.2 R | egisters | 324 | | | 18.2.1 | Peripheral Clock Select Register (PCLKR) | 325 | | | 18.2.2 | Clock Prescaler Reset Flag (CPSRF) | 325 | | | 18.2.3 | Peripheral Clock Stop Register 1 (PCLKSTP1) | 326 | | | 18.2.4 | Timer Bi Register (TBi) (i = 0 to 5) | 327 | | | 18.2.5 | Timer Bi-1 Register (TBi1) (i = 0 to 5) | 328 | | | 18.2.6 | Pulse Period/Pulse Width Measurement Mode Function Select Register i (PPWFSi) (i = 1, 2) | 329 | | | 18.2.7 | Timer B Count Source Select Register i (TBCSi) (i = 0 to 3) | 330 | | | 18.2.8 | Timer AB Division Control Register 0 (TCKDIVC0) | 331 | | | 18.2.9 | Count Start Flag (TABSR) Timer B3/B4/B5 Count Start Flag (TBSR) | 332 | | | 18.2.10 | Timer Bi Mode Register (TBiMR) (i = 0 to 5) | 333 | | | 18.3 C | perations | 334 | | | 18.3.1 | Common Operations | 334 | | | 18.3.2 | Timer Mode | 336 | | | 18.3.3 | Event Counter Mode | 338 | | | 18.3.4 | Pulse Period/Pulse Width Measurement Modes | 341 | | | 18.4 Ir | nterrupts | 346 | | | 18.5 N | otes on Timer B | 347 | | | 18.5.1 | Common Notes on Multiple Modes | 347 | | | 18.5.2 | Timer B (Timer Mode) | 347 | | | 18.5.3 | Timer B (Event Counter Mode) | 347 | | | 18.5.4 | Timer B (Pulse Period/Pulse Width Measurement Modes) | 348 | | 19. | Three- | Phase Motor Control Timer Function | 349 | | | 19.1 Ir | stroduction | 349 | | | 19.2 R | egisters | 353 | | | 19.2.1 | Timer B2 Register (TB2) | 354 | | | 19.2.2 | Timer Ai, Ai-1 Register (TAi, TAi1) (i = 1, 2, 4) | 354 | | | 19.2.3 | Three-Phase PWM Control Register 0 (INVC0) | 355 | | | 19.2.4 | Three-Phase PWM Control Register 1 (INVC1) | 357 | | | 19.2.5 | Three-Phase Output Buffer Register i (IDBi) (i = 0, 1) | 359 | | | 19.2.6 | Dead Time Timer (DTT) | 359 | | | 19.2.7 | Timer B2 Interrupt Generation Frequency Set Counter (ICTB2) | 360 | | | 19.2.8 | Timer B2 Special Mode Register (TB2SC) | 361 | | | 19.2.9 | Position-Data-Retain Function Control Register (PDRF) | 362 | | | 19 2 10 | Port Function Control Register (PECR) | 363 | | 19.2 | 2.11 Th | hree-Phase Protect Control Register (TPRC) | 363 | |----------|----------|-------------------------------------------------------|-------------| | 19.3 | Operat | ions | 364 | | 19.3 | 3.1 C | ommon Operations in Multiple Modes | 364 | | 19.3 | 3.2 Tr | riangular Wave Modulation Three-Phase Mode 0 | 370 | | 19.3 | 3.3 Tr | riangular Wave Modulation Three-Phase Mode 1 | 375 | | 19.3 | 3.4 Sa | awtooth Wave Modulation Mode | 382 | | 19.4 | Interrup | pts | 387 | | 19.4 | 1.1 Ti | mer B2 Interrupt | 387 | | 19.4 | 1.2 Ti | mer A1, A2, and A4 Interrupts | 387 | | 19.5 | Notes of | on Three-Phase Motor Control Timer Function | 388 | | 19.5 | 5.1 Ti | mer A and Timer B | 388 | | 19.5 | 5.2 In | fluence of SD | 388 | | 20. Rea | ıl-Time | Clock | 389 | | 20.1 | Introdu | ction | 389 | | 20.2 | Registe | ers | 391 | | 20.2 | 2.1 R | eal-Time Clock Second Data Register (RTCSEC) | 392 | | 20.2 | 2.2 R | eal-Time Clock Minute Data Register (RTCMIN) | 393 | | 20.2 | 2.3 R | eal-Time Clock Hour Data Register (RTCHR) | 394 | | 20.2 | 2.4 R | eal-Time Clock Day Data Register (RTCWK) | 395 | | 20.2 | 2.5 R | eal-Time Clock Control Register 1 (RTCCR1) | 396 | | 20.2 | 2.6 R | eal-Time Clock Control Register 2 (RTCCR2) | 398 | | 20.2 | 2.7 R | eal-Time Clock Count Source Select Register (RTCCSR) | 400 | | 20.2 | 2.8 R | eal-Time Clock Second Compare Data Register (RTCCSEC) | 401 | | 20.2 | 2.9 R | eal-Time Clock Minute Compare Data Register (RTCCMIN) | 402 | | 20.2 | 2.10 R | eal-Time Clock Hour Compare Data Register (RTCCHR) | 403 | | 20.3 | Operat | ions | 404 | | 20.3 | 3.1 Ba | asic Operation | 404 | | 20.3 | 3.2 C | ompare Mode | 407 | | 20.4 | Interrup | pts | 413 | | 20.5 | Notes of | on Real-Time Clock | 414 | | 20.5 | 5.1 St | tarting and Stopping the Count | 414 | | 20.5 | 5.2 R | egister Settings (Time Data, etc.) | 414 | | 20.5 | 5.3 R | egister Settings (Compare Data) | 414 | | 20.5 | 5.4 Ti | me Reading Procedure in Real-Time Clock Mode | 415 | | 21. Puls | se Width | h Modulator | 416 | | 21.1 | Introdu | ction | 416 | | 21.2 | Registe | ers | 417 | | 21.2 | 2.1 P\ | WM Control Register 0 (PWMCON0) | 418 | | 21.2 | 2.2 P\ | WMi Prescaler (PWMPREi) (i = 0, 1) | 419 | | 21.2 | ) 3 DI | WMi Register (PWMREGi) (i = 0, 1) | <b>⊿</b> 10 | | | 21.2 | .4 | PWM Control Register 1 (PWMCON1) | 420 | |-----|--------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | | 21.3 | Оре | erations | 421 | | | 21.3 | .1 | Setting Procedure | 421 | | | 21.3 | .2 | Operation Example | 421 | | 22. | Rem | note | Control Signal Receiver | 423 | | | 22.1 | Intro | oduction | 423 | | | 22.2 | Reg | gisters | 426 | | | 22.2 | .1 | PMCi Function Select Register 0 (PMCiCON0) (i = 0, 1) | 428 | | | 22.2 | .2 | PMCi Function Select Register 1 (PMCiCON1) (i = 0, 1) | 430 | | | 22.2 | .3 | PMCi Function Select Register 2 (PMCiCON2) (i = 0, 1) | 432 | | | 22.2 | .4 | PMCi Function Select Register 3 (PMCiCON3) (i = 0, 1) | 434 | | | 22.2 | .5 | PMCi Status Register (PMCiSTS) (i = 0, 1) | 435 | | | 22.2 | .6 | PMCi Interrupt Source Register (PMCiINT) (i = 0, 1) | 438 | | | 22.2 | .7 | PMCi Header Pattern Set Register (MIN) (PMCiHDPMIN) (i = 0, 1) PMCi Header Pattern Set Register (MAX) (PMCiHDPMAX) (i = 0, 1) | 439 | | | 22.2 | .8 | PMCi Data 0 Pattern Set Register (MIN) (PMCiD0PMIN) (i = 0, 1) PMCi Data 0 Pattern Set Register (MAX) (PMCiD0PMAX) (i = 0, 1) PMCi Data 1 Pattern Set Register (MIN) (PMCiD1PMIN) (i = 0, 1) PMCi Data 1 Pattern Set Register (MAX) (PMCiD1PMIN) (i = 0, 1) | 444 | | | 22.2 | 0 | PMCi Data 1 Pattern Set Register (MAX) (PMCiD1PMAX) (i = 0, 1) | | | | 22.2<br>22.2 | | PMCi Measurements Register (PMCiTIM) (i = 0, 1) | | | | | | PMC0 Receive Bit Count Register (PMC0RBIT) | | | | 22.2 | | PMC0 Receive Data Store Register i (PMC0DATi) (i = 0 to 5) | | | | 22.2 | | PMC0 Compare Control Register (PMC0CPC) | | | | 22.2 | | · · · · · · · · · · · · · · · · · · · | | | | 22.3 | • | erations | | | | 22.3 | | Common Operations in Multiple Modes | | | | 22.3 | | Pattern Match Mode (PMC0 and PMC1 Operate Independently) | | | | 22.3 | | Pattern Match Mode (Combined Operation of PMC0 and PMC1) | | | | 22.3 | | Input Capture Mode (Operating PMC0 and PMC1 Independently) | | | | 22.3 | | Input Capture Mode (Simultaneous Count Operation of PMC0 and PMC1) | | | | 22.4 | | rrupts | | | | 22.5 | | es on Remote Control Signal Receiver | | | | 22.5 | | Starting/Stopping PMCi | | | | 22.5 | | Reading the Register | | | | 22.5 | | Rewriting the Register | | | | 22.5 | .4 | Combined Operation | 470 | | 23. | | | terface UARTi (i = 0 to 2, 5 to 7) | | | | 23.1 | | oduction | | | | 23.2 | Reg | gisters | | | | 23.2 | .1 | UART Clock Select Register (UCLKSEL0) | | | | 23.2 | .2 | Peripheral Clock Select Register (PCLKR) | 478 | | 23.2.3 | UARTi Transmit/Receive Mode Register (UiMR) (i = 0 to 2, 5 to 7) | 479 | |---------------|-----------------------------------------------------------------------|-----| | 23.2.4 | UARTi Bit Rate Register (UiBRG) (i = 0 to 2, 5 to 7) | 480 | | 23.2.5 | UARTi Transmit Buffer Register (UiTB) (i = 0 to 2, 5 to 7) | 480 | | 23.2.6 | UARTi Transmit/Receive Control Register 0 (UiC0) (i = 0 to 2, 5 to 7) | 481 | | 23.2.7 | UARTi Transmit/Receive Control Register 1 (UiC1) (i = 0 to 2, 5 to 7) | 483 | | 23.2.8 | UARTi Receive Buffer Register (UiRB) (i = 0 to 2, 5 to 7) | 484 | | 23.2.9 | UART Transmit/Receive Control Register 2 (UCON) | 486 | | 23.2.10 | UARTi Special Mode Register 4 (UiSMR4) (i = 0 to 2, 5 to 7) | 487 | | 23.2.11 | UARTi Special Mode Register 3 (UiSMR3) (i = 0 to 2, 5 to 7) | 489 | | 23.2.12 | UARTi Special Mode Register 2 (UiSMR2) (i = 0 to 2, 5 to 7) | 490 | | 23.2.13 | UARTi Special Mode Register (UiSMR) (i = 0 to 2, 5 to 7) | 491 | | 23.3 Op | perations | 492 | | 23.3.1 | Clock Synchronous Serial I/O Mode | 492 | | 23.3.2 | Clock Asynchronous Serial I/O (UART) Mode | 500 | | 23.3.3 | Special Mode 1 (I <sup>2</sup> C Mode) | 509 | | 23.3.4 | Special Mode 2 | 524 | | 23.3.5 | Special Mode 3 (IE Mode) | 528 | | 23.3.6 | Special Mode 4 (SIM Mode) (UART2) | 530 | | 23.4 Int | errupts | 535 | | 23.4.1 | Interrupt Related Registers | 535 | | 23.4.2 | Reception Interrupt | 536 | | 23.5 No | stes on Serial Interface UARTi (i = 0 to 2, 5 to 7) | 537 | | 23.5.1 | Common Notes on Multiple Modes | 537 | | 23.5.2 | Clock Synchronous Serial I/O Mode | 537 | | 23.5.3 | Special Mode 1 (I <sup>2</sup> C Mode) | 538 | | 23.5.4 | Special Mode 4 (SIM Mode) | 540 | | 24. Serial Ir | nterface SI/O3 and SI/O4 | 541 | | 24.1 Int | roduction | 541 | | 24.2 Re | gisters | 543 | | 24.2.1 | Peripheral Clock Select Register (PCLKR) | 544 | | 24.2.2 | SI/Oi Transmit/Receive Register (SiTRR) (i = 3, 4) | 544 | | 24.2.3 | SI/Oi Control Register (SiC) (i = 3, 4) | 545 | | 24.2.4 | SI/Oi Bit Rate Register (SiBRG) (i = 3, 4) | 546 | | 24.2.5 | SI/O3, 4 Control Register 2 (S34C2) | 546 | | 24.3 Op | perations | 547 | | 24.3.1 | Basic Operations | 547 | | 24.3.2 | CLK Polarity Selection | | | 24.3.3 | LSB First or MSB First Selection | | | 24.3.4 | Internal Clock | 549 | | 24.3.5 | Function for Selecting SOUTi State after Transmission | 550 | | 2 | 24.3.6 | External Clock | 551 | |-------|-----------|----------------------------------------------------------------|-----| | 2 | 24.3.7 | SOUTi Pin | 551 | | 2 | 24.3.8 | Function for Setting SOUTi Initial Value | 552 | | 24.4 | 1 Inte | rrupt | 553 | | 24.5 | 5 Not | es on Serial Interface SI/O3 and SI/O4 | 554 | | 2 | 24.5.1 | SOUTi Pin Level When SOUTi Output Is Disabled | 554 | | 2 | 24.5.2 | External Clock Control | 554 | | 2 | 24.5.3 | Register Access | 554 | | 2 | 24.5.4 | Register Access When Using the External Clock | 554 | | 2 | 24.5.5 | SiTRR Register Access | 554 | | 2 | 24.5.6 | Pin Function Switch When Using the Internal Clock | 554 | | 2 | 24.5.7 | Operation after Reset When Selecting the External Clock | 554 | | 25. N | /lulti-ma | ister I <sup>2</sup> C-bus Interface | 555 | | 25.1 | | oduction | | | 25.2 | | gisters Descriptions | | | 2 | 25.2.1 | Peripheral Clock Select Register (PCLKR) | 559 | | 2 | 25.2.2 | I2C0 Data Shift Register (S00) | | | 2 | 25.2.3 | I2C0 Address Register i (S0Di) (i = 0 to 2) | 561 | | 2 | 25.2.4 | I2C0 Control Register 0 (S1D0) | 562 | | 2 | 25.2.5 | I2C0 Clock Control Register (S20) | 564 | | 2 | 25.2.6 | I2C0 Start/Stop Condition Control Register (S2D0) | 566 | | 2 | 25.2.7 | I2C0 Control Register 1 (S3D0) | 567 | | 2 | 25.2.8 | I2C0 Control Register 2 (S4D0) | 571 | | 2 | 25.2.9 | I2C0 Status Register 0 (S10) | 573 | | 2 | 25.2.10 | I2C0 Status Register 1 (S11) | 578 | | 25.3 | 3 Оре | erations | 579 | | 2 | 25.3.1 | Clock | 579 | | 2 | 25.3.2 | Generating a Start Condition | 582 | | 2 | 25.3.3 | Generating a Stop Condition | 584 | | 2 | 25.3.4 | Generating a Restart Condition | 585 | | 2 | 25.3.5 | Start Condition Overlap Protect | 586 | | 2 | 25.3.6 | Arbitration Lost | 588 | | 2 | 25.3.7 | Detecting Start/Stop Conditions | 590 | | 2 | 25.3.8 | Operation after Transmitting/Receiving a Slave Address or Data | 592 | | 2 | 25.3.9 | Timeout Detection | 593 | | 2 | 25.3.10 | Data Transmit/Receive Examples | 594 | | 25.4 | | rrupts | | | 25.5 | 5 Not | es on Multi-master I <sup>2</sup> C-bus Interface | 602 | | 2 | 25.5.1 | Limitation on CPU Clock | 602 | | 2 | 25.5.2 | Register Access | 602 | | | 25.5.3 | Low/High-level Input Voltage and Low-level Output Voltage | 602 | |-----|----------|--------------------------------------------------------------------------------------------------------------|-----| | 26. | Consur | mer Electronics Control (CEC) Function | 603 | | | 26.1 Int | troduction | 603 | | | 26.2 Re | egisters | 606 | | | 26.2.1 | CEC Function Control Register 1 (CECC1) | 606 | | | 26.2.2 | CEC Function Control Register 2 (CECC2) | 607 | | | 26.2.3 | CEC Function Control Register 3 (CECC3) | 609 | | | 26.2.4 | CEC Function Control Register 4 (CECC4) | 611 | | | 26.2.5 | CEC Flag Register (CECFLG) | 613 | | | 26.2.6 | CEC Interrupt Source Select Register (CISEL) | 614 | | | 26.2.7 | CEC Transmit Buffer Register 1 (CCTB1) | 615 | | | 26.2.8 | CEC Transmit Buffer Register 2 (CCTB2) | 615 | | | 26.2.9 | CEC Receive Buffer Register 1 (CCRB1) | 616 | | | 26.2.10 | CEC Receive Buffer Register 2 (CCRB2) | 616 | | | 26.2.11 | CEC Receive Follower Address Set Register 1 (CRADRI1), CEC Receive Follower Address Set Register 2 (CRADRI2) | 617 | | | 26.2.12 | Port Control Register (PCR) | 618 | | | 26.3 Op | perations | 619 | | | 26.3.1 | Standard Value and I/O Timing | 619 | | | 26.3.2 | Count Source | 619 | | | 26.3.3 | CEC Input/Output | 619 | | | 26.3.4 | Digital Filter | 620 | | | 26.3.5 | Reception | 621 | | | 26.3.6 | Transmission | 629 | | | 26.4 Int | terrupts | 634 | | | 26.5 No | otes on CEC | 636 | | | 26.5.1 | Registers and Bit Operation | 636 | | | 26.5.2 | VIH of the CEC pin | 636 | | 27. | A/D Co | nverter | 637 | | | 27.1 Int | troduction | 637 | | | 27.2 Re | egisters | 639 | | | 27.2.1 | Port Control Register (PCR) | 640 | | | 27.2.2 | Open-Circuit Detection Assist Function Register (AINRST) | 641 | | | 27.2.3 | A/D Register i (ADi) (i = 0 to 7) | 642 | | | 27.2.4 | A/D Control Register 2 (ADCON2) | 643 | | | 27.2.5 | A/D Control Register 0 (ADCON0) | 644 | | | 27.2.6 | A/D Control Register 1 (ADCON1) | 646 | | | 27.3 Op | perations | 647 | | | 27.3.1 | A/D Conversion Cycle | 647 | | | 27 2 2 | A/D Conversion Start Conditions | 640 | | | 27.3.3 | A/D Conversion Result | 650 | |-----|---------|--------------------------------------------|-----| | | 27.3.4 | Extended Analog Input Pins | 650 | | | 27.3.5 | Current Consumption Reduce Function | 650 | | | 27.3.6 | Open-Circuit Detection Assist Function | 650 | | 27. | .4 Op | erational Modes | 653 | | | 27.4.1 | One-Shot Mode | 653 | | | 27.4.2 | Repeat Mode | 655 | | | 27.4.3 | Single Sweep Mode | 657 | | | 27.4.4 | Repeat Sweep Mode 0 | 659 | | | 27.4.5 | Repeat Sweep Mode 1 | 661 | | 27. | .5 Ex | ernal Sensor | 664 | | 27. | .6 Int | errupt | 665 | | 27. | .7 No | tes on A/D Converter | 666 | | | 27.7.1 | Analog Input Voltage | 666 | | | 27.7.2 | Analog Input Pin | 666 | | | 27.7.3 | Pin Configuration | 666 | | | 27.7.4 | Register Access | 666 | | | 27.7.5 | A/D Conversion Start | 666 | | | 27.7.6 | A/D Operation Mode Change | 667 | | | 27.7.7 | State When Forcibly Terminated | 667 | | | 27.7.8 | A/D Open-Circuit Detection Assist Function | 667 | | | 27.7.9 | Detecting Completion of A/D Conversion | 667 | | | 27.7.10 | φAD | 667 | | 28. | D/A Coi | nverter | 668 | | 28. | .1 Int | oduction | 668 | | 28. | .2 Re | gisters | 669 | | | 28.2.1 | D/Ai Register (DAi) (i = 0, 1) | 669 | | | 28.2.2 | D/A Control Register (DACON) | 669 | | 28. | .3 Op | erations | 670 | | 28. | .4 No | tes on D/A Converter | 671 | | | 28.4.1 | When Not Using the D/A Converter | 671 | | 29. | CRC Ca | alculator | 672 | | 29. | .1 Int | oduction | 672 | | 29. | .2 Re | gisters | 673 | | | 29.2.1 | SFR Snoop Address Register (CRCSAR) | 673 | | | 29.2.2 | CRC Mode Register (CRCMR) | | | | 29.2.3 | CRC Data Register (CRCD) | 674 | | | 29.2.4 | CRC Input Register (CRCIN) | | | 29. | .3 Op | erations | | | | 20.3.1 | Rasic Operation | 675 | | | 29.3. | 2 | CRC Snoop | 675 | |-----|-------|-------|------------------------------------------------|-----| | 30. | Flash | n Me | emory | 677 | | 3 | 0.1 | Intro | duction | 677 | | 3 | 0.2 | Men | nory Map | 679 | | 3 | 0.3 | Reg | isters | 681 | | | 30.3. | 1 | Flash Memory Control Register 0 (FMR0) | 681 | | | 30.3. | 2 | Flash Memory Control Register 1 (FMR1) | 684 | | | 30.3. | 3 | Flash Memory Control Register 2 (FMR2) | 685 | | | 30.3. | 4 | Flash Memory Control Register 3 (FMR3) | 686 | | | 30.3. | 5 | Flash Memory Control Register 6 (FMR6) | 687 | | 3 | 0.4 | Opti | onal Function Select Area | 688 | | | 30.4. | 1 | Optional Function Select Address 1 (OFS1) | 689 | | 3 | 0.5 | Flas | h Memory Rewrite Disable Function | 690 | | 3 | 0.6 | Boot | t Mode | 690 | | 3 | 0.7 | Use | r Boot Mode | 690 | | | 30.7. | 1 | User Boot Function | 690 | | 3 | 8.0 | CPL | J Rewrite Mode | 694 | | | 30.8. | 1 | EW0 Mode | 695 | | | 30.8. | 2 | EW1 Mode | 701 | | | 30.8. | 3 | Operating Speed | 707 | | | 30.8. | 4 | Data Protect Function | 707 | | | 30.8. | 5 | Suspend Function | 708 | | | 30.8. | 6 | Software Commands | 710 | | | 30.8. | 7 | Status Register | 717 | | 3 | 0.9 | Stan | dard Serial I/O Mode | 720 | | | 30.9. | 1 | ID Code Check Function | 721 | | | 30.9. | 2 | Forced Erase Function | 722 | | | 30.9. | 3 | Standard Serial I/O Mode Disable Function | 722 | | | 30.9. | 4 | Standard Serial I/O Mode 1 | 723 | | | 30.9. | 5 | Standard Serial I/O Mode 2 | 725 | | 3 | 0.10 | Para | allel I/O Mode | 726 | | | 30.10 | ).1 | ROM Code Protect Function | 726 | | 3 | 0.11 | Note | es on Flash Memory | 727 | | | 30.11 | .1 | OFS1 Address and ID Code Storage Address | 727 | | | 30.11 | .2 | Reading Data Flash | 727 | | | 30.11 | .3 | CPU Rewrite Mode | 728 | | | 30.11 | .4 | User Boot | 730 | | 31. | Elect | rical | Characteristics | 731 | | 3 | 1.1 | | trical Characteristics (Common to 3 V and 5 V) | | | | 31.1. | | Absolute Maximum Rating | | | | | | <del>-</del> | | | | 31.1.2 | Recommended Operating Conditions | 732 | |----|----------|---------------------------------------------------------------------------|-----| | | 31.1.3 | A/D Conversion Characteristics | 735 | | | 31.1.4 | D/A Conversion Characteristics | 736 | | | 31.1.5 | Flash Memory Electrical Characteristics | 737 | | | 31.1.6 | Voltage Detector and Power Supply Circuit Electrical Characteristics | 739 | | | 31.1.7 | Oscillator Electrical Characteristics | 742 | | | 31.2 Ele | ctrical Characteristics (V <sub>CC1</sub> = V <sub>CC2</sub> = 5 V) | 743 | | | 31.2.1 | Electrical Characteristics | 743 | | | 31.2.2 | Timing Requirements (Peripheral Functions and Others) | 747 | | | 31.2.3 | Timing Requirements (Memory Expansion Mode and Microprocessor Mode) | 753 | | | 31.2.4 | Switching Characteristics (Memory Expansion Mode and Microprocessor Mode) | 755 | | | 31.3 Ele | ctrical Characteristics (V <sub>CC1</sub> = V <sub>CC2</sub> = 3 V) | 766 | | | 31.3.1 | Electrical Characteristics | 766 | | | 31.3.2 | Timing Requirements (Peripheral Functions and Others) | 770 | | | 31.3.3 | Timing Requirements (Memory Expansion Mode and Microprocessor Mode) | 776 | | | 31.3.4 | Switching Characteristics (Memory Expansion Mode and Microprocessor Mode) | 778 | | 32 | Usage N | lotes | 789 | | | • | es on Noise | | | | | es on SFRs | | | | 32.2.1 | Register Settings | | | | | es on Protection | | | | | es on Resets | | | | 32.4.1 | Power Supply Rising Gradient | | | | 32.4.2 | Power-On Reset | | | | 32.4.3 | OSDR Bit (Oscillation Stop Detect Reset Detect Flag) | 794 | | | 32.5 Not | es on Clock Generator | | | | 32.5.1 | Oscillator Using a Crystal or a Ceramic Resonator | 795 | | | 32.5.2 | Noise Countermeasure | 796 | | | 32.5.3 | CPU Clock | 797 | | | 32.5.4 | Oscillator Stop/Restart Detect Function | 797 | | | 32.5.5 | PLL Frequency Synthesizer | 798 | | | 32.6 Not | es on Power Control | 799 | | | 32.6.1 | CPU Clock | 799 | | | 32.6.2 | Wait Mode | 799 | | | 32.6.3 | Stop Mode | 799 | | | 32.6.4 | Low Current Consumption Read Mode | 800 | | | 32.6.5 | Slow Read Mode | 800 | | | 32.7 No | tes on Bus | 801 | | | 32.7.1 | Reading Data Flash | 801 | | | 32.7.2 | External Bus | 801 | | 32.7 | 7.3 | External Access Immediately after Writing to the SFRs | 801 | |-------|------|-----------------------------------------------------------|-----| | 32.7 | 7.4 | Wait and RDY | 801 | | 32.7 | 7.5 | HOLD | 801 | | 32.8 | Note | es on Programmable I/O Ports | 802 | | 32.8 | 3.1 | Influence of SD | 802 | | 32.8 | 3.2 | Influence of SI/O3 and SI/O4 | 802 | | 32.8 | 3.3 | 100-Pin Package | 802 | | 32.9 | Note | es on Interrupts | 803 | | 32.9 | 9.1 | Reading Address 00000h | 803 | | 32.9 | 9.2 | SP Setting | 803 | | 32.9 | 9.3 | NMI Interrupt | 803 | | 32.9 | 9.4 | Changing an Interrupt Source | 804 | | 32.9 | 9.5 | Rewriting the Interrupt Control Register | 805 | | 32.9 | 9.6 | Instruction to Rewrite the Interrupt Control Register | 805 | | 32.9 | 9.7 | INT Interrupt | 806 | | 32.10 | Note | es on the Watchdog Timer | 807 | | 32.11 | Note | es on DMAC | 808 | | 32.1 | 1.1 | Write to the DMAE Bit in the DMiCON Register (i = 0 to 3) | 808 | | 32.1 | 1.2 | Changing the DMA Request Source | 808 | | 32.12 | Note | es on Timer A | 809 | | 32.1 | 2.1 | Common Notes on Multiple Modes | 809 | | 32.1 | 2.2 | Timer A (Timer Mode) | 810 | | 32.1 | 2.3 | Timer A (Event Counter Mode) | 810 | | 32.1 | 2.4 | Timer A (One-Shot Timer Mode) | 810 | | 32.1 | 2.5 | Timer A (Pulse Width Modulation Mode) | 811 | | 32.1 | 2.6 | Timer A (Programmable Output Mode) | 812 | | 32.13 | Note | es on Timer B | 813 | | 32.1 | 3.1 | Common Notes on Multiple Modes | 813 | | 32.1 | 3.2 | Timer B (Timer Mode) | 813 | | 32.1 | 3.3 | Timer B (Event Counter Mode) | 813 | | 32.1 | 3.4 | Timer B (Pulse Period/Pulse Width Measurement Modes) | 814 | | 32.14 | Note | es on Three-Phase Motor Control Timer Function | 815 | | 32.1 | 14.1 | Timer A and Timer B | 815 | | 32.1 | 14.2 | Influence of SD | 815 | | 32.15 | Note | es on Real-Time Clock | 816 | | 32.1 | 5.1 | Starting and Stopping the Count | 816 | | 32.1 | 5.2 | Register Settings (Time Data, etc.) | 816 | | 32.1 | 5.3 | Register Settings (Compare Data) | 816 | | 32.1 | 15.4 | Time Reading Procedure in Real-Time Clock Mode | 817 | | 32.16 | Note | es on Remote Control Signal Receiver | 818 | | 32.1 | 6.1 | Starting/Stopping PMCi | 818 | | | 32.16 | .2 | Reading the Register | 818 | |-----|-------|------|-----------------------------------------------------------|-----| | | 32.16 | .3 | Rewriting the Register | 818 | | | 32.16 | .4 | Combined Operation | 819 | | 32. | 17 | Note | s on Serial Interface UARTi (i = 0 to 2, 5 to 7) | 820 | | | 32.17 | .1 | Common Notes on Multiple Modes | 820 | | | 32.17 | .2 | Clock Synchronous Serial I/O Mode | 820 | | | 32.17 | .3 | Special Mode 1 (I <sup>2</sup> C Mode) | 821 | | | 32.17 | .4 | Special Mode 4 (SIM Mode) | 823 | | 32. | 18 | Note | es on SI/O3 and SI/O4 | 824 | | | 32.18 | .1 | SOUTi Pin Level When SOUTi Output Is Disabled | 824 | | | 32.18 | .2 | External Clock Control | 824 | | | 32.18 | .3 | Register Access | 824 | | | 32.18 | .4 | Register Access When Using the External Clock | 824 | | | 32.18 | .5 | SiTRR Register Access | 824 | | | 32.18 | .6 | Pin Function Switch When Using the Internal Clock | 824 | | | 32.18 | .7 | Operation after Reset When Selecting the External Clock | 824 | | 32. | 19 | Note | s on Multi-master I <sup>2</sup> C-bus Interface | 825 | | | 32.19 | .1 | Limitation on CPU Clock | 825 | | | 32.19 | .2 | Register Access | 825 | | | 32.19 | .3 | Low/High-level Input Voltage and Low-level Output Voltage | 825 | | 32. | 20 | Note | s on CEC | 826 | | | 32.20 | .1 | Registers and Bit Operation | 826 | | | 32.20 | .2 | VIH of the CEC pin | 826 | | 32. | 21 | Note | es on A/D Converter | 827 | | | 32.21 | .1 | Analog Input Voltage | 827 | | | 32.21 | .2 | Analog Input Pin | 827 | | | 32.21 | .3 | Pin Configuration | 827 | | | 32.21 | .4 | Register Access | 827 | | | 32.21 | .5 | A/D Conversion Start | 827 | | | 32.21 | .6 | A/D Operation Mode Change | 828 | | | 32.21 | .7 | State When Forcibly Terminated | 828 | | | 32.21 | .8 | A/D Open-Circuit Detection Assist Function | 828 | | | 32.21 | .9 | Detecting Completion of A/D Conversion | 828 | | | 32.21 | .10 | φAD | 828 | | 32. | 22 | Note | s on D/A Converter | 829 | | | 32.22 | .1 | When Not Using the D/A Converter | 829 | | 32. | 23 | Note | es on Flash Memory | 830 | | | 32.23 | | OFS1 Address and ID Code Storage Address | | | | 32.23 | | Reading Data Flash | | | | 32.23 | .3 | CPU Rewrite Mode | 831 | | | 32 23 | 4 | User Boot | 833 | | Appendix 1. Package Dimensions | 834 | |------------------------------------------------------|-----| | Appendix 2. Differences between M16C/65 and M16C/65C | 836 | | REGISTER INDEX | 837 | ## **Quick Reference** Only one page number is listed for each register. Refer to the REGISTER INDEX for more details. | Address | Register | Symbol | Page | |-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------| | 0000h | | -, | | | 0001h | | | | | 0002h | | | | | 0003h | | | | | 0004h | Processor Mode Register 0 | PM0 | 56 | | 0005h | Processor Mode Register 1 | PM1 | 146 | | 0006h | System Clock Control Register 0 | CM0 | 97 | | 0007h | System Clock Control Register 1 | CM1 | 99 | | 0008h | Chip Select Control Register | CSR | 152 | | 0009h | External Area Recovery Cycle Control<br>Register | EWR | 155 | | 000Ah | Protect Register | PRCR | 50 | | 000Bh | Data Bank Register | DBR | 173 | | 000Ch | Oscillation Stop Detection Register | CM2 | 101 | | 000Dh | | | | | 000Eh | | | | | 000Fh | | | | | 0010h | Program 2 Area Control Register | PRG2C | 148 | | 0011h | External Area Wait Control Expansion<br>Register | EWC | 154 | | 0012h | Peripheral Clock Select Register | PCLKR | 103 | | 0013h | , , , , , , , , , , , , , , , , , , , , | | | | 0014h | | | | | 0015h | Clock Prescaler Reset Flag | CPSRF | 275 | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 103 | | 0017h | , | | | | 0018h | Reset Source Determine Register | RSTFR | 57 | | 0019h | Voltage Detector 2 Flag Register | VCR1 | 73 | | 001Ah | Voltage Detector Operation Enable Register | VCR2 | 74 | | 001Bh | Chip Select Expansion Control Register | CSE | 153 | | 001Ch | PLL Control Register 0 | PLC0 | 105 | | 001Dh | , and the second | | | | 001Eh | Processor Mode Register 2 | PM2 | 106 | | 001Fh | <u> </u> | | | | 0020h | | | | | 0021h | | | | | 0022h | 40 MHz On-Chip Oscillator Control Register 0 | FRA0 | 107 | | 0023h | | | | | 0024h | | | | | 0025h | | | | | 0026h | Voltage Monitor Function Select Register | VWCE | 75 | | 0027h | | | | | 0028h | Voltage Detector 1 Level Select Register | VD1LS | 76 | | 0029h | | | | | 002Ah | Voltage Monitor 0 Control Register | VW0C | 77 | | 002Bh | Voltage Monitor 1 Control Register | VW1C | 78 | | 002Ch | Voltage Monitor 2 Control Register | VW2C | 80 | | 002Dh | - | | | | 002Eh | | | | | 002Fh | | | | | 0030h | | | | | to<br>003Fh | | | | | 003Fn<br>0040h | | | | | 0040H | | | | | 0041h | INT7 Interrupt Control Register | INT7IC | 215 | | 0042H | INT6 Interrupt Control Register | INT/IC | 215 | | 0043H | INT3 Interrupt Control Register | INT3IC | 215 | | | · | | | | 50-1011 | , , | | 210 | | 0046h | UART1 Bus Collision Detection Interrupt<br>Control Register | TB4IC<br>U1BCNIC | 214 | | 0047h | Timer B3 Interrupt Control Register UART0 Bus Collision Detection Interrupt Control Register | TB3IC<br>U0BCNIC | 214 | | 0048h | SI/O4 Interrupt Control Register | S4IC<br>INT5IC | 215 | | 0045h<br>0046h<br>0047h | Timer B5 Interrupt Control Register Timer B4 Interrupt Control Register UART1 Bus Collision Detection Interrupt Control Register Timer B3 Interrupt Control Register UART0 Bus Collision Detection Interrupt Control Register | TB5IC TB4IC U1BCNIC TB3IC U0BCNIC | 215<br>214<br>214 | | Address | Register | Symbol | Page | |---------|--------------------------------------------------------------------------------------------------------------------------------|--------------------|------| | 0049h | SI/O3 Interrupt Control Register INT4 Interrupt Control Register | S3IC<br>INT4IC | 215 | | 004Ah | UART2 Bus Collision Detection Interrupt<br>Control Register | BCNIC | 214 | | 004Bh | DMA0 Interrupt Control Register | DM0IC | 214 | | 004Ch | DMA1 Interrupt Control Register | DM1IC | 214 | | 004Dh | Key Input Interrupt Control Register | KUPIC | 214 | | 004Eh | A/D Conversion Interrupt Control Register | ADIC | 215 | | 004Fh | UART2 Transmit Interrupt Control Register | S2TIC | 214 | | 0050h | UART2 Receive Interrupt Control Register | S2RIC | 214 | | 0051h | UART0 Transmit Interrupt Control Register | SOTIC | 214 | | 0052h | UART0 Receive Interrupt Control Register | SORIC | 214 | | 0053h | UART1 Transmit Interrupt Control Register | S1TIC | 214 | | 0054h | UART1 Receive Interrupt Control Register | S1RIC | 214 | | 0055h | Timer A0 Interrupt Control Register | TA0IC | 214 | | 0056h | Timer A1 Interrupt Control Register | TA1IC | 214 | | 0057h | Timer A2 Interrupt Control Register | TA2IC | 214 | | 0058h | Timer A3 Interrupt Control Register | TA3IC | 214 | | 0059h | Timer A4 Interrupt Control Register | TA4IC | 214 | | 005Ah | Timer B0 Interrupt Control Register | TB0IC | 214 | | 005Bh | Timer B1 Interrupt Control Register | TB1IC | 214 | | 005Ch | Timer B2 Interrupt Control Register | TB2IC | 214 | | 005Dh | INTO Interrupt Control Register | INTOIC | 215 | | 005Eh | INT1 Interrupt Control Register | INT1IC | 215 | | 005Fh | INT2 Interrupt Control Register | INT2IC | 215 | | 0060h | | | | | to | | | | | 0068h | DMA2 Intervent Control Decistor | DM2IC | 214 | | 0069h | DMA2 Interrupt Control Register | | 214 | | 006Ah | DMA3 Interrupt Control Register UART5 Bus Collision Detection Interrupt | DM3IC | 214 | | 006Bh | Control Register, CEC1 Interrupt Control Register | U5BCNIC,<br>CEC1IC | 214 | | 006Ch | UART5 Transmit Interrupt Control Register,<br>CEC2 Interrupt Control Register | S5TIC,<br>CEC2IC | 214 | | 006Dh | UART5 Receive Interrupt Control Register | S5RIC | 214 | | 006Eh | UART6 Bus Collision Detection Interrupt<br>Control Register,<br>Real-Time Clock Periodic Interrupt Control<br>Register | U6BCNIC<br>RTCTIC | 214 | | 006Fh | UART6 Transmit Interrupt Control Register,<br>Real-Time Clock Compare Interrupt Control<br>Register | S6TIC,<br>RTCCIC | 214 | | 0070h | UART6 Receive Interrupt Control Register | S6RIC | 214 | | 0071h | UART7 Bus Collision Detection Interrupt<br>Control Register,<br>Remote Control Signal Receiver 0 Interrupt<br>Control Register | U7BCNIC,<br>PMC0IC | 214 | | 0072h | UART7 Transmit Interrupt Control Register,<br>Remote Control Signal Receiver 1 Interrupt<br>Control Register | S7TIC,<br>PMC1IC | 214 | | 0073h | UART7 Receive Interrupt Control Register | S7RIC | 214 | | 0074h | | | | | 0075h | | | | | 0076h | | | | | 0077h | | | | | 0078h | | | | | 0079h | | | | | 007Ah | | | | | 007Bh | I2C-bus Interface Interrupt Control Register | IICIC | 214 | | 007Ch | SCL/SDA Interrupt Control Register | SCLDAIC | 214 | | 007Dh | | | | | 007Eh | | | | | 007Fh | | | | | | Do winter | 0 | D | |----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------|--------------------------| | Address<br>0080h | Register | Symbol | Page | | to | | | | | 017Fh | | | | | 0180h | | | | | 0181h | DMA0 Source Pointer | SAR0 | 256 | | 0182h | | | | | 0183h | | | | | 0184h | | | | | 0185h | DMA0 Destination Pointer | DAR0 | 256 | | 0186h | | | | | 0187h | | | | | 0188h | DMA0 Transfer Counter | TCR0 | 257 | | 0189h | | | | | 018Ah | | | | | 018Bh | D | Dittocoli | 050 | | 018Ch | DMA0 Control Register | DM0CON | 258 | | 018Dh | | | | | 018Eh | | | | | 018Fh | | | | | 0190h | DMA4 O D : : | 645: | 050 | | 0191h | DMA1 Source Pointer | SAR1 | 256 | | 0192h<br>0193h | | | | | | | | | | 0194h | DMA1 Destination Pointer | DAR1 | 250 | | 0195h | DMA I Destination Pointer | DAKI | 256 | | 0196h | | | | | 0197h | | | 257 | | 0198h<br>0199h | DMA1 Transfer Counter | TCR1 | 257 | | | | | | | 019Ah | | | | | 019Bh | DMA1 Control Register | DM4CON | 250 | | 019Ch | DMA1 Control Register | DM1CON | 258 | | 019Dh | | | | | 019Eh | | | | | 019Fh | | | | | 01A0h<br>01A1h | DMA2 Source Pointer | SAR2 | 256 | | | DMA2 Source Pointer | SARZ | 200 | | 01A2h | | | | | 01A3h | | | | | 01A4h<br>01A5h | DMA2 Destination Pointer | DARS | 256 | | 01A5h | DMA2 Destination Pointer | DAR2 | ∠30 | | UTAGIT | | | | | | | | | | 01A7h | | | | | 01A7h<br>01A8h | DMA2 Transfer Counter | TCR2 | 257 | | 01A7h<br>01A8h<br>01A9h | DMA2 Transfer Counter | TCR2 | 257 | | 01A7h<br>01A8h<br>01A9h<br>01AAh | DMA2 Transfer Counter | TCR2 | 257 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh | | | | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh | DMA2 Transfer Counter DMA2 Control Register | TCR2 DM2CON | 257 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ADh | | | | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ADh | | | | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ADh<br>01AEh<br>01AFh | | | | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ADh<br>01AEh<br>01AFh<br>01B0h | DMA2 Control Register | DM2CON | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ADh<br>01AEh<br>01AFh<br>01B0h | | | | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AEh<br>01AFh<br>01B0h<br>01B1h | DMA2 Control Register | DM2CON | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AEh<br>01AFh<br>01B0h<br>01B1h<br>01B2h | DMA2 Control Register | DM2CON | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AEh<br>01AFh<br>01B0h<br>01B1h<br>01B2h<br>01B3h | DMA2 Control Register DMA3 Source Pointer | DM2CON<br>SAR3 | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AFh<br>01B0h<br>01B1h<br>01B2h<br>01B3h<br>01B4h<br>01B5h | DMA2 Control Register | DM2CON | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AFh<br>01B0h<br>01B1h<br>01B2h<br>01B3h<br>01B4h<br>01B5h | DMA2 Control Register DMA3 Source Pointer | DM2CON<br>SAR3 | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AFh<br>01B0h<br>01B1h<br>01B2h<br>01B3h<br>01B4h<br>01B5h<br>01B6h<br>01B7h | DMA2 Control Register DMA3 Source Pointer | DM2CON<br>SAR3 | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AFh<br>01B0h<br>01B1h<br>01B2h<br>01B3h<br>01B4h<br>01B5h<br>01B6h<br>01B7h | DMA2 Control Register DMA3 Source Pointer | DM2CON<br>SAR3 | 258 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01ABh<br>01ACh<br>01ACh<br>01AFh<br>01B0h<br>01B1h<br>01B2h<br>01B3h<br>01B3h<br>01B6h<br>01B7h<br>01B6h<br>01B7h | DMA2 Control Register DMA3 Source Pointer DMA3 Destination Pointer | DM2CON SAR3 DAR3 | 258<br>256<br>256 | | 01A7h<br>01A8h<br>01A9h<br>01AAh<br>01AAh<br>01ACh<br>01ACh<br>01ACh<br>01AFh<br>01B1h<br>01B2h<br>01B3h<br>01B4h<br>01B5h<br>01B6h<br>01B7h<br>01B8h<br>01B7h | DMA2 Control Register DMA3 Source Pointer DMA3 Destination Pointer | DM2CON SAR3 DAR3 | 258<br>256<br>256 | | 01A7h 01A8h 01A9h 01AAh 01ABh 01ACh 01ACh 01ACh 01AFh 01B0h 01B1h 01B3h 01B4h 01B5h 01B6h 01B7h 01B8h 01B8h | DMA2 Control Register DMA3 Source Pointer DMA3 Destination Pointer DMA3 Transfer Counter | DM2CON SAR3 DAR3 TCR3 | 258<br>256<br>256<br>256 | | 01A7h 01A8h 01A9h 01AAh 01ABh 01ACh 01ACh 01ACh 01AFh 01B0h 01B1h 01B2h 01B3h 01B6h 01B7h 01B8h 01B8h 01B8h 01B8h 01B8h | DMA2 Control Register DMA3 Source Pointer DMA3 Destination Pointer | DM2CON SAR3 DAR3 | 258<br>256<br>256 | | 01A7h 01A8h 01A9h 01AAh 01ABh 01ACh 01ACh 01ACh 01AFh 01B0h 01B1h 01B3h 01B4h 01B5h 01B6h 01B7h 01B8h 01B9h 01B8h 01B9h 01BBh 01BDh | DMA2 Control Register DMA3 Source Pointer DMA3 Destination Pointer DMA3 Transfer Counter | DM2CON SAR3 DAR3 TCR3 | 258<br>256<br>256<br>256 | | 01A7h 01A8h 01A9h 01AAh 01ABh 01ACh 01ACh 01ACh 01AFh 01B0h 01B1h 01B3h 01B4h 01B5h 01B6h 01B7h 01B8h 01B8h 01B8h 01B8h | DMA2 Control Register DMA3 Source Pointer DMA3 Destination Pointer DMA3 Transfer Counter | DM2CON SAR3 DAR3 TCR3 | 258<br>256<br>256<br>256 | | Address | Register | Symbol | Page | |----------------|-------------------------------------------------------------------------|---------------------|------------| | 01C0h | Timer B0-1 Register | TB01 | 328 | | 01C1h | Timer Bu-1 Register | 1001 | 328 | | 01C2h | Timer B1-1 Register | TB11 | 328 | | 01C3h | Timo 2 - 1 togisto. | | 020 | | 01C4h | Timer B2-1 Register | TB21 | 328 | | 01C5h | | | | | 01C6h | Pulse Period/Pulse Width Measurement<br>Mode Function Select Register 1 | PPWFS1 | 329 | | 01C7h | <u> </u> | | | | 01C8h | Timer B Count Source Select Register 0 | TBCS0 | 330 | | 01C9h | Timer B Count Source Select Register 1 | TBCS1 | 330 | | 01CAh | | | | | 01CBh | Timer AB Division Control Register 0 | TCKDIVC0 | 277 | | 01CCh | | | | | 01CDh | | | | | 01CEh<br>01CFh | | | | | 01D0h | Timer A Count Source Select Register 0 | TACS0 | 278 | | 01D0H | Timer A Count Source Select Register 1 | TACS0 | 278 | | 01D1h | Timer A Count Source Select Register 2 | TACS2 | 278 | | 01D2h | | .71002 | 2.0 | | 01D4h | 16-bit Pulse Width Modulation Mode Function<br>Select Register | PWMFS | 279 | | 01D5h | Timer A Waveform Output Function Select | TAPOFS | 280 | | 01D6h | Register | | | | 01D6h<br>01D7h | | | | | | Timer A Output Waveform Change Enable | T4 01** | 004 | | 01D8h | Register | TAOW | 281 | | 01D9h | | | | | 01DAh | Three-Phase Protect Control Register | TPRC | 363 | | 01DBh<br>01DCh | | | | | 01DCh<br>01DDh | | | | | 01DEh | | | | | 01DFh | | | | | 01E0h | | | | | 01E1h | Timer B3-1 Register | TB31 | 328 | | 01E2h | Times D4.4 Decistor | TD44 | 220 | | 01E3h | Timer B4-1 Register | TB41 | 328 | | 01E4h | Timer B5-1 Register | TB51 | 328 | | 01E5h | • | 1551 | 320 | | 01E6h | Pulse Period/Pulse Width Measurement<br>Mode Function Select Register 2 | PPWFS2 | 329 | | 01E7h | | | | | 01E8h | Timer B Count Source Select Register 2 | TBCS2 | 330 | | 01E9h | Timer B Count Source Select Register 3 | TBCS3 | 330 | | 01EAh | | | | | 01EBh<br>01ECh | | | | | 01ECh | | | | | 01EEh | | | | | 01EFh | | | | | 01F0h | PMC0 Function Select Register 0 | PMC0CON0 | 428 | | 01F1h | PMC0 Function Select Register 1 | PMC0CON1 | 430 | | 01F2h | PMC0 Function Select Register 2 | PMC0CON2 | 432 | | 01F3h | PMC0 Function Select Register 3 | PMC0CON3 | 434 | | 01F4h | PMC0 Status Register | PMC0STS | 435 | | 01F5h | PMC0 Interrupt Source Select Register | PMC0INT | 438 | | 01F6h | PMC0 Compare Control Register | PMC0CPC | 444 | | 01F7h | PMC0 Compare Data Register | PMC0CPD | 445 | | 01F8h | PMC1 Function Select Register 0 | PMC1CON0 | 428 | | 01F9h | PMC1 Function Select Register 1 | PMC1CON1 | 430 | | 01FAh | PMC1 Function Select Register 2 | PMC1CON2 | 432 | | 01FBh<br>01FCh | PMC1 Status Register | PMC1CON3<br>PMC1STS | 434<br>435 | | 01FCh<br>01FDh | PMC1 Status Register PMC1 Interrupt Source Select Register | PMC1S1S<br>PMC1INT | 435 | | 01FDh<br>01FEh | Fivio i interrupt Source Select Register | FINICIINI | 430 | | 01FEII | | | | | V 11 11 | | l . | <u> </u> | | Address | Register | Symbol | Page | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|--------------|---------| | 0200h | | | | | 0201h | | | | | 0202h | | | | | 0203h | | | | | 0204h | | | | | 0205h | Interrupt Source Select Register 3 | IFSR3A | 216 | | 0206h | Interrupt Source Select Register 2 | IFSR2A | 217 | | 0207h | Interrupt Source Select Register | IFSR | 218 | | 0208h | | | | | 0209h | | | | | 020Ah | | | | | 020Bh | | | | | 020Ch | | | | | 020Dh | | | | | 020Eh | Address Match Interrupt Enable Register | AIER | 219 | | 020Fh | Address Match Interrupt Enable Register 2 | AIER2 | 219 | | 0210h | | | | | 0211h | Address Match Interrupt Register 0 | RMAD0 | 220 | | 0212h | | | | | 0213h | | | | | 0214h | | | | | 0215h | Address Match Interrupt Register 1 | RMAD1 | 220 | | 0216h | , | | | | 0217h | | | | | 0217h | | | | | 0219h | Address Match Interrupt Register 2 | RMAD2 | 220 | | 021Ah | ridarese mater interrupt register 2 | | | | 021Bh | | | | | 021Ch | | | | | 021Dh | Address Match Interrupt Register 3 | RMAD3 | 220 | | 021Eh | Address Mater Interrupt Register 5 | KWADS | 220 | | 021Fh | | | | | 021111<br>0220h | Flash Memory Control Register 0 | FMR0 | 681 | | | | | | | | | | | | 0221h | Flash Memory Control Register 1 | FMR1 | 684 | | 0222h | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h | - | | | | 0222h<br>0223h<br>0224h | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h<br>022Ah | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h<br>022Ah<br>022Bh | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h<br>022Ah<br>022Bh<br>022Ch | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h<br>022Ah<br>022Bh<br>022Ch<br>022Dh | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h<br>022Ah<br>022Bh<br>022Ch<br>022Dh<br>022Eh | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h<br>022Ah<br>022Bh<br>022Ch<br>022Dh<br>022Eh<br>022Fh | Flash Memory Control Register 2 | FMR2 | 124 | | 0222h<br>0223h<br>0224h<br>0225h<br>0226h<br>0227h<br>0228h<br>0229h<br>022Ah<br>022Bh<br>022Ch<br>022Dh<br>022Eh<br>022Fh<br>0230h<br>0231h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Dh 022Eh 0230h 0231h 0232h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Dh 022Fh 0230h 0231h 0232h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Eh 0230h 0231h 0232h 0233h 0234h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Eh 0230h 0231h 0232h 0233h 0234h 0235h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Dh 0230h 0231h 0232h 0233h 0234h 0235h 0236h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Dh 022Eh 0230h 0231h 0232h 0233h 0234h 0235h 0236h 0237h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Dh 0230h 0231h 0232h 0233h 0234h 0235h 0236h 0237h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Dh 022Eh 0230h 0231h 0232h 0233h 0234h 0235h 0236h 0237h 0238h 0238h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Dh 022Eh 0230h 0231h 0232h 0233h 0234h 0235h 0236h 0237h 0238h 0237h 0238h 0239h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 0231h 0233h 0233h 0235h 0236h 0237h 0238h 0238h 0238h 0238h 0238h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Dh 022Eh 0230h 0231h 0232h 0233h 0234h 0235h 0236h 0237h 0238h 0237h 0238h 0239h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 0231h 0233h 0233h 0235h 0236h 0237h 0238h 0238h 0238h 0238h 0238h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 0231h 0233h 0233h 0235h 0236h 0237h 0238h 0237h 0238h 0238h 0238h 0238h 0238h 0238h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 023Ch 0231h 0233h 0233h 0234h 0235h 0236h 0237h 0238h 0237h 0238h 0238h 0238h 0239h 0230h 0230h 0230h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Eh 0230h 0231h 0233h 0233h 0233h 0233h 0237h 0238h 0237h 0238h 0237h 0238h 0237h 0238h 0237h 0238h 0237h 0238h 0238h 0237h 0238h 0237h 0238h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 022Ah 022Bh 022Ch 022Ch 022Eh 0230h 0231h 0233h 0233h 0233h 0233h 0237h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | 0222h 0223h 0224h 0225h 0226h 0227h 0228h 0229h 0222h 0222h 0222h 0222h 0222h 0222h 0230h 0231h 0233h 0233h 0233h 0233h 0238h 0237h 0238h 0239h 0238h 0239h 0239h 0237h 0238h 0239h 0237h 0238h | Flash Memory Control Register 2 Flash Memory Control Register 3 | FMR2<br>FMR3 | 124 686 | | Address | | | | |----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------| | | Register | Symbol | Page | | 0244h | UART0 Special Mode Register 4 | U0SMR4 | 487 | | 0245h | UART0 Special Mode Register 3 | U0SMR3 | 489 | | 0246h | UART0 Special Mode Register 2 | U0SMR2 | 490 | | | · · · | U0SMR | | | 0247h | UART0 Special Mode Register | | 491 | | 0248h | UART0 Transmit/Receive Mode Register | U0MR | 479 | | 0249h | UART0 Bit Rate Register | U0BRG | 480 | | 024Ah | | | | | 024Bh | UART0 Transmit Buffer Register | U0TB | 480 | | | | | | | 024Ch | UART0 Transmit/Receive Control Register 0 | U0C0 | 481 | | 024Dh | UART0 Transmit/Receive Control Register 1 | U0C1 | 483 | | 024Eh | | | | | 024Fh | UART0 Receive Buffer Register | U0RB | 484 | | | | | | | 0250h | UART Transmit/Receive Control Register 2 | UCON | 486 | | 0251h | | | | | 0252h | UART Clock Select Register | UCLKSEL0 | 478 | | 0253h | , and the second | | | | | | | | | 0254h | UART1 Special Mode Register 4 | U1SMR4 | 487 | | 0255h | UART1 Special Mode Register 3 | U1SMR3 | 489 | | 0256h | UART1 Special Mode Register 2 | U1SMR2 | 490 | | | , , | | | | 0257h | UART1 Special Mode Register | U1SMR | 491 | | 0258h | UART1 Transmit/Receive Mode Register | U1MR | 479 | | 0259h | UART1 Bit Rate Register | U1BRG | 480 | | 025Ah | | | | | | UART1 Transmit Buffer Register | U1TB | 480 | | 025Bh | <u> </u> | | | | 025Ch | UART1 Transmit/Receive Control Register 0 | U1C0 | 481 | | 025Dh | UART1 Transmit/Receive Control Register 1 | U1C1 | 483 | | 025Eh | g | | | | | UART1 Receive Buffer Register | U1RB | 484 | | 025Fh | ŭ | | | | 0260h | | | | | 0261h | | | | | | | | | | 0262h | | | | | 0263h | | | | | 0264h | UART2 Special Mode Register 4 | U2SMR4 | 487 | | 0265h | UART2 Special Mode Register 3 | U2SMR3 | 489 | | | | | | | 0266h | UART2 Special Mode Register 2 | U2SMR2 | 490 | | 0267h | UART2 Special Mode Register | U2SMR | 491 | | 0268h | UART2 Transmit/Receive Mode Register | U2MR | 479 | | 0269h | UART2 Bit Rate Register | U2BRG | 480 | | | OARTZ Bit Rate Register | OZDICO | +00 | | 026Ah | UART2 Transmit Buffer Register | U2TB | 480 | | 026Bh | or act 2 Transmit Banet Trogister | 02.5 | .00 | | 026Ch | UART2 Transmit/Receive Control Register 0 | U2C0 | 481 | | 026Dh | UART2 Transmit/Receive Control Register 1 | U2C1 | 483 | | | OARTZ Transmit/Receive Control Register 1 | 0201 | 463 | | 026Eh | | | | | | LIAPT2 Possive Buffer Pogister | LIODE | 191 | | 026Fh | UART2 Receive Buffer Register | U2RB | 484 | | | | | | | 0270h | UART2 Receive Buffer Register SI/O3 Transmit/Receive Register | U2RB<br>S3TRR | 484<br>544 | | 0270h<br>0271h | SI/O3 Transmit/Receive Register | S3TRR | 544 | | 0270h | | | | | 0270h<br>0271h | SI/O3 Transmit/Receive Register | S3TRR | 544 | | 0270h<br>0271h<br>0272h<br>0273h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register | S3TRR<br>S3C<br>S3BRG | 544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h | SI/O3 Transmit/Receive Register SI/O3 Control Register | S3TRR<br>S3C | 544<br>545 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register | S3TRR S3C S3BRG S4TRR | 544<br>545<br>546<br>544 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register | S3TRR<br>S3C<br>S3BRG | 544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register | S3TRR S3C S3BRG S4TRR | 544<br>545<br>546<br>544 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register | S3TRR S3C S3BRG S4TRR | 544<br>545<br>546<br>544<br>545 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh<br>027Ch | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh<br>027Ch | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh<br>027Ch | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh<br>027Ch<br>027Dh<br>027Eh | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh<br>027Ch<br>027Dh<br>027Eh<br>027Eh | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh<br>027Ch<br>027Dh<br>027Eh | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h<br>0271h<br>0272h<br>0273h<br>0274h<br>0275h<br>0276h<br>0277h<br>0278h<br>0279h<br>027Ah<br>027Bh<br>027Ch<br>027Dh<br>027Eh<br>027Fh | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h 0271h 0272h 0273h 0274h 0275h 0276h 0276h 0277h 0278h 0279h 027Ah 027Bh 027Ch 027Dh 027Eh 027Eh 027Eh 027Eh 0280h 0281h 0282h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register | S3TRR S3C S3BRG S4TRR S4C S4BRG | 544<br>545<br>546<br>544<br>545<br>546 | | 0270h 0271h 0272h 0273h 0274h 0275h 0276h 0277h 0278h 0279h 0278h 0279h 027Ah 027Bh 027Ch 027Dh 027Eh 027Eh 0280h 0281h 0282h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register SI/O3, 4 Control Register 2 | S3TRR S3C S3BRG S4TRR S4C S4BRG S34C2 | 544<br>545<br>546<br>544<br>545<br>546<br>546<br>546 | | 0270h 0271h 0272h 0273h 0274h 0275h 0276h 0276h 0277h 0278h 0279h 027Ah 027Bh 027Ch 027Dh 027Eh 027Eh 0280h 0281h 0282h 0284h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register SI/O3, 4 Control Register 2 | S3TRR S3C S3BRG S4TRR S4C S4BRG S34C2 | 544<br>545<br>546<br>544<br>546<br>546<br>546<br>487 | | 0270h 0271h 0272h 0273h 0274h 0275h 0276h 0277h 0278h 0279h 0278h 0279h 027Ah 027Bh 027Ch 027Dh 027Eh 027Eh 0280h 0281h 0282h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register SI/O3, 4 Control Register 2 | S3TRR S3C S3BRG S4TRR S4C S4BRG S34C2 | 544<br>545<br>546<br>544<br>545<br>546<br>546<br>546 | | 0270h 0271h 0272h 0273h 0274h 0275h 0276h 0276h 0277h 0278h 0279h 027Ah 027Bh 027Ch 027Dh 027Eh 027Eh 0280h 0281h 0282h 0284h | SI/O3 Transmit/Receive Register SI/O3 Control Register SI/O3 Bit Rate Register SI/O4 Transmit/Receive Register SI/O4 Control Register SI/O4 Bit Rate Register SI/O3, 4 Control Register 2 | S3TRR S3C S3BRG S4TRR S4C S4BRG S34C2 | 544<br>545<br>546<br>544<br>545<br>546<br>546<br>546 | | Addross | Pogistor | Symbol | Dogo | |------------------|-----------------------------------------------|----------------|-------------| | Address<br>0288h | Register UART5 Transmit/Receive Mode Register | Symbol<br>U5MR | Page<br>479 | | 0288h | · · · · · · · · · · · · · · · · · · · | U5BRG | 479 | | | UART5 Bit Rate Register | USBRG | 460 | | 028Ah<br>028Bh | UART5 Transmit Buffer Register | U5TB | 480 | | 028Ch | UART5 Transmit/Receive Control Register 0 | U5C0 | 481 | | 028Dh | UART5 Transmit/Receive Control Register 1 | U5C1 | 483 | | 028Eh | | | | | 028Fh | UART5 Receive Buffer Register | U5RB | 484 | | 0290h | | | | | 0291h | | | | | 0292h | | | | | 0293h | | | | | 0294h | UART6 Special Mode Register 4 | U6SMR4 | 487 | | 0295h | UART6 Special Mode Register 3 | U6SMR3 | 489 | | 0296h | UART6 Special Mode Register 2 | U6SMR2 | 490 | | 0297h | UART6 Special Mode Register | U6SMR | 491 | | 0298h | UART6 Transmit/Receive Mode Register | U6MR | 479 | | 0299h | UART6 Bit Rate Register | U6BRG | 480 | | 029Ah | UART6 Transmit Buffer Register | U6TB | 480 | | 029Bh | OAKTO Hansinit Dullet Register | UUID | 400 | | 029Ch | UART6 Transmit/Receive Control Register 0 | U6C0 | 481 | | 029Dh | UART6 Transmit/Receive Control Register 1 | U6C1 | 483 | | 029Eh | UART6 Receive Buffer Register | U6RB | 484 | | 029Fh | CARTO Receive Buildi Register | OUND | 707 | | 02A0h | | | | | 02A1h | | | | | 02A2h | | | | | 02A3h | | | | | 02A4h | UART7 Special Mode Register 4 | U7SMR4 | 487 | | 02A5h | UART7 Special Mode Register 3 | U7SMR3 | 489 | | 02A6h | UART7 Special Mode Register 2 | U7SMR2 | 490 | | 02A7h | UART7 Special Mode Register | U7SMR | 491 | | 02A8h | UART7 Transmit/Receive Mode Register | U7MR | 479 | | 02A9h | UART7 Bit Rate Register | U7BRG | 480 | | 02AAh<br>02ABh | UART7 Transmit Buffer Register | U7TB | 480 | | 02ACh | UART7 Transmit/Receive Control Register 0 | U7C0 | 481 | | 02ADh | UART7 Transmit/Receive Control Register 1 | U7C1 | 483 | | 02AEh<br>02AFh | UART7 Receive Buffer Register | U7RB | 484 | | 02B0h | I2C0 Data Shift Register | S00 | 560 | | 02B0H | 1200 Data Office (Cognotor | 200 | | | 02B1h | I2C0 Address Register 0 | S0D0 | 561 | | 02B3h | I2C0 Control Register 0 | S1D0 | 562 | | 02B4h | I2C0 Clock Control Register | S20 | 564 | | 02B5h | I2C0 Start/Stop Condition Control Register | S2D0 | 566 | | 02B6h | I2C0 Control Register 1 | S3D0 | 567 | | 02B7h | I2C0 Control Register 2 | S4D0 | 571 | | 02B8h | I2C0 Status Register 0 | S10 | 573 | | 02B9h | I2C0 Status Register 1 | S11 | 578 | | 02BAh | I2C0 Address Register 1 | S0D1 | 561 | | 02BBh | I2C0 Address Register 2 | S0D2 | 561 | | 02BCh | - | | | | 02BDh | | | | | 02BEh | | | | | 02BFh | | | | | 02C0h | | | | | to | | | | | 02FFh | | | | | Address | Register | Symbol | Page | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------| | 0300h | Timer B3/B4/B5 Count Start Flag | TBSR | 332 | | 0301h | 3 | | | | 0302h | | | | | 0303h | Timer A1-1 Register | TA11 | 283 | | 0304h | | | | | 0305h | Timer A2-1 Register | TA21 | 283 | | 0305h | | | | | | Timer A4-1 Register | TA41 | 283 | | 0307h | TI DI DIMINO I ID I I O | 11.11.000 | 055 | | 0308h | Three-Phase PWM Control Register 0 | INVC0 | 355 | | 0309h | Three-Phase PWM Control Register 1 | INVC1 | 357 | | 030Ah | Three-Phase Output Buffer Register 0 | IDB0 | 359 | | 030Bh | Three-Phase Output Buffer Register 1 | IDB1 | 359 | | 030Ch | Dead Time Timer | DTT | 359 | | 030Dh | Timer B2 Interrupt Generation Frequency Set Counter | ICTB2 | 360 | | 030Eh | Position-Data-Retain Function Control<br>Register | PDRF | 362 | | 030Fh | | | | | 0310h | Timer B3 Register | TB3 | 327 | | 0311h | Timer bo register | 155 | 321 | | 0312h | Timer B4 Register | TB4 | 327 | | 0313h | Timol DT Neglotel | 1 124 | 321 | | 0314h | Timor B5 Pogistor | TB5 | 327 | | 0315h | Timer B5 Register | נפו | 321 | | 0316h | | | | | 0317h | | | | | 0318h | Port Function Control Register | PFCR | 363 | | 0319h | | | | | 031Ah | | | | | 031Bh | Timer B3 Mode Register | TB3MR | 333 | | 031Ch | Timer B4 Mode Register | TB4MR | 333 | | 031Dh | Timer B5 Mode Register | TB5MR | 333 | | 031Eh | - | | | | 031Fh | | | | | 0320h | Count Start Flag | TABSR | 283 | | 0321h | - Community and the | | | | 0322h | One-Shot Start Flag | ONSF | 284 | | 0323h | Trigger Select Register | TRGSR | 285 | | 0324h | Increment/Decrement Flag | UDF | 286 | | 0325h | more mental beginning and many | 02. | 200 | | 0326h | | | | | 0320h | Timer A0 Register | TA0 | 282 | | 0327h<br>0328h | | | | | 0328h | Timer A1 Register | TA1 | 282 | | 0329h | | | | | | Timer A2 Register | TA2 | 282 | | 032Bh | | | | | 032Ch | Timer A3 Register | TA3 | 282 | | 032Dh | | | | | 032Eh | Timer A4 Register | TA4 | 282 | | 032Fh | | | | | 0330h | Timer B0 Register | TB0 | 327 | | 0331h | | | | | 0332h | Timer B1 Register | TB1 | 327 | | 0333h | - | | | | 0334h | Timer B2 Register | TB2 | 327 | | 0335h | | | | | 0336h | Timer A0 Mode Register | TA0MR | 287 | | | | | 007 | | 0337h | Timer A1 Mode Register | TA1MR | 287 | | 0337h<br>0338h | Timer A2 Mode Register | TA2MR | 287 | | | - | | | | Address | Register | Symbol | Page | |----------------------------------------------------|-------------------------------------------------|--------------------|------------| | 033Bh | Timer B0 Mode Register | TB0MR | 333 | | 033Ch | Timer B1 Mode Register | TB1MR | 333 | | 033Dh | Timer B2 Mode Register | TB2MR | 333 | | 033Eh | Timer B2 Special Mode Register | TB2SC | 361 | | 033Fh | | | | | 0340h | Real-Time Clock Second Data Register | RTCSEC | 392 | | 0341h | Real-Time Clock Minute Data Register | RTCMIN | 393 | | 0342h | Real-Time Clock Hour Data Register | RTCHR | 394 | | 0343h | Real-Time Clock Day Data Register | RTCWK | 395 | | 0344h | Real-Time Clock Control Register 1 | RTCCR1 | 396 | | 0345h | Real-Time Clock Control Register 2 | RTCCR2 | 398 | | | Real-Time Clock Count Source Select | | | | 0346h | Register | RTCCSR | 400 | | 0347h | | | | | 0348h | Real-Time Clock Second Compare Data<br>Register | RTCCSEC | 401 | | 0349h | Real-Time Clock Minute Compare Data<br>Register | RTCCMIN | 402 | | 034Ah | Real-Time Clock Hour Compare Data<br>Register | RTCCHR | 403 | | 034Bh | | | | | 034Ch | | | | | 034Dh | | | | | 034Eh | | | | | 034Fh | | | | | 0350h | CEC Function Control Register 1 | CECC1 | 606 | | 0351h | CEC Function Control Register 2 | CECC2 | 607 | | 0352h | CEC Function Control Register 3 | CECC3 | 609 | | 0353h | CEC Function Control Register 4 | CECC4 | 611 | | 0354h | CEC Flag Register | CECFLG | 613 | | 0355h | CEC Interrupt Source Select Register | CISEL | 614 | | 0356h | CEC Transmit Buffer Register 1 | CCTB1 | 615 | | 0357h | CEC Transmit Buffer Register 2 | CCTB2 | 615 | | 0358h | CEC Receive Buffer Register 1 | CCRB1 | 616 | | 0359h | CEC Receive Buffer Register 2 | CCRB2 | 616 | | | * | CRADRI1 | | | 035Ah | CEC Receive Follower Address Set Register 1 | | 617 | | 035Bh | CEC Receive Follower Address Set Register 2 | CRADRI2 | 617 | | 035Ch | | | | | 035Dh | | | | | 035Eh | | | | | 035Fh | | | | | 0360h | Pull-Up Control Register 0 | PUR0 | 197 | | 0361h | Pull-Up Control Register 1 | PUR1 | 198 | | 0362h | Pull-Up Control Register 2 | PUR2 | 199 | | 0363h | Pull-Up Control Register 3 | PUR3 | 200 | | 0364h | | | | | 0365h | | | | | 0366h | Port Control Register | PCR | 201 | | 0367h | | | | | 0368h | | | | | 0369h | NMI/SD Digital Filter Register | NMIDF | 222 | | 036Ah | | | | | 036Bh | | | | | 036Ch | | | | | 036Dh | | | | | 0000011 | | | | | 036Eh | | | | | | | | | | 036Eh | PWM Control Register 0 | PWMCON0 | 418 | | 036Eh<br>036Fh | PWM Control Register 0 | PWMCON0 | 418 | | 036Eh<br>036Fh<br>0370h | PWM Control Register 0 PWM0 Prescaler | PWMCON0 PWMPRE0 | 418 | | 036Eh<br>036Fh<br>0370h<br>0371h | - | | | | 036Eh<br>036Fh<br>0370h<br>0371h<br>0372h | PWM0 Prescaler | PWMPRE0 | 419 | | 036Eh<br>036Fh<br>0370h<br>0371h<br>0372h<br>0373h | PWM0 Prescaler PWM0 Register | PWMPRE0<br>PWMREG0 | 419<br>419 | | Address | Register | Symbol | Page | |----------------------------------|----------------------------------------------------|---------|------| | 0377h | | | | | 0378h | | | | | 0379h | | | | | 037Ah | | | | | 037Bh | | | | | 037Ch | Count Source Protection Mode Register | CSPR | 245 | | 037Dh | Watchdog Timer Refresh Register | WDTR | 246 | | 037Eh | Watchdog Timer Start Register | WDTS | 246 | | 037Fh | Watchdog Timer Control Register | WDC | 247 | | 0380h | , , , | | | | 0381h | | | | | 0382h | | | | | 0383h | | | | | 0384h | | | | | 0385h | | - | | | 0386h | | | | | 0387h | | | | | 0388h | | | | | 0389h | | - | | | 038Ah | | | | | 038Bh | | | | | 038Ch | | | | | 038Dh | | | | | 038Eh | | | | | 038Fh | | | | | 0390h | DMA2 Source Select Pogister | DM2SL | 259 | | 0390H | DMA2 Source Select Register | DIVIZOL | 239 | | | DMA2 Course Colort Desister | DMaci | 250 | | 0392h | DMA3 Source Select Register | DM3SL | 259 | | 0393h | | | | | 0394h | | | | | 0395h | | | | | 0396h | | | | | 0397h | | | | | 0398h | DMA0 Source Select Register | DM0SL | 259 | | 0399h | | | | | 039Ah | DMA1 Source Select Register | DM1SL | 259 | | 039Bh | | | | | 039Ch | | | | | 039Dh | | | | | 039Eh | | | | | 039Fh | | | | | 03A0h | | | | | 03A1h | | | | | 03A2h | Open-Circuit Detection Assist Function<br>Register | AINRST | 641 | | 03A3h | | | | | 03A4h | | | | | 03A5h | | | | | 03A6h | | | | | 03A7h | | | | | 03A8h | | | | | 03A9h | | | | | 03AAh | | | | | 03ABh | | | | | 00/1011 | | | | | 03ACh | | | | | | | | | | 03ACh | | | | | 03ACh<br>03ADh | | | | | 03ACh<br>03ADh<br>03AEh | | | | | 03ACh<br>03ADh<br>03AEh<br>03AFh | | | | | Address | Register | Symbol | Page | |----------------|----------------------------|-----------------------------------------|-------| | 03B3h | register | Cymbol | 1 age | | 03B4h | | | | | 03B5h | SFR Snoop Address Register | CRCSAR | 673 | | 03B6h | CRC Mode Register | CRCMR | 674 | | 03B7h | Cite Mode Register | Ortowire | 014 | | 03B8h | | | | | 03B9h | | | | | 03BAh | | | | | 03BBh | | | | | 03BCh | | | | | 03BDh | CRC Data Register | CRCD | 674 | | 03BEh | CRC Input Register | CRCIN | 674 | | 03BFh | | | | | 03C0h | A/D D | 450 | 0.40 | | 03C1h | A/D Register 0 | AD0 | 642 | | 03C2h | A/D Desister 4 | A.D.4 | 040 | | 03C3h | A/D Register 1 | AD1 | 642 | | 03C4h | A/D Pagistor 2 | VD3 | 642 | | 03C5h | A/D Register 2 | AD2 | 642 | | 03C6h | A/D Register 3 | AD3 | 642 | | 03C7h | AD Register 3 | ADS | 042 | | 03C8h | A/D Register 4 | AD4 | 642 | | 03C9h | 742 (togictor ) | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 0.12 | | 03CAh | A/D Register 5 | AD5 | 642 | | 03CBh | | | * | | 03CCh | A/D Register 6 | AD6 | 642 | | 03CDh | | | | | 03CEh | A/D Register 7 | AD7 | 642 | | 03CFh | Ţ | | | | 03D0h | | | | | 03D1h | | | | | 03D2h | | | | | 03D3h<br>03D4h | A/D Control Dominton 2 | ADCONO | 040 | | 03D4h | A/D Control Register 2 | ADCON2 | 643 | | 03D3H | A/D Control Register 0 | ADCON0 | 644 | | 03D0h | A/D Control Register 1 | ADCON1 | 646 | | 03D8h | D/A0 Register | DA0 | 669 | | 03D9h | 2// to register | 27.10 | 000 | | 03DAh | D/A1 Register | DA1 | 669 | | 03DBh | | | | | 03DCh | D/A Control Register | DACON | 669 | | 03DDh | - | | | | 03DEh | | | | | 03DFh | | | | | 03E0h | Port P0 Register | P0 | 202 | | 03E1h | Port P1 Register | P1 | 202 | | 03E2h | Port P0 Direction Register | PD0 | 203 | | 03E3h | Port P1 Direction Register | PD1 | 203 | | 03E4h | Port P2 Register | P2 | 202 | | 03E5h | Port P3 Register | P3 | 202 | | 03E6h | Port P2 Direction Register | PD2 | 203 | | 03E7h | Port P3 Direction Register | PD3 | 203 | | 03E8h | Port P4 Register | P4 | 202 | | 03E9h | Port P5 Register | P5 | 202 | | 03EAh | Port P5 Direction Register | PD4 | 203 | | 03EBh | Port P5 Direction Register | PD5 | 203 | | 03ECh | Port P7 Register | P6 | 202 | | 03EDh | Port P6 Direction Register | P7 | 202 | | 03EEh | Port P7 Direction Register | PD6 | 203 | | 03EFh | Port P7 Direction Register | PD7 | 203 | | Address | Register | Symbol | Page | |----------------------|-----------------------------|--------|------| | 03F0h | Port P8 Register | P8 | 202 | | 03F1h | Port P9 Register | P9 | 202 | | 03F2h | Port P8 Direction Register | PD8 | 203 | | 03F3h | Port P9 Direction Register | PD9 | 203 | | 03F4h | Port P10 Register | P10 | 202 | | 03F5h | Port P11 Register | P11 | 202 | | 03F6h | Port P10 Direction Register | PD10 | 203 | | 03F7h | Port P11 Direction Register | PD11 | 203 | | 03F8h | Port P12 Register | P12 | 202 | | 03F9h | Port P13 Register | P13 | 202 | | 03FAh | Port P12 Direction Register | PD12 | 203 | | 03FBh | Port P13 Direction Register | PD13 | 203 | | 03FCh | Port P14 Register | P14 | 202 | | 03FDh | | | | | 03FEh | Port P14 Direction Register | PD14 | 203 | | 03FFh | | | | | D000h<br>to<br>D07Fh | | | | The blank areas are reserved. No access is allowed. | Address | Register | Symbol | Page | |-------------|----------------------------------------------|----------------|------| | D080h | PMC0 Header Pattern Set Register (Min) | PMC0HDPMIN | 439 | | D081h | rivico rieadei ratterii Set Negistei (wiiii) | FIVICUMDFIVIIN | 439 | | D082h | PMC0 Header Pattern Set Register (Max) | PMC0HDPMAX | 439 | | D083h | Fill Co Header Falletti Set Negister (Max) | | 439 | | D084h | PMC0 Data 0 Pattern Set Register (Min) | PMC0D0PMIN | 441 | | D085h | PMC0 Data 0 Pattern Set Register (Max) | PMC0D0PMAX | 441 | | D086h | PMC0 Data 1 Pattern Set Register (Min) | PMC0D1PMIN | 441 | | D087h | PMC0 Data 1 Pattern Set Register (Max) | PMC0D1PMAX | 441 | | D088h | PMC0 Measurements Register | PMC0TIM | 442 | | D089h | Pivico ivieasurements Register | PIVICUTIIVI | 442 | | D08Ah | | | | | D08Bh | | | | | D08Ch | PMC0 Receive Data Store Register 0 | PMC0DAT0 | 443 | | D08Dh | PMC0 Receive Data Store Register 1 | PMC0DAT1 | 443 | | D08Eh | PMC0 Receive Data Store Register 2 | PMC0DAT2 | 443 | | D08Fh | PMC0 Receive Data Store Register 3 | PMC0DAT3 | 443 | | D090h | PMC0 Receive Data Store Register 4 | PMC0DAT4 | 443 | | D091h | PMC0 Receive Data Store Register 5 | PMC0DAT5 | 443 | | D092h | PMC0 Receive Bit Count Register | PMC0RBIT | 442 | | D093h | | | | | D094h | DMC4 Lloader Dettern Cet Desister (Min) | PMC1HDPMIN | 439 | | D095h | PMC1 Header Pattern Set Register (Min) | PINICIADPINIIN | 439 | | D096h | PMC1 Header Pattern Set Register (Max) | PMC1HDPMAX | 439 | | D097h | FINCT Reader Fattern Set Register (Max) | FINIC INDENIAX | 439 | | D098h | PMC1 Data 0 Pattern Set Register (Min) | PMC1D0PMIN | 441 | | D099h | PMC1 Data 0 Pattern Set Register (Max) | PMC1D0PMAX | 441 | | D09Ah | PMC1 Data 1 Pattern Set Register (Min) | PMC1D1PMIN | 441 | | D09Bh | PMC1 Data 1 Pattern Set Register (Max) | PMC1D1PMAX | 441 | | D09Ch | PMC1 Measurements Register | PMC1TIM | 442 | | D09Dh | F INIC I INICASULEITIETIUS REGISTET | FIVICTITIVI | 442 | | D09Eh | | | | | D09Fh | | | | | D0A0h | | | | | to<br>D7FFh | | | | | | | | | | FFFFFh | Optional Function Select Address 1 | OFS1 | 689 | |--------|------------------------------------|------|-----| | FFFFFN | Optional Function Select Address 1 | UFSI | 009 | OFS1 address is not an SFR. M16C/65C Group RENESAS MCU R01UH0093EJ0110 Rev.1.10 Jul 31, 2012 ## 1. Overview #### 1.1 Features The M16C/65C Group microcomputer (MCU) incorporates the M16C/60 Series CPU core and flash memory, employing sophisticated instructions for a high level of efficiency. This MCU has 1 MB of address space (expandable to 4 MB), and it is capable of executing instructions at high speed. In addition, the CPU core boasts a multiplier for high-speed operation processing. This MCU consumes low power, and supports operating modes that allow additional power control. The MCU also uses an anti-noise configuration to reduce emissions of electromagnetic noise and is designed to withstand electromagnetic interference (EMI). By integrating many of the peripheral functions, including the multifunction timer and serial interface, the number of system components has been reduced. ## 1.1.1 Applications This MCU can be used in audio components, cameras, televisions, household appliances, office equipment, communication devices, mobile devices, industrial equipment, and other applications. M16C/65C Group 1. Overview ## 1.2 Specifications The M16C/65C Group includes 128-pin and 100-pin packages. Table 1.1 to Table 1.4 list specifications. Table 1.1 Specifications for the 128-Pin Package (1/2) | Item | Function | Description | |---------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CPU | Central processing unit | <ul> <li>M16C/60 Series core (multiplier: 16 bit × 16 bit → 32 bit, multiply and accumulate instruction: 16 bit × 16 bit + 32 bit → 32 bit)</li> <li>Number of basic instructions: 91</li> <li>Minimum instruction execution time: 31.25 ns (f(BCLK) = 32 MHz, VCC1 = VCC2 = 2.7 to 5.5 V)</li> <li>Operating modes: Single-chip, memory expansion, and microprocessor</li> </ul> | | Memory | ROM, RAM, data flash | See Table 1.5 "Product List (N-Version)" to Table 1.6 "Product List (D-Version)". | | Voltage<br>Detection | Voltage detector | <ul> <li>Power-on reset</li> <li>3 voltage detection points (detection level of voltage detection 0 and 1 selectable)</li> </ul> | | Clock | Clock generator | <ul> <li>5 circuits: Main clock, sub clock, low-speed on-chip oscillator (125 kHz), high-speed on-chip oscillator (40 MHz ±5%), PLL frequency synthesizer</li> <li>Oscillation stop detection: Main clock oscillation stop/restart detection function</li> <li>Frequency divider circuit: Divide ratio selectable from 1, 2, 4, 8, and 16</li> <li>Power saving features: Wait mode, stop mode</li> <li>Real-time clock</li> </ul> | | External Bus<br>Expansion | Bus memory expansion | <ul> <li>Address space: 1 MB</li> <li>External bus interface: 0 to 8 waits inserted, 4 chip select outputs, memory area expansion function (expandable to 4 MB), 3 V and 5 V interfaces</li> <li>Bus format: Separate bus or multiplexed bus selectable, data bus width selectable (8 or 16 bits), number of address buses selectable (12, 16, or 20)</li> </ul> | | I/O Ports | Programmable I/O ports | CMOS I/O ports: 111 (selectable pull-up resistors) N-channel open drain ports: 3 | | Interrupts | | <ul> <li>Interrupt vectors: 70</li> <li>External interrupt inputs: 13 (NMI, INT × 8, key input × 4)</li> <li>Interrupt priority levels: 7</li> </ul> | | Watchdog Timer | | 15-bit timer x 1 (with prescaler) Automatic reset start function selectable | | DMA | DMAC | <ul> <li>4 channels, cycle steal mode</li> <li>Trigger sources: 43</li> <li>Transfer modes: 2 (single transfer, repeat transfer)</li> </ul> | Table 1.2 Specifications for the 128-Pin Package (2/2) | Item | Function | Description | | | | |---------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | Timer A | 16-bit timer x 5 Timer mode, event counter mode, one-shot timer mode, pulse width modulation (PWM) mode Event counter two-phase pulse signal processing (two-phase encoder input) x 3 Programmable output mode x 3 | | | | | | Timer B | 16-bit timer x 6 Timer mode, event counter mode, pulse period measurement mode, pulse width measurement mode | | | | | Timers | Three-phase motor control timer functions | <ul><li>Three-phase inverter control (timer A1, timer A2, timer A4, timer B2)</li><li>On-chip dead time timer</li></ul> | | | | | | Real-time clock | Count: seconds, minutes, hours, days of the week | | | | | | PWM function | 8 bits × 2 | | | | | | Remote control signal receiver | <ul> <li>2 circuits</li> <li>4 wave pattern matchings (differentiate wave pattern for headers, data 0, data 1, and special data)</li> <li>6-byte receive buffer (1 circuit only)</li> <li>Operating frequency of 32 kHz</li> </ul> | | | | | Serial<br>Interface | UART0 to UART2, UART5 to UART7 | Clock synchronous/asynchronous × 6 channels I <sup>2</sup> C-bus, IEBus, special mode 2 SIM (UART2) | | | | | | SI/O3, SI/O4 | Clock synchronization only × 2 channels | | | | | Multi-master I | <sup>2</sup> C-bus Interface | 1 channel | | | | | CEC Function | ns (2) | CEC transmit/receive, arbitration lost detection, ACK automatic output, operation frequency of 32 kHz | | | | | A/D Converte | ır | 10-bit resolution × 26 channels, including sample and hold function Conversion time: 1.72 μs | | | | | D/A Converte | r | 8-bit resolution × 2 circuits | | | | | CRC Calculat | tor | CRC-CCITT $(X^{16} + X^{12} + X^5 + 1)$ ,<br>CRC-16 $(X^{16} + X^{15} + X^2 + 1)$ compliant | | | | | Flash Memor | у | <ul> <li>Program and erase power supply voltage: 2.7 to 5.5 V</li> <li>Program and erase cycles: 1,000 times (program ROM 1, program ROM 2), 10,000 times (data flash)</li> <li>Program security: ROM code protect, ID code check</li> </ul> | | | | | Debug Functi | ons | On-chip debug, on-board flash rewrite, address match interrupt x 4 | | | | | Operation Fre | equency/Supply Voltage | 32 MHz/VCC1 = 2.7 to 5.5 V, VCC2 = 2.7 V to VCC1 | | | | | Current Cons | umption | Refer to the Electrical Characteristics chapter | | | | | Operating Ter | mperature | -20°C to 85°C, -40°C to 85°C (1) | | | | | Package | | 128-pin LQFP: PLQP0128KB-A (Previous package code: 128P6Q-A) | | | | # Notes: - 1. See Table 1.5 "Product List (N-Version)" to Table 1.6 "Product List (D-Version)" for the operating temperature. - 2. The CEC function indicates circuitry which supports the transmission and reception of CEC signals standardized by the High-Definition Multimedia Interface (HDMI). HDMI and High-Definition Multimedia Interface are registered trademarks of HDMI Licensing, LLC. Table 1.3 Specifications for the 100-Pin Package (1/2) | Item | Function | Description | | | | |---------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | CPU | Central processing unit | M16C/60 Series core (multiplier: 16 bit × 16 bit → 32 bit, multiply and accumulate instruction: 16 bit × 16 bit + 32 bit → 32 bit) • Number of basic instructions: 91 | | | | | | | <ul> <li>Minimum instruction execution time:</li> <li>31.25 ns (f(BCLK) = 32 MHz, VCC1 = VCC2 = 2.7 to 5.5 V)</li> <li>Operating modes: Single-chip, memory expansion, and microprocessor</li> </ul> | | | | | Memory | ROM, RAM, data flash | See Table 1.5 "Product List (N-Version)" to Table 1.6 "Product List (D-Version)". | | | | | Voltage<br>Detection | Voltage detector | <ul> <li>Power-on reset</li> <li>3 voltage detection points (detection level of voltage detection 0 and 1 selectable)</li> </ul> | | | | | Clock | Clock generator | <ul> <li>5 circuits: Main clock, sub clock, low-speed on-chip oscillator (125 kHz), high-speed on-chip oscillator (40 MHz ±5%), PLL frequency synthesizer</li> <li>Oscillation stop detection: Main clock oscillation stop/restart detection function</li> <li>Frequency divider circuit: Divide ratio selectable from 1, 2, 4, 8, and 16</li> <li>Power saving features: Wait mode, stop mode</li> <li>Real-time clock</li> </ul> | | | | | External Bus<br>Expansion | Bus memory expansion | <ul> <li>Address space: 1 MB</li> <li>External bus interface: 0 to 8 waits inserted, 4 chip select outputs, memory area expansion function (expandable to 4 MB), 3 V and 5 V interfaces</li> <li>Bus format: Separate bus or multiplexed bus selectable, data bus width selectable (8 or 16 bits), number of address buses selectable (12, 16, or 20)</li> </ul> | | | | | I/O Ports | Programmable I/O ports | CMOS I/O ports: 85 (selectable pull-up resistors) N-channel open drain ports: 3 | | | | | Interrupts | | <ul> <li>Interrupt vectors: 70</li> <li>External interrupt inputs: 13 (NMI, INT x 8, key input x 4)</li> <li>Interrupt priority levels: 7</li> </ul> | | | | | Watchdog Tir | ner | 15-bit timer x 1 (with prescaler) Automatic reset start function selectable | | | | | DMA | DMAC | 4 channels, cycle steal mode Trigger sources: 43 Transfer modes: 2 (single transfer, repeat transfer) | | | | Table 1.4 Specifications for the 100-Pin Package (2/2) | Item | Function | Description | | | | | |------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | Timer A | 16-bit timer x 5 Timer mode, event counter mode, one-shot timer mode, pulse width modulation (PWM) mode Event counter two-phase pulse signal processing (two-phase encoder input) x 3 Programmable output mode x 3 | | | | | | | Timer B | 16-bit timer × 6 Timer mode, event counter mode, pulse period measurement mode, pulse width measurement mode | | | | | | Timers | Three-phase motor control timer functions | <ul> <li>Three-phase inverter control (timer A1, timer A2, timer A4, timer B2)</li> <li>On-chip dead time timer</li> </ul> | | | | | | | Real-time clock | Count: seconds, minutes, hours, days of the week | | | | | | | PWM function | 8 bits × 2 | | | | | | | Remote control signal receiver | <ul> <li>2 circuits</li> <li>4 wave pattern matchings (differentiate wave pattern for headers, data 0, data 1, and special data)</li> <li>6-byte receive buffer (1 circuit only)</li> <li>Operating frequency of 32 kHz</li> </ul> | | | | | | Serial<br>Interface | UART0 to UART2, UART5 to UART7 | Clock synchronous/asynchronous × 6 channels I <sup>2</sup> C-bus, IEBus, special mode 2 SIM (UART2) | | | | | | | SI/O3, SI/O4 | Clock synchronization only × 2 channels | | | | | | Multi-master | I <sup>2</sup> C-bus Interface | 1 channel | | | | | | CEC Functio | ons <sup>(2)</sup> | CEC transmit/receive, arbitration lost detection, ACK automatic output, operation frequency of 32 kHz | | | | | | A/D Converte | er | 10-bit resolution $\times$ 26 channels, including sample and hold function Conversion time: 1.72 $\mu s$ | | | | | | D/A Converte | er | 8-bit resolution x 2 circuits | | | | | | CRC Calcula | ator | CRC-CCITT $(X^{16} + X^{12} + X^5 + 1)$ ,<br>CRC-16 $(X^{16} + X^{15} + X^2 + 1)$ compliant | | | | | | Flash Memo | ry | <ul> <li>Program and erase power supply voltage: 2.7 to 5.5 V</li> <li>Program and erase cycles: 1,000 times (program ROM 1, program ROM 2), 10,000 times (data flash)</li> <li>Program security: ROM code protect, ID code check</li> </ul> | | | | | | Debug Funct | tions | On-chip debug, on-board flash rewrite, address match interrupt × 4 | | | | | | Operation Frequency/Supply Voltage | | 25 MHz/VCC1 = 2.7 to 5.5 V, VCC2 = 2.7 V to VCC1<br>32 MHz/VCC1 = 2.7 to 5.5 V, VCC2 = 2.7 V to VCC1 | | | | | | Current Consumption | | Refer to the Electrical Characteristics chapter | | | | | | Operating Te | emperature | -20°C to 85°C, -40°C to 85°C (1) | | | | | | Package | | 100-pin QFP: PRQP0100JD-B (Previous package code: 100P6F-A) 100-pin LQFP: PLQP0100KB-A (Previous package code: 100P6Q-A) | | | | | # Notes: - 1. See Table 1.5 "Product List (N-Version)" to Table 1.6 "Product List (D-Version)" for the operating temperature. - 2. The CEC function indicates circuitry which supports the transmission and reception of CEC signals standardized by the High-Definition Multimedia Interface (HDMI). HDMI and High-Definition Multimedia Interface are registered trademarks of HDMI Licensing, LLC. ### 1.3 Product List Table 1.5 and Table 1.6 list product information. Figure 1.1 shows the Part No., with Memory Size and Package, and Figure 1.2 shows the Marking Diagram (Top View). Table 1.5 Product List (N-Version) As of July, 2012 | | R | OM Capacity | У | RAM | | | |--------------|------------------|------------------|--------------------|----------|--------------|-------------------------------------------| | Part No. | Program<br>ROM 1 | Program<br>ROM 2 | Data flash | Capacity | Package Code | Remarks | | R5F36506CNFA | 128 KB | 16 KB | 4 KB | 12 KB | PRQP0100JD-B | | | R5F36506CNFB | 120 10 | TOTAL | × 2 blocks | 12 ND | PLQP0100KB-A | | | R5F3651ECNFC | | | 4 KB | | PLQP0128KB-A | | | R5F3650ECNFA | 256 KB | 16 KB | × 2 blocks | 20 KB | PRQP0100JD-B | Operating<br>temperature<br>-20°C to 85°C | | R5F3650ECNFB | | | 7. 2 5100110 | | PLQP0100KB-A | | | R5F3651KCNFC | | | KB 4 KB | 31 KB | PLQP0128KB-A | | | R5F3650KCNFA | 384 KB | 16 KB | | | PRQP0100JD-B | | | R5F3650KCNFB | | | X Z DIOORS | | PLQP0100KB-A | | | R5F3651MCNFC | | | 4 1/D | | PLQP0128KB-A | 20 0 10 00 0 | | R5F3650MCNFA | 512 KB | 16 KB | 4 KB<br>x 2 blocks | 31 KB | PRQP0100JD-B | 1 | | R5F3650MCNFB | | | X Z DIOOKS | | PLQP0100KB-A | | | R5F3651NCNFC | | | 4.170 | | PLQP0128KB-A | | | R5F3650NCNFA | 512 KB | 16 KB | 4 KB<br>× 2 blocks | 47 KB | PRQP0100JD-B | | | R5F3650NCNFB | | | A Z DIOORG | | PLQP0100KB-A | | (D): Under development (P): Planning Note: 1. Previous package codes are as follows: PLQP0128KB-A: 128P6Q-A, PRQP0100JD-B: 100P6F-A, PLQP0100KB-A: 100P6Q-A Table 1.6 Product List (D-Version) As of July, 2012 | | R | OM Capacit | v | | | | |--------------|------------------|------------------|--------------------------|-----------------|--------------|-------------------------------------------| | Part No. | Program<br>ROM 1 | Program<br>ROM 2 | Data flash | RAM<br>Capacity | Package Code | Remarks | | R5F36506CDFA | 128 KB | 16 KB | 16 KB 4 KB<br>× 2 blocks | 12 KB | PRQP0100JD-B | | | R5F36506CDFB | 120 KB | TOND | | IZ ND | PLQP0100KB-A | | | R5F3651ECDFC | | | 4 I/D | | PLQP0128KB-A | | | R5F3650ECDFA | 256 KB | 16 KB | 4 KB<br>× 2 blocks | 20 KB | PRQP0100JD-B | Operating<br>temperature<br>-40°C to 85°C | | R5F3650ECDFB | | | | | PLQP0100KB-A | | | R5F3651KCDFC | | | 4 1/0 | | PLQP0128KB-A | | | R5F3650KCDFA | 384 KB | 16 KB | 4 KB<br>× 2 blocks | 31 KB | PRQP0100JD-B | | | R5F3650KCDFB | | | A L BIOORO | | PLQP0100KB-A | | | R5F3651MCDFC | | | 4 KD | 31 KB | PLQP0128KB-A | | | R5F3650MCDFA | 512 KB | 16 KB | 4 KB<br>× 2 blocks | | PRQP0100JD-B | | | R5F3650MCDFB | | | A L BIOORO | | PLQP0100KB-A | | | R5F3651NCDFC | | | 4 KD 2 | | PLQP0128KB-A | | | R5F3650NCDFA | 512 KB | 16 KB | 4 KB x 2<br>blocks | 47 KB | PRQP0100JD-B | | | R5F3650NCDFB | | | | | PLQP0100KB-A | | (D): Under development (P): Planning Note: 1. Previous package codes are as follows: PLQP0128KB-A: 128P6Q-A, PRQP0100JD-B: 100P6F-A, PLQP0100KB-A: 100P6Q-A Figure 1.1 Part No., with Memory Size and Package Figure 1.2 Marking Diagram (Top View) # 1.4 Block Diagram Figure 1.3 to Figure 1.4 show block diagrams. Figure 1.3 Block Diagram for the 128-Pin Package Figure 1.4 Block Diagram for the 100-Pin Package ### 1.5 Pin Assignments Figure 1.5 to Figure 1.7 show pin assignments. Table 1.7 to Table 1.11 list pin names. Figure 1.5 Pin Assignment for the 128-Pin Package Table 1.7 Pin Names for the 128-Pin Package (1/3) | I/O Pin for Peripheral Function | | | | | | | Dua Cantral | |---------------------------------|-------------|-------|-----------|-------------|----------------------|---------------------------------|--------------------| | Pin No. | Control Pin | Port | Interrupt | | Serial interface | A/D converter,<br>D/A converter | Bus Control<br>Pin | | 1 | VREF | | | | | | | | 2 | AVCC | | | | | | | | 3 | | P9_7 | | | SIN4 | ADTRG | | | 4 | | P9_6 | | | SOUT4 | ANEX1 | | | 5 | | P9_5 | | | CLK4 | ANEX0 | | | 6 | | P9_4 | | TB4IN/PWM1 | | DA1 | | | 7 | | P9_3 | | TB3IN/PWM0 | | DA0 | | | 8 | | P9_2 | | TB2IN/PMC0 | SOUT3 | | | | 9 | | P9_1 | | TB1IN/PMC1 | SIN3 | | | | 10 | | P9_0 | | TB0IN | CLK3 | | | | 11 | | P14_1 | | | | | | | 12 | | P14_0 | | | | | | | 13 | BYTE | | | | | | | | 14 | CNVSS | | | | | | | | 15 | XCIN | P8_7 | | | | | | | 16 | XCOUT | P8_6 | | | | | | | 17 | RESET | | | | | | | | 18 | XOUT | | | | | | | | 19 | VSS | | | | | | | | 20 | XIN | | | | | | | | 21 | VCC1 | | | | | | | | 22 | | P8_5 | NMI | SD | CEC | | | | 23 | | P8_4 | INT2 | ZP | | | | | 24 | | P8_3 | INT1 | | | | | | 25 | | P8_2 | INT0 | | | | | | 26 | | P8_1 | | TA4IN/Ū | CTS5/RTS5 | | | | 27 | | P8_0 | | TA4OUT/U | RXD5/SCL5 | | | | 28 | | P7_7 | | TA3IN | CLK5 | | | | 29 | | P7_6 | | TA3OUT | TXD5/SDA5 | | | | 30 | | P7_5 | | TA2IN/W | | | | | 31 | | P7_4 | | TA2OUT/W | | | | | 32 | | P7_3 | | TA1IN/V | CTS2/RTS2 | | | | 33 | | P7_2 | | TA1OUT/V | CLK2 | | | | 34 | | P7_1 | | TA0IN/TB5IN | RXD2/SCL2/SCLMM | | | | 35 | | P7_0 | | TA0OUT | TXD2/SDA2/SDAMM | | | | 36 | | P6_7 | | | TXD1/SDA1 | | | | 37 | VCC1 | | | | | | - | | 38 | | P6_6 | | | RXD1/SCL1 | | | | 39 | VSS | | | | | | | | 40 | | P6_5 | | | CLK1 | | | | 41 | | P6_4 | | | CTS1/RTS1/CTS0/CLKS1 | | | | 42 | | P6_3 | | | TXD0/SDA0 | | | | 43 | | P6_2 | | | RXD0/SCL0 | | | | 44 | | P6_1 | | - | CLK0 | | | | 45 | | P6_0 | | RTCOUT | CTS0/RTS0 | | | | 46 | | P13_7 | | | | | | | 47 | | P13_6 | | | | | | | 48 | | P13_5 | | | | | | | 49 | | P13_4 | | | | | | | 50 | CLKOUT | P5_7 | | | | | RDY | Table 1.8 Pin Names for the 128-Pin Package (2/3) | | Control | | | I/O F | Pin for Peripheral Func | | | |---------|---------|--------------|-----------|-------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | Pin No. | Pin | Port | Interrupt | Timer | Serial interface | A/D converter,<br>D/A converter | Bus Control Pin | | 51 | | P5_6 | | | | | ALE | | 52 | | P5_5 | | | | | HOLD | | 53 | | P5_4 | | | | | HLDA | | 54 | | P13_3 | | | | | | | 55 | | P13_2 | | | | | | | 56 | | P13_1 | | | | | | | 57 | | P13_0 | | | | | | | 58 | | P5_3 | | | | | BCLK | | 59 | | P5_2 | | | | | RD | | 60 | | P5_1 | | | | | WRH/BHE | | 61 | | P5_0 | | | | | WRL/WR | | 62 | | P12_7 | | | | | | | 63 | | P12_6 | | | | | | | 64 | | P12_5 | | | | | | | 65 | | P4_7 | | PWM1 | TXD7/SDA7 | | CS3 | | 66 | | P4_6 | 1 | PWM0 | RXD7/SCL7 | | CS2 | | 67 | | P4_5 | | | CLK7 | | CS1 | | 68 | | P4_4 | | | CTS7/RTS7 | | CS0 | | 69 | | P4_3 | | | | | A19 | | 70 | | P4_2 | | | | | A18 | | 71 | | P4_1 | | | | | A17 | | 72 | | P4_0 | | | | | A16 | | 73 | | P3_7 | | | | | A15 | | 74 | | P3_6 | | | | | A14 | | 75 | | P3_5 | | | | | A13 | | 76 | | P3_4 | | | | | A12 | | 77 | | P3_3 | | | | | A11 | | 78 | | P3_2 | | | | | A10 | | 79 | | P3_1 | | | | | A9 | | 80 | | P12_4 | | | | | 7.0 | | 81 | | P12_3 | | | | | | | 82 | | P12_2 | | | | | | | 33 | | P12_1 | | | | | | | 34 | | P12_0 | | | | | | | 35 | VCC2 | 1 12_0 | | | | | | | 36 | 7002 | P3_0 | | | | | A8, [A8/D7] | | 37 | VSS | . 0_0 | | | | | 7.6, [7.6/27] | | 38 | | P2_7 | | | | AN2_7 | A7, [A7/D7], [A7/D6] | | 39 | | P2_6 | | | | AN2_6 | A6, [A6/D6], [A6/D5] | | 90 | | P2_5 | INT7 | | | AN2_5 | A5, [A5/D5], [A5/D4] | | 91 | | P2_4 | INT6 | | | AN2_4 | A4[A4/D4], [A4/D3] | | 92 | | P2_3 | | | | AN2_3 | A3, [A3/D3], [A3/D2] | | 93 | | P2_2 | 1 | | | AN2_2 | A2, [A2/D2], [A2/D1] | | 94 | | P2_1 | | | | AN2_1 | A2, [A2/D2], [A2/D1] A1, [A1/D1], [A1/D0] | | 95 | | P2_0 | 1 | | + | AN2_0 | A1, [A1/D1], [A1/D0] A0, [A0/D0], A0 | | 96 | | P1_7 | INT5 | IDU | | \(\lambda \text{\Lambda} \\ \alpha \Lamb | D15 | | 97 | | P1_6 | INT4 | IDW | | | D14 | | 98 | | P1_6<br>P1_5 | INT3 | IDV | | | D13 | | 98 | | P1_5<br>P1_4 | IIVIO | אחו | + | | D13 | | | | | | | TVDC/CD A C | | | | 100 | | P1_3 | | | TXD6/SDA6 | | D11 | Table 1.9 Pin Names for the 128-Pin Package (3/3) | Pin | Control | | | I/O F | Pin for Peripheral Fund | | | |-----|---------|-------|-----------|---------|-------------------------|----------------|-----------------| | No. | Pin | Port | Interrupt | Timer | Serial interface | A/D converter, | Bus Control Pin | | | | | ппопарс | 1111101 | | D/A converter | | | 101 | | P1_2 | | | RXD6/SCL6 | | D10 | | 102 | | P1_1 | | | CLK6 | | D9 | | 103 | | P1_0 | | | CTS6/RTS6 | | D8 | | 104 | | P0_7 | | | | AN0_7 | D7 | | 105 | | P0_6 | | | | AN0_6 | D6 | | 106 | | P0_5 | | | | AN0_5 | D5 | | 107 | | P0_4 | | | | AN0_4 | D4 | | 108 | | P0_3 | | | | AN0_3 | D3 | | 109 | | P0_2 | | | | AN0_2 | D2 | | 110 | | P0_1 | | | | AN0_1 | D1 | | 111 | | P0_0 | | | | AN0_0 | D0 | | 112 | | P11_7 | | | | | | | 113 | | P11_6 | | | | | | | 114 | | P11_5 | | | | | | | 115 | | P11_4 | | | | | | | 116 | | P11_3 | | | | | | | 117 | | P11_2 | | | | | | | 118 | | P11_1 | | | | | | | 119 | | P11_0 | | | | | | | 120 | | P10_7 | KI3 | | | AN7 | | | 121 | | P10_6 | KI2 | | | AN6 | | | 122 | | P10_5 | KI1 | | | AN5 | | | 123 | | P10_4 | KI0 | | | AN4 | | | 124 | | P10_3 | | | | AN3 | | | 125 | | P10_2 | | | | AN2 | | | 126 | | P10_1 | | | | AN1 | | | 127 | AVSS | | | | | | | | 128 | | P10_0 | | | | AN0 | | Figure 1.6 Pin Assignment for the 100-Pin Package Figure 1.7 Pin Assignment for the 100-Pin Package Table 1.10 Pin Names for the 100-Pin Package (1/2) | Pin | No. | Control Pin | Port | | I/O Pir | n for Peripheral Function | A/D converter, | Bus Control | |-----|-----|--------------|------|-----------|-------------|---------------------------|----------------|-------------| | FA | FB | Control Pill | | Interrupt | Timer | Serial interface | D/A converter | Pin | | 1 | 99 | | P9_6 | | | SOUT4 | ANEX1 | | | 2 | 100 | | P9_5 | | | CLK4 | ANEX0 | | | 3 | 1 | | P9_4 | | TB4IN/PWM1 | | DA1 | | | 4 | 2 | | P9_3 | | TB3IN/PWM0 | | DA0 | | | 5 | 3 | | P9_2 | | TB2IN/PMC0 | SOUT3 | | | | 6 | 4 | | P9_1 | | TB1IN/PMC1 | SIN3 | | | | 7 | 5 | | P9_0 | | TB0IN | CLK3 | | | | 3 | 6 | BYTE | | | | | | | | 9 | 7 | CNVSS | | | | | | | | 10 | 8 | XCIN | P8_7 | | | | | | | 11 | 9 | XCOUT | P8_6 | | | | | | | 12 | 10 | RESET | | | | | | | | 13 | 11 | XOUT | | | | | | | | 14 | 12 | VSS | | | | | | | | 15 | 13 | XIN | | | | | | | | 16 | 14 | VCC1 | | | | | | | | 17 | 15 | | P8_5 | NMI | SD | CEC | | | | 18 | 16 | | P8_4 | INT2 | ZP | | | | | 19 | 17 | | P8_3 | INT1 | | | | | | 20 | 18 | | P8_2 | INT0 | | | | | | 21 | 19 | | P8_1 | | TA4IN/U | CTS5/RTS5 | | | | 22 | 20 | | P8_0 | | TA4OUT/U | RXD5/SCL5 | | | | 23 | 21 | | P7_7 | | TA3IN | CLK5 | | | | 24 | 22 | | P7_6 | | TA3OUT | TXD5/SDA5 | | | | 25 | 23 | | P7_5 | | TA2IN/W | | | | | 26 | 24 | | P7_4 | | TA2OUT/W | | | | | 27 | 25 | | P7_3 | | TA1IN/V | CTS2/RTS2 | | | | 28 | 26 | | P7_2 | | TA1OUT/V | CLK2 | | | | 29 | 27 | | P7_1 | | TA0IN/TB5IN | RXD2/SCL2/SCLMM | | | | 30 | 28 | | P7_0 | | TA0OUT | TXD2/SDA2/SDAMM | | | | 31 | 29 | | P6_7 | | | TXD1/SDA1 | | | | 32 | 30 | | P6_6 | | | RXD1/SCL1 | | | | 33 | 31 | | P6_5 | | | CLK1 | | | | 34 | 32 | | P6_4 | | | CTS1/RTS1/CTS0/ | | | | | | | | | | CLKS1 | | | | 35 | 33 | | P6_3 | | | TXD0/SDA0 | | | | 36 | 34 | | P6_2 | 1 | | RXD0/SCL0 | | | | 37 | 35 | | P6_1 | | DTOO! | CLK0 | | | | 38 | 36 | 01146::= | P6_0 | | RTCOUT | CTS0/RTS0 | | | | 39 | 37 | CLKOUT | P5_7 | | | | | RDY | | 40 | 38 | | P5_6 | | | | | ALE | | 41 | 39 | | P5_5 | | | | | HOLD | | 42 | 40 | | P5_4 | | | | | HLDA | | 43 | 41 | | P5_3 | | | | | BCLK | | 44 | 42 | | P5_2 | | | | | RD | | 45 | 43 | | P5_1 | | | | | WRH/BHE | | 46 | 44 | | P5_0 | | | | | WRL/WR | | 47 | 45 | | P4_7 | | PWM1 | TXD7/SDA7 | | CS3 | | 48 | 46 | | P4_6 | | PWM0 | RXD7/SCL7 | | CS2 | | 49 | 47 | | P4_5 | | | CLK7 | | CS1 | | 50 | 48 | | P4_4 | | | CTS7/RTS7 | | CS0 | Table 1.11 Pin Names for the 100-Pin Package (2/2) | | No. | | T | T | | in for Peripheral Fund | ction | T | |----------|----------------------|----------|--------|-----------|-------|------------------------|----------------|----------------------| | | | Control | Port | | | 1 | A/D converter, | Bus Control Pin | | FA | FB | Pin | | Interrupt | Timer | Serial interface | D/A converter | Dao Control i III | | 51 | 49 | | P4_3 | | | | | A19 | | 52 | 50 | | P4_2 | | | | | A18 | | 53 | 51 | | P4_1 | | | | | A17 | | 54 | 52 | | P4_0 | | | | | A16 | | 55 | 53 | | P3_7 | | | | | A15 | | 56 | 54 | | P3_6 | | | | | A14 | | 57 | 55 | | P3_5 | | | | | A13 | | 58 | 56 | | P3_4 | | | | | A12 | | 59 | 57 | | P3_3 | | | | | A11 | | 30<br>30 | 58 | | P3_2 | | | | | A10 | | 30<br>31 | 59 | | P3_1 | | | | | A9 | | 52 | 60 | VCC2 | 1 0_1 | | | | | 710 | | 33 | 61 | VCC2 | P3_0 | | | | | A8, [A8/D7] | | 64 | 62 | VSS | 1 3_0 | | | | | Αο, [Αο/ <i>D1</i> ] | | 54<br>65 | 63 | V 3 3 | P2_7 | | | + | AN2_7 | Λ7 [Λ7/D7] [Λ7/D6] | | | | | | | | + | | A7, [A7/D7], [A7/D6] | | 66<br>67 | 64 | - | P2_6 | INITT | | | AN2_6 | A6, [A6/D6], [A6/D5] | | | 65 | - | P2_5 | INT7 | | | AN2_5 | A5, [A5/D5], [A5/D4] | | 8 | 66 | | P2_4 | INT6 | | | AN2_4 | A4, [A4/D4], [A4/D3] | | 59<br>70 | 67 | | P2_3 | | | | AN2_3 | A3, [A3/D3], [A3/D2] | | 70 | 68 | | P2_2 | | | | AN2_2 | A2, [A2/D2], [A2/D1] | | 71 | 69 | | P2_1 | | | | AN2_1 | A1, [A1/D1], [A1/D0] | | 72 | 70 | | P2_0 | | | | AN2_0 | A0, [A0/D0], A0 | | 73 | 71 | | P1_7 | INT5 | IDU | | | D15 | | 74 | 72 | | P1_6 | INT4 | IDW | | | D14 | | 75 | 73 | | P1_5 | INT3 | IDV | | | D13 | | 76 | 74 | | P1_4 | | | | | D12 | | 77 | 75 | | P1_3 | | | TXD6/SDA6 | | D11 | | 78 | 76 | | P1_2 | | | RXD6/SCL6 | | D10 | | 79 | 77 | | P1_1 | | | CLK6 | | D9 | | 30 | 78 | | P1_0 | | | CTS6/RTS6 | | D8 | | 31 | 79 | | P0_7 | | | | AN0_7 | D7 | | 32 | 80 | | P0_6 | | | | AN0_6 | D6 | | 33 | 81 | | P0_5 | | | | AN0_5 | D5 | | 34 | 82 | | P0_4 | | | | AN0_4 | D4 | | 35 | 83 | | P0_3 | | | | AN0_3 | D3 | | 36 | 84 | | P0_2 | | | | AN0_2 | D2 | | 37 | 85 | | P0_1 | | | | AN0_1 | D1 | | 38 | 86 | | P0_0 | | | | AN0_0 | D0 | | 39 | 87 | | | KI3 | | | AN7 | | | 90 | 88 | <u> </u> | 1 | KI2 | | | AN6 | | | 91 | 89 | | | KI1 | | | AN5 | | | 92 | 90 | | | KIO | | | AN4 | | | 93 | 91 | | P10_3 | 1 | | | AN3 | | | 94 | 92 | | P10_2 | | | | AN2 | | | 95 | 93 | <u> </u> | P10_1 | | | + | AN1 | | | 96<br>96 | 94 | AVSS | 1 10_1 | | | | / 11 11 | | | 96<br>97 | 9 <del>4</del><br>95 | AV 33 | P10_0 | | | + | AN0 | | | | | VDEF | F10_0 | | | | ANU | | | 98 | 96 | VREF | | | | | | | | 99 | 97 | AVCC | DC 7 | | | CINA | ADTEC | | | 100 | 98 | | P9_7 | | | SIN4 | ADTRG | | # 1.6 Pin Functions Table 1.12 Pin Functions for the 128-Pin Package (1/3) | Signal Name | Pin Name | I/O | Power Supply | Description | |--------------------------------------|-------------------------|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power supply input | VCC1,<br>VCC2,<br>VSS | I | - | Apply 2.7 to 5.5 V to pins VCC1 and VCC2 (VCC1 $\geq$ VCC2), and 0 V to the VSS pin. | | Analog power supply input | 9. | | VCC1 | This is the power supply for the A/D and D/A converters. Connect the AVCC pin to VCC1, and connect the AVSS pin to VSS. | | Reset input | RESET | I | VCC1 | Driving this pin low resets the MCU. | | CNVSS | CNVSS | I | VCC1 | Input pin to switch processor modes. After a reset, to start operating in single-chip mode, connect the CNVSS pin to VSS via a resistor. To start operating in microprocessor mode, connect the pin to VCC1. | | External data bus width select input | ВҮТЕ | I | VCC1 | Input pin to select the data bus of the external area. The data bus is 16 bits when it is low and 8 bits when it is high. This pin must be fixed either high or low. Connect the BYTE pin to VSS in single-chip mode. | | | D0 to D7 | I/O | VCC2 | Inputs or outputs data (D0 to D7) while accessing an external area with a separate bus. | | | D8 to D15 | I/O | VCC2 | Inputs or outputs data (D8 to D15) while accessing an external area with a 16-bit separate bus. | | | A0 to A19 | 0 | VCC2 | Outputs address bits A0 to A19. | | | A0/D0 to<br>A7/D7 | I/O | VCC2 | Inputs or outputs data (D0 to D7) and outputs address bits (A0 to A7) by timesharing, while accessing an external area with an 8-bit multiplexed bus. | | | A1/D0 to<br>A8/D7 | I/O | VCC2 | Inputs or outputs data (D0 to D7) and outputs address bits (A1 to A8) by timesharing, while accessing an external area with a 16-bit multiplexed bus. | | | CS0 to CS3 | 0 | VCC2 | Outputs chip-select signals CS0 to CS3 to specify an external area. | | Bus control pins | WRL/WR<br>WRH/BHE<br>RD | 0 | VCC2 | Outputs WRL, WRH, (WR, BHE), and RD signals. WRL and WRH can be switched with BHE and WR. • WRL, WRH, and RD selected If the external data bus is 16 bits, data is written to an even address in an external area when WRL is driven low. Data is written to an odd address when WRH is driven low. Data is read when RD is driven low. • WR, BHE, and RD selected Data is written to an external area when WR is driven low. Data in an external area is read when RD is driven low. An odd address is accessed when BHE is driven low. Select WR, BHE, and RD when using an 8-bit external data bus. | | | ALE | 0 | VCC2 | Outputs an ALE signal to latch the address. | | | HOLD | I | VCC2 | HOLD input is unavailable. Connect the HOLD pin to VCC2 via a resistor (pull-up). | | | HLDA | 0 | VCC2 | In a hold state, HLDA outputs a low-level signal. | | | RDY | I | VCC2 | The MCU bus is placed in wait state while the $\overline{RDY}$ pin is driven low. | Power supply: VCC2 is used to supply power to the external bus associated pins. The dual power supply configuration allows VCC2 to interface at a different voltage than VCC1. Table 1.13 Pin Functions for the 128-Pin Package (2/3) | Signal Name | Pin Name | I/O | Power Supply | Description | |--------------------------------------|----------------------------------------------------------------|-----|--------------|----------------------------------------------------------------------------------------------------------| | Main clock input | XIN | I | VCC1 | I/O for the main clock oscillator. Connect a ceramic resonator or crystal between pins XIN and XOUT. (1) | | Main clock output | XOUT | 0 | VCC1 | Input an external clock to XIN pin and leave XOUT pin open. | | Sub clock input | XCIN | I | VCC1 | I/O for a sub clock oscillator. Connect a crystal between pins XCIN and XCOUT. (1) Input an external | | Sub clock output | XCOUT | 0 | VCC1 | clock to XCIN pin and leave XCOUT pin open. | | BCLK output | BCLK | 0 | VCC2 | Outputs the BCLK signal. | | Clock output | CLKOUT | Ο | VCC2 | Outputs a clock with the same frequency as fC, f1, f8, or f32. | | INT interrupt input | INTO to INT2 | ļ | VCC1 | Input for the INT interrupt. | | iivi iiiterrupt iiiput | INT3 to INT7 | I | VCC2 | Triput for the five interrupt. | | NMI interrupt input | NMI | I | VCC1 | Input for the NMI interrupt. | | Key input interrupt input | KIO to KI3 | I | VCC1 | Input for the key input interrupt. | | | TA0OUT to<br>TA4OUT | I/O | VCC1 | I/O for timers A0 to A4 (TA0OUT is N-channel open drain output). | | Timer A | TA0IN to TA4IN | [ | VCC1 | Input for timers A0 to A4. | | | ZP | [ | VCC1 | Input for Z-phase. | | Timer B | TB0IN to TB5IN | [ | VCC1 | Input for timers B0 to B5. | | | $\overline{U}, \overline{U}, V, \overline{V}, W, \overline{W}$ | 0 | VCC1 | Output for the three-phase motor control timer. | | Three-phase motor control timer | SD | [ | VCC1 | Forced cutoff input. | | | IDU, IDV, IDW | [ | VCC2 | Input for the position data. | | Real-time clock output | RTCOUT | 0 | VCC1 | Output for the real-time clock. | | PWM output | PWM0, PWM1 | 0 | VCC1, VCC2 | PWM output. | | Remote control signal receiver input | PMC0, PMC1 | ı | VCC1 | Input for the remote control signal receiver. | | | CTS0 to CTS2,<br>CTS5 | I | VCC1 | Input pins to control data transmission. | | | CTS6, CTS7 | 1 | VCC2 | | | | RTS0 to RTS2,<br>RTS5 | 0 | VCC1 | Output pins to control data reception. | | | RTS6, RTS7 | 0 | VCC2 | | | Serial interface | CLK0 to CLK2,<br>CLK5 | I/O | VCC1 | Transmit/receive clock I/O. | | UART0 to UART2,<br>UART5 to UART7 | CLK6, CLK7 | I/O | VCC2 | | | UARTS to UART7 | RXD0 to RXD2,<br>RXD5 | I | VCC1 | Serial data input. | | | RXD6, RXD7 | I | VCC2 | ' | | | TXD0 to TXD2,<br>TXD5 | 0 | VCC1 | Serial data output. (2) | | | TXD6, TXD7 | 0 | VCC2 | | | | CLKS1 | 0 | VCC1 | Output for the transmit/receive clock multiple-pin output function. | #### Notes: - 1. Contact the manufacturer of crystal/ceramic resonator regarding the oscillation characteristics. - 2. TXD2, SDA2, and SCL2 are N-channel open drain output pins. TXDi (i = 0, 1, 5 to 7), SDAi, and SCLi can be selected as CMOS output pins or N-channel open drain output pins. Table 1.14 Pin Functions for the 128-Pin Package (3/3) | Signal Name | Pin Name | I/O | Power Supply | Description | |-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | SDA0 to SDA2,<br>SDA5 | I/O | VCC1 | Serial data I/O. | | UART0 to UART2,<br>UART5 to UART7 | SDA6, SDA7 | I/O | VCC2 | | | I <sup>2</sup> C mode | SCL0 to SCL2,<br>SCL5 | I/O | VCC1 | Transmit/receive clock I/O. | | | SCL6, SCL7 | I/O | VCC2 | | | Carial interfere | CLK3, CLK4 | I/O | VCC1 | Transmit/receive clock I/O. | | Serial interface<br>SI/O3, SI/O4 | SIN3, SIN4 | I | VCC1 | Serial data input. | | | SOUT3, SOUT4 | 0 | VCC1 | Serial data output. | | Multi-master I <sup>2</sup> C- | SDAMM | I/O | VCC1 | Serial data I/O (N-channel open drain output). | | bus interface | SCLMM | I/O | VCC1 | Transmit/receive clock I/O (N-channel open drain output). | | CEC I/O | CEC | I/O | VCC1 | CEC I/O (N-channel open drain output). | | Reference voltage input | VREF | ı | VCC1 | Reference voltage input for the A/D and D/A converters. | | | AN0 to AN7 | I | VCC1 | | | A/D converter | AN0_0 to AN0_7<br>AN2_0 to AN2_7 | I | VCC2 | Analog input. | | | ADTRG | I | VCC1 | External trigger input. | | | ANEX0, ANEX1 | I | VCC1 | Extended analog input. | | D/A converter | DA0, DA1 | 0 | VCC1 | Output pin the D/A converter. | | I/O ports | P0_0 to P0_7<br>P1_0 to P1_7<br>P2_0 to P2_7<br>P3_0 to P3_7<br>P4_0 to P4_7<br>P5_0 to P5_7<br>P12_0 to P12_7<br>P13_0 to P13_7 | I/O | VCC2 | 8-bit CMOS I/O ports. A direction register determines whether each pin is used as an input port or an output port. A pull-up resistor may be enabled or disabled for input ports in 4-bit units. | | · | P6_0 to P6_7 P7_0 to P7_7 P8_0 to P8_7 P9_0 to P9_7 P10_0 to P10_7 P11_0 to P11_7 P14_0, P14_1 | I/O | VCC1 | 8-bit I/O ports having equivalent functions to P0. However, P7_0, P7_1, and P8_5 are N-channel open drain output ports. No pull-up resistor is provided. P8_5 is an input port for verifying the \$\overline{NMI}\$ pin level and shares a pin with \$\overline{NMI}\$. I/O ports having equivalent functions to P0. | | | 1 14_U, F 14_1 | 1/0 | VCCI | ports having equivalent functions to Fo. | Table 1.15 Pin Functions for the 100-Pin Package (1/3) | Signal Name | Pin Name | I/O | Power Supply | Description | | |--------------------------------------|-------------------------|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Power supply input | VCC1,<br>VCC2, VSS | I | - | Apply 2.7 to 5.5 V to pins VCC1 and VCC2 (VCC1 $\geq$ VCC2) and 0 V to the VSS pin. | | | Analog power supply input | AVCC, AVSS | I | VCC1 | This is the power supply for the A/D and D/A converters. Connect the AVCC pin to VCC1, and connect the AVSS pin to VSS. | | | Reset input | RESET | [ | VCC1 | Driving this pin low resets the MCU. | | | CNVSS | CNVSS | I | VCC1 | Input pin to switch processor modes. After a reset, to start operating in single-chip mode, connect the CNVSS pin to VSS via a resistor. To start operating in microprocessor mode, connect the pin to VCC1. | | | External data bus width select input | ВҮТЕ | I | VCC1 | Input pin to select the data bus of the external area. The data bus is 16 bits when it is low, and 8 bits when it is high. This pin must be fixed either high or low. Connect the BYTE pin to VSS in single-chip mode. | | | | D0 to D7 | I/O | VCC2 | Inputs or outputs data (D0 to D7) while accessing an external area with a separate bus. | | | | D8 to D15 | I/O | VCC2 | Inputs or outputs data (D8 to D15) while accessing an external area with a 16-bit separate bus. | | | | A0 to A19 | 0 | VCC2 | Outputs address bits A0 to A19. | | | | A0/D0 to<br>A7/D7 | I/O | VCC2 | Inputs or outputs data (D0 to D7) and outputs address bits (A0 to A7) by timesharing, while accessing an external area with an 8-bit multiplexed bus. | | | | A1/D0 to<br>A8/D7 | I/O | VCC2 | Inputs or outputs data (D0 to D7) and outputs address bits (A1 to A8) by timesharing, while accessing an external area with a 16-bit multiplexed bus. | | | | CS0 to CS3 | 0 | VCC2 | Outputs chip-select signals $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ to specify an external area. | | | Bus control pins | WRL/WR<br>WRH/BHE<br>RD | 0 | VCC2 | Outputs WRL, WRH, (WR, BHE), and RD signals. WRL and WRH can be switched with BHE and WR. • WRL, WRH, and RD selected If the external data bus is 16 bits, data is written to an even address in an external area when WRL is driven low. Data is written to an odd address when WRH is driven low. Data is read when RD is driven low. • WR, BHE, and RD selected Data is written to an external area when WR is driven low. Data in an external area is read when RD is driven low. An odd address is accessed when BHE is driven low. Select WR, BHE, and RD when using an 8-bit external data bus. | | | | ALE | 0 | VCC2 | Outputs an ALE signal to latch the address. | | | | HOLD | I | VCC2 | HOLD input is unavailable. Connect the HOLD pin to VCC2 via a resistor (pull-up). | | | | HLDA | 0 | VCC2 | In a hold state, HLDA outputs a low-level signal. | | | | RDY | I | VCC2 | The MCU bus is placed in a wait state while the $\overline{\text{RDY}}$ pin is driven low. | | Power supply: VCC2 is used to supply power to the external bus associated pins. The dual power supply configuration allows VCC2 to interface at a different voltage than VCC1. Table 1.16 Pin Functions for the 100-Pin Package (2/3) | Signal Name | Pin Name | I/O | Power Supply | Description | |--------------------------------------|-------------------------------------------------------------------------------------------------|-----|--------------|------------------------------------------------------------------------------------------------------------------| | Main clock input | XIN | I | VCC1 | I/O for the main clock oscillator. Connect a ceramic resonator or crystal between pins XIN and XOUT. (1) | | Main clock output | XOUT | 0 | VCC1 | Input an external clock to XIN pin and leave XOUT pin open. | | Sub clock input | XCIN | I | VCC1 | I/O for a sub clock oscillator. Connect a crystal between XCIN pin and XCOUT pin. (1) Input an external clock to | | Sub clock output | XCOUT | 0 | VCC1 | XCIN pin and leave XCOUT pin open. | | BCLK output | BCLK | 0 | VCC2 | Outputs the BCLK signal. | | Clock output | CLKOUT | 0 | VCC2 | Outputs a clock with the same frequency as fC, f1, f8, or f32. | | INT interrupt input | INTO to INT2 | I | VCC1 | Input for the INT interrupt. | | intriniterrupt input | INT3 to INT7 | I | VCC2 | input for the five interrupt. | | NMI interrupt input | NMI | I | VCC1 | Input for the MMI interrupt. | | Key input interrupt input | KIO to KI3 | I | VCC1 | Input for the key input interrupt. | | | TA0OUT to<br>TA4OUT | I/O | VCC1 | I/O for timers A0 to A4 (TA0OUT is N-channel open drain output). | | Timer A | TA0IN to TA4IN | I | VCC1 | Input for timers A0 to A4. | | | ZP | I | VCC1 | Input for Z-phase. | | Timer B | TB0IN to TB5IN | I | VCC1 | Input for timers B0 to B5. | | | $\overline{U}, \overline{\overline{U}}, V, \overline{\overline{V}}, W, \overline{\overline{W}}$ | 0 | VCC1 | Output for the three-phase motor control timer. | | Three-phase motor control timer | SD | ı | VCC1 | Forced cutoff input. | | | IDU, IDV, IDW | I | VCC2 | Input for the position data. | | Real-time clock output | RTCOUT | 0 | VCC1 | Output for the real-time clock. | | PWM output | PWM0, PWM1 | 0 | VCC1, VCC2 | PWM output. | | Remote control signal receiver input | PMC0, PMC1 | I | VCC1 | Input for the remote control signal receiver. | | | CTS0 to CTS2,<br>CTS5 | ı | VCC1 | Input pins to control data transmission. | | | CTS6, CTS7 | ı | VCC2 | | | | RTS0 to RTS2,<br>RTS5 | 0 | VCC1 | Output pins to control data reception. | | | RTS6, RTS7 | 0 | VCC2 | | | Carial interface | CLK0 to CLK2,<br>CLK5 | I/O | VCC1 | Transmit/receive clock I/O. | | Serial interface UART0 to UART2, | CLK6, CLK7 | I/O | VCC2 | | | UART5 to UART7 | RXD0 to RXD2,<br>RXD5 | I | VCC1 | Serial data input. | | | RXD6, RXD7 | I | VCC2 | | | | TXD0 to TXD2,<br>TXD5 | 0 | VCC1 | Serial data output. (2) | | | TXD6, TXD7 | 0 | VCC2 | · | | | CLKS1 | 0 | VCC1 | Output for the transmit/receive clock multiple-pin output function. | ### Notes: 1. - 1. Contact the manufacturer of crystal/ceramic resonator regarding the oscillation characteristics. - 2. TXD2, SDA2, and SCL2 are N-channel open drain output pins. TXDi (i = 0, 1, 5 to 7), SDAi, and SCLi can be selected as CMOS output pins or N-channel open drain output pins. Table 1.17 Pin Functions for the 100-Pin Package (3/3) | Signal Name | Pin Name | I/O | Power Supply | Description | | |-----------------------------------|----------------------------------------------------------------------------------------------|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | SDA0 to SDA2,<br>SDA5 | I/O | VCC1 | Serial data I/O. | | | UART0 to UART2,<br>UART5 to UART7 | SDA6, SDA7 | I/O | VCC2 | | | | I <sup>2</sup> C mode | SCL0 to SCL2,<br>SCL5 | I/O | VCC1 | Transmit/receive clock I/O. | | | | SCL6, SCL7 | I/O | VCC2 | | | | 0 | CLK3, CLK4 | I/O | VCC1 | Transmit/receive clock I/O. | | | Serial interface<br>SI/O3, SI/O4 | SIN3, SIN4 | I | VCC1 | Serial data input. | | | | SOUT3, SOUT4 | 0 | VCC1 | Serial data output. | | | Multi-master I <sup>2</sup> C- | SDAMM | I/O | VCC1 | Serial data I/O (N-channel open drain output). | | | bus interface | SCLMM | I/O | VCC1 | Transmit/receive clock I/O (N-channel open drain output). | | | CEC I/O | CEC | I/O | VCC1 | CEC I/O (N-channel open drain output). | | | Reference voltage input | VREF | ı | VCC1 | Reference voltage input for the A/D and D/A converters. | | | | AN0 to AN7 | | VCC1 | | | | A/D converter | AN0_0 to AN0_7<br>AN2_0 to AN2_7 | I | VCC2 | Analog input. | | | | ADTRG | | VCC1 | External trigger input. | | | | ANEX0, ANEX1 | I | VCC1 | Extended analog input. | | | D/A converter | DA0, DA1 | 0 | VCC1 | Output for the D/A converter. | | | I/O ports | P0_0 to P0_7<br>P1_0 to P1_7<br>P2_0 to P2_7<br>P3_0 to P3_7<br>P4_0 to P4_7<br>P5_0 to P5_7 | I/O | VCC2 | 8-bit CMOS I/O ports. A direction register determines whether each pin is used as an input port or an output port. A pull-up resistor may be enabled or disabled for input ports in 4-bit units. | | | | P6_0 to P6_7<br>P7_0 to P7_7<br>P8_0 to P8_7<br>P9_0 to P9_7<br>P10_0 to P10_7 | I/O | VCC1 | 8-bit I/O ports having equivalent functions to P0. However, P7_0, P7_1, and P8_5 are N-channel open drain output ports. No pull-up resistor is provided. P8_5 is an input port for verifying the \$\overline{NMI}\$ pin level and shares a pin with \$\overline{NMI}\$. | | # 2. Central Processing Unit (CPU) Figure 2.1 shows the CPU registers. Seven registers (R0, R1, R2, R3, A0, A1, and FB) out of 13 compose a register bank, and there are two register banks. Figure 2.1 CPU Registers # 2.1 Data Registers (R0, R1, R2, and R3) R0, R1, R2, and R3 are 16-bit registers used for transfer, arithmetic, and logic operations. R0 and R1 can be split into upper (R0H/R1H) and lower (R0L/R1L) bits to be used separately as 8-bit data registers. R0 can be combined with R2, and R3 can be combined with R1 and be used as 32-bit data registers R2R0 and R3R1, respectively. ### 2.2 Address Registers (A0 and A1) A0 and A1 are 16-bit registers used for indirect addressing, relative addressing, transfer, arithmetic, and logic operations. A0 can be combined with A1 and used as a 32-bit address register (A1A0). ### 2.3 Frame Base Register (FB) FB is a 16-bit register that is used for FB relative addressing. # 2.4 Interrupt Table Register (INTB) INTB is a 20-bit register that indicates the start address of a relocatable interrupt vector table. ### 2.5 Program Counter (PC) The PC is 20 bits wide and indicates the address of the next instruction to be executed. # 2.6 User Stack Pointer (USP) and Interrupt Stack Pointer (ISP) The USP and ISP stack pointers (SP) are each comprised of 16 bits. The U flag is used to switch between USP and ISP. # 2.7 Static Base Register (SB) SB is a 16-bit register used for SB relative addressing. ### 2.8 Flag Register (FLG) FLG is an 11-bit register that indicates the CPU state. ### 2.8.1 Carry Flag (C Flag) The C flag retains a carry, borrow, or shift-out bit generated by the arithmetic/logic unit. # 2.8.2 Debug Flag (D Flag) The D flag is for debugging only. Set it to 0. ### 2.8.3 Zero Flag (Z Flag) The Z flag becomes 1 when an arithmetic operation results in 0. Otherwise, it becomes 0. ### 2.8.4 Sign Flag (S Flag) The S flag becomes 1 when an arithmetic operation results in a negative value. Otherwise, it becomes 0. ### 2.8.5 Register Bank Select Flag (B Flag) Register bank 0 is selected when the B flag is 0. Register bank 1 is selected when this flag is 1. # 2.8.6 Overflow Flag (O Flag) The O flag becomes 1 when an arithmetic operation results in an overflow. Otherwise, it becomes 0. # 2.8.7 Interrupt Enable Flag (I Flag) The I flag enables maskable interrupts. Maskable interrupts are disabled when the I flag is 0, and enabled when it is 1. The I flag becomes 0 when an interrupt request is accepted. # 2.8.8 Stack Pointer Select Flag (U Flag) ISP is selected when the U flag is 0. USP is selected when the U flag is 1. The U flag becomes 0 when a hardware interrupt request is accepted, or the INT instruction of software interrupt number 0 to 31 is executed. # 2.8.9 Processor Interrupt Priority Level (IPL) IPL is 3 bits wide and assigns processor interrupt priority levels from 0 to 7. If a requested interrupt has higher priority than IPL, the interrupt request is enabled. #### 2.8.10 Reserved Areas Only set these bits to 0. The read value is undefined. M16C/65C Group 3. Address Space # 3. Address Space # 3.1 Address Space The M16C/65C Group has a 1 MB address space from 00000h to FFFFFh. Address space is expandable to 4 MB with the memory area expansion function. Addresses 40000h to BFFFFh can be used as external areas from bank 0 to bank 7. Figure 3.1 shows the Address Space. Areas that can be accessed vary depending on processor mode and the status of each control bit. Figure 3.1 Address Space M16C/65C Group 3. Address Space ### 3.2 Memory Map Special function registers (SFRs) are allocated from address 00000h to 003FFh and from 0D000h to 0D7FFh. Peripheral function control registers are located here. All blank areas within SFRs are reserved. Do not access these areas. Internal RAM is allocated from address 00400h and higher, with 10 KB of internal RAM allocated from 00400h to 02BFFh. Internal RAM is used not only for data storage, but also for the stack area when subroutines are called or when an interrupt request is accepted. The internal ROM is flash memory. Three internal ROM areas are available: data flash, program ROM 1, and program ROM 2. The data flash is allocated from 0E000h to 0FFFFh. This data flash area is mostly used for data storage, but can also store programs. Program ROM 2 is allocated from 10000h to 13FFFh. Program ROM 1 is allocated from FFFFFh and lower, with the 64 KB program ROM 1 area allocated from address F0000h to FFFFFh. The special page vectors are allocated from FFE00h to FFFD7h. They are used for the JMPS and JSRS instructions. Refer to the M16C/60, M16C/20, M16C/Tiny Series Software Manual for details. The fixed vector table for interrupts is allocated from FFFDCh to FFFFFh. The 256 bytes beginning with the start address set in the INTB register compose the relocatable vector table for interrupts. Figure 3.2 shows the Memory Map. Figure 3.2 Memory Map M16C/65C Group 3. Address Space #### 3.3 Accessible Area in Each Mode Areas that can be accessed vary depending on processor mode and the status of each control bit. Figure 3.3 shows the Accessible Area in Each Mode. In single-chip mode, the SFRs, internal RAM, and internal ROM can be accessed. In memory expansion mode, the SFRs, internal RAM, internal ROM, and external areas can be accessed. Address space is expandable to 4 MB with the memory area expansion function. In microprocessor mode, the SFRs, internal RAM, and external areas can be accessed. Address space is expandable to 4 MB with the memory area expansion function. Allocate ROM to the fixed vector table from FFFDCh to FFFFFh. Figure 3.3 Accessible Area in Each Mode # 4. Special Function Registers (SFRs) ### 4.1 SFRs An SFR is a control register for a peripheral function. Table 4.1 SFR Information (1) (1) | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------|----------|---------------------------------------------------------------------------| | 0000h | | | | | 0001h | | | | | 0002h | | | | | 0003h | | | | | 0004h | Processor Mode Register 0 | PM0 | 0000 0000b<br>(CNVSS pin is low)<br>0000 0011b<br>(CNVSS pin is high) (2) | | 0005h | Processor Mode Register 1 | PM1 | 0000 1000b | | 0006h | System Clock Control Register 0 | CM0 | 0100 1000b | | 0007h | System Clock Control Register 1 | CM1 | 0010 0000b | | 0008h | Chip Select Control Register | CSR | 01h | | 0009h | External Area Recovery Cycle Control Register | EWR | XXXX XX00b | | 000Ah | Protect Register | PRCR | 00h | | 000Bh | Data Bank Register | DBR | 00h | | 000Ch | Oscillation Stop Detection Register | CM2 | 0X00 0010b (3) | | 000Dh | | | | | 000Eh | | | | | 000Fh | | | | | 0010h | Program 2 Area Control Register | PRG2C | XXXX XX00b | | 0011h | External Area Wait Control Expansion Register | EWC | 00h | | 0012h | Peripheral Clock Select Register | PCLKR | 0000 0011b | | 0013h | | | | | 0014h | | | | | 0015h | Clock Prescaler Reset Flag | CPSRF | 0XXX XXXXb | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 0017h | | | | | 0018h | Reset Source Determine Register | RSTFR | XX00 001Xb<br>(hardware reset) (4) | | 0019h | Voltage Detector 2 Flag Register | VCR1 | 0000 1000b (5) | | 001Ah | Voltage Detector Operation Enable Register | VCR2 | 00h (5) | | 001Bh | Chip Select Expansion Control Register | CSE | 00h | | 001Ch | PLL Control Register 0 | PLC0 | 0X01 X010b | | 001Dh | | | | | 001Eh | Processor Mode Register 2 | PM2 | XX00 0X01b | | 001Fh | | | | X: Undefined #### Notes: - 1. The blank areas are reserved. No access is allowed. - 2. Software reset, watchdog timer reset, oscillator stop detect reset, voltage monitor 1 reset, and voltage monitor 2 reset do not affect the following bits: bits PM01 and PM00 in the PM0 register. - 3. Oscillator stop detect reset does not affect bits CM20, CM21, and CM27. - 4. The state of bits in the RSTFR register depends on the reset type. - 5. This is the reset value after hardware reset. Refer to the explanation of each register for details. Table 4.2 SFR Information (2) (1) | Address | Register | Symbol | Reset Value | |---------|----------------------------------------------|--------|---------------------------| | 0020h | | | | | 0021h | | | | | 0022h | 40 MHz On-Chip Oscillator Control Register 0 | FRA0 | XXXX XX00b | | 0023h | | | | | 0024h | | | | | 0025h | | | | | 0026h | Voltage Monitor Function Select Register | VWCE | 00h | | 0027h | | | | | 0028h | Voltage Detector 1 Level Select Register | VD1LS | 0000 1010b <sup>(2)</sup> | | 0029h | | | | | 002Ah | Voltage Monitor 0 Control Register | VW0C | 1000 XX10b (2) | | 002Bh | Voltage Monitor 1 Control Register | VW1C | 1000 1010b (2) | | 002Ch | Voltage Monitor 2 Control Register | VW2C | 1000 0X10b <sup>(2)</sup> | | 002Dh | | | | | 002Eh | | | | | 002Fh | | | | | 0030h | | | | | 0031h | | | | | 0032h | | | | | 0033h | | | | | 0034h | | | | | 0035h | | | | | 0036h | | | | | 0037h | | | | | 0038h | | | | | 0039h | | | | | 003Ah | | | | | 003Bh | | | | | 003Ch | | | | | 003Dh | | | | | 003Eh | | | | | 003Fh | | | | #### Notes: - 1. The blank areas are reserved. No access is allowed. - 2. This is the reset value after hardware reset. Refer to the explanation of each register for details. Table 4.3 SFR Information (3) (1) | Address | Register | Symbol | Reset Value | |---------|----------------------------------------------------------------------------------------------|------------------|-------------| | 0040h | | | | | 0041h | | | | | 0042h | INT7 Interrupt Control Register | INT7IC | XX00 X000b | | 0043h | INT6 Interrupt Control Register | INT6IC | XX00 X000b | | 0044h | INT3 Interrupt Control Register | INT3IC | XX00 X000b | | 0045h | Timer B5 Interrupt Control Register | TB5IC | XXXX X000b | | 0046h | Timer B4 Interrupt Control Register UART1 Bus Collision Detection Interrupt Control Register | TB4IC<br>U1BCNIC | XXXX X000b | | 0047h | Timer B3 Interrupt Control Register UART0 Bus Collision Detection Interrupt Control Register | TB3IC<br>U0BCNIC | XXXX X000b | | 0048h | SI/O4 Interrupt Control Register INT5 Interrupt Control Register | S4IC<br>INT5IC | XX00 X000b | | 0049h | SI/O3 Interrupt Control Register INT4 Interrupt Control Register | S3IC<br>INT4IC | XX00 X000b | | 004Ah | UART2 Bus Collision Detection Interrupt Control Register | BCNIC | XXXX X000b | | 004Bh | DMA0 Interrupt Control Register | DM0IC | XXXX X000b | | 004Ch | DMA1 Interrupt Control Register | DM1IC | XXXX X000b | | 004Dh | Key Input Interrupt Control Register | KUPIC | XXXX X000b | | 004Eh | A/D Conversion Interrupt Control Register | ADIC | XXXX X000b | | 004Fh | UART2 Transmit Interrupt Control Register | S2TIC | XXXX X000b | | 0050h | UART2 Receive Interrupt Control Register | S2RIC | XXXX X000b | | 0051h | UART0 Transmit Interrupt Control Register | SOTIC | XXXX X000b | | 0052h | UART0 Receive Interrupt Control Register | SORIC | XXXX X000b | | 0053h | UART1 Transmit Interrupt Control Register | S1TIC | XXXX X000b | | 0054h | UART1 Receive Interrupt Control Register | S1RIC | XXXX X000b | | 0055h | Timer A0 Interrupt Control Register | TA0IC | XXXX X000b | | 0056h | Timer A1 Interrupt Control Register | TA1IC | XXXX X000b | | 0057h | Timer A2 Interrupt Control Register | TA2IC | XXXX X000b | | 0058h | Timer A3 Interrupt Control Register | TA3IC | XXXX X000b | | 0059h | Timer A4 Interrupt Control Register | TA4IC | XXXX X000b | | 005Ah | Timer B0 Interrupt Control Register | TB0IC | XXXX X000b | | 005Bh | Timer B1 Interrupt Control Register | TB1IC | XXXX X000b | | 005Ch | Timer B2 Interrupt Control Register | TB2IC | XXXX X000b | | 005Dh | INTO Interrupt Control Register | INTOIC | XX00 X000b | | 005Eh | INT1 Interrupt Control Register | INT1IC | XX00 X000b | | 005Fh | INT2 Interrupt Control Register | INT2IC | XX00 X000b | #### Note: Table 4.4 SFR Information (4) (1) | Address | Register | Symbol | Reset Value | |----------|-------------------------------------------------------------------------------------------------------------------------|-------------------|-------------| | 0060h | | | | | 0061h | | | | | 0062h | | | | | 0063h | | | | | 0064h | | | | | 0065h | | | | | 0066h | | | | | 0067h | | | | | 0068h | | | | | 0069h | DMA2 Interrupt Control Register | DM2IC | XXXX X000b | | 006Ah | DMA3 Interrupt Control Register | DM3IC | XXXX X000b | | 006Bh | UART5 Bus Collision Detection Interrupt Control Register<br>CEC1 Interrupt Control Register | U5BCNIC<br>CEC1IC | XXXX X000b | | 006Ch | UART5 Transmit Interrupt Control Register<br>CEC2 Interrupt Control Register | S5TIC<br>CEC2IC | XXXX X000b | | 006Dh | UART5 Receive Interrupt Control Register | S5RIC | XXXX X000b | | 006Eh | UART6 Bus Collision Detection Interrupt Control Register<br>Real-Time Clock Periodic Interrupt Control Register | U6BCNIC<br>RTCTIC | XXXX X000b | | 006Fh | UART6 Transmit Interrupt Control Register Real-Time Clock Compare Interrupt Control Register | S6TIC<br>RTCCIC | XXXX X000b | | 0070h | UART6 Receive Interrupt Control Register | S6RIC | XXXX X000b | | 0071h | UART7 Bus Collision Detection Interrupt Control Register<br>Remote Control Signal Receiver 0 Interrupt Control Register | U7BCNIC<br>PMC0IC | XXXX X000b | | 0072h | UART7 Transmit Interrupt Control Register Remote Control Signal Receiver 1 Interrupt Control Register | S7TIC<br>PMC1IC | XXXX X000b | | 0073h | UART7 Receive Interrupt Control Register | S7RIC | XXXX X000b | | 0074h | | | | | 0075h | | | | | 0076h | | | | | 0077h | | | | | 0078h | | | | | 0079h | | | | | 007Ah | | | | | 007Bh | I2C-bus Interface Interrupt Control Register | IICIC | XXXX X000b | | 007Ch | SCL/SDA Interrupt Control Register | SCLDAIC | XXXX X000b | | 007Dh | | | | | 007Eh | | | | | 007Fh | | | | | 0080h to | | | | | 017Fh | | | | #### Note: Table 4.5 SFR Information (5) (1) | Address | Register | Symbol | Reset Value | |-----------------|-----------------------------|-----------|--------------| | 0180h | | | XXh | | 0181h | DMA0 Source Pointer | SAR0 | XXh | | 0182h | | | 0Xh | | 0183h | | | | | 0184h | | | XXh | | 0185h | DMA0 Destination Pointer | DAR0 | XXh | | 0186h | | | 0Xh | | 0187h | | | | | 0188h | | | XXh | | 0189h | DMA0 Transfer Counter | TCR0 | XXh | | 018Ah | | | | | 018Bh | | | | | 018Ch | DMA0 Control Register | DM0CON | 0000 0X00b | | 018Dh | DW// to Control (Coglote) | Biviocoit | 0000 07000 | | 018Eh | | | | | 018Fh | | + | | | 0190h | | | XXh | | 0190h | DMA1 Source Pointer | SAR1 | XXh | | 019111<br>0192h | Divinci Godice i olillei | JAKI | 0Xh | | 0192h | | | UAII | | 0193h | | | XXh | | 0194n<br>0195h | DMA1 Destination Pointer | DAR1 | XXh | | 0195h | | DART | 0Xh | | 0196h | | | UAII | | 019711<br>0198h | | | XXh | | 0199h | DMA1 Transfer Counter | TCR1 | XXh | | 0199h | | | ۸۸۱۱ | | 019An | | | | | 019Bii | DMA1 Control Bosistor | DM1CON | 0000 0X00b | | 019Ch | DMA1 Control Register | DIVITCON | 00000 0000 | | 019Dh<br>019Eh | | | | | | | | | | 019Fh | | | VVI | | 01A0h | DMA2 Course Deinter | 04.00 | XXh | | 01A1h | DMA2 Source Pointer | SAR2 | XXh | | 01A2h | | | 0Xh | | 01A3h | | | VVI | | 01A4h | BMAO B of the first British | 5.50 | XXh | | 01A5h | DMA2 Destination Pointer | DAR2 | XXh | | 01A6h | | | 0Xh | | 01A7h | | | VV | | 01A8h | DMA2 Transfer Counter | TCR2 | XXh | | 01A9h | | | XXh | | 01AAh | | | | | 01ABh | | | | | 01ACh | DMA2 Control Register | DM2CON | 0000 0X00b | | 01ADh | | | | | 01AEh | | | | | 01AFh | | | X: Undefined | #### Note: Table 4.6 SFR Information (6) (1) | Address | Register | Symbol | Reset Value | |---------|----------------------------------------------------------------------|----------|-------------| | 01B0h | j j | , | XXh | | 01B1h | DMA3 Source Pointer | SAR3 | XXh | | 01B2h | | | 0Xh | | 01B3h | | | | | 01B4h | | | XXh | | 01B5h | DMA3 Destination Pointer | DAR3 | XXh | | 01B6h | | | 0Xh | | 01B7h | | | | | 01B8h | DMA3 Transfer Counter | TCR3 | XXh | | 01B9h | Divids Transfer Counter | ICKS | XXh | | 01BAh | | | | | 01BBh | | | | | 01BCh | DMA3 Control Register | DM3CON | 0000 0X00b | | 01BDh | | | | | 01BEh | | | | | 01BFh | | | | | 01C0h | Times D0 4 Desister | TDO4 | XXh | | 01C1h | Timer B0-1 Register | TB01 | XXh | | 01C2h | Times D4 4 Devictor | TD44 | XXh | | 01C3h | -Timer B1-1 Register | TB11 | XXh | | 01C4h | Times D2 4 Desister | TB21 | XXh | | 01C5h | -Timer B2-1 Register | IBZI | XXh | | 01C6h | Pulse Period/Pulse Width Measurement Mode Function Select Register 1 | PPWFS1 | XXXX X000b | | 01C7h | | | | | 01C8h | Timer B Count Source Select Register 0 | TBCS0 | 00h | | 01C9h | Timer B Count Source Select Register 1 | TBCS1 | X0h | | 01CAh | | | | | 01CBh | Timer AB Division Control Register 0 | TCKDIVC0 | 0000 X000b | | 01CCh | | | | | 01CDh | | | | | 01CEh | | | | | 01CFh | | | | | 01D0h | Timer A Count Source Select Register 0 | TACS0 | 00h | | 01D1h | Timer A Count Source Select Register 1 | TACS1 | 00h | | 01D2h | Timer A Count Source Select Register 2 | TACS2 | X0h | | 01D3h | | | | | 01D4h | 16-bit Pulse Width Modulation Mode Function Select Register | PWMFS | 0XX0 X00Xb | | 01D5h | Timer A Waveform Output Function Select Register | TAPOFS | XXX0 0000b | | 01D6h | | | | | 01D7h | | | | | 01D8h | Timer A Output Waveform Change Enable Register | TAOW | XXX0 X00Xb | | 01D9h | | | | | 01DAh | Three-Phase Protect Control Register | TPRC | 00h | | 01DBh | | | | | 01DCh | | | | | 01DDh | | | | | 01DEh | | | | | 01DFh | | | | #### Note: Table 4.7 SFR Information (7) (1) | Table 4.7 | SFR information (7) (7) | | | |-----------|----------------------------------------------------------------------|----------|-------------| | Address | Register | Symbol | Reset Value | | 01E0h | Timer B3-1 Register | TB31 | XXh | | 01E1h | Tilller B3-1 Register | 1031 | XXh | | 01E2h | Timer B4-1 Register | TB41 | XXh | | 01E3h | Timer B4-1 Register | 1641 | XXh | | 01E4h | Timer PE 1 Degister | TB51 | XXh | | 01E5h | Timer B5-1 Register | 1651 | XXh | | 01E6h | Pulse Period/Pulse Width Measurement Mode Function Select Register 2 | PPWFS2 | XXXX X000b | | 01E7h | | | | | 01E8h | Timer B Count Source Select Register 2 | TBCS2 | 00h | | 01E9h | Timer B Count Source Select Register 3 | TBCS3 | X0h | | 01EAh | | | | | 01EBh | | | | | 01ECh | | | | | 01EDh | | | | | 01EEh | | | | | 01EFh | | | | | 01F0h | PMC0 Function Select Register 0 | PMC0CON0 | 00h | | 01F1h | PMC0 Function Select Register 1 | PMC0CON1 | 00XX 0000b | | 01F2h | PMC0 Function Select Register 2 | PMC0CON2 | 0000 00X0b | | 01F3h | PMC0 Function Select Register 3 | PMC0CON3 | 00h | | 01F4h | PMC0 Status Register | PMC0STS | 00h | | 01F5h | PMC0 Interrupt Source Select Register | PMC0INT | 00h | | 01F6h | PMC0 Compare Control Register | PMC0CPC | XXX0 X000b | | 01F7h | PMC0 Compare Data Register | PMC0CPD | 00h | | 01F8h | PMC1 Function Select Register 0 | PMC1CON0 | XXX0 X000b | | 01F9h | PMC1 Function Select Register 1 | PMC1CON1 | XXXX 0X00b | | 01FAh | PMC1 Function Select Register 2 | PMC1CON2 | 0000 00X0b | | 01FBh | PMC1 Function Select Register 3 | PMC1CON3 | 00h | | 01FCh | PMC1 Status Register | PMC1STS | X000 X00Xb | | 01FDh | PMC1 Interrupt Source Select Register | PMC1INT | X000 X00Xb | | 01FEh | | _ | | | 01FFh | | | | | 0200h | | | | | 0201h | | | | | 0202h | | | | | 0203h | | | | | 0204h | | | | | 0205h | Interrupt Source Select Register 3 | IFSR3A | 00h | | 0206h | Interrupt Source Select Register 2 | IFSR2A | 00h | | 0207h | Interrupt Source Select Register | IFSR | 00h | | 0208h | 1 11 11 11 11 11 11 | | | | 0209h | | | | | 020Ah | | | | | 020Bh | | | | | | | | | | | | | | | 020Ch | | | | | | Address Match Interrupt Enable Register | AIER | XXXX XX00b | #### Note: Table 4.8 SFR Information (8) (1) | 14016 4.0 | JEK IIIIOIIIIation (6) (7 | <u> </u> | | |-----------------|------------------------------------|-----------|-----------------------------------------------------------------------------| | Address | Register | Symbol | Reset Value | | 0210h | | | 00h | | 0211h | Address Match Interrupt Register 0 | RMAD0 | 00h | | 0212h | | | X0h | | 0213h | | | | | 0214h | | | 00h | | 0215h | Address Match Interrupt Register 1 | RMAD1 | 00h | | 0216h | | | X0h | | 0217h | | | | | 0218h | | | 00h | | 0219h | Address Match Interrupt Register 2 | RMAD2 | 00h | | 021Ah | | | X0h | | 021Bh | | | | | 021Ch | | | 00h | | 021Dh | Address Match Interrupt Register 3 | RMAD3 | 00h | | 021Eh | · | | X0h | | 021Fh | | | 1 | | 0220h | Flash Memory Control Register 0 | FMR0 | 0000 0001b<br>(Other than user boot mode)<br>0010 0001b<br>(User boot mode) | | 0221h | Flash Memory Control Register 1 | FMR1 | 00X0 XX0Xb | | 0222h | Flash Memory Control Register 2 | FMR2 | XXXX 0000b | | 0223h | Flash Memory Control Register 3 | FMR3 | XXXX 0000b | | 0224h | | | | | 0225h | | | | | 0226h | | | | | 0227h | | | | | 0228h | | | | | 0229h | | | | | 022Ah | | | | | 022Bh | | | | | 022Ch | | | | | 022Dh | | | | | 022Eh | | | | | 022Fh | | | | | 0230h | Flash Memory Control Register 6 | FMR6 | XX0X XX00b | | 0231h | I lash wellery control register o | 1 1011110 | 70.07.70.005 | | 023111<br>0232h | | | + | | 0232h | | | | | 0233h | | | + | | 0234fi<br>0235h | | | | | | | | | | 0236h | | | | | 0237h | | | | | 0238h | | | | | 0239h | | | | | 023Ah | | | | | 023Bh | | | | | 023Ch | | | | | 023Dh | | | | | 023Eh | | | | | 023Fh | | | V. Hadafia ad | # Note: Table 4.9 SFR Information (9) (1) | | of K information (9) | | | |---------|-------------------------------------------------------------|----------|-------------------| | Address | Register | Symbol | Reset Value | | 0240h | | | | | 0241h | | | | | 0242h | | | | | 0243h | | | | | 0244h | UART0 Special Mode Register 4 | U0SMR4 | 00h | | 0245h | UART0 Special Mode Register 3 | U0SMR3 | 000X 0X0Xb | | 0246h | UART0 Special Mode Register 2 | U0SMR2 | X000 0000b | | 0247h | UART0 Special Mode Register | U0SMR | X000 0000b | | 0248h | UART0 Transmit/Receive Mode Register | U0MR | 00h | | 0249h | UART0 Bit Rate Register | U0BRG | XXh | | 024Ah | UART0 Transmit Buffer Register | LIOTE | XXh | | 024Bh | | U0TB — | XXh | | 024Ch | UART0 Transmit/Receive Control Register 0 | U0C0 | 0000 1000b | | 024Dh | UART0 Transmit/Receive Control Register 1 | U0C1 | 00XX 0010b | | 024Eh | | 11000 | XXh | | 024Fh | UART0 Receive Buffer Register | U0RB — | XXh | | 0250h | UART Transmit/Receive Control Register 2 | UCON | X000 0000b | | 0251h | , | | | | 0252h | UART Clock Select Register | UCLKSEL0 | X0h | | 0253h | | | | | 0254h | UART1 Special Mode Register 4 | U1SMR4 | 00h | | 0255h | UART1 Special Mode Register 3 | U1SMR3 | 000X 0X0Xb | | 0256h | UART1 Special Mode Register 2 | U1SMR2 | X000 0000b | | 0257h | UART1 Special Mode Register | U1SMR | X000 0000b | | 0258h | UART1 Transmit/Receive Mode Register | U1MR | 00h | | 0259h | UART1 Bit Rate Register | U1BRG | XXh | | 025Ah | UART1 Transmit Buffer Register | U1TB | XXh | | 025Bh | | | XXh | | 025Ch | UART1 Transmit/Receive Control Register 0 | U1C0 | 0000 1000b | | 025Dh | UART1 Transmit/Receive Control Register 1 | U1C1 | 00XX 0010b | | 025Eh | DART I Transmit Receive Control Register 1 | 8181 | XXh | | 025Eh | UART1 Receive Buffer Register | U1RB — | XXh | | 0260h | | | Ж | | 0261h | | | | | 0262h | | | | | 0262h | | | | | 0264h | IJAPT2 Special Mode Pegister 4 | U2SMR4 | 00h | | | UART2 Special Mode Register 4 UART2 Special Mode Register 3 | | 00h<br>000X 0X0Xb | | | | U2SMR3 | | | 0266h | UART2 Special Mode Register 2 | U2SMR2 | X000 0000b | | 0267h | UART2 Special Mode Register | U2SMR | X000 0000b | | 0268h | UART2 Transmit/Receive Mode Register | U2MR | 00h | | 0269h | UART2 Bit Rate Register | U2BRG | XXh | | 026Ah | UART2 Transmit Buffer Register | U2TB — | XXh | | 026Bh | - | | XXh | | 026Ch | UART2 Transmit/Receive Control Register 0 | U2C0 | 0000 1000b | | 026Dh | UART2 Transmit/Receive Control Register 1 | U2C1 | 0000 0010b | | 026Eh | UART2 Receive Buffer Register | U2RB — | XXh | | 026Fh | | | XXh | #### Note: Table 4.10 SFR Information (10) (1) | 14516 4.11 | o or k information (10) (7 | | | |------------|-------------------------------------------|--------|-------------| | Address | Register | Symbol | Reset Value | | 0270h | SI/O3 Transmit/Receive Register | S3TRR | XXh | | 0271h | | | | | 0272h | SI/O3 Control Register | S3C | 0100 0000b | | 0273h | SI/O3 Bit Rate Register | S3BRG | XXh | | 0274h | SI/O4 Transmit/Receive Register | S4TRR | XXh | | 0275h | | | | | 0276h | SI/O4 Control Register | S4C | 0100 0000b | | 0277h | SI/O4 Bit Rate Register | S4BRG | XXh | | 0278h | SI/O3, 4 Control Register 2 | S34C2 | 00XX X0X0b | | 0279h | | | | | 027Ah | | | | | 027Bh | | | | | 027Ch | | | | | 027Dh | | | | | 027Eh | | | | | 027Fh | | | | | 0280h | | | | | 0281h | | | | | 0282h | | | | | 0283h | | | | | 0284h | UART5 Special Mode Register 4 | U5SMR4 | 00h | | 0285h | UART5 Special Mode Register 3 | U5SMR3 | 000X 0X0Xb | | 0286h | UART5 Special Mode Register 2 | U5SMR2 | X000 0000b | | 0287h | UART5 Special Mode Register | U5SMR | X000 0000b | | 0288h | UART5 Transmit/Receive Mode Register | U5MR | 00h | | 0289h | UART5 Bit Rate Register | U5BRG | XXh | | 028Ah | - | | XXh | | 028Bh | UART5 Transmit Buffer Register | U5TB | XXh | | 028Ch | UART5 Transmit/Receive Control Register 0 | U5C0 | 0000 1000b | | 028Dh | UART5 Transmit/Receive Control Register 1 | U5C1 | 0000 0010b | | 028Eh | | | XXh | | 028Fh | UART5 Receive Buffer Register | U5RB _ | XXh | | 0290h | | | | | 0291h | | | | | 0292h | | | | | 0293h | | | | | 0294h | UART6 Special Mode Register 4 | U6SMR4 | 00h | | | UART6 Special Mode Register 3 | U6SMR3 | 000X 0X0Xb | | 0296h | UART6 Special Mode Register 2 | U6SMR2 | X000 0000b | | 0297h | UART6 Special Mode Register | U6SMR | X000 0000b | | 0298h | UART6 Transmit/Receive Mode Register | U6MR | 00h | | 0299h | UART6 Bit Rate Register | U6BRG | XXh | | 029Ah | | | XXh | | 029Bh | UART6 Transmit Buffer Register | U6TB — | XXh | | 029Ch | UART6 Transmit/Receive Control Register 0 | U6C0 | 0000 1000b | | 029Dh | UART6 Transmit/Receive Control Register 1 | U6C1 | 0000 1000b | | 029Eh | | | XXh | | UZULII | UART6 Receive Buffer Register | U6RB | AAH | #### Note: Table 4.11 SFR Information (11) (1) | Address | Register | Symbol | Reset Value | |----------|--------------------------------------------|--------|--------------| | 02A0h | | | | | 02A1h | | | | | 02A2h | | | | | 02A3h | | | | | 02A4h | UART7 Special Mode Register 4 | U7SMR4 | 00h | | 02A5h | UART7 Special Mode Register 3 | U7SMR3 | 000X 0X0Xb | | 02A6h | UART7 Special Mode Register 2 | U7SMR2 | X000 0000b | | 02A7h | UART7 Special Mode Register | U7SMR | X000 0000b | | 02A8h | UART7 Transmit/Receive Mode Register | U7MR | 00h | | 02A9h | UART7 Bit Rate Register | U7BRG | XXh | | 02AAh | UART7 Transmit Buffer Register | U7TB | XXh | | 02ABh | OART/ Hansinii buller Register | 0/16 | XXh | | 02ACh | UART7 Transmit/Receive Control Register 0 | U7C0 | 0000 1000b | | 02ADh | UART7 Transmit/Receive Control Register 1 | U7C1 | 0000 0010b | | 02AEh | UART7 Receive Buffer Register | U7RB - | XXh | | 02AFh | DAKT/ Receive Bullet Register | 0/16 | XXh | | 02B0h | I2C0 Data Shift Register | S00 | XXh | | 02B1h | | | | | 02B2h | I2C0 Address Register 0 | S0D0 | 0000 000Xb | | 02B3h | I2C0 Control Register 0 | S1D0 | 00h | | 02B4h | I2C0 Clock Control Register | S20 | 00h | | 02B5h | I2C0 Start/Stop Condition Control Register | S2D0 | 0001 1010b | | 02B6h | I2C0 Control Register 1 | S3D0 | 0011 0000b | | 02B7h | I2C0 Control Register 2 | S4D0 | 00h | | 02B8h | I2C0 Status Register 0 | S10 | 0001 000Xb | | 02B9h | I2C0 Status Register 1 | S11 | XXXX X000b | | 02BAh | I2C0 Address Register 1 | S0D1 | 0000 000Xb | | 02BBh | I2C0 Address Register 2 | S0D2 | 0000 000Xb | | 02BCh | | | | | 02BDh | | | | | 02BEh | | | <u> </u> | | 02BFh | | | | | 02C0h to | | | | | 02FFh | | | X: Undefined | #### Note: Table 4.12 SFR Information (12) (1) | Address | Register | Symbol | Reset Value | |-----------------|-----------------------------------------------------|--------------------------|--------------| | 0300h | Timer B3/B4/B5 Count Start Flag | TBSR | 000X XXXXb | | 0301h | | | | | 0302h | T | T0.44 | XXh | | 0303h | Timer A1-1 Register | TA11 | XXh | | 0304h | | | XXh | | 0305h | Timer A2-1 Register | TA21 | XXh | | 0306h | | | XXh | | 0307h | Timer A4-1 Register | TA41 | XXh | | 0308h | Three-Phase PWM Control Register 0 | INVC0 | 00h | | 0309h | Three-Phase PWM Control Register 1 | INVC1 | 00h | | 030Ah | Three-Phase Output Buffer Register 0 | IDB0 | XX11 1111b | | 030Bh | Three-Phase Output Buffer Register 1 | | XX11 1111b | | 030Ch | Dead Time Timer | | XXh | | 030Dh | Timer B2 Interrupt Generation Frequency Set Counter | | XXh | | 030Eh | Position-Data-Retain Function Control Register | | XXXX 0000b | | 030En | - Conton Data Notali Franction Control Neglotei | 1 DIXI | 7//// 0000D | | 030FII | | | XXh | | 0310h | Timer B3 Register | TB3 | XXh | | 0311h | | TB4 TB5 PFCR TB3MR TB4MR | XXh | | 0312h | Timer B4 Register | TB4 | XXh | | 0314h | | | XXh | | 0314II<br>0315h | Timer B5 Register | TB5 | XXh | | 0316h | | | ۸۸۱۱ | | 0317h | | | | | | Dort Function Control Desigtor | DECD | 0044 4444b | | 0318h<br>0319h | Port Function Control Register | PFCR | 0011 1111b | | 0319h | | | | | | Tirran DO Maria Danistan | TDOMD | 00/// 00001- | | 031Bh | Timer B3 Mode Register | | 00XX 0000b | | 031Ch | Timer B4 Mode Register | | 00XX 0000b | | 031Dh | Timer B5 Mode Register | TB5MR | 00XX 0000b | | 031Eh | | | | | 031Fh | | T4000 | 201 | | 0320h | Count Start Flag | TABSR | 00h | | 0321h | 0 0 10 15 | 6::2= | 00: | | 0322h | One-Shot Start Flag | ONSF | 00h | | 0323h | Trigger Select Register | TRGSR | 00h | | 0324h | Increment/Decrement Flag | UDF | 00h | | 0325h | | | 102 | | 0326h | Timer A0 Register | TA0 | XXh | | 0327h | . 3 | | XXh | | 0328h | Timer A1 Register | TA1 | XXh | | 0329h | | 1731 | XXh | | 032Ah | Timer A2 Register | TA2 | XXh | | 032Bh | Timor / Le regiotor | 1/12 | XXh | | 032Ch | Timer A3 Register | TA3 | XXh | | 032Dh | Timor Ao Register | 1/1/3 | XXh | | 032Eh | Timer A4 Register | TA4 | XXh | | 032Fh | Tillioi 714 (Cegistei | 1/4 | XXh | #### Note: Table 4.13 SFR Information (13) (1) | Address | Register | Symbol | Reset Value | |---------|------------------------------------------------------------------|-----------------|-------------| | 0330h | Timer PO Degister | TB0 | XXh | | 0331h | -Timer B0 Register | 180 | XXh | | 0332h | Timor P1 Dogistor | TB1 | XXh | | 0333h | -Timer B1 Register | I IBI | XXh | | 0334h | Timer DO Degister | TDO | XXh | | 0335h | -Timer B2 Register | TB2 | XXh | | 0336h | Timer A0 Mode Register | TA0MR | 00h | | 0337h | Timer A1 Mode Register | TA1MR | 00h | | 0338h | Timer A2 Mode Register | TA2MR | 00h | | 0339h | Timer A3 Mode Register | TA3MR | 00h | | 033Ah | Timer A4 Mode Register | TA4MR | 00h | | 033Bh | Timer B0 Mode Register | TB0MR | 00XX 0000b | | 033Ch | Timer B1 Mode Register | TB1MR | 00XX 0000b | | 033Dh | Timer B2 Mode Register | TB2MR | 00XX 0000b | | 033Eh | Timer B2 Special Mode Register | TB2SC | X000 0000b | | 033Fh | -1 | | | | 0340h | Real-Time Clock Second Data Register | RTCSEC | 00h | | 0341h | Real-Time Clock Minute Data Register | RTCMIN | X000 0000b | | 0342h | Real-Time Clock Hour Data Register | RTCHR | XX00 0000b | | 0343h | Real-Time Clock Day Data Register | RTCWK | XXXX X000b | | 0344h | Real-Time Clock Control Register 1 | RTCCR1 | 0000 X00Xb | | 0345h | Real-Time Clock Control Register 2 | RTCCR2 | X000 0000b | | 0346h | Real-Time Clock Count Source Select Register | RTCCSR | XXX0 0000b | | 0347h | Treat Time Glock Count Course Geloc Tregister | KIOOOK | 700000000 | | 0348h | Real-Time Clock Second Compare Data Register | RTCCSEC | X000 0000b | | 0349h | Real-Time Clock Minute Compare Data Register | RTCCMIN | X000 0000b | | 034Ah | Real-Time Clock Hour Compare Data Register | RTCCHR | X000 0000b | | 034Bh | Treat Time Glock Float Compare Bata Register | TOOTIK | 7,000 00000 | | 034Ch | | | | | 034Dh | | | | | 034Eh | | | | | 034Fh | | | | | 0350h | CEC Function Control Register 1 | CECC1 | XXXX X000b | | 0350h | CEC Function Control Register 2 | CECC2 | 00h | | 0351h | CEC Function Control Register 2 CEC Function Control Register 3 | CECC2 | XXXX 0000b | | 0352h | CEC Function Control Register 3 CEC Function Control Register 4 | CECC3 | 00h | | 0354h | = | CECC4<br>CECFLG | | | | CEC Flag Register | | 00h | | 0355h | CEC Interrupt Source Select Register | CISEL | 00h | | 0356h | CEC Transmit Buffer Register 1 | CCTB1 | 00h | | 0357h | CEC Transmit Buffer Register 2 | CCTB2 | XXXX XX00b | | 0358h | CEC Receive Buffer Register 1 | CCRB1 | 00h | | 0359h | CEC Receive Buffer Register 2 | CCRB2 | XXXX X000b | | 035Ah | CEC Receive Follower Address Set Register 1 | CRADRI1 | 00h | | 035Bh | CEC Receive Follower Address Set Register 2 | CRADRI2 | 00h | | 035Ch | | | | | 035Dh | | | | | 035Eh | | | | | 035Fh | | | | #### Note: Table 4.14 SFR Information (14) (1) | Address | Register | Symbol | Reset Value | |-------------------|---------------------------------------|---------|--------------------| | 0360h | Pull-Up Control Register 0 | PUR0 | 00h | | 0361h | Pull-Up Control Register 1 | PUR1 | 0000 0000b(2) | | | | | 0000 0010b | | 0362h | Pull-Up Control Register 2 | PUR2 | 00h | | 0363h | Pull-Up Control Register 3 | PUR3 | 00h | | 0364h | | | | | 0365h | | | | | 0366h | Port Control Register | PCR | 0000 0XX0b | | 0367h | | | | | 0368h | | | | | 0369h | NMI/SD Digital Filter Register | NMIDF | XXXX X000b | | 036Ah | | | | | 036Bh | | | | | 036Ch | | | | | 036Dh | | | | | 036Eh | | | | | 036Fh | | | | | 0370h | PWM Control Register 0 | PWMCON0 | 00h | | 0371h | | | | | 0372h | PWM0 Prescaler | PWMPRE0 | 00h | | 0373h | PWM0 Register | PWMREG0 | 00h | | 0374h | PWM1 Prescaler | PWMPRE1 | 00h | | 0375h | PWM1 Register | PWMREG1 | 00h | | 0376h | PWM Control Register 1 | PWMCON1 | 00h | | 0377h | | | | | 0378h | | | | | 0379h | | | | | 037Ah | | | | | 037Bh | | | | | 037Ch | Count Source Protection Mode Register | CSPR | 00h <sup>(3)</sup> | | 037Dh | Watchdog Timer Refresh Register | WDTR | XXh | | 037Eh | Watchdog Timer Start Register | WDTS | XXh | | 037Fh | Watchdog Timer Control Register | WDC | 00XX XXXXb | | 0380h to<br>038Fh | | | | | | | | X: Undefined | #### Notes: - 1. The blank areas are reserved. No access is allowed. - 2. Values after hardware reset, power-on reset, or voltage monitor 0 reset are as follows: - 00000000b when a low-level signal is input to the CNVSS pin $\,$ - 00000010b when a high-level signal is input to the CNVSS pin Values after voltage monitor 1 reset, voltage monitor 2 reset, software reset, watchdog timer reset, or oscillation stop detect reset are as follows: - 00000000b when bits PM01 and PM00 in the PM0 register are 00b (single-chip mode). - 00000010b when bits PM01 and PM00 in the PM0 register are 01b (memory expansion mode) or 11b (microprocessor mode). - 3. When the CSPROINI bit in the OFS1 address is 0, the reset value is 1000 0000b. Table 4.15 SFR Information (15) (1) | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------------|---------|-------------| | 0390h | DMA2 Source Select Register | DM2SL | 00h | | 0390h | DIVIAZ Source Select Negister | DIVIZGE | 0011 | | 0391h | DMA2 Course Colort Register | DM3SL | 00h | | 0392h | DMA3 Source Select Register | DIVISSE | 0011 | | 0394h | | | | | | | | | | 0395h | | | | | 0396h | | | | | 0397h | DMAQ Quant Quita Business | BMOOL | 001 | | 0398h | DMA0 Source Select Register | DM0SL | 00h | | 0399h | DWW 0 | 211101 | 001 | | 039Ah | DMA1 Source Select Register | DM1SL | 00h | | 039Bh | | | | | 039Ch | | | | | 039Dh | | | | | 039Eh | | | | | 039Fh | | | | | 03A0h | | | | | 03A1h | | | | | 03A2h | Open-Circuit Detection Assist Function Register | AINRST | XX00 XXXXb | | 03A3h | | | | | 03A4h | | | | | 03A5h | | | | | 03A6h | | | | | 03A7h | | | | | 03A8h | | | | | 03A9h | | | | | 03AAh | | | | | 03ABh | | | | | 03ACh | | | | | 03ADh | | | | | 03AEh | | | | | 03AFh | | | | | 03B0h | | | | | 03B1h | | | | | 03B2h | | | | | 03B3h | | | | | 03B4h | 050.0 | 656615 | XXXX XXXXb | | 03B5h | SFR Snoop Address Register | CRCSAR | 00XX XXXXb | | 03B6h | CRC Mode Register | CRCMR | 0XXX XXX0b | | 03B7h | | 2 | | | 03B8h | | | | | 03B9h | | | | | 03BAh | | | | | 03BBh | | | | | 03BCh | | | XXh | | 03BDh | CRC Data Register | CRCD | XXh | | 03BEh | CRC Input Register | CRCIN | XXh | | COLICII | TOTO INPUT NEGISTEI | CKCIN | AAII | #### Note: Table 4.16 SFR Information (16) (1) | Address | Register | Symbol | Reset Value | |---------|---------------------------------------|----------|-------------------| | 03C0h | A/D Register 0 | AD0 | XXXX XXXXb | | 03C1h | No Register 0 | l Abo | 0000 00XXb | | 03C2h | A/D Register 1 | AD1 | XXXX XXXXb | | 03C3h | AD Register 1 | l Abi | 0000 00XXb | | 03C4h | A/D Register 2 | AD2 | XXXX XXXXb | | 03C5h | A/D Register 2 | AD2 | 0000 00XXb | | 03C6h | A/D Register 2 | AD2 | XXXX XXXXb | | 03C7h | A/D Register 3 | AD3 | 0000 00XXb | | 03C8h | A/D Register 4 | AD4 | XXXX XXXXb | | 03C9h | AD Register 4 | AD4 | 0000 00XXb | | 03CAh | A/D Decistor F | ADE | XXXX XXXXb | | 03CBh | A/D Register 5 | AD5 | 0000 00XXb | | 03CCh | A/D Desistan C | ADC | XXXX XXXXb | | 03CDh | A/D Register 6 | AD6 | 0000 00XXb | | 03CEh | A/D D | 457 | XXXX XXXXb | | 03CFh | A/D Register 7 | AD7 | 0000 00XXb | | 03D0h | | | | | 03D1h | | | | | 03D2h | | | | | 03D3h | | | | | 03D4h | A/D Control Register 2 | ADCON2 | 0000 X00Xb | | 03D5h | | | | | 03D6h | A/D Control Register 0 | ADCON0 | 0000 0XXXb | | 03D7h | A/D Control Register 1 | ADCON1 | 0000 X000b | | 03D8h | D/A0 Register | DA0 | 00h | | 03D9h | I I I I I I I I I I | 27.0 | | | 03DAh | D/A1 Register | DA1 | 00h | | 03DBh | | | | | 03DCh | D/A Control Register | DACON | 00h | | 03DDh | D// Control (Cognition) | 27,10011 | 0011 | | 03DEh | | | | | 03DFh | | | | | 03E0h | Port P0 Register | P0 | XXh | | 03E1h | Port P1 Register | P1 | XXh | | 03E1h | Port P0 Direction Register | PD0 | 00h | | 03E3h | Port P1 Direction Register | PD1 | 00h | | 03E3h | Port P2 Register | P2 | XXh | | 03E5h | Port P3 Register | P3 | XXh | | 03E6h | Port P2 Direction Register | PD2 | 00h | | 03E7h | Port P3 Direction Register | PD3 | 00h | | 03E7h | | PD3 | XXh | | 03E8h | Port P4 Register | P5 | XXh | | 03E9h | Port P5 Register | PD4 | | | | Port P4 Direction Register | | 00h | | 03EBh | Port P5 Direction Register | PD5 | 00h | | 03ECh | Port P6 Register | P6 | XXh | | 03EDh | Port P7 Register | P7 | XXh | | 03EEh | Port P6 Direction Register | PD6 | 00h | | 03EFh | Port P7 Direction Register | PD7 | 00h<br>X: Undofir | #### Note: Table 4.17 SFR Information (17) (1) | Address | ess Register Symbol | | Reset Value | |---------|-----------------------------|------|-------------| | 03F0h | Port P8 Register | P8 | XXh | | 03F1h | Port P9 Register | P9 | XXh | | 03F2h | Port P8 Direction Register | PD8 | 00h | | 03F3h | Port P9 Direction Register | PD9 | 00h | | 03F4h | Port P10 Register | P10 | XXh | | 03F5h | Port P11 Register | P11 | XXh | | 03F6h | Port P10 Direction Register | PD10 | 00h | | 03F7h | Port P11 Direction Register | PD11 | 00h | | 03F8h | Port P12 Register | P12 | XXh | | 03F9h | Port P13 Register | P13 | XXh | | 03FAh | Port P12 Direction Register | PD12 | 00h | | 03FBh | Port P13 Direction Register | PD13 | 00h | | 03FCh | Port P14 Register | P14 | XXh | | 03FDh | | | | | 03FEh | Port P14 Direction Register | PD14 | XXXX XX00b | | 03FFh | | | | #### Note: Table 4.18 SFR Information (18) (1) | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | D080h | DMCO Lloader Dettern Cat Degister (Min) | DMCOLIDDMIN | 0000 0000b | | D081h | -PMC0 Header Pattern Set Register (Min) | PMCOHDPMIN | XXXX X000b | | D082h | DMC0 Hooder Pottern Cat Register (May) | DMCOHDDMAX | 0000 0000b | | D083h | -PMC0 Header Pattern Set Register (Max) | PMC0HDPMIN PMC0HDPMAX PMC0D0PMIN PMC0D0PMAX PMC0D1PMIN PMC0D1PMAX PMC0D1PMAX PMC0DAT0 PMC0DAT1 PMC0DAT2 PMC0DAT3 PMC0DAT3 PMC0DAT4 PMC0DAT5 PMC0DAT5 PMC0DAT5 PMC0DAT5 PMC1HDPMIN PMC1HDPMAX PMC1D0PMIN PMC1D0PMAX | XXXX X000b | | D084h | PMC0 Data 0 Pattern Set Register (Min) | PMC0D0PMIN | 00h | | D085h | PMC0 Data 0 Pattern Set Register (Max) | PMC0D0PMAX | 00h | | D086h | PMC0 Data 1 Pattern Set Register (Min) | PMC0D1PMIN | 00h | | D087h | PMC0 Data 1 Pattern Set Register (Max) | PMC0D1PMAX | 00h | | D088h | PMC0 Measurements Register | DMCOTIM | 00h | | D089h | Pivico measurements Register | PIVICOTIIVI | 00h | | D08Ah | | | | | D08Bh | | | | | D08Ch | PMC0 Receive Data Store Register 0 | PMC0DAT0 | 00h | | D08Dh | PMC0 Receive Data Store Register 1 | PMC0DAT1 | 00h | | D08Eh | PMC0 Receive Data Store Register 2 | PMC0DAT2 | 00h | | D08Fh | PMC0 Receive Data Store Register 3 | PMC0DAT3 | 00h | | D090h | PMC0 Receive Data Store Register 4 | PMC0DAT4 | 00h | | D091h | PMC0 Receive Data Store Register 5 | PMC0DAT5 | 00h | | D092h | PMC0 Receive Bit Count Register | PMC0RBIT | XX00 0000b | | D093h | | | | | D094h | DMC4 Hooder Pottern Cat Register (Min) | DMC4HDDMIN | 0000 0000b | | D095h | -PMC1 Header Pattern Set Register (Min) | PIVICTADPIVIIN | XXXX X000b | | D096h | DMC4 Hander Dettern Cat Desigter (May) | DMCALIDDMAX | 0000 0000b | | D097h | -PMC1 Header Pattern Set Register (Max) | PINIC I HOPINIAX | XXXX X000b | | D098h | PMC1 Data 0 Pattern Set Register (Min) | PMC1D0PMIN | 00h | | D099h | PMC1 Data 0 Pattern Set Register (Max) | PMC1D0PMAX | 00h | | D09Ah | PMC1 Data 1 Pattern Set Register (Min) | PMC1D1PMIN | 00h | | D09Bh | PMC1 Data 1 Pattern Set Register (Max) | PMC1D1PMAX | 00h | | D09Ch | PMC1 Measurements Register | PMC1TIM | 00h | | D09Dh | Trivio i ivicasulements negistei | FINICITIN | 00h | | D09Eh | | | | | D09Fh | | | | #### Note: ## 4.2 Notes on SFRs # 4.2.1 Register Settings Table 4.19 lists Registers with Write-Only Bits and registers whose function differs between reading and writing. Set these registers with immediate values. Do not use read-modify-write instructions. When establishing the next value by altering the existing value, write the existing value to the RAM as well as to the register. Transfer the next value to the register after making changes in the RAM. Read-modify-write instructions can be used when writing to the no register bits. Table 4.19 Registers with Write-Only Bits | Address | Register | Symbol | |----------------|-----------------------------------------------------|--------| | 0249h | UART0 Bit Rate Register | U0BRG | | 024Bh to 024Ah | UART0 Transmit Buffer Register | U0TB | | 0259h | UART1 Bit Rate Register | U1BRG | | 025Bh to 025Ah | UART1 Transmit Buffer Register | U1TB | | 0269h | UART2 Bit Rate Register | U2BRG | | 026Bh to 026Ah | UART2 Transmit Buffer Register | U2TB | | 0273h | SI/O3 Bit Rate Register | S3BRG | | 0277h | SI/O4 Bit Rate Register | S4BRG | | 0289h | UART5 Bit Rate Register | U5BRG | | 028Bh to 028Ah | UART5 Transmit Buffer Register | U5TB | | 0299h | UART6 Bit Rate Register | U6BRG | | 029Bh to 029Ah | UART6 Transmit Buffer Register | U6TB | | 02A9h | UART7 Bit Rate Register | U7BRG | | 02ABh to 02AAh | UART7 Transmit Buffer Register | U7TB | | 02B6h | I2C0 Control Register 1 | S3D0 | | 02B8h | I2C0 Status Register 0 | S10 | | 0303h to 0302h | Timer A1-1 Register | TA11 | | 0305h to 0304h | Timer A2-1 Register | TA21 | | 0307h to 0306h | Timer A4-1 Register | TA41 | | 030Ah | Three-Phase Output Buffer Register 0 | IDB0 | | 030Bh | Three-Phase Output Buffer Register 1 | IDB1 | | 030Ch | Dead Time Timer | DTT | | 030Dh | Timer B2 Interrupt Generation Frequency Set Counter | ICTB2 | | 0327h to 0326h | Timer A0 Register | TA0 | | 0329h to 0328h | Timer A1 Register | TA1 | | 032Bh to 032Ah | Timer A2 Register | TA2 | | 032Dh to 032Ch | Timer A3 Register | TA3 | | 032Fh to 032Eh | Timer A4 Register | TA4 | | 037Dh | Watchdog Timer Refresh Register | WDTR | | 037Eh | Watchdog Timer Start Register | WDTS | Table 4.20 Read-Modify-Write Instructions | Function | Mnemonic | |----------------------|------------------------------------------------------------------------------------| | Transfer | MOVDir | | Bit processing | BCLR, BMCnd, BNOT, BSET, BTSTC, and BTSTS | | Shifting | ROLC, RORC, ROT, SHA, and SHL | | Arithmetic operation | ABS, ADC, ADCF, ADD, DEC, DIV, DIVU, DIVX, EXTS, INC, MUL, MULU, NEG, SBB, and SUB | | Decimal operation | DADC, DADD, DSBB, and DSUB | | Logical operation | AND, NOT, OR, and XOR | | Jump | ADJNZ, SBJNZ | M16C/65C Group 5. Protection ## 5. Protection #### 5.1 Introduction In the event that a program runs out of control, this function protects the important registers so that they will not be rewritten easily. # 5.2 Register Table 5.1 Registers | Address | Register | Symbol | Reset Value | |---------|------------------|--------|-------------| | 000Ah | Protect Register | PRCR | 00h | # 5.2.1 Protect Register (PRCR) M16C/65C Group 5. Protection # PRC6, PRC3, PRC1, PRC0 (Protect bits 6, 3, 1, 0) (b6, b3, b1, b0) When setting bits PRC6, PRC3, PRC1, and PRC0 to 1 (write enabled), these bits remain 1 (write enabled). To change registers protected by these bits, follow these steps: - (1) Set the PRCi bit to 1. (i = 0, 1, 3, 6) - (2) Write to the register protected by the PRCi bit. - (3) Set the PRCi bit to 0 (write protected). #### PRC2 (Protect bit 2) (b2) After setting the PRC2 bit to 1 (write enabled), by writing to a given SFR, the PRC2 bit becomes 0. Change the registers protected by the PRC2 bit in the next instruction after setting the PRC2 bit to 1. The steps are shown below. Make sure there are no interrupts or DMA transfers between steps (1) and (2). - (1) Set the PRC2 bit to 1. - (2) Write to the register protected by the PRC2 bit. M16C/65C Group 5. Protection ## 5.3 Notes on Protection After setting the PRC2 bit to 1 (write enabled), by writing to a given SFR, the PRC2 bit becomes 0 (write disabled). Change the registers protected by the PRC2 bit in the next instruction after setting the PRC2 bit to 1. Make sure there are no interrupts or DMA transfers between the instruction that sets the PRC2 bit to 1 and the next instruction. ## 6. Resets #### 6.1 Introduction The following resets can be used to reset the MCU: hardware reset, power-on reset, voltage monitor 0 reset, voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, and software reset. Table 6.1 lists the Types of Resets and Figure 6.1 shows the Reset Circuit Block Diagram. Symbols (A) to (D) in the table and figure is explained in Table 6.2. Table 6.3 lists the I/O Pins. Table 6.1 Types of Resets | Reset Name | Trigger | Registers and Bits Not to Reset | |------------------------------|------------------------------------------------------|---------------------------------| | Hardware reset | A low-level signal is applied to the RESET pin. | (A) | | Power-on reset | A rise in voltage on VCC1 | N/A | | Voltage monitor 0 reset | A drop in voltage on VCC1 (reference voltage: Vdet0) | N/A | | Voltage monitor 1 reset | A drop in voltage on VCC1 (reference voltage: Vdet1) | (B) | | Voltage monitor 2 reset | A drop in voltage on VCC1 (reference voltage: Vdet2) | (B) | | Oscillator stop detect reset | A stop in the main clock oscillator is detected. | (B) (C) (D) | | Watchdog timer reset | The watchdog timer underflows. | (B) (C) | | Software reset | Setting the PM03 bit in the PM0 register to 1. | (B) (C) | Figure 6.1 Reset Circuit Block Diagram Table 6.2 Classification of SFRs Which are Reset | SFR | Register and Bit | | | |--------------------------------|-----------------------------------------------|--|--| | SFR (A) | Bits OSDR and CWR in the RSTFR register | | | | | CWR bit in the RSTFR register | | | | Registers VCR1, VCR2, and VW0C | | | | | SFR (B) | Bits VW1C2 and VW1C3 in the VW1C register | | | | | Bits VW2C2 and VW2C3 in the VW2C register | | | | | Bits PM00 and PM01 in the PM0 register | | | | SFR (C) | VD1LS register | | | | SFR (D) | Bits CM20, CM21, and CM27 in the CM2 register | | | ## Table 6.3 I/O Pins | Pin | I/O | Function | |-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------| | RESET | Input | Hardware reset input | | VCC1 | Input | Power input. The power-on reset, voltage monitor 0 reset, voltage monitor 1 reset, and voltage monitor 2 reset are generated by monitoring VCC1. | | XIN | Input | Main clock input. The oscillator stop detect reset is generated by monitoring the main clock. | # 6.2 Registers Refer to 7. "Voltage Detector" for registers used with the voltage monitor 0 reset, voltage monitor 1 reset, and voltage monitor 2 reset. Refer to 15. "Watchdog Timer" for registers used with the watchdog timer reset. Refer to 8.7 "Oscillator Stop/Restart Detect Function" for registers used with the oscillator stop detect reset. Table 6.4 Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------------|--------|-----------------------------------------------------------------| | 0004h | Processor Mode Register 0 | PM0 | 0000 0000b (CNVSS pin is low)<br>0000 0011b (CNVSS pin is high) | | 0018h | Reset Source Determine Register | RSTFR | _ (1) | Note: 1. Refer to 6.2.2 "Reset Source Determine Register (RSTFR)" # 6.2.1 Processor Mode Register 0 (PM0) Write to this register after setting the PRC1 bit in the PRCR register to 1 (write enabled). The software reset, watchdog timer reset, oscillator stop detect reset, voltage monitor 1 reset, and voltage monitor 2 reset have no effect on bits PM01 and PM00. Bits PM02, PM05 to PM04, PM06, and PM07 are enabled when bits PM01 to PM00 are 01b (memory expansion mode) or 11b (microprocessor mode). ### PM03 (Software reset bit) (b3) A software reset is generated by setting the PM03 bit to 1. ## 6.2.2 Reset Source Determine Register (RSTFR) Table 6.5 RSTFR Register Reset Value | Reset | Bits in the RSTFR Register | | | | | | | |------------------------------|----------------------------|-------|-------|-----|-----|-----|-----------| | Keset | OSDR | LVD2R | LVD1R | WDR | SWR | HWR | CWR | | Hardware reset | No change | 0 | 0 | 0 | 0 | 1 | No change | | Power-on reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Voltage monitor 0 reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Voltage monitor 1 reset | 0 | 0 | 1 | 0 | 0 | 0 | No change | | Voltage monitor 2 reset | 0 | 1 | 0 | 0 | 0 | 0 | No change | | Oscillator stop detect reset | 1 | 0 | 0 | 0 | 0 | 0 | No change | | Watchdog timer reset | 0 | 0 | 0 | 1 | 0 | 0 | No change | | Software reset | 0 | 0 | 0 | 0 | 1 | 0 | No change | ## CWR (Cold/warm start discrimination flag) (b0) The CWR bit also changes when the either of following condition is met: Condition to become 0: Power-on Condition to become 1: Setting this bit to 1 #### OSDR (Oscillator stop detect reset detect flag) (b6) The OSDR bit also changes when either of following condition is met: Conditions to become 0: - Power-on - Setting this bit to 0 This bit will not become 1 even when written to 1. # 6.3 Optional Function Select Area In the optional function select area, the MCU state after reset and the function to prevent rewrite in parallel I/O mode are selected. The optional function select area is not an SFR, and therefore cannot be rewritten by a program. Set an appropriate value when writing a program to flash memory. The entire optional function select area becomes FFh when the block including the optional function select area is erased. In blank products, the OFS1 address value is FFh when shipped. After a value is written by the user, this address takes on the written value. In programmed products, the OFS1 address is the value set in the user program prior to shipping. Selection using the optional function select area can be used in single-chip mode or memory expansion mode. The option function select area cannot be used in microprocessor mode. Clear the internal ROM before using the MCU in microprocessor mode. # 6.3.1 Optional Function Select Address 1 (OFS1) WDTON (Watchdog timer start select bit) (b0) CSPROINI (After-reset count source protection mode select bit) (b7) These bits select the state of the watchdog timer after reset. Set the WDTON bit to 0 (watchdog timer starts automatically after reset) when setting the CSPROINI bit to 0 (count source protection mode enabled after reset). Refer to 15. "Watchdog Timer" for details on the watchdog timer and count source protection mode. # ROMCR (ROM code protect cancel bit) (b2) ROMCP1 (ROM code protect bit) (b3) These bits prevent the flash memory from being read or changed in parallel I/O mode. Table 6.6 ROM Code Protection | Bit Se | ROM Code Protection | | |-----------|---------------------|---------------------| | ROMCR bit | ROMCP1 bit | NOW Code Protection | | 0 | 0 | Cancelled | | 0 | 1 | Cancelled | | 1 | 0 | Enabled | | 1 | 1 | Cancelled | ## VDSEL1 (Vdet0 select bit 1) (b5) Set this bit to 0 (Vdet0\_2) when using the power-on reset or voltage monitor 0 reset. Refer to 6.4.10 "Cold/Warm Start Discrimination". This bit is enabled in single-chip mode, while disabled in boot mode. ### LVDAS (Voltage detector 0 start bit) (b6) Set this bit to 0 (voltage monitor 0 reset enabled after hardware reset) when using the power-on reset. This bit is enabled in single-chip mode, while disabled in boot mode. ## 6.4 Operations #### 6.4.1 Status after Reset The status of SFRs after reset depends on the reset type. See the Reset Value column in 4. "Special Function Registers (SFRs)". Table 6.7 lists Pin Status When RESET Pin Level is Low, Figure 6.2 shows CPU Register Status after Reset, and Figure 6.3 shows Reset Sequence. Table 6.7 Pin Status When RESET Pin Level is Low | | | tus (1) | | | |-------------------------|-----------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------| | Die News | | Microprocessor mode (CN) | Boot mode | | | Pin Name | Single-chip mode<br>(CNVSS = VSS) | BYTE = VSS | BYTE = VCC1 | (CNVSS = VCC1,<br>P5_5 = low,<br>P5_0 = high) | | P0 | Input port | Data input | Data input | Input port | | P1 | Input port | Data input | Input port | Input port | | P2, P3, P4_0<br>to P4_3 | Input port | Address output (undefined) | Address output (undefined) | Input port | | P4_4 | Input port | CS0 output (high level is output) | CS0 output (high level is output) | Input port | | P4_5 to P4_7 | Input port | Input port (pulled high) | Input port (pulled high) | Input port | | P5_0 | Input port | WR output (high level is output) | WR output (high level is output) | CE input (2) | | P5_1 | Input port | BHE output (undefined) | BHE output (undefined) | Input port | | P5_2 | Input port | RD output (high level is output) | RD output<br>(high level is output) | Input port | | P5_3 | Input port | BCLK output | BCLK output | Input port | | P5_4 | Input port | HLDA output<br>(the output value depends on<br>the input to the HOLD pin) | HLDA output<br>(the output value depends on<br>the input to the HOLD pin) | Input port | | P5_5 | Input port | HOLD input (2) | HOLD input (2) | EPM input (3) | | P5_6 | Input port | ALE output<br>(low level is output) | ALE output (low level is output) | Input port | | P5_7 | Input port | RDY input | RDY input | Input port | | P6 to P14 | Input port | Input port | Input port | Input port | #### Notes: - 1. The pin status shown here is when the internal power supply voltage has stabilized after power-on. The pin status is undefined until td(P-R) has elapsed after power-on. - 2. Input a high-level signal. - 3. Input a low-level signal. Figure 6.2 CPU Register Status after Reset Figure 6.3 Reset Sequence #### 6.4.2 Hardware Reset This reset is triggered by the RESET pin. When the power supply voltage meets the recommended operating conditions, the MCU resets the pins, CPU, and SFRs when a low-level signal is applied to the RESET pin. When changing the signal applied to the RESET pin from low to high, the MCU executes the program at the address indicated by the reset vector. fOCO-S divided by 8 is automatically selected as the CPU clock after reset. The HWR bit in the RSTFR register becomes 1 (hardware reset detected) after hardware reset. Refer to 4. "Special Function Registers (SFRs)" for the remaining SFR states after reset. The internal RAM is not reset. When a low-level signal is applied to the RESET pin while writing data to the internal RAM, the internal RAM becomes undefined. The procedures for generating a hardware reset are as follows: When the power supply is stable - (1) Apply a low-level signal to the RESET pin. - (2) Wait for tw(RSTL). - (3) Apply a high-level signal to the RESET pin. When the power is turned on - (1) Apply a low-level signal to the $\overline{RESET}$ pin. - (2) Raise the power supply voltage to the recommended operating level. - (3) Wait for td(P-R) until the internal voltage stabilizes. - (4) Wait for $\frac{1}{fOCO-S} \times 20$ cycles. - (5) Apply a high-level signal to the RESET pin. Figure 6.4 shows an Reset Circuit Example. Figure 6.4 Reset Circuit Example #### 6.4.3 Power-On Reset Function The power-on reset function can be used on the system in which VCC1 is Vdet0 or higher. When the RESET pin is connected to VCC1 via a pull-up resistor, and the VCC1 voltage level rises while the rise gradient is trth, the power-on reset function is enabled and the MCU resets the pins, CPU, and SFRs. When the input voltage to the VCC1 pin reaches Vdet0 or above, the fOCO-S count starts. When the fOCO-S count reaches 32, the internal reset signal becomes high and the MCU executes the program at the address indicated by the reset vector. fOCO-S divided by 8 is automatically selected as the CPU clock after reset. The CWR bit in the RSTFR register becomes 0 (cold start) after power-on reset. Refer to 4. "Special Function Registers (SFRs)" for the remaining SFR states after reset. The internal RAM is not reset. Use the voltage monitor 0 reset together with the power-on reset. Set the LVDAS bit in the OFS1 address to 0 (voltage monitor 0 reset enabled after hardware reset) and the VDSEL1 bit to 0 (Vdet0\_2) to use the power-on reset. In this case, the voltage monitor 0 reset is enabled (the VW0C0 bit and bit 6 in the VW0C register are 1 and the VC25 bit in the VCR2 register is 1). Do not set these bits to 0 by a program. Refer to 7. "Voltage Detector" for details of the voltage monitor 0 reset. Figure 6.5 shows Power-On Reset Circuit and Operation Example. When a capacitor is connected to the RESET pin, always keep voltage to the RESET pin in the range of VIH. Figure 6.5 Power-On Reset Circuit and Operation Example #### 6.4.4 Voltage Monitor 0 Reset This reset is triggered by the MCU's on-chip voltage detector 0. The voltage detector 0 monitors the voltage applied to the VCC1 pin (Vdet0). The MCU resets the pins, CPU, and SFRs when the voltage applied to the VCC1 pin drops to Vdet0 or below. Then, the fOCO-S count starts when the voltage applied to the VCC1 pin rises to Vdet0 or above. The internal reset signal becomes high after 32 cycles of fOCO-S, and then the MCU executes the program at the address indicated by the reset vector. fOCO-S divided by 8 is automatically selected as the CPU clock after reset. The CWR bit in the RSTFR register becomes 0 (cold start) after voltage monitor 0 reset. Refer to 4. "Special Function Registers (SFRs)" for the remaining SFR states after reset. The internal RAM is not reset. When the voltage applied to the VCC1 pin drops to Vdet0 or below while writing data to the internal RAM, the internal RAM becomes undefined. Refer to 7. "Voltage Detector" for details of the voltage monitor 0 reset. ## 6.4.5 Voltage Monitor 1 Reset This reset is triggered by the MCU's on-chip voltage detector 1. Voltage detector 1 monitors the voltage applied to the VCC1 pin (Vdet1). When the VW1C6 bit in the VW1C register is 1 (voltage monitor 1 reset when Vdet1 passage is detected), the MCU resets the pins, CPU, and SFRs when the voltage applied to the VCC1 pin drops to Vdet1 or below. fOCO-S divided by 8 is automatically selected as the CPU clock after reset. After tps + 60 cycles of the CPU clock has elapsed, the MCU executes the program at the address indicated by the reset vector. The LVD1R bit in the RSTFR register becomes 1 (voltage monitor 1 reset detected) after voltage monitor 1 reset. Some SFRs are not reset at voltage monitor 1 reset. Refer to 4. "Special Function Registers (SFRs)" for details. The processor mode remains unchanged since bits PM01 and PM00 in the PM0 register are not reset. The internal RAM is not reset. Refer to 7. "Voltage Detector" for details of the voltage monitor 1 reset. ## 6.4.6 Voltage Monitor 2 Reset This reset is triggered by the MCU's on-chip voltage detector 2. Voltage detector 2 monitors the voltage applied to the VCC1 pin (Vdet2). When the VW2C6 bit in the VW2C register is 1 (voltage monitor 2 reset when Vdet2 passage is detected), the MCU resets the pins, CPU, and SFRs when the voltage applied to the VCC1 pin drops to Vdet2 or below. fOCO-S divided by 8 is automatically selected as the CPU clock after reset. After tps + 60 cycles of the CPU clock has elapsed, the MCU executes the program at the address indicated by the reset vector. The LVD2R bit in the RSTFR register becomes 1 (voltage monitor 2 reset detected) after voltage monitor 2 reset. Some SFRs are not reset at voltage monitor 2 reset. Refer to 4. "Special Function Registers (SFRs)" for details. The processor mode remains unchanged since bits PM01 and PM00 in the PM0 register are not reset. The internal RAM is not reset. Refer to 7. "Voltage Detector" for details of the voltage monitor 2 reset. #### 6.4.7 Oscillator Stop Detect Reset The MCU resets and stops the pins, CPU, and SFRs when the CM27 bit in the CM2 register is 0 (reset when oscillator stop detected), if it detects that the main clock oscillator has stopped. The OSDR bit in the RSTFR register becomes 1 (oscillator stop detect reset detected) after oscillator stop detect reset. Some SFRs are not reset at oscillator stop detect reset. Refer to 4. "Special Function Registers (SFRs)" for details. The processor mode remains unchanged since bits PM01 and PM00 in the PM0 register are not reset. The internal RAM is not reset. When the main clock oscillator stop is detected while writing data to the internal RAM, the internal RAM becomes undefined. Oscillator stop detect reset is canceled by hardware reset or voltage monitor 0 reset. Refer to 8.7 "Oscillator Stop/Restart Detect Function" for details. ## 6.4.8 Watchdog Timer Reset The MCU resets the pins, CPU, and SFRs when the PM12 bit in the PM1 register is 1 (reset when watchdog timer underflows) and the watchdog timer underflows. Then the MCU executes the program at the address determined by the reset vector. fOCO-S divided by 8 is automatically selected as the CPU clock after reset. The WDR bit in the RSTFR register becomes 1 (watchdog timer reset detected) after watchdog timer reset. Some SFRs are not reset at watchdog timer reset. Refer to 4. "Special Function Registers (SFRs)" for details. The processor mode remains unchanged since bits PM01 and PM00 in the PM0 register are not reset. The internal RAM is not reset. When the watchdog timer underflows while writing data to the internal RAM, the internal RAM becomes undefined. Refer to 15. "Watchdog Timer" for details. ## 6.4.9 Software Reset The MCU resets the pins, CPU, and SFRs when the PM03 bit in the PM0 register is 1 (MCU reset). Then the MCU executes the program at the address determined by the reset vector. fOCO-S divided by 8 is automatically selected as the CPU clock after reset. The SWR bit in the RSTFR register becomes 1 (software reset detected) after software reset. Some SFRs are not reset at software reset. Refer to 4. "Special Function Registers (SFRs)" for details. The processor mode remains unchanged since bits PM01 and PM00 in the PM0 register are not reset. The internal RAM is not reset. #### 6.4.10 Cold/Warm Start Discrimination The cold/warm start discrimination detects whether or not voltage applied to the VCC1 pin drops to the RAM hold voltage or below. The reference voltage is Vdet0. Therefore, the voltage monitor 0 reset is used for cold/warm start discrimination. Follow 7.4.2.1 "Voltage Monitor 0 Reset" to set the bits related to the voltage monitor 0 reset. The CWR bit in the RSTFR register is 0 (cold start) when power is turned on. The CWR bit also becomes 0 after power-on reset or voltage monitor 0 reset. The CWR bit becomes 1 (warm start) by writing 1, and remains unchanged at hardware reset, voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, or software reset. In the cold/warm start discrimination, the Vdet0 level can be selected by setting the VDSEL1 bit in the OFS1 address. - When power-on reset or voltage monitor 0 reset is used Set the VDSEL1 bit to 0 (Vdet0 2). - When neither power-on reset nor voltage monitor 0 reset is used as the user system The VDSEL1 bit can be set to 0 or 1. When the VDSEL1 bit is 1 (Vdet0\_0), voltage monitor 0 reset and its cancellation are based on Vdet0\_0. Therefore, execute hardware reset after cancelling the voltage monitor 0 reset. Figure 6.6 shows the Cold/Warm Start Discrimination Example. Figure 6.6 Cold/Warm Start Discrimination Example ## 6.5 Notes on Resets # 6.5.1 Power Supply Rising Gradient When supplying power to the MCU, make sure that the power supply voltage applied to the VCC1 pin meets the SVCC conditions. | Symbol Parameter | | Standard | | | Unit | | |------------------|------------------------------------------------------------------|----------------------|------|------|------|-------| | Symbol | Falameter | | Min. | Тур. | Max. | Offic | | SVcc | Power supply VCC1 rising gradient (Voltage range: 0 to 2.0 V) | | 0.05 | | | V/ms | | 3,000 | Power supply Vcc1 rising gradient (Voltage range: 2.0 V to Vcc1) | 3.6 V < VCC1 ≤ 5.5 V | | | 5.5 | V/ms | Figure 6.7 SVCC Timing (3.6 V < VCC1) Figure 6.8 SVCC Timing (VCC1 ≤ 3.6 V) #### 6.5.2 Power-On Reset Use the voltage monitor 0 reset together with the power-on reset. To use the power-on reset, set the LVDAS bit in the OFS1 address to 0 (voltage monitor 0 reset enabled after hardware reset) and the VDSEL1 bit to 0 (Vdet0\_2). In this case, the voltage monitor 0 reset is enabled (the VW0C0 bit and bit 6 in the VW0C register are 1, and the VC25 bit in the VCR2 register is 1) after power-on reset. Do not disable these bits by a program. # 6.5.3 OSDR Bit (Oscillation Stop Detect Reset Detect Flag) When an oscillator stop detect reset is generated, the MCU is reset and then stopped. This state is canceled by hardware reset or voltage monitor 0 reset. Note that the OSDR bit in the RSTFR register is not affected by a hardware reset, but becomes 0 (not detected) from a voltage monitor 0 reset. # 7. Voltage Detector #### 7.1 Introduction The voltage detector monitors the voltage applied to the VCC1 pin. This circuit can be programmed to monitor the VCC1 input voltage. Voltage monitor 0 reset, voltage monitor 1 interrupt, voltage monitor 1 reset, voltage monitor 2 interrupt, and voltage monitor 2 reset can also be used. Table 7.1 lists the Voltage Detector Specifications and Figure 7.1 shows Voltage Detector Block Diagram. **Table 7.1 Voltage Detector Specifications** | | Item | Voltage Detector 0 | Voltage Detector 1 | Voltage Detector 2 | |------------------------|-------------------------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Voltage to monitor | Vdet0 | Vdet1 | Vdet2 | | | Detection target | Whether rises through or falls through Vdet0 | Whether rises through or falls through Vdet1 | Whether rises through or falls through Vdet2 | | VCC1 | Voltage to detect | Selectable from two levels in the OFS1 address | Selectable from three levels in the VD1LS register | Fixed level | | | Monitor | None | VW1C3 bit in the VW1C register | VC13 bit in the VCR1 register | | | Normor | None | Whether VCC1 is higher or lower than Vdet1 | Whether VCC1 is higher or lower than Vdet2 | | | | Voltage monitor 0 reset | Voltage monitor 1 reset | Voltage monitor 2 reset | | | Reset | Reset when Vdet0 > VCC1; restart CPU operation when VCC1 > Vdet0 | Reset when Vdet1 > VCC1;<br>restart CPU operation after<br>tps + 60 cycles of fOCO-S<br>divided by 8 | Reset when Vdet2 > VCC1;<br>restart CPU operation after<br>tps + 60 cycles of fOCO-S<br>divided by 8 | | Process<br>when | | | Voltage monitor 1 interrupt | Voltage monitor 2 interrupt | | voltage is<br>detected | Interrupt | None | Interrupt request when Vdet1 > VCC1 and VCC1 > Vdet1 while digital filter is enabled; interrupt request when Vdet1 > VCC1 or VCC1 > Vdet1 while digital filter is disabled | Interrupt request when Vdet2 > VCC1 and VCC1 > Vdet2 while digital filter is enabled; interrupt request when Vdet2 > VCC1 or VCC1 > Vdet2 while digital filter is disabled | | Digital | Switch enabled/disabled | No digital filter function | Available | Available | | filter | Sampling time | - | (fOCO-S divided by n)<br>× 3<br>n: 1, 2, 4, 8 | (fOCO-S divided by n)<br>× 3<br>n: 1, 2, 4, 8 | Figure 7.1 Voltage Detector Block Diagram # 7.2 Registers Table 7.2 shows the registers of the voltage detector. The reset value shows the values after hardware reset. Refer to the each register explanation for details. Table 7.2 Registers | Address | Register Name | Register Symbol | Reset Value | |---------|--------------------------------------------|-----------------|-------------| | 0019h | Voltage Detector 2 Flag Register | VCR1 | 0000 1000b | | 001Ah | Voltage Detector Operation Enable Register | VCR2 | 00h | | 0026h | Voltage Monitor Function Select Register | VWCE | 00h | | 0028h | Voltage Detector 1 Level Select Register | VD1LS | 0000 1010b | | 002Ah | Voltage Monitor 0 Control Register | VW0C | 1000 XX10b | | 002Bh | Voltage Monitor 1 Control Register | VW1C | 1000 1010b | | 002Ch | Voltage Monitor 2 Control Register | VW2C | 1000 0X10b | # 7.2.1 Voltage Detector 2 Flag Register (VCR1) This register does not change at voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, or software reset. ## VC13 (Low-voltage monitor flag) (b3) The VC13 bit is enabled when the VW12E bit in the VWCE register is 1 (voltage monitors 1 and 2 enabled) and the VC27 bit in the VCR2 register is 1 (voltage detector 2 enabled). Condition to become 0: - VCC1 < Vdet2 (when the VW12E bit is 1 and the VC27 bit is 1) - Conditions to become 1: - VCC1 ≥ Vdet2 (when the VW12E bit is 1 and the VC27 bit is 1) - The VC27 bit is 0 (voltage detector 2 disabled). # 7.2.2 Voltage Detector Operation Enable Register (VCR2) Set the PRC3 bit in the PRCR register to 1 (write enabled) before rewriting this register. This register does not change at voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, or software reset. #### VC25 (Voltage detector 0 enable bit) (b5) To use voltage monitor 0 reset, set the VC25 bit to 1 (voltage detector 0 enabled). After changing the VC25 bit to 1, the detector starts operating when the td(E-A) elapses. #### VC26 (Voltage detector 1 enable bit) (b6) Voltage detector 1 is enabled when the VW12E bit in the VWCE register is 1 (voltage monitors 1 and 2 enabled) and the VC26 bit is 1 (voltage detector 1 enabled). Set bits VW12E and VC26 to 1 under the following conditions: - When using voltage monitor 1 interrupt/reset - When using bits VW1C2 and VW1C3 in the VW1C register After changing this bit from 0 to 1, the detector will start operating after td(E-A) elapses. # VC27 (Voltage detector 2 enable bit) (b7) Voltage detector 2 is enabled when the VW12E bit in the VWCE register is set to 1 (voltage monitors 1 and 2 enabled) and the VC27 bit is 1 (voltage detector 2 enabled). Set bits VW12E and VC27 to 1 under the following conditions: - When using voltage monitor 2 interrupt/reset - When using the VC13 bit in the VCR1 register - When using the VW2C2 bit in the VW2C register After changing this bit from 0 to 1, the detector will start operating after td(E-A) elapses. # 7.2.3 Voltage Monitor Function Select Register (VWCE) Set the PRC3 bit in the PRCR register to 1 (write enabled) before rewriting this register. VW12E (Voltage monitors 1 and 2 enable bit) (b0) Set this bit to 1 (enabled) to set either or both bits VC26 and VC27 in the VCR2 register to 1 (enabled). ## 7.2.4 Voltage Detector 1 Level Select Register (VD1LS) Set the PRC3 bit in the PRCR register to 1 (write enabled) before rewriting this register. Also, rewrite this register when the VW12E bit in the VWCE register is 1. This register does not change at watchdog timer reset, oscillation stop detect reset, or software reset. The register value is affected by the VW12E bit in the VWCE register. Table 7.3 lists VD1LS Register Value. After setting a value to this register, by setting the VW12E bit first to 0 and then to 1, the register will revert to the previous setting. Table 7.3 VD1LS Register Value | VW12E Bit | VD1LS Register Value | |-----------|-------------------------------------------------------------| | 0 | 0000 1010b | | 1 | Value set in the register (0000 0111b when no value is set) | ## VD1LS3 to VD1LS0 (Vdet1 select bit) (b3 to b0) When using voltage detector 1, the reset value cannot be used as is. Only set the values shown in the register. When not using detector 1, the reset values can remain as is. ## 7.2.5 Voltage Monitor 0 Control Register (VW0C) Set the PRC3 bit in the PRCR register to 1 (write enabled) before rewriting to this register. This register does not change at voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, or software reset. ### VW0C0 (Voltage monitor 0 reset enable bit) (b0) The VW0C0 bit is enabled when the VC25 bit in the VCR2 register is 1 (voltage detector 0 enabled). Set the VW0C0 bit to 0 (disabled) when the VC25 bit is 0 (voltage detector 0 disabled). #### Bit 6 When the LVDAS bit in the OFS1 address is 1, this bit becomes 0 after hardware reset. When using voltage monitor 0 reset, set this bit to 1. ## 7.2.6 Voltage Monitor 1 Control Register (VW1C) Set the PRC3 bit in the PRCR register to 1 (write enabled) before rewriting this register. Bits VW1C2 and VW1C3 do not change at voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, or software reset. The VW1C2 bit may become 1 after rewriting this register is rewritten. Therefore, set the VW1C2 bit to 0 after rewriting this register. # VW1C0 (Voltage monitor 1 interrupt/reset enable bit) (b0) The VW1C0 bit is enabled when the VW12E bit in the VWCE register is 1 (voltage monitors 1 and 2 enabled) and the VC26 bit in the VCR2 register is 1 (voltage detector 1 enabled). Set the VW1C0 bit to 0 (disabled) when the VC26 bit is 0 (voltage detector 1 disabled). ### VW1C1 (Voltage monitor 1 digital filter disable mode select bit) (b1) After using voltage monitor 1 interrupt to exit stop mode, to use it again to exit stop mode, set the VW1C1 bit to 0 first, and then to 1. ## VW1C2 (Voltage change detection flag) (b2) The VW1C2 bit is enabled when the VC26 bit in the VCR2 register is 1 (voltage detector 1 enabled). This bit does not change even if set to 1. Condition to become 0: Setting this bit to 0 Conditions to become 1: • Refer to the following table. Table 7.4 Conditions under Which the VW1C2 Bit Becomes 1 | Bit Setting (1) | | 1) | Condition | | | | |-----------------|-------|--------|---------------------------------------------------|--|--|--| | WV1C1 | VW1C6 | VW1C7 | Condition | | | | | 0 | 0 | 0 or 1 | The VW1C3 bit changes from 0 to 1 or from 1 to 0. | | | | | | 1 | 1 | The VW1C3 bit changes from 1 to 0. | | | | | | 0 | | The VW1C3 bit changes from 0 to 1. | | | | | 1 | 0 | 1 | The VW1C3 bit changes from 1 to 0. | | | | | | 1 | | The VW1C3 bit changes from 1 to 0. | | | | #### Note: 1. Only set the values listed above. #### VW1C3 (Voltage detector 1 signal monitor flag) (b3) The VW1C3 bit is enabled when the VW12E bit in the VWCE register is 1 (voltage monitors 1 and 2 enabled) and the VC26 bit in the VCR2 register is 1 (voltage detector 1 enabled). Condition to become 0: • VCC1 < Vdet1 (when the VW12E bit is 1 and the VC26 bit is 1) Conditions to become 1: - VCC1 ≥ Vdet1 (when the VW12E bit is 1 and the VC26 bit is 1) - The VC26 bit in the VCR2 register is 0 (voltage detector 1 disabled). After a hardware reset, power-on reset, voltage monitor 0 reset, voltage monitor 1 reset, or voltage monitor 2 reset, the reference level of Vdet1 switches because value in the VD1LS register changes. When monitoring the voltage detector 1 signal level, set the value to the VD1LS register again, then set the VW1C3 bit. The VW12E bit in the VWCE register becomes 0 from a reset. When monitoring the voltage detector 1 signal level, set the VW12E bit to 1 again. #### VW1C6 (Voltage monitor 1 mode select bit) (b6) The VW1C6 bit is enabled when the VW1C0 bit is 1 (voltage monitor 1 interrupt/reset enabled). ## VW1C7 (Voltage monitor 1 interrupt/reset generation condition select bit) (b7) The voltage monitor 1 interrupt/reset generation condition can be selected by the VW1C7 bit when the VW1C6 bit is 0 (voltage monitor 1 interrupt at Vdet1 passage) and the VW1C1 bit is 1 (digital filter disabled). When the VW1C6 bit is 1 (voltage monitor 1 reset at Vdet1 passage), set the VW1C7 bit to 1 (when VCC1 reaches Vdet1 or below). (Do not set the VW1C7 bit to 0.) When the VW1C1 bit is 0 (digital filter enabled), regardless of the VW1C7 bit's setting, the voltage monitor 1 interrupt is generated when VCC1 reaches, or goes above of below Vdet1. ## 7.2.7 Voltage Monitor 2 Control Register (VW2C) Set the PRC3 bit in the PRCR register to 1 (write enabled) before rewriting the VW2C register. Bits VW2C2 and VW2C3 do not change at voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, or software reset. When rewriting the VW2C register (excluding the VW2C3 bit), the VW2C2 bit may become 1. Set the VW2C2 bit to 0 after rewriting the VW2C register. #### VW2C0 (Voltage monitor 2 interrupt/reset enable bit) (b0) The VW2C0 bit is enabled when the VW12E bit in the VWCE register is 1 (voltage monitors 1 and 2 enabled) and the VC27 bit in the VCR2 register is 1 (voltage detector 2 enabled). Set the VW2C0 bit to 0 (disabled) when the VC27 bit is 0 (voltage detector 2 disabled). ### VW2C1 (Voltage monitor 2 digital filter disable mode select bit) (b1) After using the voltage monitor 2 interrupt to exit stop mode, to use it again to exit stop mode, set the VW2C1 bit to 0 first and then to 1. ## VW2C2 (Voltage change detection flag) (b2) The VW2C2 bit is enabled when the VC27 bit in the VCR2 register is 1 (voltage detector 2 enabled). This bit does not change even if set to 1. Condition to become 0: Writing this bit to 0 Condition to become 1: • Refer to the following table. Table 7.5 Conditions Under Which the VW2C2 Bit Becomes 1 | Bit Setting (1) | | 1) | Conditions under Which the VW2C2 Bit Becomes 1 | | | |----------------------|-------|--------|--------------------------------------------------|--|--| | VW2C1 | VW2C6 | VW2C7 | Conditions under which the vw2C2 bit becomes i | | | | 0 | 0 | 0 or 1 | The VC13 bit changes from 0 to 1 or from 1 to 0. | | | | | 1 | 1 | The VC13 bit changes from 1 to 0. | | | | 1 | 1 0 0 | | The VC13 bit changes from 0 to 1. | | | | 1 The VC13 bit chang | | 1 | The VC13 bit changes from 1 to 0. | | | | | 1 | 1 | The VC13 bit changes from 1 to 0. | | | VC13 bit: Bit in the VCR1 register Note: 1. Only set the values listed above. ### VW2C6 (Voltage monitor 2 mode select bit) (b6) The VW2C6 bit is enabled when the VW2C0 bit is 1 (voltage monitor 2 interrupt/reset enabled). # VW2C7 (Voltage monitor 2 interrupt/reset generation condition select bit) (b7) The voltage monitor 2 interrupt/reset generation condition can be selected by the VW2C7 bit when the VW2C6 bit is 0 (voltage monitor 2 interrupt at Vdet2 passage) and the VW2C1 bit is 1 (digital filter disabled). When the VW2C6 bit is 1 (voltage monitor 2 reset at Vdet2 passage), set the VW2C7 bit to 1 (when VCC1 reaches Vdet2 or below). (Do not set the VW2C7 bit to 0.) When the VW2C1 bit is 0 (digital filter enabled), regardless of the VW2C7 bit setting, the voltage monitor 2 interrupt is generated when VCC1 reaches Vdet2 or above, and also when VCC1 reaches Vdet2 or below. # 7.3 Optional Function Select Area In the optional function select area, the MCU state after reset and the function to prevent rewrite in parallel I/O mode are selected. The optional function select area is not an SFR, and therefore cannot be rewritten by a program. Set an appropriate value when writing a program to flash memory. The entire optional function select area becomes FFh when the block including the optional function select area is erased. In blank products, the OFS1 address value is FFh when shipped. After a value is written by the user, this address takes on the written value. In programmed products, the OFS1 address value is the value set in the user program prior to shipping. Selection using the optional function select area can be used in single-chip mode or memory expansion mode. The option function select area cannot be used in microprocessor mode. When using the MCU in microprocessor mode, clear the internal ROM. ## 7.3.1 Optional Function Select Address 1 (OFS1) ## VDSEL1 (Vdet0 select bit 1) (b5) The Vdet0 level used in voltage detector 0 is selectable. Voltage detector 0 operates based on Vdet0. Set the VDSEL1 bit to 0 (Vdet0\_2) when using power-on reset or voltage monitor 0 reset. Refer to 6.4.10 "Cold/Warm Start Discrimination". This bit is enabled in single-chip mode, while disabled in boot mode. ## LVDAS (Voltage detector 0 start bit) (b6) When using power-on reset, set this bit to 0 (voltage monitor 0 reset enabled after hardware reset). This bit is enabled in single-chip mode, while disabled in boot mode. ### 7.4 Operations ## 7.4.1 Digital Filter A digital filter can be used to monitor VCC1 input voltage. For the voltage detector i (i = 1 to 2), the digital filter is enabled when the VWiC1 bit in the VWiC register is set to 0 (digital filter enabled). fOCO-S divided by 1, 2, 4, or 8 is selected as a sampling clock. When using the digital filter, set the CM14 bit in the CM1 register to 0 (125 kHz on-chip oscillator on). The VCC1 input level is sampled by the digital filter for every sampling clock. When the same sampled level is detected twice in a row, at the next sampling timing, the internal reset signal goes low or a voltage monitor i interrupt request is generated. Therefore, when the digital filter is used, the time from when the VCC1 input voltage level passes Vdeti until when a reset or an interrupt is generated is up to three cycles of the sampling clock. Since fOCO-S stops in stop mode, the digital filter does not function. When using voltage detector i to exit stop mode, set the VWiC1 bit in the VWiC register to 1 (digital filter disabled). Figure 7.2 shows Digital Filter Operation Example. Figure 7.2 Digital Filter Operation Example ## 7.4.2 Voltage Detector 0 When the VC25 bit in the VCR2 register is 1 (voltage detector 0 enabled), voltage detector 0 monitors the voltage applied to the VCC1 pin and detects whether the voltage rises through or falls through Vdet0. The Vdet0 level can be selected by the VDSEL1 bit in the OFS1 address. Figure 7.3 Voltage Monitor 0 Reset Generator Block Diagram ## 7.4.2.1 Voltage Monitor 0 Reset When using voltage monitor 0 reset, set the VDSEL1 bit in the OFS1 address to 0 (Vdet0\_2). When the LVDAS bit in the OFS1 address is 1 (voltage monitor 0 reset disabled after hardware reset), set the related bits according to the procedure listed in Table 7.6. When the LVDAS bit in the OFS1 address is 0 (voltage monitor 0 reset enabled after hardware reset), the procedure listed in Table 7.6 is unnecessary. Table 7.6 Procedure for Setting Voltage Monitor 0 Reset Related Bits | Step | Processing | |------|--------------------------------------------------------------------------------| | 1 | Set the VC25 bit in the VCR2 register to 1 (voltage detector 0 enabled). | | 2 | Wait for td(E-A). | | 3 | Set the VW0C0 bit in the VW0C register to 1 (voltage monitor 0 reset enabled). | When voltage monitor 0 reset is generated, the CWR bit in the RSTFR register becomes 0 (cold start). Refer to 6.4.4 "Voltage Monitor 0 Reset" for status after reset. Figure 7.4 shows Voltage Monitor 0 Reset Operation Example. The above diagram assumes the following: - The VC25 bit in the VCR2 register is 1 (voltage detector 0 enabled). - The VW0C0 bit in the VW0C register is 1 (voltage monitor 0 reset énabled). The pins, CPU, and SFRs are initialized when the internal reset signal goes low. The MCU executes the program at the address indicated by the reset vector when the internal reset signal changes from low to high. Refer to 4. "SFRs" for the SFR status after reset. #### Note 1. Make sure that VCC1 does not drop to recommended operating condition VCC1 during sampling time. Figure 7.4 Voltage Monitor 0 Reset Operation Example ## 7.4.3 Voltage Detector 1 When the VW12E bit in the VWCE register is 1 (voltage monitors 1 and 2 enabled) and the VC26 bit in the VCR2 register is 1 (voltage detector 1 enabled), voltage detector 1 monitors the voltage applied to the VCC1 pin and detects whether the voltage rises through or falls through Vdet1. Figure 7.5 Voltage Monitor 1 Interrupt/Reset Generator ## 7.4.3.1 Monitoring Vdet1 Set the VW12E bit in the VWCE register to 1 (voltage monitors 1 and 2 enabled) and the VC26 bit in the VCR2 register to 1 (voltage detector 1 enabled). Vdet1 can be monitored by using the VW1C3 bit in the VW1C register after td(E-A) elapses. ## 7.4.3.2 Voltage Monitor 1 Interrupt and Voltage Monitor 1 Reset Table 7.7 lists Procedures for Setting Voltage Monitor 1 Interrupt/Reset Related Bits. Table 7.7 Procedures for Setting Voltage Monitor 1 Interrupt/Reset Related Bits | | When Using the Digital Filter | | When Not Using | the Digital Filter | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------| | Step | Voltage monitor 1 interrupt | Voltage monitor 1 reset | Voltage monitor 1 interrupt | Voltage monitor 1 reset | | 1 | Set the VW12E bit in th | e VWCE register to 1 (v | roltage monitors 1 and 2 | enabled). | | 2 | Set bits VD1LS3 to VD1LS0 in the VD1LS register to select Vdet1. | | | | | 3 | Set the VC26 bit in the | VCR2 register to 1 (volt | age detector 1 enabled) | | | 4 | Wait for td(E-A). | | | | | 5 | Use bits VW1F1 and VV register to select the dicclock. | | Use the VW1C7 bit in the VW1C register to select the timing of the interrupt and reset request. (1) | | | 6 (2) | Set the VW1C1 bit in the VW1C register to 0 (digital filter enabled). | | Set the VW1C1 bit in the VW1C register to 1 (digital filter disabled). | | | 7 (2) | Set the VW1C6 bit in the VW1C register to 0 (voltage monitor 1 interrupt). Set the VW1C6 bit in the VW1C register to 1 (voltage monitor 1 reset). | | Set the VW1C6 bit in the VW1C register to 0 (voltage monitor 1 interrupt). | Set the VW1C6 bit in the VW1C register to 1 (voltage monitor 1 reset). | | 8 | Set the VW1C2 bit in the VW1C register to 0 (Vdet1 passage not detected). | | | | | 9 | Set the CM14 bit in the kHz on-chip oscillator o | , | - | | | 10 | Wait for digital filter san | npling clock x 3 cycles. | - (no wait time) | | | 11 | Set the VW1C0 bit in the VW1C register to 1 (voltage monitor 1 interrupt/reset enabled). | | | | #### Notes: - 1. Set the VW1C7 bit to 1 (when VCC1 reaches Vdet1 or below) for the voltage monitor 1 reset. - 2. When the VW1C0 bit is 0, steps 5, 6, and 7 can be executed simultaneously (with one instruction). - 3. If above setting is performed while voltage monitor 1 interrupt/reset is disabled (VW1C0 bit in the VW1C register is 0, VC26 bit in the VCR2 register is 0) and VCC1 < Vdet1 (or VCC1 > Vdet1) is detected before enabling voltage monitor 1 interrupt/reset (step 11), an interrupt does not occur. When VCC1 < Vdet1 (or VCC1 > Vdet1) is detected while executing steps 9 to 11, the VW1C2 bit becomes 1. When using this result detected between steps 9 and 11, read the VW1C2 bit after step 11. If the bit is 1, execute the process to be performed after detecting the VCC1 < Vdet1 (or VCC1 > Vdet1). When ignoring the result detected between steps 9 and 11, set the VW1C2 bit to 0 after step 11. When using voltage monitor 1 interrupt or voltage monitor 1 reset to exit stop mode, set the VW1C1 bit in the VW1C register to 1 (digital filter disabled). When voltage monitor 1 reset is generated, the LVD1R bit in the RSTFR register becomes 1 (voltage monitor 1 reset detected). Refer to 6.4.5 "Voltage Monitor 1 Reset" for status after reset. Figure 7.6 shows Voltage Monitor 1 Interrupt/Reset Operation Example. Figure 7.6 Voltage Monitor 1 Interrupt/Reset Operation Example ## 7.4.4 Voltage Detector 2 When the VW12E bit in the VWCE register is 1 (voltage monitors 1 and 2 enabled) and the VC27 bit in the VCR2 register is 1 (voltage detector 2 enabled), voltage detector 2 monitors the voltage applied to the VCC1 pin and detects whether the voltage rises through or falls through Vdet2. Figure 7.7 Voltage Monitor 2 Interrupt/Reset Generator ## 7.4.4.1 Monitoring Vdet2 Set the VW12E bit in the VWCE register to 1 (voltage monitors 1 and 2 enabled) and the VC27 bit in the VCR2 register to 1 (voltage detector 2 enabled). Vdet2 can be monitored using the VC13 bit in the VCR1 register after td(E-A) elapses. ### 7.4.4.2 Voltage Monitor 2 Interrupt and Voltage Monitor 2 Reset Table 7.8 lists Procedure for Setting Voltage Monitor 2 Interrupt/Reset Related Bits. Table 7.8 Procedure for Setting Voltage Monitor 2 Interrupt/Reset Related Bits | | When Using th | ne Digital Filter | When Not Using the Digital Filter | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--| | Step | Voltage monitor 2 interrupt | Voltage monitor 2 reset | Voltage monitor 2<br>interrupt | Voltage monitor 2 reset | | | 1 | Set the VW12E bit in th | e VWCE register to 1 (v | oltage monitors 1 and 2 | enabled). | | | 2 | Set the VC27 bit in the | VCR2 register to 1 (volt | tage detector 2 enabled). | | | | 3 | Wait for td(E-A). | | | | | | 4 | Set bits VW2F0 to VW2 register to select the dig clock. | | Set the VW2C7 bit in the VW2C register to select the timing of the interrupt and reset request. (1) | | | | 5 (2) | Set the VW2C1 bit in the VW2C register to 0 (digital filter enabled). | | Set the VW2C1 bit in the VW2C register to 1 (digital filter disabled). | | | | 6 (2) | Set the VW2C6 bit in the VW2C register to 0 (voltage monitor 2 interrupt). Set the VW2C6 bit in the VW2C register to 1 (voltage monitor 2 reset). | | Set the VW2C6 bit in<br>the VW2C register to 0<br>(voltage monitor 2<br>interrupt). | Set the VW2C6 bit in<br>the VW2C register to 1<br>(voltage monitor 2<br>reset). | | | 7 | Set the VW2C2 bit in the VW2C register to 0 (Vdet2 passage not detected). | | | | | | 8 | Set the CM14 bit in the CM1 register to 0 (125 kHz on-chip oscillator on) | | - | | | | 9 | Wait for digital filter sam | npling clock x 3 cycles. | - (no wait time) | | | | 10 | Set the VW2C0 bit in th | e VW2C register to 1 (v | oltage monitor 2 interrup | ot/reset enabled). | | | Mataa. | | | | | | #### Notes: - 1. Set the VW2C7 bit to 1 (when VCC1 reaches Vdet2 or below) for the voltage monitor 2 reset. - 2. When the VW2C0 bit is 0, steps 4, 5, and 6 can be executed simultaneously (with one instruction). - 3. If the above settings are performed while the voltage monitor 2 interrupt/reset is disabled (VW2C0 bit in the VW2C register is 0, VC27 bit in the VCR2 register is 0), and VCC1 < Vdet2 (or VCC1 > Vdet2) is detected before enabling the voltage monitor 2 interrupt/reset (step 10), an interrupt is not generated. When VCC1 < Vdet2 (or VCC1 > Vdet2) is detected while executing steps 8 to 10, the VW2C2 bit becomes 1. When using this result detected between steps 8 and 10, read the VW2C2 bit after step 10. If the bit is 1, execute the process to be performed after detecting the VCC1 < Vdet2 (or VCC1 > Vdet2). When ignoring the result detected between steps 8 and 10, set the VW2C2 bit to 0 after step 10. When using voltage monitor 2 interrupt or voltage monitor 2 reset to exit stop mode, set the VW2C1 bit in the VW2C register to 1 (digital filter disabled). When voltage monitor 2 reset is generated, the LVD2R bit in the RSTFR register is automatically becomes 1 (voltage monitor 2 reset detected). Refer to 6.4.6 "Voltage Monitor 2 Reset" for status after reset. Figure 7.8 shows Voltage Monitor 2 Interrupt/Reset Operation Example. Figure 7.8 Voltage Monitor 2 Interrupt/Reset Operation Example ## 7.5 Interrupts The voltage monitor 1 interrupt and voltage monitor 2 interrupt is a non-maskable interrupt. The watchdog timer interrupt, oscillator stop/restart detect interrupt, voltage monitor 1 interrupt, and voltage monitor 2 interrupt share the same vector. When using some functions together, read the detect flags of the events in an interrupt processing program, and determine the source of the interrupt. The detect flag for voltage monitor 1 is the VW1C2 bit in the VW1C register, and the detect flag for voltage monitor 2 is the VW2C2 bit in the VW2C register. After the interrupt source is determined, set bits VW1C2 and VW2C2 to 0 (not detected). ## 8. Clock Generator ### 8.1 Introduction The clock generator generates operating clocks for the CPU and peripheral functions. The following circuits are incorporated to generate the system clock signals. - Main clock oscillator - PLL frequency synthesizer - 40 MHz on-chip oscillator - 125 kHz on-chip oscillator - Sub clock oscillator Table 8.1 lists the specifications of the clock generator, and Figure 8.1 shows the block diagram of system clock generator. Table 8.1 Clock Generator Specifications | | Main Clock | PLL Frequency | On-Chi | Sub Clock | | |------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------| | Item | Oscillator | Synthesizer | 40 MHz on-chip oscillator | 125 kHz on-chip<br>oscillator | Oscillator | | Application | CPU clock<br>source Peripheral<br>function clock<br>source | CPU clock<br>source Peripheral<br>function clock<br>source | CPU clock source Peripheral function clock source CPU and peripheral function clock sources when the main clock stops oscillating | CPU clock source Peripheral function clock source CPU and peripheral function clock sources when the main clock stops oscillating Watchdog timer count source when the CPU clock is stopped | CPU clock<br>source Peripheral<br>function clock<br>source | | Clock frequency | f(XIN) | f(PLL) | fOCO40M | fOCO-S | f(XCIN) | | Connectable oscillators | <ul><li>Ceramic resonator</li><li>Crystal</li></ul> | _ (see note 1) | - | - | Crystal | | Pins connecting to oscillator | XIN, XOUT | _ (see note 1) | - | - | XCIN, XCOUT | | Oscillator start/<br>stop function | Enabled | Enabled | Enabled | Enabled | Enabled | | Oscillator status after reset | Oscillating | Stopped | Stopped | Oscillating | Stopped | | Other | An externally generated clock can be input. | _ (see note 1) | - | - | An externally generated clock can be input. | #### Note: 1. The PLL frequency synthesizer uses the main clock oscillator as a reference clock source. The items above are based on the main clock oscillator. Figure 8.1 System Clock Generator Table 8.2 I/O Pins | Pin Name | I/O | Function | | |----------|------------|------------------------------------------------------------|--| | XIN | Input | I/O pins for the main clock oscillator | | | XOUT | Output | - 1/O pins for the main clock oscillator | | | XCIN | Input (1) | I/O pins for a sub clock oscillator | | | XCOUT | Output (1) | | | | CLKOUT | Output | Clock output (in single-chip mode) | | | BCLK | Output | BCLK output (in memory expansion and microprocessor modes) | | Note: 1. Set the port direction bits which share pins to 0 (input mode). # 8.2 Registers Table 8.3 Registers | Address | Register | Symbol | Reset Value | |---------|----------------------------------------------|----------|---------------------------| | | | | 0000 0000b | | 0004h | Processor Mode Register 0 | PM0 | (CNVSS pin is low) | | 000411 | Processor wode Register o | FIVIO | 0000 0011b | | | | | (CNVSS pin is high) | | 0006h | System Clock Control Register 0 | CM0 | 0100 1000b | | 0007h | System Clock Control Register 1 | CM1 | 0010 0000b | | 000Ch | Oscillation Stop Detection Register | CM2 | 0X00 0010b <sup>(1)</sup> | | 0012h | Peripheral Clock Select Register | PCLKR | 0000 0011b | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 001Ch | PLL Control Register 0 | PLC0 | 0X01 X010b | | 001Eh | Processor Mode Register 2 | PM2 | XX00 0X01b | | 0022h | 40 MHz On-Chip Oscillator Control Register 0 | FRA0 | XXXX XX00b | Note: 1. Bits CM20, CM21, and CM27 remain unchanged at oscillator stop detect reset. # 8.2.1 Processor Mode Register 0 (PM0) Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. Bits PM01 to PM00 do not change at software reset, watchdog timer reset, oscillator stop detect reset, voltage monitor 1 reset, or voltage monitor 2 reset. Bits PM02, PM05 to PM04, PM06, and PM07 are enabled when bits PM01 to PM00 are 01b (memory expansion mode) or 11b (microprocessor mode). ### PM07 (BCLK output disable bit) (b7) This bit is enabled in memory expansion mode and microprocessor mode. A clock with the same frequency as the CPU clock can be output as the BCLK signal from the BCLK pin. # 8.2.2 System Clock Control Register 0 (CM0) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. See Table 9.3 "Clock-Related Bit Setting and Modes" to select a clock and mode. ### CM01 and CM00 (Clock output function select bit) (b1-b0) The CLKOUT pin outputs can be selected. These bits are enabled when the PCLK5 bit in the PCLKR register is set to 0 in single-chip mode. When the PCLK5 bit is 1, set bits CM01 and CM00 to 00b. Table 8.4 lists CLKOUT Pin Functions in Single-Chip Mode. Table 8.4 CLKOUT Pin Functions in Single-Chip Mode | PCLKR Register | CM0 Register | | CLKOUT Pin Output | |----------------|--------------|----------|--------------------| | PCLK5 bit | CM01 bit | CM00 bit | CEROOT FIII Output | | 0 | 0 | 0 | I/O port | | 0 | 0 | 1 | fC is output | | 0 | 1 | 0 | f8 is output | | 0 | 1 | 1 | f32 is output | | 1 | 0 | 0 | f1 is output | Only set the combinations listed above. #### CM02 (Wait mode peripheral function clock stop bit) (b2) This bit is used to stop the f1 peripheral function clock in wait mode. fC, fC32, fOCO-S, fOCO-F, and fOCO40M are not affected by the CM02 bit. When the PM21 bit in the PM2 register is 1 (clock change disabled), the CM02 bit remains unchanged even when written to. #### CM03 (XCIN-XCOUT drive capacity select Bit) (b3) Setting the driving capacity to low while sub clock oscillation is stable reduces power consumption. The CM03 bit becomes 1 (high) while the CM04 bit is 0 (P8\_6 and P8\_7 are I/O ports), or when entering stop mode. #### CM04 (Port XC select bit) (b4) The CM03 bit becomes 1 (high) while the CM04 bit is 0 (P8\_6 and P8\_7 are I/O ports). #### CM05 (Main clock stop bit) (b5) This bit is used to stop the main clock. The main clock is allowed to stop in the following cases. - Entering low power mode - Entering 125 kHz on-chip oscillator low power mode - Stopping the main clock in 40 MHz on-chip oscillator mode This bit cannot be used to detect if the main clock is stopped or not. Refer to 8.7 "Oscillator Stop/Restart Detect Function" for details on main clock stop detection. When the PM21 bit in the PM2 register is 1 (clock change disabled), this bit remains unchanged even when written to. #### CM06 (Main clock division select bit) (b6) The CM06 bit becomes 1 (divide-by-8 mode) under the following conditions: - When entering stop mode - When the CM21 bit in the CM2 register is 0 (main clock or PLL clock) and the CM05 bit is 1 (main clock off) ### CM07 (System clock select bit) (b7) The CPU clock source and the peripheral function clock f1 depend on combinations of the bit status of the CM07 bit, the CM11 bit in the CM1 register, and the CM21 bit in the CM2 register. When the CM07 bit is 0 (main clock, PLL clock or on-chip oscillator clock used as CPU clock), the CPU clock source and the peripheral function clock f1 can be selected by combinations of the bit status of the CM11 bit and the CM21 bit. When the CM07 bit is 1 (sub clock used as CPU clock), the CPU clock source is fC, and the peripheral function clock f1 can be selected by combinations of the bit status of bits CM11 and CM21. When setting the PM21 bit in the PM2 register to 1 (clock change disabled), set the CM07 bit to 0 (main clock) before setting the PM21 bit to 1. When the PM21 bit is set to 1, this bit remains unchanged even when written to. ## 8.2.3 System Clock Control Register 1 (CM1) Rewrite the CM1 register after setting the PRC0 bit in the PRCR register to 1 (write enabled). See Table 9.3 "Clock-Related Bit Setting and Modes" to select a clock and a mode. #### CM10 (All clock stop control bit) (b0) When the CM11 bit is 1 (PLL clock), or the CM20 bit in the CM2 register is 1 (oscillator stop/restart detect function enabled), do not set the CM10 bit to 1. In the following cases, this bit remains unchanged even when written to (The MCU does not enter stop mode). - The PM21 bit in the PM2 register is 1 (clock change disabled). - The CSPRO bit in the CSPR register is 1 (watchdog timer count source protection mode enabled). - The PLC07 bit in the PLC0 register is 1 (PLL on). - A low is input to the NMI pin. ### CM11 (System clock select bit) (b1) The CM11 bit is valid when the CM21 bit in the CM2 register is set to 0 (main clock or PLL clock). The CPU clock source and the peripheral function clock f1 can be selected by the CM11 bit when the CM07 bit is 0 (main clock, PLL clock, or on-chip oscillator clock used as CPU clock). The peripheral function clock f1 can be selected by the CM11 bit when the CM07 bit is 1 (sub clock used as CPU clock). When the PM21 bit in the PM2 register is 1 (clock change disabled), the CM11 bit remains unchanged even when written to. ## CM13 (XIN-XOUT feedback resistor select bit) (b3) The CM13 bit can be used when the main clock is not used at all, or when the externally generated clock is supplied to the XIN pin. When connecting a ceramic resonator or crystal between pins XIN and XOUT, set the CM13 bit to 0 (internal feedback resistor connected). Do not set this bit to 1. When the CM10 bit is 1 (stop mode), the feedback resistor is not connected regardless of the CM13 bit value. ### CM14 (125 kHz on-chip oscillator stop bit) (b4) The CM14 bit can be set to 1 (125 kHz on-chip oscillator off) when the CM21 bit is 0 (main clock or PLL clock). When the CM21 bit is set to 1 (on-chip oscillator clock), the CM14 bit is automatically set to 0 (125 kHz on-chip oscillator on) and remains unchanged even when 1 is written to this bit. Note that the 125 kHz on-chip oscillator does not stop. When the CSPRO bit in the CSPR register is 1 (watchdog timer count source protection mode), the CM14 bit is automatically set to 0 (125 kHz on-chip oscillator on) and remains unchanged even when 1 is written to this bit. Note that the 125 kHz on-chip oscillator does not stop. ### CM15 (XIN-XOUT drive capacity select bit) (b5) In the following cases, the CM15 bit is fixed as 1 (drive capacity high): - Entering stop mode. - The CM21 bit in the CM2 register is 0 (main clock or PLL clock) and the CM05 bit in the CM0 register is set to 1 (main clock stopped). #### CM17 and CM16 (Main clock division select bit 1) (b7-b6) Bits CM17 and CM16 are enabled when the CM06 bit is 0 (bits CM17 and CM16 enabled). ## 8.2.4 Oscillation Stop Detection Register (CM2) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. Bits CM20, CM21, and CM27 do not change at oscillator stop detect reset. See Table 9.3 "Clock-Related Bit Setting and Modes" to select a clock and a mode. ## CM20 (Oscillator stop/restart detect enable bit) (b0) Set the CM20 bit to 0 (oscillator stop/restart detect function disabled) to enter stop mode. Set the CM20 bit back to 1 (enabled) after exiting stop mode. When the PM21 bit in the PM2 register is 1 (clock change disabled), the CM20 bit remains unchanged even when being written. #### CM21 (System clock select bit 2) (b1) When the CM07 bit is 0 (main clock, PLL clock, or on-chip oscillator clock used as CPU clock source), the CPU clock source and the peripheral function clock f1 can be selected by the CM21 bit. When the CM07 bit is 1 (sub clock used as CPU clock source), the peripheral function clock f1 can be selected by the CM21 bit. To set the CM21 bit to 1 (on-chip oscillator clock), set the FRA01 bit in the FRA0 register to select either the 125 kHz on-chip oscillator, or the 40 MHz on-chip oscillator. When the CM20 bit is 1 (oscillator stop/restart detect function enabled) and the CM23 bit is 1 (main clock stopped), do not set the CM21 bit to 0 (main clock or PLL clock). When the CM20 bit is 1 (oscillator stop/restart detect function enabled), the CM27 bit is 1 (oscillator stop/restart detect interrupt), and the main clock is used as a CPU clock source, the CM21 bit becomes 1 (on-chip oscillator clock) if the main clock stop is detected. Refer to 8.7 "Oscillator Stop/Restart Detect Function" for details. ## CM22 (Oscillator stop/restart detect flag) (b2) Condition to become 0: • Set it to 0. #### Conditions to become 1: - Main clock stop is detected. - Main clock restart is detected. (The CM22 bit remains unchanged even if 1 is written.) When the CM22 bit changes state from 0 to 1, an oscillator stop/restart detect interrupt is generated. Use this bit in an interrupt routine to determine the factors of interrupts between the oscillator stop/restart detect interrupt and other interrupts. When the CM22 bit is 1 and oscillator stop or restart is detected, an oscillator stop/restart detect interrupt is not generated. The bit does not become 0 even if an oscillator stop/restart detect interrupt request is accepted. ## CM23 (XIN monitor flag) (b3) Determine the main clock status by reading the CM23 bit several times in the oscillator stop/restart detect interrupt routine. ## 8.2.5 Peripheral Clock Select Register (PCLKR) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. ### PCLK5 (Clock output function extension bit) (b5) The PCLK5 bit is enabled in single-chip mode. Output from the CLKOUT pin is selectable. When the PCLK5 bit is 1, set bits CM01 and CM00 to 00b. See Table 8.4 "CLKOUT Pin Functions in Single-Chip Mode". ## 8.2.6 Peripheral Clock Stop Register 1 (PCLKSTP1) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. ### PCKSTP1A (Peripheral clock stop bit) (b0) When using f1 for the clock source for the following peripherals, set the PCKSTP1A bit to 0 (f1 provide enabled): Real-time clock, pulse width modulator, remote control signal receiver, serial interface UART0 to UART2, UART5 to UART7, SI/O3, SI/O4 multi-master I2C-bus interface, A/D converter To change the PCKSTP1A bit from 1 (f1 provide disabled) to 0, use following procedure: - (1) Stop the peripherals listed above that use peripheral clock f1. - (2) Set the PCKSTP1A bit to 0. - (3) Set the registers for the peripherals again. To change the clock source for the peripherals from fOCO-F or fOCO40M to f1, perform (1) and (2) above, and change the clock source from fOCO-F or fOCO40M to f1, then perform (3). ## PCKSTP11 (Timer peripheral clock stop bit) (b1) When using f1 or the main clock for the timer A and timer B count source, set the PCKSTP11 bit to 0 (f1 provide enabled). To change the PCKSTP11 bit from 1 (f1 provide disabled) to 0, use following procedure: - (1) Stop timer A and timer B. - (2) Set the PCKSTP11 bit to 0. - (3) Set the registers for timer A and timer B again. To change the timer A and timer B count source from fOCO-F to f1, perform (1) and (2) above, and set the TCDIV00 bit in the TCKDIVC0 register from 1 (fOCO-F) to 0 (f1), then perform (3). ### PCKSTP17 (Timer clock source select bit) (b7) Change the PCKSTP17 bit when all of the following conditions are met: - Both f1 and the main clock are stably supplied. - Both timer A and timer B are stopped. The PCKSTP17 bit is used for supplying the main clock to timer A and timer B. When in PLL operating mode, high-speed mode, medium-speed mode, or wait mode, the main clock can be used for the timer A and timer B count source. Do not use the main clock for the timer A and timer B count source in other normal operating modes (refer to 9.3 "Clock"). # 8.2.7 PLL Control Register 0 (PLC0) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. ### PLC02 to PLC00 (PLL multiplying factor select bit) (b2-b0) Write to bits PLC00 to PLC02 when the PLC07 bit is 0 (PLL off). When the PM21 bit in the PM2 register is 1 (clock change disabled), writing to bits PLC02 to PLC00 has no effect. ### PLC05 and PLC04 (Reference frequency counter set bit) (b5-b4) Write to bits PLC05 and PLC04 when the PLC07 bit is 0 (PLL off). When the PM21 bit in the PM2 register is 1 (clock change disabled), writing to bits PLC05 and PLC04 has no effect. ## PLC07 (Operation enable bit) (b7) When the PM21 bit in the PM2 register is 1 (clock change disabled), writing to the PLC07 bit has no effect. ## 8.2.8 Processor Mode Register 2 (PM2) Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. ### PM21 (System clock protection bit) (b1) The PM21 bit is used to protect the CPU clock. (Refer to 8.6 "System Clock Protection Function"). When the PM21 bit is set to 1, writing to the following bits has no effect: - Bits CM02, CM05, and CM07 in the CM0 register - Bits CM10 and CM11 in the CM1 register - The CM20 bit in the CM2 register - All bits in the PLC0 register Do not execute the WAIT instruction when the PM21 bit is 1. Once the PM21 bit is set to 1, it cannot be set to 0 by a program (writing 0 has no effect). ### PM25 (Peripheral clock fC provide bit) (b5) The PM25 bit provides fC to the real-time clock, CEC function, and remote control signal receiver. (See Figure 8.5 "Peripheral Function Clocks".) # 8.2.9 40 MHz On-Chip Oscillator Control Register 0 (FRA0) Rewrite the FRA0 register after setting the PRC0 bit in the PRCR register to 1 (write enabled). See Table 9.3 "Clock-Related Bit Setting and Modes" to select a clock and a mode. ### FRA00 (40 MHz on-chip oscillator start bit) (b0) When using an oscillator stop/restart detect interrupt, do not set the FRA00 bit to 0 (40 MHz on-chip oscillator off) while the FRA01 bit to 1 (40 MHz on-chip oscillator), and vice versa. ### FRA01 (On-chip oscillator select bit) (b1) Change the FRA01 bit if the both of the following conditions are met: - When the FRA00 bit is 1 (40 MHz on-chip oscillator on) and oscillation is stable - When the CM14 bit in the CM1 register is 0 (125 kHz on-chip oscillator on) and oscillation is stable When setting the FRA01 bit to 0 (125 kHz on-chip oscillator), do not set the FRA00 bit to 0 (40 MHz on-chip oscillator off) at the same time. Set the FRA00 bit to 0 after setting the FRA01 bit to 0. ### 8.3 Clocks Generated by Clock Generators Clocks generated by the clock generators are described below. #### 8.3.1 Main Clock This clock is supplied by the main clock oscillator and used as a clock source for the CPU and peripheral function clocks. After reset, the main clock is running, but is not used as a clock source for the CPU. The main clock oscillator is configured by connecting a ceramic resonator or crystal between pins XIN and XOUT. The main clock oscillator contains a feedback resistor, which is disconnected from the oscillator in stop mode in order to reduce the amount of power consumed by the chip. The main clock oscillator may also be configured by feeding an externally generated clock to the XIN pin. Figure 8.2 shows Main Clock Connection Example. Figure 8.2 Main Clock Connection Example The XOUT becomes high by setting the CM05 bit in the CM0 register to 1 (main clock oscillator turned off) after switching the clock source for the CPU clock to the sub clock (fC) or on-chip oscillator clock (fOCO-F, fOCO-S). In this case, the XIN is pulled high to the XOUT via the feedback resistor because the internal feedback resistor remains connected. When the main clock oscillator is not used, setting the CM13 bit in the CM1 register to 1 enables to select the internal feedback resistor not connected. Perform the following steps to start or stop the main clock. Refer to 8.2 "Registers" for details on register and bit access. To start the main clock oscillation: - (1) Set the CM15 bit to 1 (drive capacity high) when a ceramic resonator or crystal is connected between pins XIN and XOUT. - (2) Set the CM05 bit to 0 (main clock oscillating). - (3) Wait until main clock oscillation stabilizes. (When using an external clock, input the external clock through the XIN pin.) To stop the main clock oscillation, - (1) Set the CM20 bit in the CM2 register to 0 (oscillator stop/restart detect function disabled). - (2) Set the CM05 bit to 1 (stop). - (3) Stop the external clock (when inputting the external clock through the XIN pin). #### 8.3.2 PLL Clock PLL clock is generated by the PLL frequency synthesizer. This clock is used as the clock source for the CPU and peripheral function clocks. After reset, the PLL frequency synthesizer is stopped. PLL clock is a clock which divides the main clock by the selected values of bits PLC05 to PLC04 in the PLC0 register, and then multiplied by the selected values of bits PLC02 to PLC00. Set bits PLC05 and PLC04 to fit divided frequency between 2 MHz and 5 MHz. Figure 8.3 shows Relation between Main Clock and PLL Clock. Figure 8.3 Relation between Main Clock and PLL Clock Table 8.5 Example Settings for PLL Clock Frequencies | Main Clock | Setting Value | | PLL Clock | | |-------------------------|---------------------|----------------------|------------|--| | IVIAITI CIOCK | Bits PLC05 to PLC04 | Bits PLC02 to PLC00 | I LE GIOCK | | | 10 MHz | 01b (divide-by-2) | 010b (multiply-by-4) | 20 MHz | | | 5 MHz | 00b (not divided) | 010b (multiply-by-4) | 20 1011 12 | | | 12 MHz | 10b (divide-by-4) | 100b (multiply-by-8) | 24 MHz | | | 6 MHz | 01b (divide-by-2) | 100b (multiply-by-8) | 24 IVII IZ | | | 16 MHz | 10b (divide-by-4) | 100b (multiply-by-8) | 32 MHz | | | 8 MHz 01b (divide-by-2) | | 100b (multiply-by-8) | JZ IVII IZ | | #### 8.3.3 **fOCO40M** fOCO40M is a 40 MHz clock (approx.) supplied by the 40 MHz on-chip oscillator. It is the clock source for $\phi$ AD in the A/D converter. Follow the steps below to start or stop the 40 MHz on-chip oscillator clock. Refer to 8.2 "Registers" for details on register and bit access. - 40 MHz on-chip oscillator start - (1) Set the FRA00 bit in the FRA0 register to 1 (40 MHz on-chip oscillator on). - (2) Wait for tsu(fOCO40M). - 40 MHz on-chip oscillator stop - (1) Set the FRA01 bit in the FRA0 register to 0 (125 MHz on-chip oscillator) (when the CM27 bit is 1 (oscillator stop/restart detect interrupt)). - (2) Set the FRA00 bit in the FRA0 register to 0 (40 MHz on-chip oscillator off). #### 8.3.4 fOCO-F fOCO-F is a 40 MHz clock (approx.) supplied by the 40 MHz on-chip oscillator, and divided by 2. It is the clock source for the CPU and peripheral function clocks. After reset, fOCO-F is stopped. If the main clock stops oscillating and the FRA01 bit is 1 when the CM20 bit in the CM2 register is 1 (oscillator stop/restart detect function enabled), and the CM27 bit is 1 (oscillator stop/restart detect interrupt), fOCO-F is used as the clock source for the CPU. Refer to 8.3.3 "fOCO40M" to start or stop the 40 MHz on-chip oscillator clock. ## 8.3.5 125 kHz On-Chip Oscillator Clock (fOCO-S) This clock is approximately 125 kHz, and is supplied by the 125 kHz on-chip oscillator. It is used as the clock source for the CPU and peripheral function clocks. In addition, when the CSPRO bit in the CSPR register is 1 (count source protection mode enabled), this clock is used as the count source for the watchdog timer (refer to 15.4.2 "Count Source Protection Mode Enabled"). After reset, fOCO-S divided by 8 becomes the CPU clock. If the main clock stops oscillating and the FRA01 bit is 0, when the CM20 bit in the CM2 register is 1 (oscillator stop/restart detect function enabled) and the CM27 bit is 1 (oscillator stop/restart detect interrupt), the 125 kHz on-chip oscillator automatically starts operating and supplying the necessary clock for the MCU. Follow the steps below to start or stop fOCO-S. Refer to 8.2 "Registers" for details on register and bit access To start fOCO-S: - (1) Set the CM14 bit in the CM1 register to 0 (125 kHz on-chip oscillator on). - (2) Wait for tsu(fOCO-S). To start fOCO-S: (1) Set the CM14 bit in the CM1 register to 1 (125 kHz on-chip oscillator off). When the CM21 bit is 1 (on-chip oscillator used as the clock source for the CPU), the CM14 bit becomes 0 (125 kHz on-chip oscillator on). # 8.3.6 Sub Clock (fC) The sub clock is supplied by the sub clock oscillator. This clock is the clock source for count sources of the CPU clock, timer A, timer B, real-time clock, CEC function, and remote control signal receiver. The sub clock oscillator is configured by connecting a crystal between pins XCIN and XCOUT. The sub clock oscillator contains a feedback resistor, which is disconnected from the oscillation circuit in stop mode in order to reduce the amount of power consumed by the chip. The sub clock oscillator circuit may also be configured by feeding an externally generated clock to the XCIN pin. Figure 8.4 shows Sub Clock Connection Example. Insert a damping resistor if required. The resistance will vary depending on a crystal/ceramic resonator and the oscillation drive capacity setting. Use the value recommended by the manufacturer of crystal/ceramic resonator. When the oscillation drive capacity is set to low, check if oscillation is stable in low status. Also, place a feedback resistor between XCIN and XCOUT if the manufacturer recommends placing the resistor externally. Figure 8.4 Sub Clock Connection Example After reset, the sub clock is stopped. At this time, the feedback resistor is disconnected from the oscillator. Follow the steps below to start the sub clock. Refer to 8.2 "Registers" for details on register and bit access. - (1) Set the PU21 bit in the PUR2 register to 0 (P8\_4, P8\_6 and P8\_7 not pulled high). - (2) Set bits PD8 6 and PD8 7 in the PD8 register to 0 (P8 6, P8 7 function as input ports). - (3) Set the CM04 bit to 1 (XCIN-XCOUT oscillation function). Set the CM03 bit to 1 (XCIN-XCOUT drive capacity high). - (4) Wait until sub clock oscillation stabilizes (enter the external clock when entering it from the XCIN pin). ## 8.4 CPU Clock and Peripheral Function Clocks The CPU is run by the CPU clock, and the peripheral functions are run by the peripheral function clocks. #### 8.4.1 CPU Clock and BCLK The CPU clock is an operating clock for the CPU and watchdog timer. It is also used as a sampling clock for the NMI/SD digital filter. The main clock, PLL clock, fOCO-F, fOCO-S, or fC can be selected as the clock source for the CPU clock. (See Table 9.2 "Clocks in Normal Operating Mode".) When the main clock, PLL clock, or fOCO-S is selected as the clock source for the CPU clock, the selected clock divided by 1, 2, 4, 8 or 16 becomes the CPU clock. Use the CM06 bit in the CM0 register and bits CM17 to CM16 in the CM1 register to select a frequency-divided value. When selecting fOCO-F as the clock source for the CPU clock, fOCO-F divided by 2, 4, 8, or 16 becomes the CPU clock. Use the CM06 bit in the CM0 register and bits CM17 to CM16 in the CM1 register to select a frequency-divided value. When fC is selected as the clock source for the CPU clock, it is not divided and is used directly as the CPU clock. After reset, fOCO-S divided by 8 becomes the CPU clock. Note that when entering stop mode or when the CM21 bit in the CM2 register is 0 (main clock or PLL clock) and the CM05 bit is 1 (main clock off), the CM06 bit in the CM0 register becomes 1 (divide-by-8 mode). BCLK is a bus reference clock. In memory expansion or microprocessor mode, a BCLK signal with the same frequency as the CPU clock can be output from the BCLK pin by setting the PM07 bit in the PM0 register to 0 (output enabled). # 8.4.2 Peripheral Function Clocks (f1, f0CO40M, f0CO-F, f0CO-S, fC32, fC, Main Clock) f1, fOCO40M, fOCO-F, fOCO-S, and fC32 are operating clocks for the peripheral functions. f1 is one of the following: - Main clock divided by 1 (no division) - PLL clock divided by 1 (no division) - fOCO-S divided by 1 (no division) - fOCO-F divided by 1 (no division) f1 is used for timers A and B, PWM, real-time clock, remote control signal receiver, UART0 to UART2, UART5 to UART7, SI/O3, SI/O4, multi-master I<sup>2</sup>C-bus interface, and the A/D converter. When the WAIT instruction is executed after setting the CM02 bit in the CM0 register to 1 (peripheral function clock f1 turned off during wait mode), the f1 clock is stopped. fOCO40M can be used for the A/D converter. fOCO40M can be used when the FRA00 bit in the FRA0 register is 1 (40 MHz on-chip oscillator on). fOCO-F can be used for timers A and B, UART0 to UART2, UART5 to UART7, SI/O3, and SI/O4. fOCO-F can be used when the FRA00 bit in the FRA0 register is 1 (40 MHz on-chip oscillator on). fOCO-S is used for timers A and B. It is also used for reset, voltage detector, and watchdog timer. fOCO-S is also used when the CM14 bit in the CM1 register is set to 0 (125 kHz on-chip oscillator on). fC divided by 32 becomes fC32. fC32 is used for timers A and B, and can be used when the sub clock is on. fC is used as the count source for the real-time clock, remote control signal receiver, and CEC function when the PM25 bit in the PM2 register is 1 (peripheral clock fC provided). fC can be used when the sub clock is on. When in PLL operating mode, high-speed mode, medium-speed mode, or wait mode, main clock can be used for the timer A and timer B count source. Figure 8.5 shows Peripheral Function Clocks. Figure 8.5 Peripheral Function Clocks ## 8.5 Clock Output Function In single-chip mode, the f1, f8, f32 or fC clock can be output from the CLKOUT pin. Use bits CM01 to CM00 in the CM0 register, and the PCLK5 bit in the PCLKR register to select a clock. f8 has the same frequency as f1 divided by 8, and f32 has the same frequency as f1 divided by 32. Set the frequency of the clock output from the CLKOUT pin to 25 MHz or below. #### 8.6 System Clock Protection Function The system clock protection function prohibits the CPU clock from changing clock sources when the main clock is selected as the CPU clock source. This is to prevent the CPU clock from stopping due to an unexpected program operation. When the PM21 bit in the PM2 register is set to 1 (clock change disabled), the following bits remain unchanged even if they are written to: - The CM02 bit in the CM0 register (peripheral function clock f1 in wait mode) - The CM05 bit in the CM0 register (to prevent the main clock from being stopped) - The CM07 bit in the CM0 register (clock source of the CPU clock) - The CM10 bit in the CM1 register (MCU does not enter stop mode) - The CM11 bit in the CM1 register (clock source of the CPU clock) - The CM20 bit in the CM2 register (oscillator stop/restart detect function set) - All bits in the PLC0 register (PLL frequency synthesizer set) To use the system clock protect function, set the CM05 bit in the CM0 register to 0 (main clock oscillation) and CM07 bit to 0 (main clock as CPU clock source), and then follow the steps below. - (1) Set the PRC1 bit in the PRCR register to 1 (write to PM2 register enabled). - (2) Set the PM21 bit in the PM2 register to 1 (clock change disabled). - (3) Set the PRC1 bit in the PRCR register to 0 (write to PM2 register disabled). When the PM21 bit is 1, do not execute the WAIT instruction. ## 8.7 Oscillator Stop/Restart Detect Function This function detects a stop/restart of the main clock oscillator. The oscillator stop/restart detect function can be enabled and disabled with the CM20 bit in the CM2 register. A reset or oscillator stop/restart detect interrupt is generated when an oscillator stop or restart is detected. Set the CM27 bit in the CM2 register to select the reset or interrupt. Table 8.6 lists Oscillator Stop/Restart Detect Function Specifications. Table 8.6 Oscillator Stop/Restart Detect Function Specifications | Item | Specification | |--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | Oscillator stop detectable clock and frequency bandwidth | f(XIN) ≥ 2 MHz | | Enabling condition for the oscillator stop/restart detect function | Set the CM20 bit to 1 (enabled) | | Operation when oscillator stop/restart detected | When CM27 bit is 0: Oscillator stop detect reset generated When CM27 bit is 1: Oscillator stop/restart detect interrupt generated | # 8.7.1 Operation When CM27 Bit is 0 (Oscillator Stop Detect Reset) When main clock stop is detected while the CM20 bit is 1 (oscillator stop/restart detect function enabled), the MCU is initialized, and then stops (oscillator stop reset). Refer to 4. "Special Function Registers (SFRs)" and 6. "Resets". The status can be cancelled by a hardware reset or a voltage monitor 0 reset. The MCU can also be initialized and stopped when a restart is detected, but do not use the MCU in this manner. During main clock stop, do not set the CM20 bit to 1 and the CM27 bit to 0. # 8.7.2 Operation When CM27 Bit is 1 (Oscillator Stop/Restart Detect Interrupt) When the CM20 bit is 1 (oscillator stop/restart detect function enabled), the system is placed in the state shown in Table 8.7 if the main clock detects oscillator stop or restart. The CM21 bit becomes 1 in high-speed, medium-speed, or low-speed mode. The FRA01 bit does not change. Thus, high-speed and medium-speed mode become 125 kHz on-chip oscillator mode or 40 MHz on-chip oscillator mode. Because the CM07 bit does not change, low-speed mode remains in low-speed mode, but fOCO-S or fOCO-F becomes the clock source for the peripheral functions. When the CM21 bit is set to 1, the CM14 bit becomes 0 (125 kHz on-chip oscillator on), but the FRA00 bit does not change (40 MHz on-chip oscillator does not oscillate automatically). Thus, when the FRA01 bit is 1 (40 MHz on-chip oscillator selected), set the FRA00 bit to 1 (40 MHz on-chip oscillator on). Do not set the FRA00 bit to 0 while the FRA01 bit is 1, and vice versa. Since the CM21 bit does not change in PLL operating mode, change the mode to 125 kHz on-chip oscillator mode or 40 MHz on-chip oscillator mode in the interrupt routine. Table 8.7 State after Oscillator Stop/Restart Detect When CM27 Bit is 1 | С | ondition | After Detection | | | |-------------------------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | High-speed mode<br>Medium-speed<br>mode | <ul> <li>Oscillator stop/restart detect interrupt is generated</li> <li>CM14 bit is 0 (125 kHz on-chip oscillator on)</li> <li>CM21 bit is 1 (fOCO-S or fOCO-F is used as the clock source for</li> </ul> | | | | | Low-speed mode | the CPU and peripheral function clocks) (1, 2) | | | | Main clock | 40 MHz on-chip oscillator mode | <ul><li>CM22 bit is 1 (main clock stop detected)</li><li>CM23 bit is 1 (main clock stopped)</li></ul> | | | | oscillator stop<br>detected | 125 kHz on-chip oscillator mode | | | | | | PLL operating mode | <ul> <li>Oscillator stop/restart detect interrupt is generated</li> <li>CM14 bit is 0 (125 kHz on-chip oscillator on)</li> <li>CM21 bit remains unchanged</li> <li>CM22 bit is 1 (main clock stop detected)</li> <li>CM23 bit is 1 (main clock stopped)</li> </ul> | | | | Main clock<br>oscillator<br>restart<br>detected | - | <ul> <li>Oscillator stop/restart detect interrupt is generated</li> <li>CM14 bit is 0 (125 kHz on-chip oscillator on)</li> <li>CM21 bit does not change</li> <li>CM22 bit is 1 (main clock stop detected)</li> <li>CM23 bit is 0 (main clock oscillating)</li> </ul> | | | CM14 bit: Bit in the CM1 register Bits CM21, CM22, CM23: Bits in the CM2 register Notes: - 1. fOCO-S or fOCO-F is selected depending on the FRA01 bit setting. - 2. fC is used as the CPU clock in low-speed mode. # 8.7.3 Using the Oscillator Stop/Restart Detect Function After oscillator stop is detected, if the main clock reoscillates, set the main clock back to the clock source for the CPU clock and peripheral functions by a program. Figure 8.6 shows the Switching from On-Chip Oscillator Clock to Main Clock. Figure 8.6 Switching from On-Chip Oscillator Clock to Main Clock The CM22 bit becomes 1 at the same time an oscillator stop/restart detect interrupt is generated. When the CM22 bit is 1, the oscillator stop/restart detect interrupt is disabled. When setting the CM22 bit to 0 by a program, the oscillator stop/restart detect interrupt is enabled. # 8.8 Interrupt The oscillator stop/restart detect interrupt is a non-maskable interrupt. The watchdog timer interrupt, oscillator stop/restart detect interrupt, voltage monitor 1 interrupt, and voltage monitor 2 interrupt share the same vector. When using multiple interrupts together, read the detect flags of the events in the interrupt processing program, and determine the source of the interrupt. The detect flag for oscillator stop/restart detect is the CM22 bit in the CM2 register. After the interrupt source is determined, set the CM22 bit to 0 (not detected). #### 8.9 Notes on Clock Generator ## 8.9.1 Oscillator Using a Crystal or a Ceramic Resonator To connect a crystal/ceramic resonator follow the instructions below: - The oscillation characteristics are tied closely to the user's board design. Perform a careful evaluation of the board before connecting an oscillator. - Oscillator structure depends on a crystal/ceramic resonator. The M16C/65C Group MCU contains a feedback resistor, but an additional external feedback resistor may be required. Contact the manufacturer of crystal/ceramic resonator regarding circuit constants, as they are dependent on the a crystal/ceramic resonator or stray capacitance of the mounted circuit. - Check output from the CLKOUT pin to confirm that the clock generated by the oscillator is properly transmitted to the MCU. The procedure for outputting a clock from the CLKOUT pin is listed below. Set the clock output from the CLKOUT pin to 25 MHz or lower. Outputting the main clock - (1) Set the PRC0 bit in the PRCR register to 1 (write enabled). - (2) Set the CM11 bit in the CM1 register, the CM07 bit in the CM0 register, and the CM21 bit in the CM2 register all to 0 (main clock selected). - (3) Select the clock output from the CLKOUT pin (see the table below). - (4) Set the PRC0 bit in the PRCR register to 0 (write disabled). Table 8.8 Output from CLKOUT Pin When Selecting Main Clock | Bit Setting | | | |----------------|-------------------|-------------------------------------------------| | PCLKR register | CM0 register | Output from the CLKOUT Pin | | PCLK5 bit | Bits CM01 to CM00 | | | 1 | 00b | Clock with the same frequency as the main clock | | 0 | 10b | Main clock divided by 8 | | 0 | 11b | Main clock divided by 32 | Outputting the sub clock - (1) Set the PRC0 bit in the PRCR register to 1 (write enabled). - (2) Set the CM07 bit in the CM0 register to 1 (sub clock selected). - (3) Set the PCLK5 bit in the PCLKR register to 0, and bits CM01 to CM00 in the CM0 register to 01b (fC output from CLKOUT pin). - (4) Set the PRC0 bit in the PRCR register to 0 (write disabled). Figure 8.7 Oscillator Example #### 8.9.2 Noise Countermeasure # 8.9.2.1 Clock I/O Pin Wiring - Connect the shortest possible wiring to the clock I/O pin. - Connect (a) the capacitor's ground lead connected to the crystal/ceramic resonator, and (b) the MCU's VSS pin, with the shortest possible wiring (maximum 20 mm). Figure 8.8 Clock I/O Pin Wiring #### Reason: When noise enters the clock I/O pin, the clock waveform becomes unstable, which causes an error in operation or a program runaway. Also, if a potential difference attributed to the noise occurs between the VSS level of the MCU and the VSS level of the crystal/ceramic resonator, an accurate clock is not input to the MCU. # 8.9.2.2 Large Current Signal Line For large currents that exceed the MCU's current range, wire the signal lines as far away from the MCU as possible (especially the crystal/ceramic resonator). #### Reason: In the system using the MCU, there are signal lines for controlling motors, LEDs, and thermal heads. When a large current flows through these signal lines, noise is generated due to mutual inductance. Figure 8.9 Large Current Signal Line Wiring # 8.9.2.3 Signal Line Whose Level Changes at a High-Speed For a signal line whose level changes at a high-speed, wire it as far away from the crystal/ceramic resonator and its wiring pattern as possible. Do not wire it across or extend it parallel to a clock-related signal line or other signal lines which are sensitive to noise. #### Reason: A signal whose level changes at a high-speed (such as the signal from the TAiOUT pin) affects other signal lines due to the level change at rising or falling edges. Specifically, when the signal line crosses the clock-related signal line, the clock waveform becomes unstable, which causes an error in operation or a program runaway. Figure 8.10 Wiring of Signal Line Whose Level Changes at High-Speed #### 8.9.3 CPU Clock (Technical update number: TN-M16C-109-0309) When an external clock is input from the XIN pin and the main clock is used as the CPU clock, do not stop the external clock. ## 8.9.4 Oscillator Stop/Restart Detect Function - In the following cases, set the CM20 bit to 0 (oscillator stop/restart detect function disabled), and then change the setting of each bit. - When the CM05 bit is set to 1 (main clock stopped) - When the CM10 bit is set to 1 (stop mode) - To enter wait mode while using the oscillator stop/restart detect function, set the CM02 bit to 0 (peripheral function clock f1 not turned off during wait mode). - This function cannot be used if the main clock frequency is 2 MHz or lower. In that case, set the CM20 bit to 0 (oscillator stop/restart detect function disabled). - While the CM27 bit is 1 (oscillation stop/restart detect interrupt), when the FRA01 bit is 1 (40 MHz on-chip oscillator selected), set the FRA00 bit to 1 (40 MHz on-chip oscillator on). (Do not set the FRA00 bit to 0 while FRA01 bit is 1, and vice versa.) # 8.9.5 PLL Frequency Synthesizer To use the PLL frequency synthesizer, stabilize the supply voltage within the acceptable range of power supply ripple. Table 8.9 Acceptable Range of Power Supply Ripple | Symbol | Parameter | | Standard | | | Unit | |---------------|------------------------------------------------|--------------|----------|------|------|-------| | Symbol | Farameter | Farameter | | Тур. | Max. | Offic | | f(ripple) | Power supply ripple allowable frequency (VCC1) | | | | 10 | kHz | | VP-P(ripple) | Power supply ripple allowable | (VCC1 = 5 V) | | | 0.5 | V | | | amplitude voltage | (VCC1 = 3 V) | | | 0.3 | V | | VCC( ΔV /ΔT ) | Power supply ripple rising/falling | (VCC1 = 5 V) | | | 0.3 | V/ms | | | gradient | (VCC1 = 3 V) | | | 0.3 | V/ms | Figure 8.11 Voltage Fluctuation Timing # 9. Power Control # 9.1 Introduction This chapter describes how to reduce the amount of current consumption. # 9.2 Registers Refer to 8. "Clock Generator" for clock-related registers. Table 9.1 Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------------|--------|-----------------------------| | | | | 0000 0001b | | 0220h | Plash Memory Control Register 0 | FMR0 | (Other than user boot mode) | | 022011 | | | 0010 0001b | | | | | (User boot mode) | | 0222h | Flash Memory Control Register 2 | FMR2 | XXXX 0000b | # 9.2.1 Flash Memory Control Register 0 (FMR0) ## FMR01 (CPU rewrite mode select bit) (b1) Commands can be accepted by setting the FMR01 bit to 1 (CPU rewrite mode enabled). To set the FMR01 bit to 1, write 0 and then 1 in succession. Do not generate any interrupts or DMA transfers between setting 0 and 1. Change the FMR01 bit when the PM24 bit in the PM2 register is 0 ( $\overline{\text{NMI}}$ interrupt disabled) or high is input to the $\overline{\text{NMI}}$ pin. While in EW0 mode, write to this bit from a program in an area other than flash memory. Enter read array mode, and then set this bit to 0. ## FMSTP (Flash memory stop bit) (b3) The FMSTP bit resets the flash memory control circuits and minimizes current consumption in the flash memory. Access to the internal flash memory is disabled when the FMSTP bit is set to 1 (flash memory operation stopped). Set the FMSTP bit by a program located in an area other than the flash memory. Set the FMSTP bit to 1 under the following condition: • A flash memory access error occurs while erasing or programming in EW0 mode (the FMR00 bit does not revert to 1 (ready)). # 9.2.2 Flash Memory Control Register 2 (FMR2) ## FMR22 (Slow read mode enable bit) (b2) This bit enables the mode which reduces the amount of current consumption when reading the flash memory. When rewriting the flash memory (CPU rewrite mode), set the FMR22 bit to 0 (slow read mode disabled). To set the FMR22 bit to 1, write 0 and then 1 in succession. Make sure no interrupts or DMA transfers occur between writing 0 and 1. Set the FMR23 bit to 1 (low current consumption read mode enabled) after the FMR22 bit is set to 1 (slow read mode enabled). Also, set the FMR22 bit to 0 (slow read mode disabled) after the FMR23 bit is set to 0 (low current consumption read mode disabled). Do not change the FMR22 bit and FMR23 bit at the same time. #### FMR23 (Low current consumption read mode enable bit) (b3) This bit enables the mode which reduces the amount of current consumption when reading the flash memory. When rewriting the flash memory (CPU rewrite mode), set the FMR23 bit to 0 (low current consumption read mode disabled). Low current consumption read mode can be used when the CM07 bit in the CM0 register is 1 (sub clock used as CPU clock). To set the FMR23 bit to 1, write 0 and then 1 in succession. Make sure no interrupts or DMA transfers occur between writing 0 and 1. Set the FMR23 bit to 1 (low current consumption read mode enabled) after the FMR22 bit is set to 1 (slow read mode enabled). Also, set the FMR22 bit to 0 (slow read mode disabled) after the FMR23 bit is set to 0 (low current consumption read mode disabled). Do not change bits FMR22 and FMR23 at the same time. Do not set the FMR23 bit to 1 (low current consumption read mode enabled) when any of the following occurs: - When the CM07 bit is 0 (main clock, PLL clock, or on-chip oscillator clock selected as CPU clock source). - When the FMR22 bit is 0 (slow read mode disabled) - When the FMSTP bit is 1 (flash memory stopped) - During the wake up operation when the FMSTP bit is changed from 1 to 0 (tps) Do not perform the operations below when the FMR23 bit is 1. Set the FMR23 to 0 before performing them. - Change the CPU clock - Set to the FMSTP bit to 1 (flash memory stopped) - Enter the wait mode or stop mode - Execute the following commands: Program, block erase, lock bit program, read lock bit status, and block blank check #### 9.3 Clock The amount of current consumption correlates with the number of operating clocks and frequency. When there are fewer operating clocks and a lower frequency, current consumption will be low. Normal operating mode, wait mode, and stop mode can be used to control power consumption. All mode states, except wait mode and stop mode, are referred to as normal operating mode in this document. ## 9.3.1 Normal Operating Mode In normal operating mode, because both the CPU clock and the peripheral function clocks are supplied, the CPU and the peripheral functions are operating. Power control is exercised by controlling the CPU clock frequency. The higher the CPU clock frequency, the higher the processing capability. The lower the CPU clock frequency, the lower the power consumption in the chip. If unnecessary oscillator are stopped, power consumption is further reduced. ## 9.3.1.1 High-Speed Mode and Medium-Speed Mode In high-speed mode, the main clock divided by 1 (no division) is used as the CPU clock. In medium-speed mode, the main clock divided by 2, 4, 8 or 16 is used as the CPU clock. f1 with the same frequency of the main clock divided by 1 is used as the peripheral function clocks in both high-speed and medium-speed modes. When fC is supplied, fC and fC32 can be used as the peripheral function clocks. When fOCO-S is supplied, it can be used as the peripheral function clocks. When fOCO40M and fOCO-F are supplied, they can be used as the peripheral function clocks. # 9.3.1.2 PLL Operating Mode The PLL clock divided by 1 (no division), 2, 4, 8 or 16 is used as the CPU clock. f1 with the same frequency of the PLL clock divided by 1 (no division) is used as the peripheral function clocks. When fC is supplied, fC and fC32 can be used as the peripheral function clocks. When fOCO-S is supplied, it can be used as the peripheral function clocks. When fOCO40M and fOCO-F are supplied, they can be used as the peripheral function clocks. PLL operating mode can be entered and exited from medium-speed mode. To enter other modes including wait mode and stop mode, enter medium-speed mode first, and then enter the intended mode. Refer to Figure 9.1 "Clock Mode Transition" for details. # 9.3.1.3 40 MHz On-Chip Oscillator Mode The fOCO-F clock divided by 2, 4, 8 or 16 is used as the CPU clock. f1 with the same frequency of the fOCO-F clock divided by 1 is used as the peripheral function clocks. When fC is supplied, fC and fC32 can be used as the peripheral function clocks. When fOCO-S is supplied, it can be used as the peripheral function clocks. fOCO40M and fOCO-F can be used as the peripheral function clocks. ## 9.3.1.4 125 kHz On-Chip Oscillator Mode The fOCO-S clock divided by 1 (no division), 2, 4, 8 or 16 is used as the CPU clock. f1 with the same frequency of the fOCO-S clock divided by 1 is used as the peripheral function clocks. When fC is supplied, fC and fC32 can be used as the peripheral function clocks. fOCO-S can be used as the peripheral function clocks. When fOCO40M and fOCO-F are supplied, they can be used as the peripheral function clocks. ## 9.3.1.5 125 kHz On-Chip Oscillator Low Power Mode The main clock and fOCO-F are turned off after the MCU enters 125 kHz on-chip oscillator mode. The fOCO-S clock divided by 1 (no division), 2, 4, 8 or 16 is used as the CPU clock. f1 with the same frequency of the fOCO-S clock divided by 1 is used as the peripheral function clocks. When fC is supplied, fC and fC32 can be used as the peripheral function clocks. fOCO-S can be used as the peripheral function clocks. # 9.3.1.6 Low-Speed Mode fC is used as the CPU clock. When the CM21 bit is 0 and the CM11 bit is 0 (main clock), f1 with the same frequency of the main clock divided by 1 is used as the peripheral function clocks. When the CM21 bit is 0 and the CM11 bit is 1 (PLL clock), f1 with the same frequency of the PLL clock divided by 1 is used as the peripheral function clocks. When the CM21 bit is 1 (on-chip oscillator clock) and the FRA01 bit is 0 (125 kHz on-chip oscillator), f1 with the same frequency as the fOCO-S clock divided by 1 is used as the peripheral function clocks. When the CM21 bit is 1 (on-chip oscillator clock) and the FRA01 bit is 1 (40 MHz on-chip oscillator), f1 with the same frequency as the fOCO-F clock divided by 1 is used as the peripheral function clocks. fC and fC32 can be used as the peripheral function clocks. When fOCO-S is supplied, it can be used as the peripheral function clocks. When fOCO40M and fOCO-F are supplied, they can be used as the peripheral function clocks. #### 9.3.1.7 Low Power Mode The main clock and fOCO-F are stopped after the MCU enters low-speed mode. fC is used as the CPU clock. When the CM21 bit is 1 (on-chip oscillator clock) and the FRA01 bit is 0 (125 kHz on-chip oscillator clock), f1 with the same frequency as the fOCO-S clock divided by 1 is used as the peripheral function clocks. fC and fC32 can be used as the peripheral function clocks. When fOCO-S is supplied, it can be used as the peripheral function clocks. Table 9.2 Clocks in Normal Operating Mode | | | Peripheral C | clocks <sup>(2)</sup> | | | |-----------------|---------------------|--------------------------------------------------------------|-----------------------|----------|-------------------| | Mode | CPU Clock | f1 | fC, fC32 | fOCO-S | fOCO-F<br>fOCO40M | | High-speed | Main clock | | | | | | mode | divided by 1 (1) | Main clock divided by 1 | | | | | Medium-speed | Main clock | Wall Clock divided by 1 | Enabled | Enabled | Enabled | | mode | divided by n (1) | | Lilabled | Lilabled | Lilabied | | PLL operating | PLL clock | PLL clock divided by 1 | | | | | mode | divided by n (1) | T LE GOOK GIVIAGA BY T | | | | | 40 MHz on-chip | fOCO-F divided | fOCO-F divided by 1 | Enabled | Enabled | Enabled | | oscillator mode | by n <sup>(1)</sup> | 1000 F divided by 1 | Enablea | Lilabica | | | 125 kHz on-chip | fOCO-S divided | fOCO-S divided by 1 | Enabled | Enabled | Enabled | | oscillator mode | by n <sup>(1)</sup> | Todo o arriada sy T | 21100100 | 21145164 | Lilabioa | | 125 kHz on-chip | fOCO-S divided | 1000 0 11 11 11 | | | D | | oscillator low | by n <sup>(1)</sup> | fOCO-S divided by 1 | Enabled | Enabled | Disabled | | power mode | , | Any of the following: | | | | | | | Any of the following: Main clock divided by 1 (when the CM21 | | | | | | | is 0 and the CM11 is 0) | | | | | | | PLL clock divided by 1 (when the CM21 is | | | | | Low-speed | fC | 0 and the CM11 is 1) | Enabled | Enabled | Enabled | | mode | | fOCO-F divided by 1 (when the CM21 is 1 | | | | | | | and the FRA01 is 1) | | | | | | | fOCO-S divided by 1 (when the CM21 is 1 | | | | | | | and the FRA01 is 0) | | | | | Low power | fC | fOCO-S divided by 1 | Enabled | Enabled | Disabled | | mode | | (when the CM21 is 1 and the FRA01 is 0) | Lilabieu | Lilabieu | Disabled | CM11 : Bit in the CM1 register CM21 : Bit in the CM2 register FRA01 : Bit in the FRA0 register #### Notes: - 1. Select by setting the CM06 bit in the CM0 register and bits CM17 to CM16 in the CM1 register. - 2. The peripheral clock is enabled when each clock is supplied. Refer to 8. "Clock Generator" for the clock supply method. Table 9.3 Clock-Related Bit Setting and Modes | Mode | CM2 Register | CM1 Register | | CM0 Register | | FRA0 Register | | | |-------------------------------------------|--------------|--------------|------|--------------|-------|---------------|-------|-------| | Mode | CM21 | CM14 | CM11 | CM07 | CM05 | CM04 | FRA01 | FRA00 | | High-speed mode,<br>medium-speed mode | 0 | - | 0 | 0 | 0 | - | - | _ | | PLL operating mode | 0 | _ | 1 | 0 | 0 | - | - | _ | | 40 MHz on-chip oscillator mode | 1 | _ | 0 | 0 | _ | - | 1 | 1 | | 125 kHz on-chip oscillator mode | 1 | 0 | 0 | 0 | 0 (1) | - | 0 | 1 (1) | | 125 kHz on-chip oscillator low power mode | 1 | 0 | 0 | 0 | 1 | - | 0 | 0 | | Low-speed mode | _ | _ | 0 | 1 | 0 (1) | 1 | _ | 1 (1) | | Low power mode | _ | _ | 0 | 1 | 1 | 1 | - | 0 | -: 0 or 1 #### Note: 1. Both or either the main clock and fOCO-F are oscillated. Table 9.4 Selecting Clock Division Related Bits (1) | Division | CM1 Register | CM0 Register | |-----------------|-------------------|--------------| | Division | Bits CM17 to CM16 | CM06 bit | | No division (2) | 00b | 0 | | Divide-by-2 | 01b | 0 | | Divide-by-4 | 10b | 0 | | Divide-by-8 | - | 1 | | Divide-by-16 | 11b | 0 | -: Any value from 00b to 11b #### Notes: - 1. While in high-speed mode, medium-speed mode, PLL operating mode, 125 kHz on-chip oscillator mode, or 125 kHz on-chip oscillator low power mode. - 2. Select divide-by-1 (no division) in high-speed mode. Table 9.5 Example Settings for 40 MHz On-Chip Oscillator Mode Division Related Bits | Division | CPU Clock Frequency | CM1 Register | CM0 Register | |-----------------------------------|---------------------|--------------------|-----------------| | Division | CFO Clock Flequency | Bits CM17 and CM16 | CM06 bit | | Divide-by-4 (fOCO divided by 2) | Approx. 10 MHz | 01b (divide-by-2) | 0 | | Divide-by-8 (fOCO divided by 4) | Approx. 5 MHz | 10b (divide-by-4) | 0 | | Divide-by-16 (fOCO divided by 8) | Approx. 2.5 MHz | - | 1 (divide-by-8) | | Divide-by-32 (fOCO divided by 16) | Approx. 1.25 MHz | 11b (divide-by-16) | 0 | -: Any value from 00b to 11b #### 9.3.2 Clock Mode Transition Procedure Figure 9.1 shows Clock Mode Transition. Arrows indicate possible mode transitions. Figure 9.1 Clock Mode Transition To start or stop clock oscillations, or to change modes in normal operating mode, follow the instructions below. - Enter a different mode after the clock for that mode stabilizes completely. - When stopping a clock, do it after mode transition is completed. Do not stop the clock at the same time as mode transition. - When entering a new mode from PLL operating mode, high-speed or medium-speed mode, 40 MHz on-chip oscillator mode, or 125 kHz on-chip oscillator mode, or entering one of these modes from another mode, select divide by 8 or divide by 16. - When the clock division ratio is switched in PLL operating mode, high-speed or medium-speed mode, or 40 MHz on-chip oscillator mode, the ratio changes in the order shown in Figure 9.2. - To change the mode, follow procedures a to h listed below. For details on register and bit access, refer to 9.2 "Registers". Letters a to h correspond to those in Figure 9.1 "Clock Mode Transition" and Figure 9.2 "Clock Divide Transition". - For details on oscillator start and stop, refer to 8.3.1 "Main Clock" to 8.3.6 "Sub Clock (fC)". Figure 9.2 Clock Divide Transition a. Entering high-speed mode or medium-speed mode from 40 MHz on-chip oscillator mode, 125 kHz on-chip oscillator mode, or low-speed mode - (1) Start the main clock and wait until the oscillation stabilizes. Refer to 8.3.1 "Main Clock" for details. - (2) Select divide-by-8 or divide-by-16 mode by setting the CM06 bit and bits CM17 to CM16. - (3) Set the CM11 bit to 0, the CM21 bit to 0, and the CM07 bit to 0 (main clock selected as CPU clock source). - b. Entering PLL operating mode from high-speed mode or medium-speed mode - (1) Select the division of reference frequency counter by setting bits PLC05 and PLC04 in the PLC0 register, and the multiplication rate by setting bits PLC02 to PLC00 in the PLC0 register. - (2) Set the PLC07 bit to 1 (PLL on). - (3) Wait for tsu(PLL) until the PLL clock stabilizes. - (4) Select divide-by-8 or divide-by-16 mode by setting the CM06 bit and bits CM17 to CM16. - (5) Set the CM11 bit to 1, the CM21 bit to 0, and the CM07 bit to 0 (PLL clock selected as CPU clock source). - c. Entering high-speed mode or medium-speed mode from PLL operating mode - (1) Select divide-by-8 or divide-by-16 mode by setting the CM06 bit and bits CM17 to CM16. - (2) Set the CM11 bit to 0, the CM21 bit to 0, and the CM07 bit to 0 (main clock selected as CPU clock source). - (3) Set the PLC07 bit to 0 (PLL off). - d. Entering 40 MHz on-chip oscillator mode from high-speed mode, medium-speed mode, or 125 kHz on-chip oscillator mode - (1) Start the 40 MHz on-chip oscillator and wait until the oscillation stabilizes. Refer to 8.3.4 "fOCO-F" for details. - (2) Select divide-by-8 or divide-by-16 mode by setting the CM06 bit and bits CM17 to CM16. - (3) Set the FRA01 bit to 1 (40 MHz on-chip oscillator). - (4) Set the CM21 bit to 1 (on-chip oscillator clock selected as CPU clock source). - (5) Set the CM07 bit to 0 (main clock, PLL clock, or on-chip oscillator clock selected as CPU clock source). - e. Entering 125 kHz on-chip oscillator mode from 40 MHz on-chip oscillator mode, high-speed mode, medium-speed mode, or low-speed mode - (1) Start the 125 kHz on-chip oscillator and wait until the oscillation stabilizes. Refer to 8.3.5 "125 kHz On-Chip Oscillator Clock (fOCO-S)" for details. - (2) Select divide-by-8 or divide-by-16 mode by setting the CM06 bit and bits CM17 to CM16. - (3) Set the FRA01 bit to 0 (125 kHz on-chip oscillator). - (4) Set the CM21 bit to 1 (on-chip oscillator clock selected as CPU clock source). - (5) Set the CM07 bit to 0 (main clock, PLL clock, or on-chip oscillator clock selected as CPU clock source). - f. Entering low-speed mode from high-speed mode, medium-speed mode, or 125 kHz on-chip oscillator mode - (1) Start the sub clock and wait until the oscillation stabilizes. Refer to 8.3.6 "Sub Clock (fC)" for details. - (2) Select divide-by-8 or divide-by-16 mode by setting the CM06 bit and bits CM17 to CM16. - (3) Set the CM07 bit to 1 (sub clock selected as CPU clock source). g. Entering 125 kHz on-chip oscillator low power mode from 125 kHz on-chip oscillator mode Entering low power mode from low-speed mode Follow both or either of the procedures below (in no particular order). - (1) Stop the main clock. Refer to 8.3.1 "Main Clock" for details. - (2) Stop the 40 MHz on-chip oscillator. Refer to 8.3.4 "fOCO-F" for details for details. - h. Entering 125 kHz on-chip oscillator mode from 125 kHz on-chip oscillator low power mode Entering low-speed mode from low power mode - Follow both or either of the procedures below (in no particular order). - (1) Start the main clock and wait until the oscillation stabilizes. Refer to 8.3.1 "Main Clock" for details - (2) Start the 40 MHz on-chip oscillator and wait until the oscillation stabilizes. Refer to 8.3.4 "fOCO-F" for details. #### 9.3.3 Wait Mode The CPU clock stops in wait mode, therefore, the CPU, the watchdog timer, and $\overline{\text{NMI/SD}}$ digital filter clocked by the CPU clock stops running. However, if the CSPRO bit in the CSPR register is 1 (count source protection mode enabled), the watchdog timer remains active. Because the clock generator does not stop, peripheral functions supplied by a peripheral clock keep operating. ## 9.3.3.1 Peripheral Function Clock Stop Function When the CM02 bit is 1 (peripheral function clock f1 stops in wait mode), the f1 clock is turned off while in wait mode, and power consumption is reduced. However, all the peripheral clocks except f1 (i.e. fOCO40M, fOCO-F, fOCO-S, fC, and fC32) do not stop. ## 9.3.3.2 Entering Wait Mode The MCU enters wait mode by executing a WAIT instruction. When the CM11 bit is 1 (PLL clock selected as CPU clock source), set the CM11 bit to 0 (main clock selected as CPU clock source) before entering wait mode. Chip power consumption can be reduced by setting the PLC07 bit to 0 (PLL off). When using wait mode, set the following: - (1) Set the I flag to 0. - (2) Set the interrupt priority level of bits ILVL2 to ILVL0 in the interrupt control register for the peripheral function interrupt which is used to exit wait mode. Start the peripheral function which is used to exit wait mode if it is stopped. - (3) Set 000b (interrupt disabled) to bits ILVL2 to ILVL0 in the interrupt control registers for the peripheral function interrupts not used to exit wait mode. (When using any of the following resets or interrupts to exit wait mode, set 000b to bits ILVL2 to ILVL0 in all interrupt control registers for peripheral function interrupts: hardware reset, voltage monitor 0 reset, voltage monitor 1 reset, voltage monitor 2 reset, watchdog timer reset, NMI interrupt, voltage monitor 1 interrupt, or voltage monitor 2 interrupt). - (4) Set the I flag to 1. - (5) Execute the WAIT instruction. #### 9.3.3.3 Pin Status in Wait Mode Table 9.6 lists Pin Status in Wait Mode. Table 9.6 Pin Status in Wait Mode | Pin | | Memory Expansion Mode<br>Microprocessor Mode | Single-Chip Mode | |--------------------------------|-------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | A0 to A19, D0<br>CS0 to CS3, B | • | Retains the status just prior to entering wait mode | | | RD, WR, WRL | , WRH | High | Cannot be used as a bus control pin | | HLDA, BCLK | | High | | | ALE | | Low | | | I/O ports | | Retains the status just prior to entering wait mode | Retains the status just prior to entering wait mode | | | fC selected | | Does not stop | | CLKOUT f1, f8, f32 selected | | Cannot be used as a CLKOUT pin | Does not stop when the CM02 bit is 0. When the CM02 bit is 1, the status immediately prior to entering wait mode is retained. | # 9.3.3.4 Exiting Wait Mode The MCU exits wait mode by a reset or interrupt. Table 9.7 lists Resets and Interrupts to Exit Wait Mode and Conditions for Use. The peripheral function interrupts are affected by the CM02 bit in the CM0 register. When the CM02 bit is 0 (peripheral function clock f1 does not stop in wait mode), peripheral function interrupts can be used to exit wait mode. When the CM02 bit is 1 (peripheral function clock f1 stops in wait mode), the peripheral functions using the peripheral function clock f1 stop operating, so the peripheral functions activated by external signals and the peripheral function clocks except f1 (fOCO40M, fOCO-F, fOCO-S, fC, fC32) can be used to exit wait mode. fOCO-S is also used for the digital filter in the voltage detector, so the MCU exits wait mode when the digital filter is disabled or when fOCO-S is supplied. Table 9.7 Resets and Interrupts to Exit Wait Mode and Conditions for Use | | Interrupt, Reset | | | Conditions for Use | | | |-----------|-----------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | ın | terrupt, Reset | CM02 = 0 | CM02 = 1 | | | | | | ĪNT | Usable | Usable | | | | | | Key input | Usable | Usable | | | | | Peripheral function interrupt | Timer A,<br>timer B | Usable in all modes | Usable when fOCO-F, fOCO-S or fC32 is supplied and is used as count source. Usable when counting external signals in event counter mode. | | | | | | Remote control signal receiver | Usable | Usable when fC is supplied and is used as count source. Usable when fOCO-F, fOCO-S, or fC32 is supplied and is used as count source for timer B1 or B2, and timer B1 or B2 underflow is used as count source for remote control signal receiver. | | | | | | Serial interface | Usable in internal clock or external clock | Usable in external clock The internal clock can be used when fOCO-F is supplied and the internal clock is operated by fOCO-F. | | | | | | Multi-master<br>I <sup>2</sup> C-bus interface | Both I <sup>2</sup> C-bus interface interrupt and SCL/SDA interrupt are usable | SCL/SDA interrupt is usable | | | | pt | | CEC function | Usable | Usable when fC is supplied and is used as count source. | | | | Interrupt | | A/D converter Usable in one-shot mode or sweep mode. | | Usable when fOCO40M is supplied and is used as fAD in one-shot mode or single sweep mode. | | | | | | Real-time clock | Usable when fC is supplied and is | | | | | | | tage monitor 1,<br>tage monitor 2 | in the VW2C register is 1). Usable when the digital filter is ena in the VW2C register is 0) and fOC | abled (VW1C1 bit in the VW1C register or the VW2C1 bit abled (VW1C1 bit in the VW1C register or the VW2C1 bit CO-S is supplied (CM14 bit in the CM1 register is 0). | | | | | NM | Ī | Usable when the digital filter is disabled (bits NMIDF2 to NMIDF0 in the NMIDF register are 000b) | | | | | | Har | rdware reset | Usable | | | | | | Volt<br>res | tage monitor 0<br>et | Usable | | | | | Reset | Voltage monitor 1<br>reset,<br>Voltage monitor 2<br>reset | | Usable when the digital filter is disabled (VW1C1 bit in the VW1C register or the VW2C1 bit in the VW2C register is 1). Usable when the digital filter is enabled (VW1C1 bit in the VW1C register or the VW2C1 bit in the VW2C register is 0) and fOCO-S is supplied (CM14 bit in the CM1 register is 0). | | | | | | Wa | tchdog timer | register is 1). | ion mode is enabled (the CSPRO bit in the CSPR | | | When the MCU exits wait mode by using an interrupt, an interrupt request is generated, the CPU clock starts running, and interrupt routine is performed. When the MCU exits wait mode by an interrupt, the CPU clock is the same CPU clock used while executing the WAIT instruction. ## 9.3.4 Stop Mode In stop mode, all oscillator are stopped, so the CPU clock and peripheral function clocks are also stopped. Therefore, the CPU and the peripheral functions using these clocks stop operating. The least amount of power is consumed in this mode. If the voltage applied to pins VCC1 and VCC2 is VRAM or greater, the contents of internal RAM are retained. When applying 2.7 V or less to pins VCC1 and VCC2, make sure $VCC1 \ge VCC2 \ge VRAM$ . However, the peripheral functions activated by external signals keep operating. ## 9.3.4.1 Entering Stop Mode The MCU enters stop mode by setting the CM10 bit in the CM1 register to 1 (all clocks turned off). At the same time, the CM06 bit in the CM0 register becomes 1 (divide-by-8 mode), and the CM15 bit in the CM1 register becomes 1 (main clock oscillator drive capability high). Before entering stop mode, set the CM20 bit to 0 (oscillator stop/restart detect function disabled). When the CM11 bit is 1 (PLL clock used as the CPU clock source), set the CM11 bit to 0 (main clock used as the CPU clock source), and then the PLC07 bit to 0 (PLL turned off) before entering stop mode. When using stop mode, set the following: - (1) Set the I flag to 0. - (2) Set the interrupt priority level of bits ILVL2 to ILVL0 in the interrupt control register for the peripheral function interrupt which is used to exit stop mode. Start the peripheral function which is used to stop mode if it is stopped. - (3) Set 000b (interrupt disabled) to bits ILVL2 to ILVL0 in the interrupt control registers for the peripheral function interrupts not used to exit stop mode. (When using any of the following resets or interrupts to exit stop mode, set 000b to bits ILVL2 to ILVL0 in all interrupt control registers for peripheral function interrupts: hardware reset, voltage monitor 0 reset, NMI interrupt, voltage monitor 1 interrupt, or voltage monitor 2 interrupt) - (4) Set the I flag to 1. - (5) Set the CM10 bit in the CM1 register to 1. ## 9.3.4.2 Pin Status in Stop Mode Table 9.8 lists Pin Status in Stop Mode. Table 9.8 Pin Status in Stop Mode | Pin | Memory Expansion Mode<br>Microprocessor Mode | Single-Chip Mode | | |-------------------------------------------------------------------------|----------------------------------------------|----------------------------------------|--| | A0 to A19, D0 to D15,<br>CS0 to CS3, BHE | Retains status just prior to stop mode | | | | $\overline{RD}$ , $\overline{WR}$ , $\overline{WRL}$ , $\overline{WRH}$ | High | Cannot be used as bus control pin | | | HLDA, BCLK | High | | | | ALE | Undefined | | | | I/O ports | Retains status just prior to stop mode | Retains status just prior to stop mode | | | CLKOUT f1, f8, f32, fC selected | Cannot be used as CLKOUT pin | Retains status just prior to stop mode | | | XOUT | High | | | | XCIN, XCOUT | High-impedance | | | # 9.3.4.3 Exiting Stop Mode Use a reset or an interrupt to exit stop mode. Table 9.9 lists Resets and Interrupts to Exit Stop Mode and Conditions for Use. Table 9.9 Resets and Interrupts to Exit Stop Mode and Conditions for Use | | Interrupt, Reset | | Conditions for Use | |-----------|-------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------| | | Peripheral function interrupt | INT | Usable | | | | Key input | Usable | | | | Timer A, timer B | Usable when counting external signals in event counter mode | | | | Serial interface | Usable when an external clock is selected | | | | Multi-master I <sup>2</sup> C-bus interface | SCL/SDA interrupt is usable | | Interrupt | Voltage monitor 1 interrupt | | Usable when the digital filter is disabled (VW1C1 bit in the VW1C register is 1) | | Inte | Voltage monitor 2 interrupt | | Usable when the digital filter is disabled (VW2C1 bit in the VW2C register is 1) | | | NMI | | Usable when the digital filter is disabled (bits NMIDF2 to NMIDF0 in the NMIDF register are 000b) | | Reset | Hardware reset | | Usable | | Re | Voltage monitor 0 reset | | Usable | To exit stop mode by using hardware reset, voltage monitor 0 reset, $\overline{\text{NMI}}$ interrupt, voltage monitor 1 interrupt, or voltage monitor 2 interrupt, set bits ILVL2 to ILVL0 in the interrupt control registers for the peripheral function interrupt to 000b (interrupt disabled) before setting the CM10 bit to 1. When the MCU exits stop mode by using an interrupt, an interrupt request is generated, the CPU clock starts running, and interrupt routine is performed. When exiting stop mode by means of an interrupt, the CPU clock source varies depending on the CPU clock source setting before the MCU had entered stop mode. Table 9.10 lists CPU Clock After Exiting Stop Mode. Table 9.10 CPU Clock After Exiting Stop Mode | CPU Clock Before Entering Stop Mode | CPU Clock After Exiting Stop Mode | |------------------------------------------------------|-----------------------------------| | Main clock divided by 1 (no division), 2, 4, 8 or 16 | Main clock divided by 8 | | fOCO-S divided by 1 (no division), 2, 4, 8 or 16 | fOCO-S divided by 8 | | fOCO-F divided by 2, 4, 8 or 16 | fOCO-F divided by 8 | | fC | fC | # 9.4 Power Control in Flash Memory # 9.4.1 Stopping Flash Memory When the flash memory is stopped, current consumption is reduced. Execute a program in any area other than the flash memory. Figure 9.3 shows the setting procedure to stop and restart the flash memory. Follow the flowchart of Figure 9.3. Figure 9.3 Stop and Restart of the Flash Memory # 9.4.2 Reading Flash Memory Current consumption while reading the flash memory can be reduced by using bits FMR22 and FMR23 in the FMR2 register. #### 9.4.2.1 Slow Read Mode Slow read mode can be used when f(BCLK) is less than or equal to f(SLOW\_R) and the PM17 bit in the PM1 register is 1 (one wait). Figure 9.4 shows Setting and Canceling Slow Read Mode. When using 125 kHz on-chip oscillator clock or sub clock as the CPU clock source, a wait is unnecessary (technical update number: TN-16C-A179A/E). Figure 9.4 Setting and Canceling Slow Read Mode # 9.4.2.2 Low Current Consumption Read Mode Low current consumption read mode can be used when the CM07 bit in the CM0 register is 1 (sub clock used as CPU clock). Figure 9.5 shows Setting and Canceling Low Current Consumption Read Mode. Figure 9.5 Setting and Canceling Low Current Consumption Read Mode ## 9.5 Reducing Power Consumption To reduce power consumption, refer to the following descriptions when designing a system or writing a program. ## 9.5.1 Ports The MCU retains the state of each I/O port even when it enters wait mode or stop mode. A current flows in the active output ports. A shoot-through current flows to the input ports in the high-impedance state. Set the unassigned pins to input state, wait until the potential stabilizes, and then enter wait mode or stop mode. #### 9.5.2 A/D Converter When not performing A/D conversion, set the ADSTBY bit in the ADCON1 register to 0 (A/D operation stopped). #### 9.5.3 D/A Converter When not performing D/A conversion, set the DAiE bit (i = 0, 1) in the DACON register to 0 (Output disabled) and the DAi register to 00h. # 9.5.4 Stopping Peripheral Functions Use the PCLKSTP1 register to stop providing f1 to the peripheral functions not using f1. Use the CM02 bit in the CM0 register to stop the unnecessary peripheral functions while in wait mode. ## 9.5.5 Switching the Oscillation-Driving Capacity Set the driving capacity to low when oscillation is stable. #### 9.6 Notes on Power Control ## 9.6.1 CPU Clock When switching the CPU clock source, wait until oscillation of the switched clock source is stable. After exiting stop mode, wait until oscillation stabilizes before changing the division. #### 9.6.2 Wait Mode • Insert four or more NOP instructions following the WAIT instruction. When entering wait mode, because the instruction queue prefetches instructions that follow the WAIT instruction, prefetched instructions are sometimes executed prior to the interrupt routine used to exit wait mode. As shown below, when the instruction to set the I flag to 1 is allocated just before the WAIT instruction, interrupt requests are not accepted before the WAIT instruction is executed. The following is an example program for entering wait mode: Program Example: FSET I ; WAIT ; Enter wait mode NOP ; Insert at least four NOP instructions NOP NOP - Do not enter wait mode from PLL operating mode. To enter wait mode from PLL operating mode, first enter medium-speed mode, then set the PLC07 bit to 0 (PLL off). - Do not enter wait mode from low current consumption read mode. To enter wait mode from low current consumption read mode, set the FMR23 bit in the FMR2 register to 0 (low current consumption read mode disabled). - Do not enter wait mode from CPU rewrite mode. To enter wait mode from CPU rewrite mode, first set the FMR01 bit in the FMR0 register to 0 (CPU rewrite mode disabled), then disable the DMA transfer. - Set the PLC07 bit in the PLC0 register to 0 (PLL off). When the PLC07 bit is 1 (PLL on), current consumption cannot be reduced even in wait mode. ## 9.6.3 Stop Mode - When exiting stop mode by a hardware reset, drive the RESET pin low for 20 fOCO-S cycles or more. - Set the MR0 bit in the TAiMR register (i = 0 to 4) to 0 (pulse not output) when using timer A to exit stop mode. - When entering stop mode, insert a JMP.B instruction immediately after executing an instruction that sets the CM10 bit in the CM1 register to 1 (stop mode), and then insert at least four NOP instructions. When entering stop mode, the instruction queue reads ahead the instructions following the instruction which sets the CM10 bit to 1. Thus, some of the instructions may be executed before the MCU enters stop mode or before the interrupt routine for returning from stop mode. As shown below, when the instruction to set the I flag to 1 is allocated just before the instruction to set the CM10 bit to 1, interrupt requests are not accepted before entering stop mode. The following is an example program for entering stop mode: Program Example: FSET BSET 0, CM1; Enter stop mode JMP.B L2 ; Insert a JMP.B instruction L2: NOP ; At least four NOP instructions NOP NOP Do not enter stop mode from PLL operating mode. To enter stop mode from PLL operating mode, first enter medium-speed mode, then set the PLC07 bit to 0 (PLL off). - Do not enter stop mode from low current consumption read mode. To enter stop mode from low current consumption read mode, set the FMR23 bit in the FMR2 register to 0 (low current consumption read mode disabled). - Do not enter stop mode from CPU rewrite mode. To enter stop mode from CPU rewrite mode, first set the FMR01 bit in the FMR0 register to 0 (CPU rewrite mode disabled), then disable the DMA transfer. - Do not enter stop mode when the oscillator stop/restart detect function is enabled. To enter stop mode, set the CM20 bit in the CM2 register to 0 (oscillator stop/restart detect function disabled). - Do not enter stop mode when the FMR01 bit is 1 (CPU rewrite mode enabled), and do not enter stop mode when the flash memory is stopped (bits FMR01 and FMSTP are 1). ## 9.6.4 Low Current Consumption Read Mode - Enter low current consumption read mode through slow read mode (see Figure 9.5 "Setting and Canceling Low Current Consumption Read Mode" for details). - When the FMR23 bit in the FMR2 register is 1 (low current consumption read mode enabled), do not set the FMSTP bit to 1 (flash memory stopped). Also, when the FMSTP bit is 1, do not set the FMR23 bit to 1. - When the FMR01 bit in the FMR0 register to 1 (CPU rewrite mode enabled), do not set the FMR23 bit in the FMR2 register to 1 (low current consumption read mode enable). #### 9.6.5 Slow Read Mode • When the FMR01 bit in the FMR0 register to 1 (CPU rewrite mode enabled), do not set the FMR22 bit in the FMR2 register to 1 (slow read mode enabled). M16C/65C Group 10. Processor Mode # 10. Processor Mode ## 10.1 Introduction Single-chip mode, memory expansion mode, or microprocessor mode can be selected for the processor mode. Table 10.1 lists the Processor Mode Features. Table 10.1 Processor Mode Features | Processor Mode | Access Space | Pins Assigned as I/O Ports | | |--------------------------|---------------------------------------------------------------|--------------------------------------------------------|--| | Single-chip mode | SFR, internal RAM, internal ROM | All pins are I/O ports or peripheral function I/O pins | | | IIVIAMORV AVNONCION MOGA | SFR, internal RAM, internal ROM, external area <sup>(1)</sup> | Some pins serve as bus control pins (1) | | | Microprocessor mode | SFR, internal RAM, external area (1) | Some pins serve as bus control pins (1) | | Note: 1. Refer to 11. "Bus" for details. Table 10.2 I/O Pins | Pin Name | I/O | Function | |----------|-------|--------------------------| | CNVSS | Input | Selects a processor mode | M16C/65C Group 10. Processor Mode # 10.2 Registers Table 10.3 Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------------|--------|-----------------------------------------------------------------| | 0004h | Processor Mode Register 0 | PM0 | 0000 0000b (CNVSS pin is low)<br>0000 0011b (CNVSS pin is high) | | 0005h | Processor Mode Register 1 | PM1 | 0000 1000b | | 0010h | Program 2 Area Control Register | PRG2C | XXXX XX00b | # 10.2.1 Processor Mode Register 0 (PM0) Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. Bits PM01 to PM00 do not change at software reset, watchdog timer reset, oscillator stop detect reset, voltage monitor 1 reset, or voltage monitor 2 reset. Bits PM02, PM05 to PM04, PM06, and PM07 are enabled when bits PM01 to PM00 are 01b (memory expansion mode) or 11b (microprocessor mode). ## PM01 to PM00 (Processor mode bit) (b1 to b0) Do not rewrite bits PM01 to PM00 and PM07 to PM02 at the same time. (Technical update number: TN-M16C-71-0105) M16C/65C Group 10. Processor Mode # 10.2.2 Processor Mode Register 1 (PM1) Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. The PM12 bit becomes 1 by a program. Setting it to 0 has no effect. Bits PM11, PM15 to PM14 are enabled when bits PM01 to PM00 are 01b (memory expansion mode) or 11b (microprocessor mode). # PM10 (CS2 area switch bit (data flash enable bit)) (b0) This bit is used to select the function of addresses 0E000h to 0FFFFh. Table 10.4 lists Data Flash (Addresses 0E000h to 0FFFFh). Table 10.4 Data Flash (Addresses 0E000h to 0FFFFh) | PM10 Bit in PM1 Register | | 0 | 1 | |--------------------------|-----------------------|---------------|---------------| | | Single-chip mode | Reserved area | Data flash | | Processor Mode | Memory expansion mode | External area | Data flash | | | Microprocessor mode | External area | Reserved area | Data flash includes block A (addresses 0E000h to 0EFFFh) and block B (addresses 0F000h to 0FFFFh). When data flash is selected by the setting of the PM10 bit, both block A and block B can be used. The PM10 bit automatically becomes 1 while the FMR01 bit in the FMR0 register is 1 (CPU rewrite mode). ## PM13 (Internal area expansion bit 0) (b3) This bit is used to select the range of the RAM, program ROM 1, and external area. When the PM13 bit is 0, the size of the RAM and program ROM 1 is limited, but a wide range can be selected for the external area. When the PM13 bit is 1, the entire RAM and addresses 80000h to CFFFFh in program ROM 1 are available. Table 10.5 lists the Functions of PM13 Bit and Table 10.6 lists Functions of Addresses 80000h to CFFFFh. Table 10.5 Functions of PM13 Bit | | Access Are | .0 | Bit S | etting | |----------|-----------------------------|---------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------| | | ACCESS AIE | a | PM13 = 0 | PM13 = 1 | | Internal | Internal RAM Program ROM 1 | | Addresses 00400h up to 03FFFh (15 KB) are available (addresses 04000h to 0CFFFh cannot be used). | The entire area is usable. | | | | | Addresses D0000h up to FFFFFh (192 KB) are available (addresses 40000h to CFFFFh cannot be used). | Addresses 80000h up to FFFFFh are available (addresses 40000h to 7FFFFh cannot be used). | | External | Memory<br>expansion<br>mode | 04000h to<br>0CFFFh | Usable | Reserved | | | | 40000h to<br>7FFFFh | Usable | Usable | | | | 80000 to<br>CFFFFh | Usable | Reserved | | | Micro-<br>processor<br>mode | 04000h to<br>0CFFFh | Usable | Reserved | | | | 40000h to<br>7FFFFh | Usable | Usable | | | | 80000 to<br>CFFFFh | Usable | Usable | PM13: Bit in the PM1 register Table 10.6 Functions of Addresses 80000h to CFFFFh | PM13 Bit | in PM1 Register | 0 | 1 | |----------------|-----------------------|---------------|-------------------------------------------------------------------------| | | Single-chip mode | Reserved area | When program ROM 1 is available, then | | Processor Mode | Memory expansion mode | Evtornal area | program ROM 1. When program ROM 1 is not available, then reserved area. | | | Microprocessor mode | External area | External area | The PM13 bit becomes 1 while the FMR01 bit in the FMR0 register is set to 1 (CPU rewrite mode). ## 10.2.3 Program 2 Area Control Register (PRG2C) Set the PRC6 bit in the PRCR register to 1 (write enabled) before rewriting this register. ## PRG2C0 (Program ROM 2 disable bit) (b0) This bit is used to select the function of addresses 10000h to 13FFFh. Table 10.7 lists Program ROM 2 (Addresses 10000h to 13FFFh). Table 10.7 Program ROM 2 (Addresses 10000h to 13FFFh) | PRG2C0 E | Bit in PRG2C Register | 0 | 1 | |----------------|-----------------------|---------------|---------------| | | Single-chip mode | Program ROM 2 | Reserved area | | Processor Mode | Memory expansion mode | Program ROM 2 | External area | | | Microprocessor mode | Reserved area | External area | Program ROM 2 includes the on-chip debugger monitor area and user boot code area. Refer to 30.7.1 "User Boot Function" for details. ## 10.3 Operations ## 10.3.1 Processor Mode Settings Set the processor mode using the CNVSS pin and bits PM01 to PM00 in the PM0 register. In hardware reset, power-on reset, or voltage monitor 0 reset, the processor mode is selected by the CNVSS pin input level. Table 10.8 lists Processor Mode after Hardware Reset, Power-On Reset, or Voltage Monitor 0 Reset. Table 10.8 Processor Mode after Hardware Reset, Power-On Reset, or Voltage Monitor 0 Reset | CNVSS Pin Input Level | Processor Mode | Bits PM01 to PM00 in the PM0 Register | |-----------------------|---------------------|---------------------------------------| | VSS | Single-chip mode | 00b (single-chip mode) | | VCC1 | Microprocessor mode | 11b (microprocessor mode) | Rewriting bits PM01 to PM00 places the MCU in the mode corresponding to bits PM01 to PM00 regardless of whether the input level of the CNVSS pin is high or low. When VCC1 is applied to the CNVSS pin and then the MCU is reset by hardware reset, power-on reset, or voltage monitor 0 reset, the internal ROM cannot be accessed regardless of the value of bits PM01 to PM00. Table 10.9 lists Bits PM01 to PM00 Set Values and Processor Modes. Do not rewrite these bits to enter microprocessor mode in the internal ROM, or to exit microprocessor mode in areas overlapping the internal ROM. Table 10.9 Bits PM01 to PM00 Set Values and Processor Modes | Bits PM01 to PM00 | Processor Mode | |-------------------|------------------------| | 00b | Single-chip mode | | 01b | Memory expansion mode | | 10b | Do not set this value. | | 11b | Microprocessor mode | Figure 10.1 shows Memory Map in Single-Chip Mode. Figure 10.1 Memory Map in Single-Chip Mode ## 11. Bus ### 11.1 Introduction Two types of buses are available: - Internal bus in the MCU - External bus which is used to access to external devices in memory expansion mode or microprocessor mode Table 11.1 Bus Specifications | Item | Specification | |--------------|-------------------------------------------------------------------------------------| | | Used in all processor modes | | Internal bus | Separate bus | | internal bus | • 16-bit data bus width | | | • 0 or 1 software waits can be inserted | | | Used in memory expansion mode or microprocessor mode | | | Separate bus or multiplexed bus selectable | | | Data bus width selectable (8 or 16 bits) | | | •Number of address buses selectable (12, 16, or 20 buses) | | | •4 chip select outputs CS0 to CS3 | | External bus | • Combinations of read and write signals selectable (RD, BHE, WR or RD, WRL, WRH) | | | • RDY available | | | •0 to 8 software waits can be inserted | | | • Memory area expansion function (up to 4 MB) (refer to 12. "Memory Space Expansion | | | Function") | | | •3 V or 5 V interface | ## 11.2 Registers Table 11.2 lists bus related registers. Refer to 10. "Processor Mode" for registers PM0 and PM1. Refer to 30. "Flash Memory" for the FMR1 register. Table 11.2 Registers | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------|--------|---------------------| | | | | 0000 0000b | | 0004h | Processor Mode Register 0 | PM0 | (CNVSS pin is low) | | 000411 | Flocessor Mode Register o | PIVIO | 0000 0011b | | | | | (CNVSS pin is high) | | 0005h | Processor Mode Register 1 | PM1 | 0000 1000b | | 0008h | Chip Select Control Register | CSR | 01h | | 0009h | External Area Recovery Cycle Control Register | EWR | XXXX XX00b | | 0011h | External Area Wait Control Expansion Register | EWC | 00h | | 001Bh | Chip Select Expansion Control Register | CSE | 00h | | 0221h | Flash Memory Control Register 1 | FMR1 | 00X0 XX0Xb | ## 11.2.1 Chip Select Control Register (CSR) # CSiW ( $\overline{CSi}$ wait bit) (i = 0 to 3) (b7-b4) Set the CSiW bit to 0 (wait state) under the following conditions: - The $\overline{RDY}$ signal is used in the area indicated by $\overline{CSi}$ . - The multiplexed bus is used in the area indicated by CSi. - The PM17 bit in the PM1 register is 1 (wait state) in memory expansion mode or microprocessor mode. When the CSiW bit is 0 (wait state), the number of wait states can be selected using bits CSEi1W to CSEi0W in the CSE register. ## 11.2.2 Chip Select Expansion Control Register (CSE) Set the CSiW bit (i = 0 to 3) in the CSR register to 0 (wait state) before writing to bits CSEi1W to CSEi0W. To set the CSiW bit to 1 (no wait state), set bits CSEi1W to CSEi0W to 00b first, and then set the CSiW bit to 1. Do not set bits CSEi1W to CSEi0W to 11b for a multiplexed bus area. ## 11.2.3 External Area Wait Control Expansion Register (EWC) This register can be used as a separate bus area. When bits CSEi1W to CSEi0W in the CSE register are 11b (select wait states by bits EWCi1 to EWCi0), bits EWCi1 to EWCi0 are enabled (i = 0 to 3). The following is an example of the number of cycles: Example: $2\phi + 3\phi$ The number of cycles between the falling edge and the rising edge of the $\overline{RD}$ or $\overline{WR}$ signal. The number of cycles between bus access start and the falling edge of the $\overline{RD}$ or $\overline{WR}$ signal. # 11.2.4 External Area Recovery Cycle Control Register (EWR) The EWR register is enabled when bits CSEi1W to CSEi0W in the CSE register are 11b. ## 11.3 Operations ## 11.3.1 Common Specifications between the Internal Bus and External Bus ### 11.3.1.1 Reference Clock Both the internal and external buses operate based on the BCLK. However, the area accessed and wait states affect bus operation. Refer to 11.3.2.1 "Software Wait States of the Internal Bus" and 11.3.5.9 "Software Wait States" for details. ### 11.3.1.2 Bus Hold Both the internal and external buses are in a hold state under the following condition: • Rewriting the flash memory in EW1 mode while auto-programming or auto-erasing When the bus is in hold state, the following occur: - CPU stops - DMAC stops - The watchdog timer stops when the CSPRO bit in the CSPR register is 0 (count source protection mode disabled) - State of I/O ports is retained. Bus use priority is given to bus hold, DMAC, and CPU in descending order. However, if the CPU is accessing an odd address in word units, DMAC cannot gain control of the bus between two separate accesses. # Bus Hold > DMAC > CPU Figure 11.1 Bus Use Priority ### 11.3.2 Internal Bus The internal bus is used to access the internal area in the MCU. ### 11.3.2.1 Software Wait States of the Internal Bus The PM17 bit in the PM1 register, which is a software-wait-related bit, affects both the internal memory and the external area. Table 11.3 lists Bits and Bus Cycles Related to Software Wait States (SFR and Internal Memory). The data flash of the internal ROM is affected by both the PM17 bit in the PM1 register and the FMR17 bit in the FMR1 register. Table 11.3 Bits and Bus Cycles Related to Software Wait States (SFR and Internal Memory) | Area | | Setting of Software- | Wait-Related Bits | Software Wait | | | |--------------|---------------|-------------------------------------|-------------------|---------------|-------------------|--| | | | FMR1 register PM1 register PM17 bit | | States | Bus Cycle | | | SFR | | 0 or 1 | 0 or 1 | 1 | 2 BCLK cycles (1) | | | Internal RAM | | 0 or 1 | 0 | None | 1 BCLK cycle (1) | | | IIILEIIIAII | CAIVI | 0 01 1 | 1 | 1 | 2 BCLK cycles | | | | Program ROM 1 | 0 or 1 | 0 | None | 1 BCLK cycle (1) | | | Internal | Program ROM 2 | 0 01 1 | 1 | 1 | 2 BCLK cycles | | | ROM | Data flash | 0 | 0 or 1 | 1 | 2 BCLK cycles (1) | | | | | 1 | 0 | None | 1 BCLK cycle | | | | | ı | 1 | 1 | 2 BCLK cycle | | Note: 1. Status after reset. ### 11.3.3 External Bus The external bus is used to access external devices in memory expansion mode or microprocessor mode. In memory expansion or microprocessor mode, some pins serve as the bus control pins to perform data input to and output from external devices. The bus control pins are as follows: A0 to A19, D0 to D15, CS0 to CS3, RD, WRL/WR, WRH/BHE, ALE, RDY, HOLD, HLDA, and BCLK. ### 11.3.4 External Bus Mode Multiplexed bus mode or separate bus mode can be selected using bits PM05 to PM04 in the PM0 register. Table 11.4 lists the Difference between Separate Bus and Multiplexed Bus Modes. ## **11.3.4.1** Separate Bus In external bus mode, data and address are separate. ### 11.3.4.2 Multiplexed Bus In external bus mode, data and address are multiplexed. - When the input level to the BYTE pin is high (8-bit data bus) D0 to D7 and A0 to A7 are multiplexed. - When the input level to the BYTE pin is low (16-bit data bus) D0 to D7 and A1 to A8 are multiplexed. D8 to D15 are not multiplexed (do not use these pins). External devices connected to a multiplexed bus are assigned only even addresses of the MCU. Table 11.4 Difference between Separate Bus and Multiplexed Bus Modes | Pin Name (1) | Separate Bus | Multiplexed Bus | | | |-----------------------------------------------|--------------|--------------------------|-------------------|--| | Fill Name (*) | Separate bus | BYTE = high | BYTE = low | | | P0_0 to P0_7/D0 to D7 | D0 to D7 | (Note 2) | (Note 2) | | | P1_0 to P1_7/D8 to D15 | D8 to D15 | I/O port<br>P1_0 to P1_7 | (Note 2) | | | P2_0/A0 (/D0) | A0 X | A0 D0 | X A0 | | | P2_1 to P2_7/A1 to A7<br>(/D1 to D7/D0 to D6) | A1 to A7 | A1 to A7 D1 to D7 | A1 to A7 D0 to D6 | | | P3_0/A8 (/D7) | | | \\A8\\D7\_\ | | #### Notes: - 1. See Table 11.8 "Pin Functions for Each Processor Mode" for bus control signals not listed above. - 2. Depends on the setting of bits PM05 to PM04 in the PM0 register, and area being accessed. See Table 11.8 "Pin Functions for Each Processor Mode" for details. ### 11.3.5 External Bus Control The following describes the signals needed for accessing external devices and the functionality of software wait states. ### 11.3.5.1 Address Bus The address bus consists of 20 lines: A0 to A19. The address bus width can be set to 12, 16, or 20 bits using the PM06 bit in the PM0 register, and the PM11 bit in the PM1 register. Table 11.5 lists the Set Value of Bits PM06 and PM11 and the Corresponding Address Bus Widths. Table 11.5 Set Value of Bits PM06 and PM11 and the Corresponding Address Bus Widths | Bit Set Value (1) | Pin Function | Address Bus Width | | |-------------------|--------------|-------------------|--| | PM11 = 1 | P3_4 to P3_7 | 12 bits | | | PM06 = 1 | P4_0 to P4_3 | 12 Dits | | | PM11 = 0 | A12 to A15 | 16 bits | | | PM06 = 1 | P4_0 to P4_3 | TO DIIS | | | PM11 = 0 | A12 to A15 | 20 hita | | | PM06 = 0 | A16 to A19 | 20 bits | | Note: 1. Only set the values listed above. When the processor mode is changed from single-chip mode to memory expansion mode, the address bus is undefined until an external area is accessed. ### 11.3.5.2 Data Bus When input to the BYTE pin is high (8-bit width), the data bus is comprised of eight lines (D0 to D7). When input to the BYTE pin is low (16-bit width), the data bus is comprised of 16 lines (D0 to D15). Do not change the input level to the BYTE pin. ### 11.3.5.3 Chip Select Signal The chip select signals (hereafter referred to as $\overline{CS}$ ) are output from the $\overline{CSi}$ pin (i = 0 to 3). These pins can be set to function as I/O ports or as $\overline{CS}$ using the CSi bit in the CSR register. In 1-MB mode, the external area can be separated into a maximum of four spaces by the $\overline{\text{CSi}}$ signal. In 4-MB mode, the $\overline{\text{CSi}}$ signal or bank number is output from the $\overline{\text{CSi}}$ pin. Refer to 12. "Memory Space Expansion Function". Figure 11.2 shows Examples of Address Bus and $\overline{\text{CSi}}$ Signal Output in 1-MB Mode. #### Example 1 Accessing the external area indicated by $\overline{\text{CSj}}$ in the next cycle after accessing the external area indicated by $\overline{\text{CSi.}}$ The address bus and chip select signal both change state between these two cycles. #### Example 2 Accessing the internal ROM or internal RAM in the next cycle after accessing the external area indicated by $\overline{\text{CSi.}}$ The chip select signal changes state, but the address bus does not. #### Example 3 Accessing the external area indicated by $\overline{\text{CSi}}$ in the next cycle after accessing the external area indicated by the same $\overline{\text{CSi}}$ . The address bus changes state, but the chip select signal does not. #### Example 4 Not accessing any area (no instruction prefetch generated) in the next cycle after accessing the external area indicated by $\overline{\text{CSi.}}$ Neither the address bus nor the chip select signal changes state between these two cycles. #### Note: 1. These examples show the address bus and chip select signal when accessing areas in two successive cycles. The chip select bus cycle may be extended to more than two cycles depending on the combination of these examples. The figure above assume a separate bus is selected and the area is accessed for read without wait states. i = 0 to 3 (not including $i \neq j$ , however) Figure 11.2 Examples of Address Bus and CSi Signal Output in 1-MB Mode ## 11.3.5.4 Read and Write Signals When the data bus is 16 bits wide, the read and write signals can be selected based on combinations of $\overline{RD}$ , $\overline{BHE}$ , and $\overline{WR}$ , or combinations of $\overline{RD}$ , $\overline{WRL}$ , and $\overline{WRH}$ using the PM02 bit in the PM0 register. When the data bus is 8 bits wide, use combinations of $\overline{RD}$ , $\overline{WR}$ , and $\overline{BHE}$ . Table 11.6 lists Operation of the $\overline{RD}$ , $\overline{WRL}$ and $\overline{WRH}$ Signals. Table 11.7 lists Operation of the $\overline{RD}$ , $\overline{WR}$ and $\overline{BHE}$ Signals. Table 11.6 Operation of the RD, WRL and WRH Signals | Data Bus Width | RD | WRL | WRH | Status of External Data Bus | |------------------------|----|-----|-----|-------------------------------------------| | | L | Н | Н | Read data | | 16-bit | Н | L | Н | Write 1 byte of data to an even address | | (BYTE pin input = low) | Н | Н | L | Write 1 byte of data to an odd address | | | Н | L | L | Write data to both even and odd addresses | Table 11.7 Operation of the RD, WR and BHE Signals | Data Bus<br>Width | RD | WR | BHE | A0 | Status of External Data Bus | |---------------------|----|----|-------|--------|---------------------------------------------| | | Н | L | L | Н | Write 1 byte of data to an odd address. | | 40 54 | L | Н | L | Н | Read 1 byte of data from an odd address. | | 16-bit<br>(BYTE pin | Н | L | Н | L | Write 1 byte of data to an even address. | | input = low) | L | Н | Н | L | Read 1 byte of data from an even address. | | input = low) | Н | L | L | L | Write data to both even and odd addresses. | | | L | Н | L | L | Read data from both even and odd addresses. | | 8-bit<br>(BYTE pin | Н | L | _ (1) | H or L | Write 1 byte of data. | | input = high) | L | Н | _ (1) | H or L | Read 1 byte of data. | Note: 1. Do not use. ## 11.3.5.5 ALE Signal The ALE signal is used to latch the address when a multiplexed bus space is accessed. Latch the address at the falling edge of the ALE signal. Figure 11.3 ALE Signal, Address Bus, and Data Bus ## 11.3.5.6 **RDY** Signal This signal is provided for accessing external devices which need to be accessed at low speed. If input to the $\overline{\text{RDY}}$ pin is low at the last falling edge of BCLK in the bus cycle, one wait state is inserted in the bus cycle. While in wait state, the following signals retain the state in which they were when the $\overline{\text{RDY}}$ signal was acknowledged: A0 to A19, D0 to D15, CS0 to CS3, RD, WRL, WRH, WR, BHE, ALE, HLDA Then, when input to the $\overline{RDY}$ pin is detected high at the falling edge of BCLK, the remaining bus cycle is executed. Figure 11.4 shows Examples in Which Wait State Was Inserted into Read Cycle by $\overline{RDY}$ Signal. To use the $\overline{RDY}$ signal, set the corresponding bit (among bits CS3W to CS0W) in the CSR register to 0 (with wait state). When not using the $\overline{RDY}$ signal, pull-up the $\overline{RDY}$ pin. Figure 11.4 Examples in Which Wait State Was Inserted into Read Cycle by RDY Signal ### 11.3.5.7 BCLK Output When the PM07 bit in the PM0 register is set to 0 (output enabled), a clock with the same frequency as the CPU clock is output as BCLK from the BCLK pin. Refer to 8.4 "CPU Clock and Peripheral Function Clocks". **Table 11.8 Pin Functions for Each Processor Mode** | Processor Mode | | Memory Expansion Mode or Microprocessor Mode | | | | Memory<br>Expansion Mode | | | |-------------------------|-----------------------------------------------|----------------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------------------|--|--| | Bits PM05 to PM04 | | 00b (separate bus) | | 01b (CS2 is for multiplexed bus and the others are for separate bus) 10b (CS1 is for multiplexed bus and the others are for separate bus) | | 11b (the entire CS space is for multiplexed bus) (1, 2, 3) | | | | Data bus width BYTE Pin | | 8 bits<br>High | 16 bits<br>Low | 8 bits<br>High | 16 bits<br>Low | 8 bits<br>High | | | | P0_0 to P0_7 | | D0 to D7 | D0 to D7 | D0 to D7 (6) | D0 to D7 <sup>(6)</sup> | I/O ports | | | | P1_0 to P1_7 | | I/O ports | D8 to D15 | I/O ports | D8 to D15 <sup>(6, 7)</sup> | I/O ports | | | | P2_0 | | A0 | A0 | A0/D0 (4) | A0 | A0/D0 | | | | P2_1 to P2_7 | | A1 to A7 | A1 to A7 | A1 to A7<br>/D1 to D7 <sup>(4)</sup> | A1 to A7<br>/D0 to D6 <sup>(4)</sup> | A1 to A7<br>/D1 to D7 | | | | P3_0 | P3_0 | | A8 | A8 | A8/D7 <sup>(4)</sup> | Undefined value is output | | | | P3_1 to P3_3 | | A9 to A11 | | | | I/O ports | | | | P3_4 to P3_7 | PM11 = 0 | A12 to A15 | A12 to A15 | | | | | | | 1 0_4 10 1 0_7 | PM11 = 1 | I/O ports | | | | | | | | P4_0 to P4_3 | PM06 = 0 | A16 to A19 I/O ports | | | | | | | | 1 4_0 10 1 4_0 | PM06 = 1 | I/O ports | | | | | | | | P4 4 | $P4\_4 \qquad \qquad \frac{CS0 = 0}{CS0 = 1}$ | | I/O ports | | | | | | | 1 7_7 | | | CS0 | | | | | | | P4_5 | CS1 = 0 | I/O ports | | | | | | | | 1 | CS1 = 1 | CS1 | | | | | | | | P4_6 | CS2 = 0 | I/O ports | | | | | | | | 1 | CS2 = 1 | CS2 | | | | | | | | P4_7 | CS3 = 0 | I/O ports | | | | | | | | ¬_/ | CS3 = 1 | CS3 | | | | | | | | P5_0 | PM02 = 0 | WR | | | | | | | | F5_0 | PM02 = 1 | _ (5) | _ (5) | | | _ (5) | | | | DC 4 | PM02 = 0 | BHE | | | | | | | | P5_1 PM02 = 1 | | _ (5) | WRH | _ (5) | WRH | _ (5) | | | | P5_2 | | RD | | | | | | | | P5_3 | | BCLK | | | | | | | | P5_4 | | HLDA | | | | | | | | P5_5 | | HOLD | | | | | | | | P5_6 | | ALE | | | | | | | | P5_7 | | RDY | | | | | | | | I/O port: Eupoti | one on I/O nor | to or pariphar | al function I/O ni | no | | | | | I/O port: Functions as I/O ports or peripheral function I/O pins. PM11: Bit in the PM1 register PM06, PM05 to PM04, PM02: Bits in the PM0 register CS3 to CS0: Bits in the CSR register #### Notes: - When setting bits PM05 and PM04 to 11b (multiplexed bus assigned to the entire CS space) while bits 1. PM01 and PM00 are 01b (memory expansion mode), apply a high to the BYTE pin (external data bus 8 bits wide). - While the CNVSS pin is driven high (= VCC1), do not set bits PM05 to PM04 to 11b. When bits PM05 to PM04 are set to 11b in memory expansion mode, P3\_1 to P3\_7 and P4\_0 to P4\_3 become I/O ports, in which case the accessible area for each $\overline{\text{CS}}$ is 256 bytes. - In separate bus mode, these pins serve as the address bus. - When the data bus is 8 bits wide, set the PM02 bit to 0 (RD, BHE, WR). - When accessing an area using a multiplexed bus, these pins output an undefined value while writing. - Do not use D8 to D15 with multiplexed bus. ## 11.3.5.8 External Bus Status When Internal Area is Accessed Table 11.9 lists the External Bus Status When an Internal Area is Accessed. Figure 11.5 shows the Typical Bus Timings When Accessing SFRs. Table 11.9 External Bus Status When an Internal Area is Accessed | Item | | SFR Accessed | Internal ROM or RAM Accessed | |------------------|-------|-------------------------|----------------------------------------------------------| | A0 to A19 | | Address output | Retain the last accessed address of external area or SFR | | D0 to | Read | High-impedance | High-impedance | | D15 | Write | Data output | Undefined | | RD, WR, WRL, WRH | | RD, WR, WRL, WRH output | High-level output | | BHE | | BHE output | Retain the last accessed status of external area or SFRs | | CS0 to CS3 | | High-level output | High-level output | | ALE | | Low-level output | Low-level output | Figure 11.5 Typical Bus Timings When Accessing SFRs ### 11.3.5.9 Software Wait States The PM17 bit in the PM1 register, which is a software-wait-related bit, affects both the internal memory and the external area. Software wait states can be inserted to the external area by setting the PM17 bit, setting the CSiW bit in the CSR register, and bits CSEi1W to CSEi0W in the CSE register for each $\overline{CSi}$ (i = 0 to 3). To use the $\overline{RDY}$ signal, set the corresponding CSiW bit to 0 (wait state). See Table 11.10 "Bits and Bus Cycles Related to Software Wait States (External Area)" for details. Table 11.10 Bits and Bus Cycles Related to Software Wait States (External Area) | Area Bus Mode | | Setting of Software-Wait-Related Bits | | | Software | | | |---------------|-------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------|---------------------|-----------------------| | | | PM17 | CSiW | CSEi1W to<br>CSEi0W | EWCi1 to<br>EWCi0 | Wait Cycles | Bus Cycles | | | | 0 | 1 | 00b | _ | None | 1 BCLK cycle (read) | | | | O | l | OOD | - | None | 2 BCLK cycles (write) | | | | - | 0 | 00b | - | $1 (1\phi + 1\phi)$ | 2 BCLK cycles (4) | | | | - | 0 | 01b | - | $2(1\phi + 2\phi)$ | 3 BCLK cycles | | | Separate | - | 0 | 10b | - | $3(1\phi + 3\phi)$ | 4 BCLK cycles | | area | bus | - 0 | | 00b | $(2\phi + 3\phi)$ | 5 BCLK cycles | | | | | | , and the second | 11b | 01b | $(2\phi + 4\phi)$ | 6 BCLK cycles | | - Juli | | | | | 10b | $(3\phi + 4\phi)$ | 7 BCLK cycles | | External | | | | | 11b | $(4\phi + 5\phi)$ | 9 BCLK cycles | | " | " | | 0 (3) | 00b | - | $1 (1\phi + 1\phi)$ | 2 BCLK cycles | | | | | 0 (2) | 00b | - | 1 (5) | 3 BCLK cycles | | | Multiplexed | - | 0 (2) | 01b | | 2 | 3 BCLK cycles | | | bus | - | 0 (2) | 10b | - | 3 | 4 BCLK cycles | | | | 1 | 0 (2, 3) | 00b | - | 1 (5) | 3 BCLK cycles | i = 0 to 3 - indicates that either 0 or 1 can be set. PM17: Bit in the PM1 register CSiW: Bits in the CSR register (1) CSEi1W, CSEi0W: Bits in the CSE register EWCi1, EWCi0: Bits in the EWC register #### Notes: - 1. To use the RDY signal, set the CSiW bit to 0 (wait state). - 2. When accessing with a multiplexed bus, set the CSiW bit to 0 (wait state). - 3. To access an external area when the PM17 bit is 1, set the CSiW bit to 0 (wait state). - 4. After reset, the PM17 bit is set to 0 (no wait state), bits CS0W to CS3W are set to 0 (wait state), and the CSE register is set to 00h (one wait state for CS0 to CS3). Therefore, all external areas are accessed with one wait state. - 5. When setting one wait in the multiplexed bus, the bus cycle is the same as two waits. Figure 11.6 Typical Bus Timings Using Software Wait States (1/4) Figure 11.7 Typical Bus Timings Using Software Wait States (2/4) Figure 11.8 Typical Bus Timings Using Software Wait States (3/4) Figure 11.9 Typical Bus Timings Using Software Wait States (4/4) Figure 11.10 Recovery Cycle ### 11.4 Notes on Bus ## 11.4.1 Reading Data Flash When 2.7 V $\leq$ VCC1 $\leq$ 3.0 V and f(BCLK) $\geq$ 16 MHz, or when 3.0 V < VCC1 $\leq$ 5.5 V and f(BCLK) $\geq$ 20 MHz, one wait must be inserted to read the data flash. Use the PM17 bit or the FMR17 bit to insert one wait. ### 11.4.2 External Bus When a hardware reset, power-on reset, or voltage monitor 0 reset is performed with a high-level input on the CNVSS pin, the internal ROM cannot be read. ## 11.4.3 External Access Immediately after Writing to the SFRs When accessing an external device after writing to the SFRs, the write signal and $\overline{CSi}$ signal switch simultaneously. Thus, adjust the capacity of each signal so as not to delay the write signal. ### 11.4.4 Wait and $\overline{RDY}$ Do not use the RDY function when bits CSEi1W to CSEi0W in the CSE register are 11b. ### 11.4.5 **HOLD** HOLD input is unavailable. Connect the HOLD pin to VCC2 via a resistor (pull-up). # 12. Memory Space Expansion Function ### 12.1 Introduction The following describes the memory space expansion function. In memory expansion or microprocessor mode, the memory space expansion function allows the access space to be expanded. Table 12.1 lists Memory Space Expansion Function Specifications. In this chapter, the external area accessed by the $\overline{\text{CSi}}$ (i = 0 to 3) signal is referred to as the $\overline{\text{CSi}}$ area. **Table 12.1** Memory Space Expansion Function Specifications | Item | Specification | |-----------|----------------------------------------------------------------------| | 1-MB mode | Memory space 1 MB (no expansion) | | 1-MB Mode | • Specify the external area (CSi area) accessed by the CSi signal. | | | Memory space 4 MB | | 4-MB mode | Select bank numbers to access to data. | | | Allows the accessed address to be offset by 40000h | | | • The CSi pin function differs depending on the area to be accessed. | i = 0 to 3 ## 12.2 Registers Table 12.2 lists registers related to the memory expansion function. Refer to 10. "Processor Mode" for the PM1 register. Table 12.2 Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------|--------|-------------| | 0005h | Processor Mode Register 1 | PM1 | 0000 1000b | | 000Bh | Data Bank Register | DBR | 00h | ## 12.2.1 Data Bank Register (DBR) The DBR register is enabled when bits PM01 to PM00 in the PM0 register are 01b (memory expansion mode) or 11b (microprocessor mode). This register becomes write enabled when bits PM15 to PM14 in the PM1 register are 11b (4-MB mode). ## 12.3 Operations ### 12.3.1 1-MB Mode In 1-MB mode, the memory space is 1 MB. The external area to be accessed is specified using the $\overline{\text{CSi}}$ signals. #### Notes: 1. When the PM13 bit in the PM1 register is 0, 15 KB of the internal RAM and 192 KB of the internal ROM can be used. See the table below for addresses XXXXXh and YYYYYh. | Internal RAM | | | | | |--------------|----------------|--|--|--| | Capacity | Address XXXXXh | | | | | 12 KB | 033FFh | | | | | 20 KB | 03FFFh | | | | | 31 KB | 03FFFh | | | | | 47 KB | 03FFFh | | | | | Program ROM 1 | | | | |---------------|----------------|--|--| | Capacity | Address YYYYYh | | | | 128 KB | E0000h | | | | 256 KB | D0000h | | | | 384 KB | D0000h | | | | 512 KB | D0000h | | | - 2. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as internal ROM (data flash). - 3. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as internal ROM (program ROM 2). - 4. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as a reserved area. - 5. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as a reserved area. Figure 12.1 Memory Mapping and $\overline{CS}$ Areas in 1-MB Mode (PM13 = 0) #### Notes 1. See the table below for addresses XXXXXh and YYYYYh. | Internal RAM | | | | | |--------------|----------------|--|--|--| | Capacity | Address XXXXXh | | | | | 12 KB | 033FFh | | | | | 20 KB | 053FFh | | | | | 31 KB | 07FFFh | | | | | 47 KB | 0BFFFh | | | | | Program ROM 1 | | | |---------------|----------------|--| | Capacity | Address YYYYYh | | | 128 KB | E0000h | | | 256 KB | C0000h | | | 384 KB | A0000h | | | 512 KB | 80000h | | - 2. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as internal ROM (data flash). - 3. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as internal ROM (program ROM 2). - 4. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as a reserved area. - 5. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as a reserved area. Figure 12.2 Memory Mapping and $\overline{CS}$ Areas in 1-MB Mode (PM13 = 1) ### 12.3.2 4-MB Mode In 4-MB mode, the memory space is 4 MB. Bits BSR2 to BSR0 in the DBR register select the bank number to be accessed to read or write data. Setting the OFS bit to 1 (offset) allows the accessed address to be offset by 40000h. In 4-MB mode, the $\overline{\text{CSi}}$ pin function differs depending on the area to be accessed. ## 12.3.2.1 Addresses 04000h to 3FFFFh, C0000h to FFFFFh • The $\overline{\text{CSi}}$ signal is output from the $\overline{\text{CSi}}$ pin (same operation as 1-MB mode, except the last address of the $\overline{\text{CS1}}$ area is up to 3FFFFh). ### 12.3.2.2 Addresses 40000h to BFFFFh - The CS0 pin outputs a low-level signal. - Pins CS3 to CS1 output the setting values of bits BSR2 to BSR0 (bank number). Figure 12.3 and Figure 12.4 show the memory mapping and $\overline{CS}$ areas in 4-MB mode. Note that banks 0 to 6 are data-only areas. Place programs in bank 7 or the $\overline{CSi}$ area. #### Notes 1. When the PM13 bit in the PM1 register is 0, 15 KB of the internal RAM and 192 KB of the internal ROM can be used. See the table below for addresses XXXXXh and YYYYYh. | Internal RAM | | | | | |--------------|----------------|--|--|--| | Capacity | Address XXXXXh | | | | | 12 KB | 033FFh | | | | | 20 KB | 03FFFh | | | | | 31 KB | 03FFFh | | | | | 47 KB | 03FFFh | | | | | Program ROM 1 | | | | |---------------|----------------|--|--| | Capacity | Address YYYYYh | | | | 128 KB | E0000h | | | | 256 KB | D0000h | | | | 384 KB | D0000h | | | | 512 KB | D0000h | | | - 2. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as internal ROM (data flash). - 3. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as internal ROM (program ROM 2). - 4. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as a reserved area. - 5. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as a reserved area. - 6. The CS0 pin outputs a low signal, and pins CS3 to CS1 output a bank number. Figure 12.3 Memory Mapping and $\overline{CS}$ Areas in 4-MB Mode (PM13 = 0) #### Notes: 1. See the table below for addresses XXXXXh and YYYYYh. | Internal RAM | | | | |--------------|----------------|--|--| | Capacity | Address XXXXXh | | | | 12 KB | 033FFh | | | | 20 KB | 053FFh | | | | 31 KB | 07FFFh | | | | 47 KB | 0BFFFh | | | | Program ROM 1 | | |---------------|----------------| | Capacity | Address YYYYYh | | 128 KB | E0000h | | 256 KB | C0000h | | 384 KB | A0000h | | 512 KB | 80000h | - 2. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as internal ROM (data flash). - 3. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as internal ROM (program ROM 2). - 4. When the PM10 bit is 0, this area is used as an external area; when the bit is 1, this area is used as a reserved area. - 5. When the PRG2C0 bit in the PRG2C register is 1, this area is used as an external area; when the bit is 0, this area is used as a reserved area. - 6. The CS0 pin outputs a low signal, and pins CS3 to CS1 output a bank number. Figure 12.4 Memory Mapping and $\overline{CS}$ Areas in 4-MB Mode (PM13 = 1) In the example below, the $\overline{\text{CS}}$ pin of a 4-MB ROM is connected to the MCU's $\overline{\text{CS0}}$ pin. The 4-MB ROM address input pins AD21, AD20, and AD19 are connected to the MCU's $\overline{\text{CS3}}$ , $\overline{\text{CS2}}$ , and $\overline{\text{CS1}}$ pins, respectively. The address input AD18 pin is connected to the MCU's A19 pin. Figure 12.6 to Figure 12.8 show the relationship of addresses between the 4-MB ROM and the MCU in the connection example of Figure 12.5. In microprocessor mode or memory expansion mode, where the PM13 bit in the PM1 register is 0, banks are located every 512 KB. Setting the OFS bit in the DBR register to 1 (offset) allows the accessed address to be offset by 40000h, allowing even data overlapping at a bank boundary to be accessed in succession. In memory expansion mode, where the PM13 bit is 1, each 512-KB bank can be accessed in 256 KB units by switching them with the OFS bit. Because the SRAM can be accessed when the chip select signals S2 is high and $\overline{S1}$ is low, $\overline{CS0}$ and $\overline{CS2}$ can be connected to S2 and $\overline{S1}$ , respectively. If SRAM does not have the input pins that accept high active and low active chip select signals ( $\overline{S1}$ , S2), $\overline{CS0}$ and $\overline{CS2}$ should be decoded externally to the chip. Figure 12.5 External Memory Connection Example in 4-MB Mode Figure 12.6 Relationship between Addresses in 4-MB ROM and Those in MCU (1/3) Figure 12.7 Relationship between Addresses in 4-MB ROM and Those in MCU (2/3) Figure 12.8 Relationship between Addresses in 4-MB ROM and Those in MCU (3/3) # 13. Programmable I/O Ports Note = For the 100-pin package, do not access the addresses of registers P11 to P14, PD11 to PD14, or PUR3. #### 13.1 Introduction Table 13.1 lists Programmable I/O Ports Specifications (hereafter referred to as I/O ports). Each pin functions as an I/O port, a peripheral function input/output, or a bus control pin. To set peripheral functions, refer to the description for the individual function. To use ports as peripheral function input/output pins, refer to 13.4 "Peripheral Function I/O". To use ports as bus control pins, refer to 11.3.5 "External Bus Control". Table 13.1 Programmable I/O Ports Specifications | Item | | Specification | | | |--------------------|-----------------------------|---------------------------------------------------------------|-----------------|--| | | | 128-pin package | 100-pin package | | | | Total | 114 | 88 | | | Number of | CMOS output | 111 | 85 | | | ports | N-channel open drain output | 3 | 3 | | | 1 | VCC2 level | P0 to P5, P12, P13 <sup>(1)</sup> | P0 to P5 | | | Input/output | VCC1 level | P6 to P11, P14 <sup>(1)</sup> | P6 to P10 | | | Input/output level | | Select input or output for each individual port by a program. | | | | Select function | | Select a pull-up resistor in 4-bit units. | | | Note: 1. P11 to P14 can be used when the PU37 bit in the PUR3 register is 1 (P11 to P14 enabled). Table 13.2 I/O Pins | Pin Name | I/O | Function | |-----------------------------------------------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------| | P0_0 to P0_7, P1_0 to P1_7,<br>P2_0 to P2_7, P3_0 to P3_7,<br>P4_0 to P4_7, P5_0 to P5_7,<br>P6_0 to P6_7 | I/O | Input/output port CMOS output, pull-up resistor selectable | | P7_0 to P7_7 | I/O | Input/output port P7_0 to P7_1: N-channel open drain output, no pull-up resistor P7_2 to P7_7: CMOS output, pull-up resistor selectable | | P8_0 to P8_7 | I/O | Input/output port P8_0 to P8_4, P8_6, P8_7: CMOS output, pull-up resistor selectable P8_5: N-channel open drain output, no pull-up resistor | | P9_0 to P9_7, P10_0 to P10_7,<br>P11_0 to P11_7, P12_0 to P12_7,<br>P13_0 to P13_7, P14_0 to P14_1 | I/O | Input/output port CMOS output, pull-up resistor selectable | #### 13.2 I/O Ports and Pins Figure 13.1 to Figure 13.11 and Table 13.3 to Table 13.11 show the I/O port configuration, and Figure 13.12 shows the I/O pin configuration. Figure 13.1 I/O Ports (Basic) Table 13.3 I/O Ports (Basic) | | Peripheral Function I/O | | | |--------------------------------------|----------------------------------------------|---------------------------------|----------------------------------------------| | Port | Peripheral function input (A) in Figure 13.1 | Analog input (B) in Figure 13.1 | Peripheral function input (A) in Figure 13.1 | | P3_0 to P3_7, P4_0 to P4_3, P5_0 to | | | | | P5_4, P5_6, P11_0 to P11_7, P12_0 to | N/A | N/A | N/A | | P12_7, P13_0 to P13_7, P14_0, P14_1 | | | | | P0_0 to P0_7, P2_0 to P2_3, P2_6, | N/A | Available | N/A | | P2_7, P10_0 to P10_3 | IN/A | Available | IN/A | | P5_5 | Available (HOLD) | N/A | N/A | | P8_2 to P8_4, P9_1, P9_7 | Available | N/A | N/A | | P2_4, P2_5, P10_4 to P10_7 | N/A | Available | Available | Figure 13.2 I/O Ports (Basic + Output from Peripheral Functions) Table 13.4 I/O Ports (Basic + Output from Peripheral Functions) | | Peripheral Function I/O | | | |--------------------------------------------------|---------------------------|------------------|--| | Port | Peripheral function input | Analog input (B) | | | | (A) in Figure 13.2 | in Figure 13.2 | | | P9_6 | N/A | Available | | | P4_4, P6_0, P6_4, P7_3 to P7_5, P8_1, P9_0, P9_2 | Available | N/A | | | P5_7 | Available (RDY) | N/A | | | P9_5 | Available | Available | | Figure 13.3 I/O Ports (Port P1) Table 13.5 I/O Ports (Port P1) | | Peripheral Function I/O | | | |--------------|---------------------------|------------------|--| | Port | Peripheral function input | Analog input (B) | | | | (A) in Figure 13.3 | in Figure 13.3 | | | P1_4 | N/A | N/A | | | P1_5 to P1_7 | Available | N/A | | Figure 13.4 I/O Ports (Port P1 + Output from Peripheral Functions) Table 13.6 I/O Ports (Port P1 + Output from Peripheral Functions) | | Peripheral Function I/O | | |------|---------------------------|------------------| | Port | Peripheral function input | Analog input (B) | | | (A) in Figure 13.4 | in Figure 13.4 | | P1_0 | Available | N/A | Figure 13.5 I/O Ports (Port P1, CMOS Output/N-channel Open Drain Output Selection) Table 13.7 I/O Ports (Port P1, CMOS Output/N-channel Open Drain Output Selection) | | Peripheral Function I/O | | | |--------------|---------------------------|------------------|--| | Port | Peripheral function input | Analog input (B) | | | | (A) in Figure 13.5 | in Figure 13.5 | | | P1_1 to P1_3 | Available | N/A | | Figure 13.6 I/O Ports (CMOS Output/N-channel Open Drain Output Selection) Table 13.8 I/O Ports (CMOS Output/N-channel Open Drain Output Selection) | | Peripheral Function I/O | | | |----------------------------------------------------------|---------------------------|------------------|--| | Port | Peripheral function input | Analog input (B) | | | | (A) in Figure 13.6 | in Figure 13.6 | | | P4_5, P6_1 to P6_3, P6_5 to P6_7, P7_2, P7_6, P7_7, P8_0 | Available | N/A | | Figure 13.7 I/O Ports (CMOS Output/N-channel Open Drain Output Selection, PWM) Table 13.9 I/O Ports (CMOS Output/N-channel Open Drain Output Selection, PWM) | | Peripheral Function I/O | | | |------------|---------------------------|------------------|--| | Port | Peripheral function input | Analog input (B) | | | | (A) in Figure 13.7 | in Figure 13.7 | | | P4_6, P4_7 | Available | N/A | | Figure 13.8 I/O Ports (N-channel Open Drain Output) Table 13.10 I/O Ports (N-channel Open Drain Output) | | Peripheral Function I/O | | |------------|---------------------------|------------------| | Port | Peripheral function input | Analog input (B) | | | (A) in Figure 13.8 | in Figure 13.8 | | P7_0, P7_1 | Available | N/A | Figure 13.9 I/O Ports (NMI) Figure 13.10 I/O Ports (XC) Figure 13.11 I/O Ports (D/A) Table 13.11 I/O Ports (D/A) | | Peripheral Function I/O | | | |------------|---------------------------|------------------|--| | Port | Peripheral function input | Analog input (B) | | | | (A) in Figure 13.11 | in Figure 13.11 | | | P9_3, P9_4 | Available | N/A | | Figure 13.12 I/O Pins # 13.3 Registers Table 13.12 Registers | Address | Register | Symbol | Reset Value | |---------|--------------------------------|--------|---------------------------| | 0360h | Pull-Up Control Register 0 | PUR0 | 00h | | 0361h F | Pull-Up Control Register 1 | PUR1 | 0000 0000b <sup>(1)</sup> | | 030111 | Full-op Control Register 1 | FUNT | 0000 0010b | | 0362h | Pull-Up Control Register 2 | PUR2 | 00h | | 0363h | Pull-Up Control Register 3 | PUR3 | 00h | | 0366h | Port Control Register | PCR | 0000 0XX0b | | 0369h | NMI/SD Digital Filter Register | NMIDF | XXXX X000b | | 03E0h | Port P0 Register | P0 | XXh | | 03E1h | Port P1 Register | P1 | XXh | | 03E2h | Port P0 Direction Register | PD0 | 00h | | 03E3h | Port P1 Direction Register | PD1 | 00h | | 03E4h | Port P2 Register | P2 | XXh | | 03E5h | Port P3 Register | P3 | XXh | | 03E6h | Port P2 Direction Register | PD2 | 00h | | 03E7h | Port P3 Direction Register | PD3 | 00h | | 03E8h | Port P4 Register | P4 | XXh | | 03E9h | Port P5 Register | P5 | XXh | | 03EAh | Port P4 Direction Register | PD4 | 00h | | 03EBh | Port P5 Direction Register | PD5 | 00h | | 03ECh | Port P6 Register | P6 | XXh | | 03EDh | Port P7 Register | P7 | XXh | | 03EEh | Port P6 Direction Register | PD6 | 00h | | 03EFh | Port P7 Direction Register | PD7 | 00h | | 03F0h | Port P8 Register | P8 | XXh | | 03F1h | Port P9 Register | P9 | XXh | | 03F2h | Port P8 Direction Register | PD8 | 00h | | 03F3h | Port P9 Direction Register | PD9 | 00h | | 03F4h | Port P10 Register | P10 | XXh | | 03F5h | Port P11 Register | P11 | XXh | | 03F6h | Port P10 Direction Register | PD10 | 00h | | 03F7h | Port P11 Direction Register | PD11 | 00h | | 03F8h | Port P12 Register | P12 | XXh | | 03F9h | Port P13 Register | P13 | XXh | | 03FAh | Port P12 Direction Register | PD12 | 00h | | 03FBh | Port P13 Direction Register | PD13 | 00h | | 03FCh | Port P14 Register | P14 | XXh | | 03FEh | Port P14 Direction Register | PD14 | XXXX XX00b | Note: - 1. Values after hardware reset, power-on reset, or voltage monitor 0 reset are as follows: - 00000000b when input to the CNVSS pin is low. - 00000010b when input to the CNVSS pin is high. Values after voltage monitor 1 reset, voltage monitor 2 reset, software reset, watchdog timer reset, or oscillation stop detection reset are as follows: - 00000000b when bits PM01 to PM00 in the PM0 register are 00b (single-chip mode). - 00000010b when bits PM01 to PM00 in the PM0 register are 01b (memory expansion mode) or 11b (microprocessor mode). # 13.3.1 Pull-Up Control Register 0 (PUR0) In memory expansion or microprocessor mode, the register value can be modified, but the pins are not pulled high. PU0i (b7-b0) ( $$i = 0 \text{ to } 7$$ ) When the PU0i bit is 1 (pulled high) and the direction bit is 0 (input mode), the corresponding pin is pulled high. # 13.3.2 Pull-Up Control Register 1 (PUR1) Values after hardware reset, power-on reset, or voltage monitor 0 reset are as follows: - 00000000b when input to the CNVSS pin is low - 00000010b when input to the CNVSS pin is high Values after voltage monitor 1 reset, voltage monitor 2 reset, software reset, watchdog timer reset, or oscillation stop detection reset are as follows: - 00000000b when bits PM01 to PM00 are 00b (single-chip mode). - 00000010b when bits PM01 to PM00 are 01b (memory expansion mode) or 11b (microprocessor mode). PU10 (P4\_0 to P4\_3 pull-up) (b0) PU11 (P4\_4 to P4\_7 pull-up) (b1) PU12 (P5\_0 to P5\_3 pull-up) (b2) PU13 (P5\_4 to P5\_7 pull-up) (b3) When the PU1i bit (i = 0 to 3) is 1 (pulled high) and the direction bit is 0 (input mode), the corresponding pin is pulled high. In memory expansion and microprocessor modes, pins are not pulled high although the bit values can be modified. PU14 (P6\_0 to P6\_3 pull-up) (b4) PU15 (P6 4 to P6 7 pull-up) (b5) PU17 (P7\_4 to P7\_7 pull-up) (b7) When the PU1i (i = 4, 5, 7) bit is 1 (pulled high) and the direction bit is 0 (input mode), the corresponding pin is pulled high. PU16 (P7\_2 to P7\_3 pull-up) (b6) When the PU16 bit is 1 (pulled high) and the direction bit is 0 (input mode), the corresponding pin is pulled high. Pins P7\_0 and P7\_1 are not pulled high. # 13.3.3 Pull-Up Control Register 2 (PUR2) PU20 (P8\_0 to P8\_3 pull-up) (b0) PU22 (P9\_0 to P9\_3 pull-up) (b2) PU23 (P9\_4 to P9\_7 pull-up) (b3) PU24 (P10\_0 to P10\_3 pull-up) (b4) PU25 (P10\_4 to P10\_7 pull-up) (b5) When the PU2i (i = 0, 2 to 5) bit is 1 (pulled high) and the direction bit is 0 (input mode), the corresponding pin is pulled high. #### PU21 (P8\_4, P8\_6, P8\_7 pull-up) (b1) When the PU21 bit is 1 (pulled high) and the direction bit is 0 (input mode), the corresponding pin is pulled high. The P8\_5 pin is not pulled high. # 13.3.4 Pull-Up Control Register 3 (PUR3) PU3i (b6-b0) (i = 0 to 6) The pin for which the PU3i bit is 1 (pulled high) and the direction bit is 0 (input mode) is pulled high. #### PU37 (P11 to P14 enable bit) (b7) When the PU37 bit is 1 (P11 to P14 enabled), registers P11 to P14 and registers PD0 to PD14 are enabled. #### 13.3.5 Port Control Register (PCR) # PCR0 (Port P1 control bit) (b0) When the P1 register is read after the PCR0 bit is set to 1, the corresponding port latch is read regardless of the PD1 register setting. #### 13.3.6 Port Pi Register (Pi) (i = 0 to 14) Data input/output to and from external devices is accomplished by reading and writing to the Pi register. Each bit in the Pi register consists of a port latch to hold the output data and a circuit to read the pin status. For ports set to input mode, the input level of the pin can be read by reading the corresponding Pi register, and data can be written to the port latch by writing to the Pi register. For ports set to output mode, the port latch can be read by reading the corresponding Pi register, and data can be written to the port latch by writing to the Pi register. The data written to the port latch is output from the pin. Each bit in the Pi register corresponds to one port. In memory expansion and microprocessor modes, the Pi register for the pins functioning as bus control pins (A0 to A19, D0 to D15, $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ , $\overline{\text{RD}}$ , $\overline{\text{WRL/WR}}$ , $\overline{\text{WRH/BHE}}$ , ALE, $\overline{\text{RDY}}$ , $\overline{\text{HOLD}}$ , $\overline{\text{HLDA}}$ , and BCLK) cannot be modified (writing a value has no effect). Since P7\_0, P7\_1, and P8\_5 are N-channel open drain ports, when set to 1, the pin status becomes high-impedance. When the CM04 bit in the CM0 register is 1 (XCIN-XCOUT oscillation function) and bits PD8\_6 and PD8\_7 in the PD8 register are 0 (input mode), values of bits P8\_6 and P8\_7 in the P8 register are undefined. Registers P11 to P14 are enabled when the PU37 bit in the PUR3 register is 1 (P11 to P14 enabled). Access registers P11 to P14 after setting the PU37 bit to 1. When the PU37 bit is 0 (P11 to P14 disabled), the values of registers P11 to P14 are retained. In this case, the read value is undefined. # 13.3.7 Port Pi Direction Register (PDi) (i = 0 to 14) Write to the PD9 register in the next instruction after setting the PRC2 bit in the PRCR register to 1 (write enabled). Select whether I/O ports are to be used for input or output by the PDi register. Each bit in the PDi register has a corresponding port. In memory expansion mode or microprocessor mode, the PDi register for the pins functioning as bus control pins (A0 to A19, D0 to D15, $\overline{\text{CS0}}$ to $\overline{\text{CS3}}$ , $\overline{\text{RD}}$ , $\overline{\text{WRL/WR}}$ , $\overline{\text{WRH/BHE}}$ , ALE, $\overline{\text{RDY}}$ , $\overline{\text{HOLD}}$ , $\overline{\text{HLDA}}$ , and BCLK) cannot be modified (writing a value has no effect). Registers PD11 to PD14 are enabled when the PU37 bit in the PUR3 register is 1 (P11 to P14 enabled). Access registers PD11 to PD14 after setting the PU37 bit to 1. When the PU37 bit is 0 (P11 to P14 disabled), the values of registers PD11 to PD14 are retained. In this case, the read value is undefined. # 13.3.8 NMI/SD Digital Filter Register (NMIDF) Change the NMIDF register under the following conditions: - The PM24 bit in the PM2 register is 0 (NMI interrupt disabled) - Bits INV02 and INV03 in the INVC0 register are 0 (three-phase motor control timer function not used, three-phase motor control timer output disabled). Once the PM24 bit is set to 1 (NMI interrupt enabled), it cannot be set to 0 by a program. Change the NMIDF register before setting the PM24 bit to 1. #### 13.4 Peripheral Function I/O #### 13.4.1 Peripheral Function I/O and Port Direction Bits Programmable I/O ports can share pins with peripheral function I/O (see Table 1.7 to Table 1.11 "Pin Names, Pin Package"). Some peripheral function I/O are affected by a port direction bit which shares the same pin. Table 13.13 lists Setting of Direction Bits Functioning as Peripheral Function I/O. For peripheral function settings, see descriptions of each function. Table 13.13 Setting of Direction Bits Functioning as Peripheral Function I/O | Pe | ripheral Function I/O | Setting of the Port Direction Bit Sharing the Same Pin | |--------|-----------------------|-------------------------------------------------------------------------| | Input | | Set to 0 (input mode). | | | PWM | Set to 1 (output mode). | | Output | D/A converter | Set to 0 (input mode). | | | Others | Set to either 0 or 1 (outputs regardless of the direction bit setting). | #### 13.4.2 Priority Level of Peripheral Function I/O Multiple peripheral functions can share the same pin. For example, when peripheral function A and peripheral function B share a pin, input and output are as follows: - When the pin functions as input for peripheral functions A and B The same signal is input as an input signal for each function. However, the timing of accepting the signal differs depending on conditions (e.g. internal delay) of peripheral functions A and B. - When the pin functions as output for peripheral function A and as input for peripheral function B Peripheral function A outputs a signal from the pin, and peripheral function B inputs the signal. #### 13.4.3 NMI/SD Digital Filter The $\overline{\text{NMI/SD}}$ input function includes a digital filter. A sampling clock can be selected by bits NMIDF2 to NMIDF0 in the NMIDF register. The $\overline{\text{NMI}}$ level is sampled for every sampling clock. When the same sampled level is detected three times in a row, the level is transferred to the internal circuit. When using the NMI/SD digital filter, do not enter wait mode or stop mode. Port P8\_5 is not affected by the digital filter. Figure 13.13 shows NMI/SD Digital Filter, and Figure 13.14 shows NMI/SD Digital Filter Operation Example. Figure 13.13 NMI/SD Digital Filter Figure 13.14 NMI/SD Digital Filter Operation Example #### 13.4.4 CNVSS Pin The built-in pull-up resistor of the CNVSS pin is activated after watchdog timer reset, hardware reset, power-on reset, or voltage monitor 0 reset. Thus, the CNVSS pin outputs a high-level signal up to two cycles of fOCO-S. Connect the CNVSS pin to VSS via a resistor to use it in single-chip mode. #### 13.5 Unassigned Pin Handling Table 13.14 Unassigned Pin Handling in Single-Chip Mode | Pin Name | Connection (2) | |--------------------------|-------------------------------------------------------------------------| | | One of the following: | | Ports P0 to P5, P12, P13 | • Set to input mode and connect a pin to VSS via a resistor (pull-down) | | POIS PO 10 P3, P12, P13 | • Set to input mode and connect a pin to VCC2 via a resistor (pull-up) | | | • Set to output mode and leave the pins open (1) | | | One of the following: | | Dorto D6 to D11 D14 | • Set to input mode and connect a pin to VSS via a resistor (pull-down) | | Ports P6 to P11, P14 | • Set to input mode and connect a pin to VCC1 via a resistor (pull-up) | | | • Set to output mode and leave the pins open (1, 3) | | XOUT (4) | Open | | XIN | Connect to VCC1 via a resistor (pull-up) | | AVCC | Connect to VCC1 | | AVSS, VREF, BYTE | Connect to VSS | #### Notes: - 1. When setting a port to output mode and leaving it open, be aware that the port remains in input mode until it is switched to output mode by a program after reset. For this reason, the voltage level on the pin becomes undefined, causing the power supply current to increase while the port remains in input mode. Furthermore, since the values of the direction registers can be changed by noise or noise-induced loss of control, it is recommended that the values of the direction registers be regularly reset in software to improve the reliability of the program. - Make sure unassigned pins are connected with the shortest possible wiring from the MCU pins (maximum 2 cm). - 3. Ports P7\_0, P7\_1, and P8\_5 are N-channel open drain outputs. When ports P7\_0, P7\_1, and P8\_5 are set to output mode, make sure a low is output from the pins. - 4. This applies when an external clock is input to the XIN pin or when VCC1 is connected via a resistor. Figure 13.15 Unassigned Pin Handling in Single-Chip Mode | Pin Name | Connection (2) | |------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ports P0 to P5, P12, P13 | One of the following: Set to input mode and connect a pin to VSS via a resistor (pull-down) Set to input mode and connect a pin to VCC2 via a resistor (pull-up) Set to output mode and leave the pins open (1, 3) | | Ports P6 to P11, P14 | One of the following: • Set to input mode and connect a pin to VSS via a resistor (pull-down) • Set to input mode and connect a pin to VCC1 via a resistor (pull-up) • Set to output mode and leave the pins open (1, 4) | | BHE, ALE, HLDA, XOUT (5), BCLK (6) | Open | | HOLD, RDY | Connect to VCC2 via a resistor (pull-up) | | XIN | Connect to VCC1 via a resistor (pull-up) | | AVCC | Connect to VCC1 | | AVSS, VREF | Connect to VSS | Table 13.15 Unassigned Pin Handling in Memory Expansion Mode and Microprocessor Mode #### Notes: - 1. When setting a port to output mode and leaving it open, be aware that the port remains in input mode until it is switched to output mode by a program after reset. For this reason, the voltage level on the pin becomes undefined, causing the power supply current to increase while the port remains in input mode. Furthermore, since the values of the direction registers can be changed by noise or noise-induced loss of control, it is recommended that the values of the direction registers be regularly reset in software to improve the reliability of the program. - Connect unassigned pins with shortest possible wiring from the MCU pins (maximum 2 cm). - 3. When the CNVSS pin has the VSS level applied to it, these pins are set as input ports until the processor mode is switched by a program after reset. For this reason, the voltage levels on these pins become undefined, causing the power supply current to increase while they remain set as input ports. - 4. Ports P7\_0, P7\_1, and P8\_5 are N-channel open drain outputs. When ports P7\_0, P7\_1, and P8\_5 are set to output mode, make sure a low is output from the pins. - 5. This applies when an external clock is input to the XIN pin or when VCC1 is connected via a resistor. - 6. When the PM07 bit in the PM0 register is 1 (BCLK not output), connect it to VCC2 via a resistor (pull-up). Figure 13.16 Unassigned Pin Handling in Memory Expansion Mode and Microprocessor Mode #### 13.6 Notes on Programmable I/O Ports #### 13.6.1 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/ $\overline{CTS2}/\overline{RTS2}/\overline{TA1IN/V}$ , P7\_4/TA2OUT/W, P7\_5/TA2IN/ $\overline{W}$ , P8\_0/TA4OUT/RXD5/SCL5/U, P8\_1/TA4IN/ $\overline{CTS5}/\overline{RTS5}/\overline{U}$ #### 13.6.2 Influence of SI/O3 and SI/O4 When the SMi2 bit in the SiC register is set to 1 (SOUTi output disabled), the target pin becomes high-impedance regardless of which pin function being used. # 13.6.3 100-Pin Package Do not access the addresses assigned to registers P11 to P14, PD11 to PD14, and the PUR3 register. # 14. Interrupts #### 14.1 Introduction Table 14.1 lists Types of Interrupts, and Table 14.2 lists I/O Pins. The pins shown in Table 14.2 are external interrupt input pins. Refer to the peripheral functions for the pins related to the peripheral functions. Table 14.1 Types of Interrupts | Ty | /pe | Interrupt | Function | |----------|---------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | Software | | Undefined instruction (UND instruction) Overflow (INTO instruction) BRK instruction INT instruction | An interrupt is generated by executing an instruction. Non-maskable interrupt (2) | | Hardware | Specific | NMI Watchdog timer Oscillator stop/restart detect Voltage monitor 1 Voltage monitor 2 Address match Single step (1) DBC (1) | Interrupt by the MCU hardware Non-maskable interrupt (2) | | | Peripheral function | INT, timers, etc.<br>(Refer to 14.6.2 "Relocatable<br>Vector Tables".) | Interrupt by the peripheral functions in the MCU Maskable interrupt (interrupt priority level: 7 levels) (2) | #### Notes: - 1. This interrupt is provided exclusively for developers and should not be used. - 2. Maskable interrupt: Interrupt status (enabled or disabled) can be selected by the interrupt enable flag (I flag). Interrupt priority can be changed by the interrupt priority level. Non-maskable interrupt: Interrupt status (enabled or disabled) cannot be selected by the interrupt enable flag (I flag). Interrupt priority cannot be changed by the interrupt priority level. Table 14.2 I/O Pins | Pin Name | I/O | Function | |------------|-----------|----------------------| | NMI | Input (1) | NMI interrupt input | | ĪNTi | Input (1) | INTi interrupt input | | KIO to KI3 | Input (1) | Key input | i = 0 to 7 Note: 1. Set the port direction bits which share pins to 0 (input mode). # 14.2 Registers Table 14.3 Registers (1/2) | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------------------|---------------|---------------| | 001Eh | Processor Mode Register 2 | PM2 | XX00 0X01b | | 0042h | INT7 Interrupt Control Register | INT7IC | XX00 X000b | | 0043h | INT6 Interrupt Control Register | INT6IC | XX00 X000b | | 0044h | INT3 Interrupt Control Register | INT3IC | XX00 X000b | | 0045h | Timer B5 Interrupt Control Register | TB5IC | XXXX X000b | | 00.4Ch | Timer B4 Interrupt Control Register, | TB4IC, | VVVV V000h | | 0046h | UART1 Bus Collision Detection Interrupt Control Register | U1BCNIC | XXXX X000b | | 0047h | Timer B3 Interrupt Control Register, | TB3IC, | XXXX X000b | | 004711 | UART0 Bus Collision Detection Interrupt Control Register | U0BCNIC | XXXX X000D | | 0048h | SI/O4 Interrupt Control Register, | S4IC, INT5IC | XX00 X000b | | 004011 | INT5 Interrupt Control Register | 0410, 1141310 | 77,00 7,000 | | 0049h | SI/O3 Interrupt Control Register, | S3IC, INT4IC | XX00 X000b | | | INT4 Interrupt Control Register | | | | 004Ah | UART2 Bus Collision Detection Interrupt Control Register | BCNIC | XXXX X000b | | 004Bh | DMA0 Interrupt Control Register | DM0IC | XXXX X000b | | 004Ch | DMA1 Interrupt Control Register | DM1IC | XXXX X000b | | 004Dh | Key Input Interrupt Control Register | KUPIC | XXXX X000b | | 004Eh | A/D Conversion Interrupt Control Register | ADIC | XXXX X000b | | 004Fh | UART2 Transmit Interrupt Control Register | S2TIC | XXXX X000b | | 0050h | UART2 Receive Interrupt Control Register | S2RIC | XXXX X000b | | 0051h | UART0 Transmit Interrupt Control Register | S0TIC | XXXX X000b | | 0052h | UART0 Receive Interrupt Control Register | SORIC | XXXX X000b | | 0053h | UART1 Transmit Interrupt Control Register | S1TIC | XXXX X000b | | 0054h | UART1 Receive Interrupt Control Register | S1RIC | XXXX X000b | | 0055h | Timer A0 Interrupt Control Register | TA0IC | XXXX X000b | | 0056h | Timer A1 Interrupt Control Register | TA1IC | XXXX X000b | | 0057h | Timer A2 Interrupt Control Register | TA2IC | XXXX X000b | | 0058h | Timer A3 Interrupt Control Register | TA3IC | XXXX X000b | | 0059h | Timer A4 Interrupt Control Register | TA4IC | XXXX X000b | | 005Ah | Timer B0 Interrupt Control Register | TB0IC | XXXX X000b | | 005Bh | Timer B1 Interrupt Control Register | TB1IC | XXXX X000b | | 005Ch | Timer B2 Interrupt Control Register | TB2IC | XXXX X000b | | 005Dh | INTO Interrupt Control Register | INT0IC | XX00 X000b | | 005Eh | INT1 Interrupt Control Register | INT1IC | XX00 X000b | | 005Fh | INT2 Interrupt Control Register | INT2IC | XX00 X000b | | 0069h | DMA2 Interrupt Control Register | DM2IC | XXXX X000b | | 006Ah | DMA3 Interrupt Control Register | DM3IC | XXXX X000b | | | UART5 Bus Collision Detection Interrupt Control Register, | U5BCNIC, | | | 006Bh | CEC1 Interrupt Control Register | CEC1IC | XXXX X000b | | 00001 | UART5 Transmit Interrupt Control Register, | S5TIC, | V/V/V/ V/2021 | | 006Ch | CEC2 Interrupt Control Register | CEC2IC | XXXX X000b | | 006Dh | UART5 Receive Interrupt Control Register | S5RIC | XXXX X000b | | | UART6 Bus Collision Detection Interrupt Control Register, | U6BCNIC, | VVVV V0001 | | 006Eh | Real-Time Clock Periodic Interrupt Control Register | RTCTIC | XXXX X000b | Table 14.4 Registers (2/2) | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------------------------------------------------------------------------------------|--------------------|-------------| | 006Fh | UART6 Transmit Interrupt Control Register,<br>Real-Time Clock Compare Interrupt Control<br>Register | S6TIC,<br>RTCCIC | XXXX X000b | | 0070h | UART6 Receive Interrupt Control Register | S6RIC | XXXX X000b | | 0071h | UART7 Bus Collision Detection Interrupt Control<br>Register, Remote Control Signal Receiver 0<br>Interrupt Control Register | U7BCNIC,<br>PMC0IC | XXXX X000b | | 0072h | UART7 Transmit Interrupt Control Register,<br>Remote Control Signal Receiver 1 Interrupt<br>Control Register | S7TIC,<br>PMC1IC | XXXX X000b | | 0073h | UART7 Receive Interrupt Control Register | S7RIC | XXXX X000b | | 007Bh | I2C-bus Interface Interrupt Control Register | IICIC | XXXX X000b | | 007Ch | SCL/SDA Interrupt Control Register | SCLDAIC | XXXX X000b | | 0205h | Interrupt Source Select Register 3 | IFSR3A | 00h | | 0206h | Interrupt Source Select Register 2 | IFSR2A | 00h | | 0207h | Interrupt Source Select Register | IFSR | 00h | | 020Eh | Address Match Interrupt Enable Register | AIER | XXXX XX00b | | 020Fh | Address Match Interrupt Enable Register 2 | AIER2 | XXXX XX00b | | 0210h | | RMAD0 | 00h | | 0211h | Address Match Interrupt Register 0 | | 00h | | 0212h | | | X0h | | 0214h | | RMAD1 | 00h | | 0215h | Address Match Interrupt Register 1 | | 00h | | 0216h | | | X0h | | 0218h | | RMAD2 | 00h | | 0219h | Address Match Interrupt Register 2 | | 00h | | 021Ah | ] | | X0h | | 021Ch | | RMAD3 | 00h | | 021Dh | Address Match Interrupt Register 3 | | 00h | | 021Eh | ] | | X0h | | 0366h | Port Control Register | PCR | 0000 0XX0b | | 0369h | NMI/SD Digital Filter Register | NMIDF | XXXX X000b | # 14.2.1 Processor Mode Register 2 (PM2) Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. #### PM24 (NMI interrupt enable bit) (b4) Once this bit is set to 1, it cannot be set to 0 by a program (writing 0 has no effect). # 14.2.2 Interrupt Control Register 1 (TB5IC, TB4IC/U1BCNIC, TB3IC/U0BCNIC, BCNIC, DM0IC to DM3IC, KUPIC, ADIC, S0TIC to S2TIC, S0RIC to S2RIC, TA0IC to TA4IC, TB0IC to TB2IC, U5BCNIC/CEC1IC, S5TIC/CEC2IC, S5RIC to S7RIC, U6BCNIC/RTCTIC, S6TIC/RTCCIC, U7BCNIC/PMC0IC, S7TIC/PMC1IC, IICIC, SCLDAIC) | Symbol | Address | |---------------|---------| | TB5IC | 0045h | | TB4IC/U1BCNIC | 0046h | | TB3IC/U0BCNIC | 0047h | | BCNIC | 004Ah | | DM0IC | 004Bh | | DM1IC | 004Ch | | DM2IC | 0069h | | DM3IC | 006Ah | | KUPIC | 004Dh | | ADIC | 004Eh | | SOTIC | 0051h | | S1TIC | 0053h | | S2TIC | 004Fh | | SORIC | 0052h | | S1RIC | 0054h | | S2RIC | 0050h | | TA0IC | 0055h | | TA1IC | 0056h | | Symbol | Address | |----------------|---------| | TA2IC | 0057h | | TA3IC | 0058h | | TA4IC | 0059h | | TB0IC | 005Ah | | TB1IC | 005Bh | | TB2IC | 005Ch | | U5BCNIC/CEC1IC | 006Bh | | S5TIC/CEC2IC | 006Ch | | S5RIC | 006Dh | | S6RIC | 0070h | | S7RIC | 0073h | | U6BCNIC/RTCTIC | 006Eh | | S6TIC/RTCCIC | 006Fh | | U7BCNIC/PMC0IC | 0071h | | S7TIC/PMC1IC | 0072h | | IICIC | 007Bh | | SCLDAIC | 007Ch | Rewrite these registers at a point where an interrupt request for the corresponding register is not generated. When multiple interrupt sources share the register, select an interrupt source in registers IFSR2A and IFSR3A. #### IR (Interrupt request bit) (b3) Do not set the IR bit to 1 when it is 0. # 14.2.3 Interrupt Control Register 2 (INT7IC, INT6IC, INT3IC, S4IC/INT5IC, S3IC/INT4IC, INT0IC to INT2IC) | Symbol | Address | |-------------|---------| | INT7IC | 0042h | | INT6IC | 0043h | | INT3IC | 0044h | | S4IC/INT5IC | 0048h | | S3IC/INT4IC | 0049h | | Address | |---------| | 005Dh | | 005Eh | | 005Fh | | | Rewrite these registers at a point where an interrupt request for the corresponding register is not generated. When multiple interrupt sources share the register, select an interrupt source in the IFSR register. #### ILVL2-ILVL0 (Interrupt priority level select bit) (b2-b0) In memory expansion or microprocessor mode, set bits ILVL2 to ILVL0 in registers INT6IC and INT7IC to 000b (interrupts disabled). When the BYTE pin is low in memory expansion or microprocessor mode, set bits ILVL2 to ILVL0 in registers INT3IC, INT4IC, and INT5IC to 000b (interrupts disabled). #### IR (Interrupt request bit) (b3) Do not set the IR bit to 1 when it is 0. #### POL (Polarity select bit) (b4) When the IFSRi bit in the IFSR register is 1 (both edges), set the POL bit in the INTiIC register to 0 (falling edge) (i = 0 to 5). When bits IFSR30 and IFSR31 in the IFSR3A register are 1 (both edges), set the POL bit in registers INT6IC and INT7IC to 0 (falling edge). Set the POL bit in the S3IC or S4IC register to 0 (falling edge) when the IFSR6 bit in the IFSR register is 0 (SI/O3 selected) or IFSR7 bit is 0 (SI/O4 selected), respectively. # 14.2.4 Interrupt Source Select Register 3 (IFSR3A) IFSR31 and IFSR30 (INT7 and INT6 interrupt polarity select bit) (b1-b0) When setting this bit to 1 (both edges), make sure the corresponding POL bit in registers INT6IC and INT7IC is set to 0 (falling edge). # 14.2.5 Interrupt Source Select Register 2 (IFSR2A) | b7 b6 b5 b4 b3 b2 b1 b0 0 0 | Symbol<br>IFSR2A | Address<br>0206h | ; R | eset Value<br>00h | |-----------------------------|------------------|-------------------------------------|-----------------------------------------------------------------------------------|-------------------| | | Bit Symbol | Bit Name | Function | RW | | | <br>(b1-b0) | Reserved bits | Set to 0 | RW | | | IFSR22 | Interrupt request source select bit | 0 : Not used<br>1 : I <sup>2</sup> C-bus interface | RW | | | IFSR23 | Interrupt request source select bit | 0 : Not used<br>1 : SCL/SDA | RW | | | IFSR24 | Interrupt request source select bit | UART7 start/stop condition detection bus collision detection Remote control 0 | on, RW | | | IFSR25 | Interrupt request source select bit | 0 : UART7 transmission, NACK<br>1 : Remote control 1 | RW | | | IFSR26 | Interrupt request source select bit | Timer B3 UART0 start/stop condition detection bus collision detection | on, RW | | | IFSR27 | Interrupt request source select bit | Timer B4 UART1 start/stop condition detection bus collision detection | on, RW | # 14.2.6 Interrupt Source Select Register (IFSR) #### IFSR5-IFSR0 (INT5-INT0 interrupt polarity select bit) (b5-b0) When setting these bits to 1 (both edges), make sure the corresponding POL bit in registers INT0IC to INT5IC is set to 0 (falling edge). #### IFSR7, IFSR6 (Interrupt request source select bit) (b7, b6) In memory expansion or microprocessor mode, when the data bus is 16 bits wide (BYTE pin is low), set these bits to 0 (SI/O3, SI/O4). When setting these bits to 0 (SI/O3, SI/O4), make sure the corresponding POL bit in registers S3IC and S4IC is set to 0 (falling edge). ### 14.2.7 Address Match Interrupt Enable Register (AIER) ### 14.2.8 Address Match Interrupt Enable Register 2 (AIER2) # 14.2.9 Address Match Interrupt Register i (RMADi) (i = 0 to 3) ### 14.2.10 Port Control Register (PCR) ### PCR5 (INT6 input enable bit) (b5) To use the AN2\_4 pin as an analog input pin, set the PCR5 bit to 1 (INT6 input disabled). ## PCR6 (INT7 input enable bit) (b6) To use the AN2\_5 pin as an analog input pin, set the PCR6 bit to 1 (INT7 input disabled). ### PCR7 (Key input enable bit) (b7) To use pins AN4 to AN7 as analog input pins, set the PCR7 bit to 1 (key input disabled). ### 14.2.11 NMI/SD Digital Filter Register (NMIDF) Change the NMIDF register under the following conditions: - The PM24 bit in the PM2 register is 0 (NMI interrupt disabled) - Bits INV02 and INV03 in the INVC0 register are 0 (three-phase motor control timer function not used, three-phase motor control timer output disabled). Once the PM24 bit is set to 1 (NMI interrupt enabled), it cannot be set to 0 by a program. Change the NMIDF register before setting the PM24 bit to 1. ### 14.3 Types of Interrupts Figure 14.1 shows Types of Interrupts. Figure 14.1 Types of Interrupts • Maskable interrupt : The I flag (interrupt enable flag) **can** enable/disable these interrupts. The interrupt priority order **can be changed** by using the interrupt priority level. • Non-maskable interrupt : The I flag (interrupt enable flag) **cannot** enable/disable these interrupts. The interrupt priority order $\underline{\textbf{cannot be changed}}$ by using the interrupt priority level. #### 14.4 Software Interrupts A software interrupt occurs when executing instructions. Software interrupts are non-maskable interrupts. #### 14.4.1 Undefined Instruction Interrupt An undefined instruction interrupt occurs when executing the UND instruction. #### 14.4.2 Overflow Interrupt An overflow interrupt occurs when executing the INTO instruction with the O flag in the FLG register set to 1 (the operation resulted in an overflow). The following are instructions whose O flag changes by an arithmetic operation: ABS, ADC, ADCF, ADD, CMP, DIV, DIVU, DIVX, NEG, RMPA, SBB, SHA, and SUB ### 14.4.3 BRK Interrupt A BRK interrupt occurs when the BRK instruction is executed. ### 14.4.4 INT Instruction Interrupt An INT instruction interrupt occurs when the INT instruction is executed. Software interrupt numbers 0 to 63 can be specified for the INT instruction. Because software interrupt numbers 2 to 31, 41 to 51, 59, and 60 are assigned to peripheral function interrupts, the same interrupt routine used for peripheral function interrupts can be executed by executing the INT instruction. For software interrupt numbers 0 to 31, the U flag is saved on the stack during instruction execution and is cleared to 0 (ISP selected) before executing an interrupt sequence. The U flag is restored from the stack when returning from the interrupt routine. For software interrupt numbers 32 to 63, the U flag does not change state during instruction execution, and the SP selected at the time is used. #### 14.5 Hardware Interrupts Hardware interrupts are classified into two types: special interrupts and peripheral function interrupts. #### 14.5.1 Special Interrupts Special interrupts are non-maskable interrupts. ### 14.5.1.1 NMI Interrupt An $\overline{\text{NMI}}$ interrupt is generated when input on the $\overline{\text{NMI}}$ pin changes state from high to low. For details on the $\overline{\text{NMI}}$ interrupt, refer to 14.9 " $\overline{\text{NMI}}$ Interrupt". ### **14.5.1.2 DBC** Interrupt Do not use this interrupt because it is provided exclusively for use by development tools. #### 14.5.1.3 Watchdog Timer Interrupt This interrupt is generated by the watchdog timer. Once a watchdog timer interrupt is generated, be sure to refresh the watchdog timer. For details on the watchdog timer, refer to 15. "Watchdog Timer". ### 14.5.1.4 Oscillator Stop/Restart Detect Interrupt The interrupt is generated by the oscillator stop/restart detect function. For details on this function, refer to 8. "Clock Generator". ### 14.5.1.5 Voltage Monitor 1, Voltage Monitor 2 Interrupt The interrupt is generated by the voltage detector. For details on the voltage detector, refer to 7. "Voltage Detector". ### 14.5.1.6 Single-Step Interrupt Do not use this interrupt because it is provided exclusively for use by development tools. #### 14.5.1.7 Address Match Interrupt When the AIER0 or AIER1 bit in the AIER register, or the AIER20 or AIER21 bit in the AIER2 register is 1 (address match interrupt enabled), an address match interrupt is generated immediately before executing an instruction at the address indicated by the corresponding registers RMAD0 to RMAD3. For details on the address match interrupt, refer to 14.11 "Address Match Interrupt". #### 14.5.2 Peripheral Function Interrupts A peripheral function interrupt occurs when a request from a peripheral function in the MCU is acknowledged. Peripheral function interrupts are maskable interrupts. See Table 14.6 and Table 14.7 "Relocatable Vector Tables". Refer to the descriptions of each function for details on how the corresponding peripheral function interrupt is generated. ### 14.6 Interrupts and Interrupt Vectors One interrupt vector consists of 4 bytes. Set the start address of each interrupt routine in the respective interrupt vectors. When an interrupt request is accepted, the CPU branches to the address set in the corresponding interrupt vector. Figure 14.2 shows an Interrupt Vector. Figure 14.2 Interrupt Vector #### 14.6.1 Fixed Vector Tables The fixed vector tables are allocated to addresses from FFFDCh to FFFFFh. Table 14.5 lists the Fixed Vector Tables. In the flash memory MCU version, the vector addresses (H) of fixed vectors are used for the ID code check function and OFS1 address. For details, refer to 30. "Flash Memory". Table 14.5 Fixed Vector Tables | Interrupt Source | Vector Table Addresses<br>Address (L) to Address (H) | Reference | |--------------------------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------| | Undefined instruction (UND instruction) | FFFDCh to FFFDFh | M16C/60, M16C/20, | | Overflow (INTO instruction) | FFFE0h to FFFE3h | M16C/Tiny Series Software | | BRK instruction (2) | FFFE4h to FFFE7h | Manual | | Address match | FFFE8h to FFFEBh | 14.11 "Address Match<br>Interrupt" | | Single-step (1) | FFFECh to FFFEFh | - | | Watchdog timer,<br>oscillator stop/restart detect,<br>voltage monitor 1, voltage monitor 2 | FFFF0h to FFFF3h | <ul><li>15. "Watchdog Timer"</li><li>8. "Clock Generator"</li><li>7. "Voltage Detector"</li></ul> | | DBC (1) | FFFF4h to FFFF7h | - | | NMI | FFFF8h to FFFFBh | 14.9 "NMI Interrupt" | | Reset | FFFFCh to FFFFFh | 6. "Resets" | #### Notes: - 1. Do not use this interrupt because it is provided exclusively for use by development tools. - 2. If the value of address FFFE6h is FFh, program execution starts from the address shown by the vector in the relocatable vector table. #### 14.6.2 **Relocatable Vector Tables** The 256 bytes beginning with the start address set in the INTB register compose a relocatable vector table area. Setting an even address in the INTB register results in the interrupt sequence being executed faster than setting an odd address. **Table 14.6 Relocatable Vector Tables (1/2)** | Interrupt Source | Vector Address <sup>(1)</sup><br>Address (L) to Address (H) | Software<br>Interrupt<br>Number | Reference | | |----------------------------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------|-------------------------------------------------------|--| | INT instruction interrupt (5) | +0 to +3 (0000h to 0003h) to<br>+252 to +255 (00FCh to 00FFh) | 0 to 63 | M16C/60, M16C/20, M16C/Tiny<br>Series Software Manual | | | BRK instruction <sup>(5)</sup> | +0 to +3 (0000h to 0003h) | 0 | Series Software Manual | | | INT7 | +8 to +11 (0008h to 000Bh) | 2 | | | | ĪNT6 | +12 to +15 (000Ch to 000Fh) | 3 | 14.8 "INT Interrupt" | | | ĪNT3 | +16 to +19 (0010h to 0013h) | 4 | | | | Timer B5 | +20 to +23 (0014h to 0017h) | 5 | 18. "Timer B" | | | Timer B4, UART1 start/stop condition detection, bus collision detection <sup>(4)</sup> | +24 to +27 (0018h to 001Bh) | 6 | 18. "Timer B" | | | Timer B3, UART0 start/stop condition detection, bus collision detection <sup>(4)</sup> | +28 to +31 (001Ch to 001Fh) | 7 | 23. "Serial Interface UARTi (i = 0 to 2, 5 to 7)" | | | SI/O4, INT5 (2) | +32 to +35 (0020h to 0023h) | 8 | 14.8 "INT Interrupt" | | | SI/O3, ĪNT4 (2) | +36 to +39 (0024h to 0027h) | 9 | 24. "Serial Interface SI/O3 and SI/O4" | | | UART2 start/stop condition detection, bus collision detection (4) | +40 to +43 (0028h to 002Bh) | 10 | 23. "Serial Interface UARTi (i = 0 to 2, 5 to 7)" | | | DMA0 | +44 to +47 (002Ch to 002Fh) | 11 | 40 "DMAO" | | | DMA1 | +48 to +51 (0030h to 0033h) | 12 | 16. "DMAC" | | | Key input interrupt | +52 to +55 (0034h to 0037h) | 13 | 14.10 "Key Input Interrupt" | | | A/D converter | +56 to +59 (0038h to 003Bh) | 14 | 27. "A/D Converter" | | | UART2 transmit, NACK2 (3) | +60 to +63 (003Ch to 003Fh) | 15 | | | | UART2 receive, ACK2 (3) | +64 to +67 (0040h to 0043h) | 16 | | | | UART0 transmit, NACK0 (3) | +68 to +71 (0044h to 0047h) | 17 | 23. "Serial Interface UARTi (i = 0 to 2, 5 to 7)" | | | UART0 receive, ACK0 (3) | +72 to +75 (0048h to 004Bh) | 18 | | | | UART1 transmit, NACK1 (3) | +76 to +79 (004Ch to 004Fh) | 19 | | | | UART1 receive, ACK1 (3) | +80 to +83 (0050h to 0053h) | 20 | | | | Timer A0 | +84 to +87 (0054h to 0057h) | 21 | | | | Timer A1 | +88 to +91 (0058h to 005Bh) | 22 | | | | Timer A2 | +92 to +95 (005Ch to 005Fh) | 23 | 17. "Timer A" | | | Timer A3 | +96 to +99 (0060h to 0063h) | 24 | | | | Timer A4 | +100 to +103 (0064h to 0067h) | 25 | | | | Timer B0 | +104 to +107 (0068h to 006Bh) | 26 | | | | Timer B1 | +108 to +111 (006Ch to 006Fh) | 27 | 18. "Timer B" | | | Timer B2 | +112 to +115 (0070h to 0073h) | 28 | | | #### Notes: - Address relative to address in INTB. - Use bits IFSR6 and IFSR7 in the IFSR register to select a source. 2. - 3. - In I $^2$ C mode, NACK and ACK are interrupt sources. Use bits IFSR26 and IFSR27 in the IFSR2A register to select a source. - These interrupts cannot be disabled using the I flag. **Table 14.7** Relocatable Vector Tables (2/2) | Interrupt Source | Vector Address <sup>(1)</sup><br>Address (L) to Address (H) | Software<br>Interrupt<br>Number | Reference | | |------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------|---------------------------------------------------|--| | ĪNT0 | +116 to +119 (0074h to 0077h) | 29 | | | | ĪNT1 | +120 to +123 (0078h to 007Bh) | 30 | 14.8 "INT Interrupt" | | | ĪNT2 | +124 to +127 (007Ch to 007Fh) | 31 | | | | DMA2 | +164 to +167 (00A4h to 00A7h) | 41 | 16. "DMAC" | | | DMA3 | +168 to +171 (00A8h to 00ABh) | 42 | 10. DIVIAC | | | UART5 start/stop condition detection, bus collision detection, CEC1 (3) | +172 to +175 (00ACh to 00AFh) | 43 | 23. "Serial Interface UARTi (i = 0 to 2, 5 to 7)" | | | UART5 transmit, NACK5, CEC2 (2, 3) | +176 to +179 (00B0h to 00B3h) | 44 | 26. "Consumer Electronics Control | | | UART5 receive, ACK5 (2) | +180 to +183 (00B4h to 00B7h) | 45 | (CEC) Function" | | | UART6 start/stop condition detection, bus collision detection, real-time clock period <sup>(4)</sup> | +184 to +187 (00B8h to 00BBh) | 46 | 20. "Real-Time Clock" | | | UART6 transmit, NACK6, real-time clock compare (2, 4) | +188 to +191 (00BCh to 00BFh) | 47 | 23. "Serial Interface UARTi (i = 0 to 2, 5 to 7)" | | | UART6 receive, ACK6 (2) | +192 to +195 (00C0h to 00C3h) | 48 | | | | UART7 start/stop condition detection, bus collision detection, remote control 0 <sup>(5)</sup> | +196 to +199 (00C4h to 00C7h) | 49 | 22. "Remote Control Signal Receiver" | | | UART7 transmit, NACK7, remote control 1 ( <sup>2</sup> , <sup>5</sup> ) | +200 to +203 (00C8h to 00CBh) | 50 | 23. "Serial Interface UARTi (i = 0 to 2, 5 to 7)" | | | UART7 receive, ACK7 (2) | +204 to +207 (00CCh to 00CFh) | 51 | | | | I <sup>2</sup> C-bus interface interrupt <sup>(6)</sup> | +236 to +239 (00ECh to 00EFh) | 59 | 25. "Multi-master I <sup>2</sup> C-bus Interface" | | | SCL/SDA interrupt (6) | +240 to +243 (00F0h to 00F3h) | 60 | 23. Wulli-Master 1-0-bus intellace | | #### Notes: - 1. Address relative to address in INTB. - 2. In I2C mode, NACK and ACK are the interrupt sources. - Use bits IFSR33 and IFSR34 in the IFSR3A register to select a source. Use bits IFSR35 and IFSR36 in the IFSR3A register to select a source. Use bits IFSR24 and IFSR25 in the IFSR2A register to select a source. - Use bits IFSR22 and IFSR23 in the IFSR2A register to select a source. #### 14.7 Interrupt Control ### 14.7.1 Maskable Interrupt Control The settings for enabling/disabling the maskable interrupts and of the acceptance priority are explained below. Note that these explanations do not apply to non-maskable interrupts. Use the I flag in the FLG register, IPL, and bits ILVL2 to ILVL0 in the corresponding interrupt control register to enable or disable a maskable interrupt. Whether an interrupt is requested or not is indicated by the IR bit in the corresponding interrupt control register. #### 14.7.1.1 I Flag The I flag enables or disables maskable interrupts. Setting the I flag to 1 (enabled) enables maskable interrupts. Setting the I flag to 0 (disabled) disables all maskable interrupts. #### 14.7.1.2 IR Bit The IR bit becomes 1 (interrupt requested) when an interrupt request is generated. Then, when the interrupt request is accepted, the IR bit becomes 0 (interrupt not requested). The IR bit can be set to 0 by a program. Do not write 1 to this bit. #### 14.7.1.3 Bits ILVL2 to ILVL0 and IPL Interrupt priority levels can be selected by setting bits ILVL2 to ILVL0. Table 14.8 lists the Settings of Interrupt Priority Levels and Table 14.9 lists the Interrupt Priority Levels Enabled by IPL. An interrupt request is accepted under the following conditions. - I flag = 1 - IR bit = 1 - Interrupt priority level > IPL The I flag, IR bit, bits ILVL2 to ILVL0, and IPL are independent of each other. They do not affect one another. Table 14.8 Settings of Interrupt Priority Levels | Bits ILVL2 to ILVL0 | Interrupt Priority Level | Priority | |---------------------|------------------------------|----------| | 000b | Level 0 (interrupt disabled) | | | 001b | Level 1 | Low | | 010b | Level 2 | 1 | | 011b | Level 3 | | | 100b | Level 4 | | | 101b | Level 5 | | | 110b | Level 6 | V | | 111b | Level 7 | High | Table 14.9 Interrupt Priority Levels Enabled by IPL | IPL | Enabled Interrupt Priority Levels | |------|--------------------------------------| | 000b | Level 1 and above are enabled | | 001b | Level 2 and above are enabled | | 010b | Level 3 and above are enabled | | 011b | Level 4 and above are enabled | | 100b | Level 5 and above are enabled | | 101b | Level 6 and above are enabled | | 110b | Level 7 and above are enabled | | 111b | All maskable interrupts are disabled | #### 14.7.2 Interrupt Sequence The interrupt sequence is explained here. The sequence starts when an interrupt request is accepted and ends when the interrupt routine is executed. When an interrupt request occurs during execution of an instruction, the processor determines its priority after the execution of the instruction is completed, and transfers control to the interrupt sequence from the next cycle. However, if an interrupt occurs during execution of either the SMOVB, SMOVF, SSTR, or RMPA instruction, the processor temporarily suspends the instruction being executed, and transfers control to the interrupt sequence. The CPU behavior during the interrupt sequence is described below. Figure 14.3 shows Time Required for Executing Interrupt Sequence. - (1) The CPU obtains interrupt information (interrupt number and interrupt request level) by reading address 00000h. Then, the IR bit applicable to the interrupt information is set to 0 (interrupt not requested). - (2) The FLG register, prior to the interrupt sequence, is saved to a temporary register <sup>(1)</sup> within the CPU. - (3) Flags I, D, and U in the FLG register are set as follows: - The I flag is set to 0 (interrupt disabled) - The D flag is set to 0 (single-step interrupt disabled). - The U flag is set to 0 (ISP selected). Note that the U flag does not change states when an INT instruction for software interrupt numbers 32 to 63 is executed. - (4) The temporary register (1) within the CPU is saved on the stack. - (5) The PC is saved on the stack. - (6) The interrupt priority level of the acknowledged interrupt is set in the IPL. - (7) The start address of the relevant interrupt routine set in the interrupt vector is stored in the PC. After the interrupt sequence is completed, an instruction is executed from the starting address of the interrupt routine. #### Note: 1. Temporary registers cannot be modified by the user. Figure 14.3 Time Required for Executing Interrupt Sequence #### 14.7.3 Interrupt Response Time Figure 14.4 shows the Interrupt Response Time. The interrupt response or interrupt acknowledge time denotes the time from when an interrupt request is generated until the first instruction in the interrupt routine is executed. Specifically, it consists of the time from when an interrupt request is generated until the executing instruction is completed ((a) in Figure 14.4) and the time during which the interrupt sequence is executed ((b) in Figure 14.4). - (a) The time from when an interrupt request is generated until the instruction being executed is completed. The length of this time varies with the instruction being executed. The DIVX instruction requires the longest time, which is equal to 30 cycles (no wait state, and when the divisor is a register). - (b) The time during which the interrupt sequence is executed. For details, see the table below. Note, however, that the values in this table must be increased by two cycles for the DBC interrupt and by one cycle for the address match and single-step interrupts. | Interrupt Vector Address | SP Value | 16-bit Bus, No Wait States | 8-bit Bus, No Wait States | |--------------------------|----------|----------------------------|---------------------------| | Even | Even | 18 cycles | 20 cycles | | Even | Odd | 19 cycles | 20 cycles | | Odd | Even | 19 cycles | 20 cycles | | Odd | Odd | 20 cycles | 20 cycles | Figure 14.4 Interrupt Response Time #### 14.7.4 Variation of IPL When Interrupt Request is Accepted When a maskable interrupt request is accepted, the interrupt priority level of the accepted interrupt is set in the IPL. When a software interrupt or special interrupt request is accepted, one of the interrupt priority levels listed in Table 14.10 is set in the IPL. Table 14.10 lists the IPL Level Set in IPL When Software or Special Interrupt is Accepted. Table 14.10 IPL Level Set in IPL When Software or Special Interrupt is Accepted | Interrupt Source | Level Set in IPL | |-------------------------------------------------------------------------------------------|------------------| | Watchdog timer, NMI, oscillator stop/restart detect, voltage monitor 1, voltage monitor 2 | 7 | | Software, address match, DBC, single-step | Not changed | #### 14.7.5 Saving Registers In the interrupt sequence, the FLG register and PC are saved on the stack. At this time, the 4 upper bits of the PC and the 4 upper (IPL) and 8 lower bits in the FLG register, 16 bits in total, are saved on the stack first. Next, the 16 lower bits of the PC are saved. Figure 14.5 shows the Stack Status Before and After Acceptance of Interrupt Request. The other necessary registers must be saved by a program at the beginning of the interrupt routine. Use the PUSHM instruction, and all registers except SP can be saved with a single instruction. Figure 14.5 Stack Status Before and After Acceptance of Interrupt Request The register save operation carried out in the interrupt sequence is dependent on whether the SP <sup>(1)</sup>, at the time of acceptance of an interrupt request, is even or odd. If the SP <sup>(1)</sup> is even, the FLG register and the PC are saved 16 bits at a time. If odd, they are saved in two steps, 8 bits at a time. Figure 14.6 shows the Register Save Operation. #### Note: 1. When an INT instruction with software numbers 32 to 63 has been executed, it is the SP indicated by the U flag. Otherwise, it is the ISP. Figure 14.6 Register Save Operation ### 14.7.6 Returning from an Interrupt Routine The FLG register and PC saved in the stack immediately before entering the interrupt sequence are restored from the stack by executing the REIT instruction at the end of the interrupt routine. Then, the CPU returns to the program which was being executed before the interrupt request was accepted. Restore the other registers saved by a program within the interrupt routine using the POPM or a similar instruction before executing the REIT instruction. The register bank is switched back to the bank used prior to the interrupt sequence by the REIT instruction. ### 14.7.7 Interrupt Priority If two or more interrupt requests occur at the same sampling points (the point in time at which interrupt requests are detected), the interrupt with the highest priority is acknowledged. For maskable interrupts (peripheral function interrupts), any priority level can be selected using bits ILVL2 to ILVL0. However, if two or more maskable interrupts have the same priority level, their interrupt priority is selected by hardware, with the highest priority interrupt accepted. The watchdog timer interrupt and other special interrupts have their priority levels set in hardware. Figure 14.7 shows the Hardware Interrupt Priority. Software interrupts are not affected by the interrupt priority. When an instruction is executed, control always branches to the interrupt routine. Figure 14.7 Hardware Interrupt Priority #### 14.7.8 Interrupt Priority Level Select Circuit The interrupt priority level select circuit selects the highest priority interrupt among sampled interrupt requests at the same sampling point. Figure 14.8 shows the Interrupt Priority Select Circuit 1, and Figure 14.9 shows the Interrupt Priority Select Circuit 2. Figure 14.8 Interrupt Priority Select Circuit 1 Figure 14.9 Interrupt Priority Select Circuit 2 ### 14.7.9 Multiple Interrupts The following shows the internal bit states when control has branched to an interrupt routine. - I flag = 0 (interrupt disabled) - IR bit = 0 (interrupt not requested) - Interrupt priority level = IPL By setting the I flag to 1 (interrupt enabled) in the interrupt routine, an interrupt request with higher priority than the IPL can be acknowledged. The interrupt requests not acknowledged because of their low interrupt priority level are kept pending. When the IPL is restored by the REIT instruction and interrupt priority is resolved against it, the pending interrupt request is acknowledged if the following condition is met: Interrupt priority level of pending interrupt request > Restored IPL ### 14.8 INT Interrupt The $\overline{\text{INTi}}$ interrupt (i = 0 to 7) is triggered by the edges of external inputs. The edge polarity is selected using the IFSRi bit in the IFSR register, or the IFSR30 or IFSR31 bit in the IFSR3A register. INT4 and INT5 each share an interrupt vector and interrupt control register with SI/O3 and SI/O4, respectively. To use the INT4 interrupt, set the IFSR6 bit in the IFSR register to 1 (INT4). To use the INT5 interrupt, set the IFSR7 bit in the IFSR register to 1 (INT5). After modifying the IFSR6 or IFSR7 bit, set the corresponding IR bit to 0 (interrupt not requested) before enabling the interrupt. To use the $\overline{\text{INT6}}$ interrupt, set the PCR5 bit in the PCR register to 0 ( $\overline{\text{INT6}}$ input enabled). To use the $\overline{\text{INT7}}$ interrupt, set the PCR6 bit in the PCR register to 0 ( $\overline{\text{INT7}}$ input enabled). ## 14.9 NMI Interrupt An $\overline{\text{NMI}}$ interrupt is generated when input to the $\overline{\text{NMI}}$ pin changes state from high to low. The $\overline{\text{NMI}}$ interrupt is a non-maskable interrupt. To use the $\overline{\text{NMI}}$ interrupt, set the PM24 bit in the PM2 register to 1 ( $\overline{\text{NMI}}$ interrupt enabled). The $\overline{\text{NMI}}$ input uses the digital filter. Refer to 13. "Programmable I/O Ports" for the digital filter. Figure 14.10 shows $\overline{\text{NMI}}$ Interrupt Block Diagram. Figure 14.10 NMI Interrupt Block Diagram #### 14.10 Key Input Interrupt If the PCR7 bit in the PCR register is 0 ( $\overline{\text{KI0}}$ to $\overline{\text{KI3}}$ key input enabled), when input to any pin from P10\_4 to P10\_7 becomes low where the corresponding PD10\_4 to PD10\_7 bit in the PD10 register is 0 (input), the IR bit in the KUPIC register becomes 1 (key input interrupt request). When using any pin from $\overline{\text{KI0}}$ to $\overline{\text{KI3}}$ for the key input interrupt, do not use all four pins AN4 to AN7 as analog input pins. While input to any pin from P10\_4 to P10\_7 is low, inputs to all other pins of the port are not detected as interrupts. Key input interrupts can be used as a key-on wake up function for getting the MCU out of wait or stop mode. Figure 14.11 shows Block Diagram of Key Input Interrupt. Figure 14.11 Block Diagram of Key Input Interrupt ### 14.11 Address Match Interrupt An address match interrupt is generated immediately before executing the instruction at the address indicated by the RMADi register (i = 0 to 3). Set the start address of any instruction in the RMADi register. Use bits AIER0 and AIER1 in the AIER register, and bits AIER20 and AIER21 in the AIER2 register to enable or disable the interrupt. Note that the address match interrupt is unaffected by the I flag and IPL. When an address match interrupt request is acknowledged, the value of the PC that is saved to the stack area (refer to 14.7.5 "Saving Registers") varies depending on the instruction at the address indicated by the RMADi register. (The value of the PC that is saved to the stack area is not the correct return address.) Therefore, use one of the following methods to return from the address match interrupt: - Rewrite the values of the stack and then use the REIT instruction to return. - Restore the stack to its previous state by using the POP or similar instructions before the interrupt request was accepted and then use a jump instruction to return. Table 14.11 Value of PC Saved on Stack Area When Address Match Interrupt Request Accepted | | Instruction at the Address Indicated by the RMADi Register | | | | Value of the PC That Is Saved to the Stack Area | | |-------------|------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------|----------------|-------------------------------------------------|------------------------------------------------| | | peration code in shown below #IMM8, dest #IMM8, dest #IMM8, dest #IMM8 #IMM8 #IMM8 | w among 8<br>SUB.B:S<br>MOV.B:S<br>STZX<br>PUSHM<br>JSRS | Hold operation<br>#IMM8, dest<br>#IMM8, dest<br>#IMM81, #IMM<br>src<br>#IMM8 | AND.B:S<br>STZ | #IMM8, dest<br>#IMM8, dest | The address indicated by the RMADi register +2 | | Instruction | nstructions not listed above | | | | The address indicated by the RMADi register +1 | | Refer to 14.7.5 "Saving Registers" for PC values saved to the stack area. Table 14.12 Relationship between Address Match Interrupt Sources and Associated Registers | Address Match Interrupt Sources | Address Match Interrupt Enable Bit | Address Match Interrupt Register | |---------------------------------|------------------------------------|----------------------------------| | Address match interrupt 0 | AIER0 | RMAD0 | | Address match interrupt 1 | AIER1 | RMAD1 | | Address match interrupt 2 | AIER20 | RMAD2 | | Address match interrupt 3 | AIER21 | RMAD3 | ### 14.12 Non-Maskable Interrupt Source Discrimination The watchdog timer interrupt, oscillator stop/restart detect interrupt, voltage monitor 1 interrupt, and voltage monitor 2 interrupt share the same interrupt vector. When using some functions together, read the detect flags of the events in an interrupt processing program, and determine the source of the interrupt. Table 14.13 lists Bits Used for Non-Maskable Interrupt Source Discrimination. Table 14.13 Bits Used for Non-Maskable Interrupt Source Discrimination | Interrupt | Detect Flag | | | | | |------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------|--|--|--| | Interrupt | Bit Position | Function | | | | | Watchdog timer | VW2C3 bit in the VW2C register (watchdog timer underflow detected) | | | | | | Oscillator stop/restart CM22 bit in the CM2 register detect (oscillator stop/restart detected) | | 0: Not detected 1: Detected | | | | | Voltage monitor 1 | VW1C2 bit in the VW1C register (Vdet1 passage detected) | | | | | | Voltage monitor 2 | VW2C2 bit in the VW2C register (Vdet2 passage detected) | ] | | | | #### 14.13 Notes on Interrupts #### 14.13.1 Reading Address 00000h Do not read address 00000h by a program. When a maskable interrupt request is accepted, the CPU reads interrupt information (interrupt number and interrupt request priority level) from address 00000h during the interrupt sequence. At this time, the IR bit of the accepted interrupt is cleared to 0 (interrupt not requested). If address 00000h is read by a program, the IR bit for the interrupt which has the highest priority among the enabled interrupts becomes 0. This may cause problems such as interrupts being canceled or an unexpected interrupt request being generated. #### 14.13.2 SP Setting Set a value in the SP (USP, ISP) before accepting an interrupt. The SP (USP, ISP) is set to 0000h after reset. Therefore, if an interrupt is accepted before setting a value in the SP (USP, ISP), the program may go out of control. Set a value in the ISP at the beginning of the program. For the first instruction after reset only, all interrupts are disabled. ### 14.13.3 NMI Interrupt - When not using the NMI interrupt, set the PM24 bit in the PM2 register to 0 (NMI interrupt disabled). - The $\overline{\text{NMI}}$ interrupt is disabled after reset. The $\overline{\text{NMI}}$ interrupt is enabled by setting the PM24 bit in the PM2 register to 1. Set the PM24 bit to 1 when a high-level signal is applied to the $\overline{\text{NMI}}$ pin. When the PM24 bit is set to 1 while a low-level signal is applied, an $\overline{\text{NMI}}$ interrupt is generated. Once the $\overline{\text{NMI}}$ interrupt is enabled, it cannot be disabled until the MCU is reset. - The MCU cannot enter stop mode while the PM24 bit is 1 (NMI interrupt enabled) and input on the NMI pin is low. When input on the NMI pin is low, the CM10 bit in the CM1 register is fixed to 0. - Do not enter wait mode while the PM24 bit is 1 (\overline{NMI}\) interrupt enabled) and a low signal is input to the \overline{NMI}\) pin. When the \overline{NMI}\) pin is driven low, the CPU clock remains active even though the CPU stops, and therefore, the current consumption of the chip does not drop. In this case, the normal condition is restored by the next interrupt generation. - Set the low- and high-level durations of the input signal to the NMI pin to 2 CPU clock cycles + 300 ns or more. #### 14.13.4 Changing an Interrupt Source When the interrupt source is changed, the IR bit in the interrupt control register may become 1 (interrupt requested). To use an interrupt, change the interrupt source, and then set the IR bit to 0 (interrupt not requested). In this section, the changing of an interrupt source refers to all elements used in changing the interrupt source, polarity, and timing assigned to each software interrupt number. Therefore, if a mode change of any peripheral function involves changing the source, polarity or timing of an interrupt, be sure to clear the IR bit for that interrupt to 0 (interrupt not requested) after making such changes. Refer to the descriptions of the individual peripheral functions for details of the interrupts. Figure 14.12 shows the Procedure for Changing the Interrupt Generate Source. Figure 14.12 Procedure for Changing the Interrupt Generate Source #### 14.13.5 Rewriting the Interrupt Control Register To modify the interrupt control register, follow either of the procedures below: - Modify in places where no interrupt requests corresponding to the interrupt control register may occur. - If an interrupt request can be generated, disable that interrupt and then rewrite the interrupt control register. When using the I flag to disable an interrupt, set the I flag as shown in the sample program code below. (Refer to 14.13.6 "Instruction to Rewrite the Interrupt Control Register" for rewriting the interrupt control registers using the sample program code.) Examples 1 through 3 show how to prevent the I flag from becoming 1 (interrupt enabled) before the contents of the interrupt control register is rewritten, owing to the effects of the internal bus and the instruction queue buffer. Example 1: Using the NOP instruction to pause the program until the interrupt control register is modified ``` INT_SWITCH1: FCLR I ; Disable interrupts. AND.B #00H, 0055H ; Set the TA0IC register to 00h. NOP ; NOP FSET I ; Enable interrupts. ``` Example 2: Using a dummy read to delay the FSET instruction ``` INT_SWITCH2: FCLR I ; Disable interrupts. AND.B #00H, 0055H ; Set the TA0IC register to 00h. MOV.W MEM, R0 ; Dummy read. FSET I ; Enable interrupts. ``` Example 3: Using the POPC instruction to change the I flag ``` INT_SWITCH3: PUSHC FLG FCLR I ; Disable interrupts. AND.B #00H, 0055H ; Set the TA0IC register to 00h. POPC FLG ; Enable interrupts. ``` ### 14.13.6 Instruction to Rewrite the Interrupt Control Register - Do not use the BTSTC and BTSTS instructions to rewrite the interrupt control registers. - Use the AND, OR, BCLR, BSET, or MOV instruction to rewrite interrupt control registers. When an interrupt request is generated for the register being rewritten while executing an AND, OR, BCLR, or BSET instruction, the IR bit becomes 1 (interrupt requested) and remains 1. # 14.13.7 INT Interrupt • Either a low level of at least tw(INL) width or a high level of at least tw(INH) width is necessary for the signal input to pins INTO through INT7, regardless of the CPU operation clock. • If the POL bit in registers INT0IC to INT7IC, bits IFSR7 to IFSR0 in the IFSR register, or bits IFSR31 to IFSR30 in the IFSR3A register are changed, the IR bit may inadvertently become 1 (interrupt requested). Be sure to set the IR bit to 0 (interrupt not requested) after changing any of these register bits. # 15. Watchdog Timer #### 15.1 Introduction The watchdog timer contains a 15-bit counter, and the count source protection mode (enabled/disabled) can be set. Table 15.1 lists Watchdog Timer Specifications. Refer to 6.4.8 "Watchdog Timer Reset" for details of watchdog timer reset. Figure 15.1 shows Watchdog Timer Block Diagram. Table 15.1 Watchdog Timer Specifications | Item | Count Source Protection Mode Disabled | Count Source Protection Mode Enabled | | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--| | Count source | CPU clock fOCO-S | | | | Count operation | Decrement | | | | Count start conditions | Either of the following can be selected (selected by the WDTON bit in the OFS1 address) Count automatically starts after reset. | | | | | Count starts by writing to the WDTS reg | u<br>I | | | Count stop condition | Stop mode, wait mode, bus hold None | | | | Watchdog timer | • Reset (refer to 6. "Resets") | | | | counter refresh | Write 00h, and then FFh to the WDTR register. | | | | timing | • Underflow | | | | Operation when the timer underflows | Watchdog timer interrupt or watchdog timer reset | Watchdog timer reset | | | Selectable functions | <ul> <li>Prescaler divide ratio Divide-by-16 or divide-by-128 (selected by the WDC7 bit in the WDC register) However, divide-by-2 is selected when the CM07 bit in the CM0 register is 1 (sub clock). </li> <li>Count source protection mode Enabled or disabled (selected by the CSPROINI bit in the OFS1 address and the CSPRO bit in the CSPR register) </li> </ul> | | | Figure 15.1 Watchdog Timer Block Diagram ### 15.2 Registers Table 15.2 Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------------------|--------|--------------------| | 002Ch | Voltage Monitor 2 Control Register | VW2C | 1000 0X10b | | 037Ch | Count Source Protection Mode Register | CSPR | 00h <sup>(1)</sup> | | 037Dh | Watchdog Timer Refresh Register | WDTR | XXh | | 037Eh | Watchdog Timer Start Register | WDTS | XXh | | 037Fh | Watchdog Timer Control Register | WDC | 00XX XXXXb | Note: 1. When the CSPROINI bit in the OFS1 address is 0, the reset value becomes 1000 0000b. ### 15.2.1 Voltage Monitor 2 Control Register (VW2C) Set the PRC3 bit in the PRCR register to 1 (write enabled) before rewriting the VW2C register. Bits VW2C2 and VW2C3 do not change at voltage monitor 1 reset, voltage monitor 2 reset, oscillator stop detect reset, watchdog timer reset, or software reset. When rewriting the VW2C register (excluding the VW2C3 bit), the VW2C2 bit may become 1. Set the VW2C2 bit to 0 after rewriting the VW2C register. ### VW2C3 (WDT detection flag) (b3) Use this bit in an interrupt routine to determine the source of the interrupts from the watchdog timer, the oscillator stop/restart detect, the voltage monitor 1, and the voltage monitor 2. Condition to become 0: Writing 0 by a program Condition to become 1: Watchdog timer underflow detected (This flag remains unchanged even if 1 is written by a program.) ### 15.2.2 Count Source Protection Mode Register (CSPR) ### CSPRO (Count source protection mode select bit) (b7) Select the CSPRO bit before the watchdog timer starts counting. Once counting starts, do not change the CSPRO bit. Condition to become 0: • Reset when the CSPROINI bit in the OFS1 address is 1. (This flag remains unchanged even if 0 is written by a program.) #### Conditions to become 1: - When the CSPROINI bit in the OFS1 address is 0 - Write 0, and then write 1. Make sure no interrupts or DMA transfers occur between setting the bit to 0 and setting it to 1. # 15.2.3 Watchdog Timer Refresh Register (WDTR) After the watchdog timer interrupt occurs, refresh the watchdog timer by setting the WDTR register. ### 15.2.4 Watchdog Timer Start Register (WDTS) The WDTS register is enabled when the WDTON bit in the OFS1 address is 1 (watchdog timer is in a stopped state after reset). ### 15.2.5 Watchdog Timer Control Register (WDC) ### WDC4-WDC0 (b4-b0) When reading the watchdog timer value while the CSPRO bit in the CSPR register is 1 (count source protection mode enabled), read bits WDC4 to WDC0 more than three times to determine the values. ### 15.3 Optional Function Select Area In the optional function select area, the MCU state after reset and the function to prevent rewrite in parallel I/O mode are selected. The optional function select area is not an SFR, and therefore cannot be rewritten by a program. Set an appropriate value when writing a program to flash memory. The entire optional function select area becomes FFh when the block including the optional function select area is erased. In blank products, the OFS1 address value is FFh when shipped. After a value is written by the user, this register takes on the written value. In programmed products, the OFS1 address is the value set in the user program prior to shipping. Selection using the optional function select area can be used in single-chip mode or memory expansion mode. The option function select area cannot be used in microprocessor mode. When using the MCU in microprocessor mode, clear the internal ROM. ### 15.3.1 Optional Function Select Address 1 (OFS1) WDTON (Watchdog timer start select bit) (b0) CSPROINI (After-reset count source protection mode select bit) (b7) Set the WDTON bit to 0 (watchdog timer starts automatically after reset) when setting the CSPROINI bit to 0 (count source protection mode enabled after reset). ### 15.4 Operations #### 15.4.1 Count Source Protection Mode Disabled The CPU clock is used as the watchdog timer count source when count source protection mode is disabled. Table 15.3 lists Watchdog Timer Specifications (Count Source Protection Mode Disabled). Table 15.3 Watchdog Timer Specifications (Count Source Protection Mode Disabled) | Item | Specification | | | |------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count source | CPU clock | | | | Count operation | Decrement | | | | | When the CM07 bit in the CM0 register is 0 (main clock, PLL clock, fOCO-F, fOCO-S): | | | | | Prescaler divide value (n) × watchdog timer count value (32768) (1) CPU clock | | | | Cycles | n: 16 or 128 (selected by the WDC7 bit in the WDC register) Example: When CPU clock frequency is 16 MHz and the prescaler division rate is 16, the watchdog timer cycle is approximately 32.8 ms. | | | | | When the CM07 bit is 1 (sub clock): | | | | | Prescaler divide value (2) × watchdog timer count value (32768) (1) CPU clock | | | | Watchdog timer | • Reset (refer to 6. "Resets") | | | | counter refresh | Write 00h, and then FFh to the WDTR register. | | | | timing | • Underflow | | | | | Set the WDTON bit in the OFS1 address to select the watchdog timer operation after reset. | | | | 0 | WDTON bit is 1 (watchdog timer is in stop state after reset) | | | | Count start conditions | The watchdog timer counter and prescaler stop after reset and count starts by writing to the WDTS register. | | | | | WDTON bit is 0 (watchdog timer starts automatically after reset) | | | | | The watchdog timer counter and prescaler start counting automatically after reset. | | | | | • Stop mode | | | | Count stop | Wait mode | | | | conditions | • Bus hold | | | | | (Count resumes from the hold value after exiting.) | | | | | PM12 bit in the PM1 register is 0 | | | | Operation when | Watchdog timer interrupt | | | | timer underflows | PM12 bit in the PM1 register is 1 | | | | | Watchdog timer reset (Refer to 6.4.8 "Watchdog Timer Reset".) | | | #### Note: When writing 00h and then FFh to the WDTR register, the watchdog timer is refreshed, but the prescaler is not initialized. Thus, some errors in the watchdog timer period may be caused by the prescaler. The prescaler is initialized after reset. #### 15.4.2 Count Source Protection Mode Enabled fOCO-S is used as the watchdog timer count source when the count source protection mode is enabled. Table 15.4 lists the Watchdog Timer Specifications (Count Source Protection Mode Enabled). Table 15.4 Watchdog Timer Specifications (Count Source Protection Mode Enabled) | Item | Specification | | | |---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count source | fOCO-S (The 125 kHz on-chip oscillator clock automatically starts oscillating.) | | | | Count operation | Decrement | | | | Cycle | Watchdog timer count value (4096) fOCO-S | | | | | (The watchdog timer cycle is approximately 32.8 ms.) | | | | Watchdog timer | • Reset (refer to 6. "Resets") | | | | counter refresh | Write 00h, then FFh to the WDTR register. | | | | timing | • Underflow | | | | Count start conditions | Set the WDTON bit in the OFS1 address to select the watchdog timer operation after reset. • WDTON bit is 1 (watchdog timer is stopped after reset) The watchdog timer counter and prescaler stop after reset and count starts by writing to the WDTS register. • WDTON bit is 0 (watchdog timer starts automatically after reset) The watchdog timer counter and prescaler start counting automatically after rese | | | | Count stop condition | None (The count does not stop in wait mode or by bus hold once started. The MCU does not enter stop mode.) | | | | Operation when timer underflows | Watchdog timer reset (refer to 6.4.8 "Watchdog Timer Reset"). | | | When the CSPRO bit in the CSPR register is 1 (count source protection mode enabled), the watchdog timer counter underflows every 4096 cycles because the 3 low-order bits are not used. Also when the CSPRO bit is set to 1 (count source protection mode enabled), the following bits change: - The CM14 bit in the CM1 register becomes 0 (125 kHz on-chip oscillator on). It remains unchanged even if 1 is written, and the 125 kHz on-chip oscillator does not stop. - The PM12 bit in the PM1 register becomes 1 (watchdog timer reset when watchdog timer counter underflows). - The CM10 bit in the CM1 register remains unchanged even if 1 is written, and the MCU does not enter stop mode. ### 15.5 Interrupts Watchdog timer interrupts are non-maskable interrupts. The watchdog timer interrupt, oscillator stop/restart detect interrupt, voltage monitor 1 interrupt, and voltage monitor 2 interrupt share an vector. When using multiple functions, read the detect flag in an interrupt process program to determine the source of the interrupt. The VW2C3 bit in the VW2C register is the detect flag for the watchdog timer. After the interrupt factor is determined, set the VW2C3 bit to 0 (not detected) by a program. # 15.6 Notes on the Watchdog Timer After the watchdog timer interrupt is generated, use the WDTR register to refresh the watchdog timer counter. M16C/65C Group 16. DMAC ### 16. DMAC #### 16.1 Introduction The direct memory access controller (DMAC) allows data to be transferred without CPU intervention. There are four DMAC channels. Each time a DMA request occurs, the DMAC transfers one (8- or 16-bit) unit of data from the source address to the destination address. The DMAC uses the same data bus used by the CPU. Because the DMAC has higher priority for bus control than the CPU, and because it makes use of a cycle steal method, it can transfer 1 word (16 bits) or 1 byte (8 bits) of data within a very short time after a DMA request is generated. Table 16.1 lists DMAC Specifications, and Figure 16.1 shows the DMAC Block Diagram. Table 16.1 DMAC Specifications | Item | | Specification | |---------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Number of channels | | 4 (cycle steal method) | | Transfer memory spaces | | <ul> <li>From a given address in a 1 MB space to a fixed address</li> <li>From a fixed address to a given address in a 1 MB space</li> <li>From a fixed address to a fixed address</li> </ul> | | Maximum number of bytes transferred | | 128 KB (with 16-bit transfers) or 64 KB (with 8-bit transfers) | | DMA request sources (1) | | 43 sources Falling edge of INTO to INT7 (8) Both edge of INTO to INT7 (8) Timer A0 to timer A4 interrupt request (5) Timer B0 to timer B5 interrupt request (6) UART0 to UART2, UART5 to 7 transmission interrupt request (6) UART0 to UART2, UART5 to 7 reception/ACK interrupt request (6) SI/O3, SI/O4 interrupt request (2) A/D conversion interrupt request (1) Software trigger (1) | | Channel priority | | DMA0 > DMA1 > DMA2 > DMA3 (DMA0 takes precedence) | | Transfers | | 8 bits or 16 bits | | Transfer address direction | | Forward or fixed (The source and destination addresses cannot both be in the forward direction.) | | Transfer<br>mode | Single transfer | Transfer is completed when the DMAi transfer counter underflows. | | | Repeat transfer | When the DMAi transfer counter underflows, it is reloaded with the value of the DMAi transfer counter reload register, and DMA transfer continues. | | DMA interrupt request generation timing | | When the DMAi transfer counter underflows | | DMA transfer start | | Data transfer is initiated each time a DMA request is generated when the DMAE bit in the DMiCON register is 1 (enabled). | | DMA<br>transfer<br>stop | Single transfer | When the DMAE bit is set to 0 (disabled) After the DMAi transfer counter underflows | | | Repeat transfer | When the DMAE bit is set to 0 (disabled) | | Reload timing for forward address pointer and DMAi transfer counter | | When a data transfer is started after setting the DMAE bit to 1 (enabled), the forward address pointer is reloaded with the value of the SARi or DARi register (whichever is specified to be in the forward direction), and the DMAi transfer counter is reloaded with the value of the DMAi transfer counter reload register. | | DMA transfer cycles | | Minimum 3 cycles between SFR and internal RAM | i = 0 to 3 Note: 1. The selectable sources of DMA requests differ for each channel. M16C/65C Group 16. DMAC Figure 16.1 DMAC Block Diagram # 16.2 Registers Table 16.2 lists Registers. Do not access these registers using the DMAC. Table 16.2 Registers | Address | Register | Symbol | Reset Value | |---------|-----------------------------|--------|-------------| | 0180h | | | XXh | | 0181h | DMA0 Source Pointer | SAR0 | XXh | | 0182h | | | 0Xh | | 0184h | | | XXh | | 0185h | DMA0 Destination Pointer | DAR0 | XXh | | 0186h | | | 0Xh | | 0188h | DMAQ To color Occupant | TODO | XXh | | 0189h | DMA0 Transfer Counter | TCR0 | XXh | | 018Ch | DMA0 Control Register | DM0CON | 0000 0X00b | | 0190h | | | XXh | | 0191h | DMA1 Source Pointer | SAR1 | XXh | | 0192h | | | 0Xh | | 0194h | | | XXh | | 0195h | DMA1 Destination Pointer | DAR1 | XXh | | 0196h | | | 0Xh | | 0198h | DMA4 Torrestor Orantes | TODA | XXh | | 0199h | DMA1 Transfer Counter | TCR1 | XXh | | 019Ch | DMA1 Control Register | DM1CON | 0000 0X00b | | 01A0h | | | XXh | | 01A1h | DMA2 Source Pointer | SAR2 | XXh | | 01A2h | | | 0Xh | | 01A4h | | | XXh | | 01A5h | DMA2 Destination Pointer | DAR2 | XXh | | 01A6h | | | 0Xh | | 01A8h | DMAQ Tennefor Country | TODO | XXh | | 01A9h | DMA2 Transfer Counter | TCR2 | XXh | | 01ACh | DMA2 Control Register | DM2CON | 0000 0X00b | | 01B0h | | | XXh | | 01B1h | DMA3 Source Pointer | SAR3 | XXh | | 01B2h | | | 0Xh | | 01B4h | | | XXh | | 01B5h | DMA3 Destination Pointer | DAR3 | XXh | | 01B6h | | | 0Xh | | 01B8h | DMA2 Transfer Country | TODO | XXh | | 01B9h | DMA3 Transfer Counter | TCR3 | XXh | | 01BCh | DMA3 Control Register | DM3CON | 0000 0X00b | | 0390h | DMA2 Source Select Register | DM2SL | 00h | | 0392h | DMA3 Source Select Register | DM3SL | 00h | | 0398h | DMA0 Source Select Register | DM0SL | 00h | | 039Ah | DMA1 Source Select Register | DM1SL | 00h | ### 16.2.1 DMAi Source Pointer (SARi) (i = 0 to 3) If the DSD bit in the DMiCON register is 0 (fixed), write to SARi register when the DMAE bit in the DMiCON register is 0 (DMA disabled). If the DSD bit is 1 (forward direction), this register can be written to at any time. If the DSD bit is 1 and the DMAE bit is 1 (DMA enabled), the DMAi forward address pointer can be read from this register. Otherwise, the value written to it can be read. The forward address pointer increments when a DMA request is accepted. # 16.2.2 DMAi Destination Pointer (DARi) (i = 0 to 3) If the DAD bit in the DMiCON register is 0 (fixed), write to the DARi register when the DMAE bit in the DMiCON register is 0 (DMA disabled). If the DAD bit is 1 (forward direction), this register can be written to at any time. If the DAD bit is 1 and the DMAE bit is 1 (DMA enabled), the DMAi forward address pointer can be read from this register. Otherwise, the value written to it can be read. The forward address pointer increments when a DMA request is accepted. # 16.2.3 DMAi Transfer Counter (TCRi) (i = 0 to 3) The value written in the TCRi register is stored in the DMAi transfer counter reload register. The DMAi transfer counter reload register value is transferred to the DMAi transfer counter in either of the following cases: - The DMAE bit in the DMiCON register is set to 1 (DMA enabled) (single transfer mode, repeat transfer mode). - The DMAi transfer counter underflows (repeat transfer mode). # 16.2.4 DMAi Control Register (DMiCON) (i = 0 to 3) #### DMAS (DMA request bit) (b2) Conditions to become 0: - Set the bit to 0. - Start data transfer Condition to become 1: • Set the bit to 1. #### DMAE (DMA enable bit) (b3) Conditions to become 0: - Set the bit to 0. - The DMA transfer counter underflows (single transfer mode). Condition to become 1: • Set the bit to 1. DSD (Source address direction select bit) (b4) DAD (Destination address direction select bit) (b5) Set the DAD bit and/or DSD bit to 0 (address direction fixed). # 16.2.5 DMAi Source Select Register (DMiSL) (i = 0 to 3) #### DSEL4-DSEL0 (DMA request source select bit) (b4-b0) The DMAi request sources can be selected by a combination of the DMS bit and bits DSEL4 to DSEL0 in the manner shown in Table 16.3 to Table 16.6. These tables list the DMAi request sources. Table 16.3 Sources of DMA Request (DMA0) | DSEL4 to DSEL0 | DMS is 0 (Basic Source of Request) | DMS is 1 (Expanded Source of Request) | |----------------|------------------------------------|---------------------------------------| | 0 0000b | Falling edge of the INTO pin | - | | 0 0001b | Software trigger | _ | | 0 0 0 1 0 b | Timer A0 | _ | | 0 0 0 1 1 b | Timer A1 | _ | | 0 0100b | Timer A2 | _ | | 0 0101b | Timer A3 | _ | | 0 0110b | Timer A4 | Both edges of the INTO pin | | 0 0111b | Timer B0 | Timer B3 | | 0 1000b | Timer B1 | Timer B4 | | 0 1001b | Timer B2 | Timer B5 | | 0 1010b | UART0 transmission | _ | | 0 1011b | UART0 reception | - | | 0 1100b | UART2 transmission | - | | 0 1101b | UART2 reception | _ | | 0 1110b | A/D converter | _ | | 0 1111b | UART1 transmission | _ | | 1 0000b | UART1 reception | Falling edge of the INT4 pin | | 1 0001b | UART5 transmission | Both edges of the INT4 pin | | 1 0 0 1 0 b | UART5 reception | - | | 1 0 0 1 1 b | UART6 transmission | - | | 1 0100b | UART6 reception | - | | 1 0101b | UART7 transmission | - | | 1 0110b | UART7 reception | - | | 1 0111b | _ | _ | | 1 1 X X X b | _ | | X: 0 or 1 —: Do not set. Table 16.4 Source of DMA Request (DMA1) | DSEL4 to DSEL0 | DMS = 0 (Basic Source of Request) | DMS = 1 (Expanded Source of Request) | |----------------|-----------------------------------|--------------------------------------| | 0 0000b | Falling edge of the INT1 pin | _ | | 0 0001b | Software trigger | - | | 0 0 0 1 0 b | Timer A0 | - | | 0 0 0 1 1 b | Timer A1 | - | | 0 0100b | Timer A2 | - | | 0 0101b | Timer A3 | SI/O3 | | 0 0110b | Timer A4 | SI/O4 | | 0 0111b | Timer B0 | Both edges of the INT1 pin | | 0 1000b | Timer B1 | - | | 0 1001b | Timer B2 | - | | 0 1010b | UART0 transmission | - | | 0 1011b | UART0 reception/ACK0 | _ | | 0 1100b | UART2 transmission | _ | | 0 1101b | UART2 reception/ACK2 | _ | | 0 1110b | A/D converter | _ | | 0 1111b | UART1 reception/ACK1 | _ | | 1 0000b | UART1 transmission | Falling edge of the INT5 pin | | 1 0001b | UART5 transmission | Both edges of the INT5 pin | | 1 0 0 1 0 b | UART5 reception/ACK5 | - | | 1 0 0 1 1 b | UART6 transmission | - | | 1 0100b | UART6 reception/ACK6 | - | | 1 0101b | UART7 transmission | - | | 1 0110b | UART7 reception/ACK7 | - | | 1 0111b | _ | - | | 1 1 X X X b | _ | _ | X: 0 or 1 — Do not set. Table 16.5 Sources of DMA Request (DMA2) | DSEL4 to DSEL0 | DMS is 0 (Basic Source of Request) | DMS is 1 (Expanded Source of Request) | |----------------|------------------------------------|---------------------------------------| | 0 0000b | Falling edge of the INT2 pin | - | | 0 0001b | Software trigger | - | | 0 0010b | Timer A0 | - | | 0 0 0 1 1 b | Timer A1 | - | | 0 0100b | Timer A2 | _ | | 0 0101b | Timer A3 | _ | | 0 0110b | Timer A4 | Both edges of the INT2 pin | | 0 0111b | Timer B0 | Timer B3 | | 0 1000b | Timer B1 | Timer B4 | | 0 1001b | Timer B2 | Timer B5 | | 0 1010b | UART0 transmission | _ | | 0 1011b | UART0 reception | _ | | 0 1100b | UART2 transmission | _ | | 0 1101b | UART2 reception | _ | | 0 1110b | A/D converter | _ | | 0 1111b | UART1 transmission | _ | | 1 0000b | UART1 reception | Falling edge of the INT6 pin | | 1 0001b | UART5 transmission | Both edges of the INT6 pin | | 1 0 0 1 0 b | UART5 reception | _ | | 1 0 0 1 1 b | UART6 transmission | - | | 1 0100b | UART6 reception | - | | 1 0101b | UART7 transmission | - | | 1 0110b | UART7 reception | - | | 1 0111b | _ | - | | 1 1 X X X b | _ | - | X: 0 or 1 - Do not set. Table 16.6 Source of DMA Request (DMA3) | DSEL4 to DSEL0 | DMS is 0 (Basic Source of Request) | DMS is 1 (Expanded Source of Request) | |----------------|------------------------------------|---------------------------------------| | 0 0000b | Falling edge of the INT3 pin | - | | 0 0001b | Software trigger | - | | 0 0010b | Timer A0 | - | | 0 0 0 1 1 b | Timer A1 | _ | | 0 0100b | Timer A2 | _ | | 0 0101b | Timer A3 | SI/O3 | | 0 0110b | Timer A4 | SI/O4 | | 0 0111b | Timer B0 | Both edges of the INT3 pin | | 0 1000b | Timer B1 | _ | | 0 1001b | Timer B2 | _ | | 0 1010b | UART0 transmission | _ | | 0 1011b | UART0 reception/ACK0 | _ | | 0 1100b | UART2 transmission | _ | | 0 1101b | UART2 reception/ACK2 | _ | | 0 1110b | A/D converter | _ | | 0 1111b | UART1 reception/ACK1 | _ | | 1 0000b | UART1 transmission | Falling edge of the INT7 pin | | 1 0001b | UART5 transmission | Both edges of the INT7 pin | | 1 0010b | UART5 reception/ACK5 | - | | 1 0 0 1 1 b | UART6 transmission | - | | 1 0100b | UART6 reception/ACK6 | - | | 1 0101b | UART7 transmission | - | | 1 0110b | UART7 reception/ACK7 | - | | 1 0111b | _ | - | | 1 1 X X X b | _ | - | X: 0 or 1 — Do not set. #### 16.3 Operations #### 16.3.1 DMA Enabled When data transfer starts after setting the DMAE bit in the DMiCON register to 1 (enabled), the DMAC operates as listed below (i = 0 to 3). If 1 is written to the DMAE bit when it is already set to 1, the DMAC also performs the following operations. - The forward address pointer is reloaded with the SARi register value when the DSD bit in the DMiCON register is 1 (forward), or the DARi register value when the DAD bit in the DMiCON register is 1 (forward). - The DMAi transfer counter is reloaded with the DMAi transfer counter reload register value. # 16.3.2 DMA Request The DMAC can generate a DMA request as triggered by the request source that is selected with the DMS bit and bits DSEL4 to DSEL0 in the DMiSL register (i = 0 to 3) on each channel. Table 16.7 lists the Timing at Which the DMAS Bit Value Changes. When a DMA request is generated, the DMAS bit becomes 1 (DMA requested) regardless of the DMAE bit status. If the DMAE bit is 1 (enabled) when this occurs, the DMAS bit becomes 0 (DMA not requested) immediately before a data transfer starts. This bit cannot be set to 1 by a program (writing 1 has no effect). If the DMAE bit is 1, data transfers start immediately after a DMA request is generated, so the DMAS bit in almost all cases is 0 when read in a program. Read the DMAE bit to determine whether the DMAC is enabled. When a DMA request transfer cycle is shorter than the DMA transfer cycle, the number of transfer requests and the number of transfers do not match. When a peripheral function is selected as the DMA source, relations with the interrupt control registers are as follows: - DMA transfers are not affected by the I flag or interrupt control registers. DMA requests are always accepted even when interrupt requests are not accepted. - The IR bit in the interrupt control register retains its value when a DMA transfer is accepted. Table 16.7 Timing at Which the DMAS Bit Value Changes | DMA Source | DMAS Bit in the [ | OMiCON Register | |---------------------|--------------------------------------------|--------------------------------------------------------| | DIVIA Source | Timing at which the bit becomes 1 | Timing at which the bit becomes 0 | | Software trigger | When the DSR bit in the DMiSL register | | | Software trigger | is set to 1. | | | | When an input edge of pins INTO to | | | External source | INT7 matches with what is selected by | | | External source | setting bits DSEL4 to DSEL0 and DMS | | | | in the DMiSL register. | <ul> <li>Immediately before a data transfer</li> </ul> | | | When an interrupt request is generated | starts | | | by the peripheral function selected by | <ul> <li>When set to 0 by a program</li> </ul> | | | setting the DMS bit and bits DSEL4 to | | | Peripheral function | DSEL0 in the DMiSL register.(If the IR | | | | bit in an interrupt control register is 0, | | | | the timing is when the IR bit becomes | | | | 1.) | | i = 0 to 3 ### 16.3.3 Transfer Cycles A transfer cycle is composed of a bus cycle to read data from a source address (source read), and a bus cycle to write data to a destination address (destination write). The number of read and write bus cycles varies with the source and destination addresses. Figure 16.2 shows Source Read Cycle Example. For convenience, the destination write cycle is shown as one bus cycle and the source read cycles for the different conditions are shown. In reality, the destination write cycle is subject to the same conditions as the source read cycle, with the transfer cycle changing accordingly. When calculating transfer cycles, take into consideration each condition for the source read and the destination write cycle. For example, when data is transferred in 16-bit units, and the source and destination addresses are both odd addresses ((2) in Figure 16.2), two source read bus cycles and two destination write bus cycles are required. #### 16.3.3.1 Effect of Source and Destination Addresses When a 16-bit unit of data is transferred with a 16-bit data bus and the source address starts with an odd address, the source read cycle increments by one bus cycle, compared to a source address starting with an even address. When a 16-bit unit of data is transferred with a 16-bit data bus and the destination address starts with an odd address, the destination write cycle increments by one bus cycle, compared to a destination address starting with an even address. #### 16.3.3.2 Effect of Software Wait For memory or SFR accesses in which one or more software wait states are inserted, the number of bus cycles required increases by an amount equal to the number of software wait states. #### 16.3.3.3 Memory Expansion Mode and Microprocessor Mode In memory expansion or microprocessor mode, the transfer cycle is also affected by the BYTE pin level. Furthermore, the bus cycle itself is extended by a software wait or $\overline{RDY}$ signal. If 16 bits of data are transferred on an 8-bit data bus (input to the BYTE pin is high), the operation is accomplished by transferring 8 bits of data twice. Therefore, this operation requires two bus cycles to read data and two bus cycles to write data. Furthermore, if the DMAC accesses an internal area (internal ROM, internal RAM, or SFR), unlike in the case of the CPU, the DMAC uses the data bus width selected by the BYTE pin. DMA transfers to and from an external area are affected by the $\overline{RDY}$ signal. Refer to 11.3.5.6 " $\overline{RDY}$ Signal" for more information. Figure 16.2 Source Read Cycle Example # 16.3.4 DMAC Transfer Cycles The formula for calculating the number of DMAC transfer cycles is shown below. Number of transfer cycles per transfer unit = Number of read cycles x j + Number of write cycles x k Table 16.8 DMAC Transfer Cycles | Transfer Unit | Bus Width | Access | Single-Chip Mode | | Memory Expansion Mode<br>Microprocessor Mode | | | |---------------------------------|---------------|---------|------------------|--------------|----------------------------------------------|--------------|--| | Transier Offic | Dus Widili | Address | Number of | Number of | Number of | Number of | | | | | | read cycles | write cycles | read cycles | write cycles | | | | 16-bit | Even | 1 | 1 | 1 | 1 | | | 8-bit transfers | (BYTE = low) | Odd | 1 | 1 | 1 | 1 | | | (DMBIT = 1) | 8-bit | Even | N/A | N/A | 1 | 1 | | | | (BYTE = high) | Odd | N/A | N/A | 1 | 1 | | | | 16-bit | Even | 1 | 1 | 1 | 1 | | | 16-bit transfers<br>(DMBIT = 0) | (BYTE = low) | Odd | 2 | 2 | 2 | 2 | | | | 8-bit | Even | N/A | N/A | 2 | 2 | | | | (BYTE = high) | Odd | N/A | N/A | 2 | 2 | | DMBIT: Bit in the DMiCON register (i = 0 to 3) Table 16.9 Coefficients j and k (1/2) | | | Internal Area | | | External Area | | |---|------------|---------------|----------|-------------------|---------------|------------| | | Internal R | OM, RAM | SFR | Multiplex bus | | | | | No waits | Wait | one wait | Wait inserted (1) | | | | | inserted | inserted | inserted | one wait | two wait | three wait | | j | 1 | 2 | 2 | 3 | 3 | 4 | | k | 1 | 2 | 2 | 3 | 3 | 4 | Note: 1. Depends on the set value of the CSE register. Table 16.10 Coefficients j and k (2/2) | | | External Area | | | | | | | | |---|----------|-----------------------------|-------------------|-------------------|---------|----------|----------------|---------|--| | | | Separate bus <sup>(1)</sup> | | | | | | | | | | No waits | Wait inserted (2) | | | | | | | | | | inserted | one wait | two wait | three wait | 2φ + 3φ | 2φ + 4φ | 3φ <b>+</b> 4φ | 4φ + 5φ | | | | | $(1\phi + 1\phi)$ | $(1\phi + 2\phi)$ | $(1\phi + 3\phi)$ | _γ . σγ | <b>-</b> | σφ : :φ | .φ. σφ | | | j | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 9 | | | k | 2 | 2 | 2 3 4 5 6 7 | | | | | | | Notes: - 1. When recovery cycle inserted is selected by setting bits EWR1 and EWR0 in the EWR register, add the recovery cycle. - 2. Depends on the set values of registers CSE and EWC. ### 16.3.5 Single Transfer Mode In single transfer mode, the transfer stops when the DMAi transfer counter underflows. Figure 16.3 shows an Operation Example in Single Transfer Mode. Figure 16.3 Operation Example in Single Transfer Mode ### 16.3.6 Repeat Transfer Mode In repeat transfer mode, when the DMAi transfer counter underflows, it is reloaded with the value of the DMAi transfer counter reload register and DMA transfer continues. Figure 16.4 shows an Operation Example in Repeat Transfer Mode. Figure 16.4 Operation Example in Repeat Transfer Mode ### 16.3.7 Channel Priority and DMA Transfer Timing If multiple channels among DMA0 to DMA3 are enabled and DMA transfer request signals are detected as active in the same sampling period (one period from a falling edge to the next falling edge of BCLK), the DMAS bit on each channel becomes 1 (DMA requested) at the same time. In this case, the DMA requests are arbitrated according to the following channel priority: DMA0 > DMA1 > DMA2 > DMA3. DMAC operation when DMA0 and DMA1 requests are detected as active in the same sampling period is described below. Figure 16.5 shows an example of DMA Transfer Initiated by External Sources. In Figure 14.5, as DMA0 and DMA1 requests are generated simultaneously, the higher channel prioritized DMA0 is received first, and data transfer starts. After one DMA0 transfer is completed, the bus access privilege is returned to the CPU. When the CPU has completed one bus access, a DMA1 transfer starts. After one DMA1 transfer is completed, the bus access privilege is again returned to the CPU. In addition, DMA requests cannot increment since each channel has one DMAS bit. Therefore, when DMA requests, such as DMA1 in Figure 16.5, occur more than once, the DMAS bit is set to 0 after receiving the bus access privilege. The bus access privilege is returned to the CPU when one transfer is completed. Figure 16.5 DMA Transfer Initiated by External Sources #### 16.4 Interrupts Refer to operation examples for interrupt request generation timing. For details on interrupt control, refer to 14.7 "Interrupt Control". Table 16.11 DMAC Interrupt Related Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------------|--------|-------------| | 004Bh | DMA0 Interrupt Control Register | DM0IC | XXXX X000b | | 004Ch | DMA1 Interrupt Control Register | DM1IC | XXXX X000b | | 0069h | DMA2 Interrupt Control Register | DM2IC | XXXX X000b | | 006Ah | DMA3 Interrupt Control Register | DM3IC | XXXX X000b | When the DMS bit or bits DSEL4 to DSEL0 in the DMiSL register are changed, the DMAS bit in the DMiCON sometimes becomes 1 (DMA requested) (i = 0 to 3). Therefore, set the DMAS bit to 0 (DMA not requested) after the DMS bit or bits DSEL4 to DSEL0 in the DMiSL register are changed. Refer to 14.13 "Notes on Interrupts" for more details. #### 16.5 Notes on DMAC # 16.5.1 Write to the DMAE Bit in the DMiCON Register (i = 0 to 3) (Technical update number: TN-M16C-92-0306) When both of the following conditions are met, follow steps (1) and (2) below. #### Conditions - Write 1 (DMAi is in active state) to the DMAE bit when it is 1. - A DMA request may be generated simultaneously when writing to the DMAE bit. #### Steps - (1) Set bits DMAE and DMAS in the DMiCON register to 1 simultaneously. (1) - (2) Make sure the DMAi circuit is in an initialized state <sup>(2)</sup> by a program. If DMAi is not in an initialized state, repeat these two steps. #### Notes: - 1. The DMAS bit does not change even if set to 1. However, it becomes 0 when set to 0 (DMA not requested). Therefore, when writing to the DMiCON register to set the DMAE bit to 1, set the value to be written to the DMAS bit to 1 to retain its state immediately before writing. Similarly, when writing to the DMAE bit with a read-modify-write instruction, set the DMAS bit to 1 to retain the DMA request that was generated while executing the instruction. - 2. Read the TCRi register to verify whether DMAi is in an initialized state. If the read value is equal to the value that was written to the TCRi register before the DMA transfer started, DMAi is in an initialized state. When a DMA request is generated after writing to the DMAE bit, the read value is a value written to the TCRi register minus 1. If the read value is a value in the middle of a transfer, DMAi is not in an initialized state. #### 16.5.2 Changing the DMA Request Source When the DMS bit or any of bits from DSEL4 to DSEL0 in the DMiSL register is changed, the DMAS bit in the DMiCON sometimes becomes 1 (DMA requested). Set the DMAS bit to 0 (DMA not requested) after changing the DMS bit or bits DSEL4 to DSEL0 in the DMiSL register. #### 17. Timer A #### 17.1 Introduction Timers A consists of timers A0 to A4. Each timer operates independently of the others. Table 17.1 lists Timer A Specifications, Table 17.2 lists Differences in Timer A Mode, Figure 17.1 shows Timer A and B Count Sources, Figure 17.2 shows Timer A Configuration, Figure 17.3 shows Timer A Block Diagram, and Table 17.3 lists I/O Ports. Table 17.1 Timer A Specifications | Item | Specification | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Configuration | 16-bit timer × 5 | | Operating modes | <ul> <li>Timer mode The timer counts an internal count source.</li> <li>Event counter mode The timer counts pulses from an external device, or overflows and underflows of other timers.</li> <li>One-shot timer mode The timer outputs a single pulse before it reaches the count 0000h.</li> <li>Pulse width modulation mode (PWM mode) The timer outputs pulses of given width and cycle successively.</li> <li>Programmable output mode The timer outputs a given pulse width of a high/low level signal (timers A1, A2, and A4).</li> </ul> | | Interrupt sources | Overflow/underflow × 5 | Table 17.2 Differences in Timer A Mode | Item | | Timer | | | | | | |--------------------------------------------------------|----|-------|-----|-----|-----|--|--| | | | A1 | A2 | А3 | A4 | | | | Event counter mode (two-phase pulse signal processing) | No | No | Yes | Yes | Yes | | | | Programmable output mode | | Yes | Yes | No | Yes | | | Figure 17.1 Timer A and B Count Sources Figure 17.2 Timer A Configuration Figure 17.3 Timer A Block Diagram Table 17.3 I/O Ports | Pin Name | I/O | Function | |----------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TAilN | Input <sup>(1)</sup> | Gate input (timer mode) Count source input (event counter mode) Two-phase signal input (event counter mode (two-phase pulse signal processing)) Trigger input (one-shot timer mode, PWM mode, programmable output mode) | | TAiOUT | Output (2) | Pulse output (timer mode, event counter mode, one-shot timer mode, PWM mode, and programmable output mode) | | | Input (1) | Two-phase pulse input (event counter mode (two-phase pulse signal processing)) | | ZP | Input (1) Z-phase (counter initialization) input (event counter mode (two-phasignal processing)) | | i = 0 to 4; however, i = 2, 3, 4 for two-phase pulse input, and i = 1, 2, 4 in programmable output mode Notes: - 1. When using pins TAilN, TAiOUT, and ZP for input, set the port direction bits sharing pins to 0 (input mode). - 2. The TA0OUT pin is N-channel open drain output. # 17.2 Registers Table 17.4 lists registers associated with timer A. Set the TCDIV00 bit in the TCKDIVC0 register before setting other registers associated with timer A. After changing the TCDIV00 bit, set other registers associated with timer A again. Refer to "registers and the setting" in each mode for registers and bit settings. Table 17.4 Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------------------------|----------|-------------| | 0012h | Peripheral Clock Select Register | PCLKR | 0000 0011b | | 0015h | Clock Prescaler Reset Flag | CPSRF | 0XXX XXXXb | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 01CBh | Timer AB Division Control Register 0 | TCKDIVC0 | 0000 X000b | | 01D0h | Timer A Count Source Select Register 0 | TACS0 | 00h | | 01D1h | Timer A Count Source Select Register 1 | TACS1 | 00h | | 01D2h | Timer A Count Source Select Register 2 | TACS2 | X0h | | 01D4h | 16-bit Pulse Width Modulation Mode Function Select Register | PWMFS | 0XX0 X00Xb | | 01D5h | Timer A Waveform Output Function Select Register | TAPOFS | XXX0 0000b | | 01D8h | Timer A Output Waveform Change Enable Register | TAOW | XXX0 X00Xb | | 0302h | Timer A1-1 Register | TA11 | XXh | | 0303h | Timer A1-1 Negister | IAII | XXh | | 0304h | Timer A2-1 Register | TA21 | XXh | | 0305h | Timer A2-1 Register | | XXh | | 0306h | Timer A4-1 Register | TA41 | XXh | | 0307h | Timer A4-1 Register | 1/1 | XXh | | 0320h | Count Start Flag | TABSR | 00h | | 0322h | One-Shot Start Flag | ONSF | 00h | | 0323h | Trigger Select Register | TRGSR | 00h | | 0324h | Increment/Decrement Flag | UDF | 00h | | 0326h | Timer A0 Register | TA0 | XXh | | 0327h | Timer Ad Register | IAU | XXh | | 0328h | Timer A1 Register | TA1 | XXh | | 0329h | Timer At Register | 17(1 | XXh | | 032Ah | Timer A2 Register | TA2 | XXh | | 032Bh | Timer Az Kegister | IAZ | XXh | | 032Ch | Timer A3 Register | TA3 | XXh | | 032Dh | Timer As Register | IAU | XXh | | 032Eh | Timer A4 Register | TA4 | XXh | | 032Fh | Timer 714 Register | | XXh | | 0336h | Timer A0 Mode Register | TA0MR | 00h | | 0337h | Timer A1 Mode Register | TA1MR | 00h | | 0338h | Timer A2 Mode Register | TA2MR | 00h | | 0339h | Timer A3 Mode Register | TA3MR | 00h | | 033Ah | Timer A4 Mode Register | TA4MR | 00h | # 17.2.1 Peripheral Clock Select Register (PCLKR) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. # 17.2.2 Clock Prescaler Reset Flag (CPSRF) ### 17.2.3 Peripheral Clock Stop Register 1 (PCLKSTP1) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register #### PCKSTP11 (Timer peripheral clock stop bit) (b1) When using f1 or the main clock for the timer A and timer B count source, set the PCKSTP11 bit to 0 (f1 provide enabled). To change the PCKSTP11 bit from 1 (f1 provide disabled) to 0, use following procedure: - (1) Stop timer A and timer B. - (2) Set the PCKSTP11 bit to 0. - (3) Set the registers for timer A and timer B again. To change the timer A and timer B count source from fOCO-F to f1, perform (1) and (2) above, and set the TCDIV00 bit in the TCKDIVC0 register from 1 (fOCO-F) to 0 (f1), then perform (3). #### PCKSTP17 (Timer clock source select bit) (b7) Change the PCKSTP17 bit when all of the following conditions are met: - Both f1 and the main clock are stably supplied. - Both timer A and timer B are stopped. The PCKSTP17 bit is used for supplying the main clock to timer A and timer B. When in PLL operating mode, high-speed mode, medium-speed mode, or wait mode, the main clock can be used for the timer A and timer B count source. Do not use the main clock for the timer A and timer B count source in other normal operating modes (refer to 9.3 "Clock"). # 17.2.4 Timer AB Division Control Register 0 (TCKDIVC0) TCDIV00 (Clock select prior to timer AB division bit) (b0) Set the TCDIV00 bit while timers A and B are stopped. Set the TCDIV00 bit before setting other registers associated with timer A. After changing the TCDIV00 bit, set other registers associated with timer A again. # 17.2.5 Timer A Count Source Select Register i (TACSi) (i = 0 to 2) TCS2 to TCS0 (TAi count source select bit) (b2-b0) (i = 0, 2, 4) TCS6 to TCS4 (TAj count source select bit) (b6-b4) (i = 1, 3) Select f1TIMAB or f2TIMAB by the PCLK0 bit in the PCLKR register. ### 17.2.6 16-bit Pulse Width Modulation Mode Function Select Register (PWMFS) PWMFS1 (Timer A1 programmable output mode select bit) (b1) PWMFS2 (Timer A2 programmable output mode select bit) (b2) PWMFS4 (Timer A4 programmable output mode select bit) (b4) These bits are enabled when bits TMOD1 to TMOD0 in the TAiMR register are 11b (PWM mode or programmable output mode), and the MR3 bit in the TAiMR register is 0 (16-bit PWM mode). # 17.2.7 Timer A Waveform Output Function Select Register (TAPOFS) | 07 b6 b5 b4 b3 b2 b1 b0 | Symbol<br>TAPOFS | Address 01D5h | | set Value<br>X0 0000b | |-------------------------|------------------|---------------------------------|-----------------------------------------------------------------------------------------------|-----------------------| | | Bit Symbol | Bit Name | Function | RW | | | POFS0 | TA0OUT output polar control bit | | RW | | | POFS1 | TA1OUT output polar control bit | 0 : Output waveform high-level active 1 : Output waveform high-level active (output inverted) | RW | | | POFS2 | TA2OUT output polar control bit | | RW | | | POFS3 | TA3OUT output polar control bit | ` ' | RW | | | POFS4 | TA4OUT output polar control bit | | RW | | | —<br>(b7-b5) | No register bits. If necessary, | set to 0. The read value is undefined. | _ | # 17.2.8 Timer A Output Waveform Change Enable Register (TAOW) The TAOW register is enabled in programmable output mode. To change cycles or width of the output waveform, follow the instructions below. - (1) Set the TAiOW bit to 0 (output waveform change disabled). (i = 1, 2, 4) - (2) Write to the TAi register and/or the TAi1 register. - (3)Set the TAiOW bit to 1 (output waveform change enabled). The updated value is reloaded when the TAiOW bit is 1 (output waveform change enabled) at one cycle before the rising edge of the TAiOUT output (the falling edge when the POFSi bit is 1). The value before the update is reloaded when the TAiOW bit is 0 (output waveform change disabled). # 17.2.9 Timer Ai Register (TAi) (i = 0 to 4) Access the register in 16-bit units. Use the MOV instruction to write to the TAi register. #### **Event Counter Mode** The timer counts pulses from an external device, or the overflows/underflows of other timers. #### One-Shot Timer Mode If the TAi register is set to 0000h, the counter does not work and timer Ai interrupt requests are not generated. Furthermore, if pulse output is selected, no pulses are output from the TAiOUT pin. #### Pulse Width Modulation Mode (16-bit PWM mode) When the TAi register is set to 0000h, the counter does not work, the output level on the TAiOUT pin remains low, and timer Ai interrupt requests are not generated. #### Pulse Width Modulation Mode (8-bit PWM mode) This mode operates as an 8-bit prescaler (lower 8 bits) and an 8-bit pulse width modulator (upper 8 bits). When the upper 8 bits of the TAi register are set to 00h, the counter does not work, the output level on the TAiOUT pin remains low, and a timer Ai interrupt request is not generated. # 17.2.10 Timer Ai-1 Register (TAi1) (i = 1, 2, 4) Access the register in 16-bit units. Use the MOV instruction to write to the TAi1 register. #### 17.2.11 Count Start Flag (TABSR) # 17.2.12 One-Shot Start Flag (ONSF) #### TAiOS (Timer Ai one-shot start flag) (b4-b0) (i = 0 to 4) This bit is enabled in one-shot timer mode. When the MR2 bit in the TAi register is 0 (TAiOS bit enabled), the timer Ai count starts by setting the TAiOS bit to 1 after setting the TAiS bit in the TABSR register to 1 (start counting). #### TAZIE (Z-phase input enable bit) (b5) This bit is used in event counter mode (two-phase pulse signal processing) of timer A3. Refer to 17.3.4.3 "Counter Initialization Using Two-Phase Pulse Signal Processing" for details. #### TAOTGH-TAOTGL (Timer A0 event/trigger select bit) (b7-b6) These bits are used to select an event or a trigger in the following modes: - An event in event counter mode (when not using two-phase pulse signal processing) - A trigger in one-shot timer mode or PWM mode The above applies when the MR2 bit in the TA0MR register is 1 (trigger selected by setting bits TA0TGH to TA0TGL). When bits TA0TGH to TA0TGL are 00b, the active edge of input signals can be selected by setting the MR1 bit in the TA0MR register. When bits TA0TGH to TA0TGL are set to 01b, 10b, or 11b, an event or a trigger occurs when an interrupt request for the selected timer is generated. An event or trigger can occur while interrupts are disabled because an interrupt request signal is generated regardless of the I flag, IPL, or interrupt control registers. # 17.2.13 Trigger Select Register (TRGSR) TA1TGH-TA1TGL (Timer A1 event/trigger select bit) (b1-b0) TA2TGH-TA2TGL (Timer A2 event/trigger select bit) (b3-b2) TA3TGH-TA3TGL (Timer A3 event/trigger select bit) (b5-b4) TA4TGH-TA4TGL (Timer A4 event/trigger select bit) (b7-b6) These bits are used to select an event or a trigger of the following modes: - An event in event counter mode (when not using two-phase pulse signal processing) - A trigger in one-shot timer mode, PWM mode, or programmable output mode The above applies when the MR2 bit in the TAiMR register is 1 (trigger selected by setting bits TAiTGH to TAiTGL). When bits TAiTGH to TAiTGL are 00b, the active edge of input signals can be selected by setting the MR1 bit in the TAiMR register. When bits TAiTGH to TAiTGL are set to 01b, 10b, or 11b, an event or a trigger occurs when an interrupt request of the selected timer is generated. An event or trigger can occur while interrupts are disabled because an interrupt request signal is generated regardless of the I flag, IPL, or interrupt control registers. # 17.2.14 Increment/Decrement Flag (UDF) TAiUD (Timer Ai increment/decrement flag) (b4 to b0) (i = 0 to 4) Enabled in event counter mode (when not using two-phase pulse signal processing). TA2P (Timer A2 two-phase pulse signal processing select bit) (b5) TA3P (Timer A3 two-phase pulse signal processing select bit) (b6) TA4P (Timer A4 two-phase pulse signal processing select bit) (b7) Set these bits to 0 when not using two-phase pulse signal processing. # 17.2.15 Timer Ai Mode Register (TAiMR) (i = 0 to 4) | b7 b6 b5 b4 b3 b2 b1 b0 | Symbo<br>TA0MR to T | | | Reset Value<br>00h | | |-------------------------|---------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------|--------------------|--| | | Bit Symbol | Bit Name | Function | RW | | | | TMOD0 | Operation mode color hit | b1 b0<br>0 0: Timer mode<br>0 1: Event counter mode | RW | | | | TMOD1 | Operation mode select bit | 0 : One-shot timer mode 1 : Pulse width modulation (PWM) mode or programmable output mode | RW | | | | MR0 | | • | | | | | MR1 | Function varies with the operation mode | | | | | | MR2 | | | | | | MR3 TCK0 | | | | | | | | | | | | | | TCK1 | | Function varies with operation mode | | RW | | #### 17.3 Operations #### 17.3.1 Common Operations # 17.3.1.1 Operating Clock The count source for each timer acts as a clock, controlling such timer operations as counting and reloading. If the conditions to start counting are met, the stopped counter starts counting at the count timing of the first count source. For this reason, a delay exists between when the count start conditions are met and the counter starts counting. Figure 17.4 shows Output Example of One-Shot Timer Mode. Figure 17.4 Output Example of One-Shot Timer Mode #### 17.3.1.2 Counter Reload Timing Timer Ai starts counting from the value set (n) in the TAi register. The TAi register consists of a counter and a reload register. The counter starts decrementing the count source from n, reloads a value in the reload register at the next count source after the value becomes 0000h, and continues decrementing. When incrementing, the counter reloads a value in the reload register at the next count source after the value becomes FFFFh. The value written in the TAi register is reflected in the counter and the reload register at the following timings: - When the count is stopped - Between when the count starts and when the first count source is input A value written to the TAi register is immediately written to the counter and the reload register. - After the count starts and the first count source is input A value written to the TAi register is immediately written to the reload register. The counter continues counting and reloads the value in the reload register at the next count source after the value becomes 0000h (or FFFFh). #### 17.3.1.3 Count Source Internal clocks are counted in timer mode, one-shot timer mode, PWM mode, and programmable output mode. Refer to Figure 17.1 "Timer A and B Count Sources" for details. Table 17.5 lists the Timer A Count Sources. f1 is any of the clocks listed below (refer to 8. "Clock Generator" for details). - Main clock divided by 1 (no division) - PLL clock divided by 1 (no division) - fOCO-S divided by 1 (no division) - fOCO-F divided by 1 (no division) When f1 or the main clock is used for the timer A and timer B count source, set the PCKSTP11 bit in the PCLKSTP1 register to 0 (f1 supply enabled). When the clock mode is PLL operating mode, high-speed mode, medium-speed mode, or wait mode, the main clock can be used for the timer A and timer B count source instead of f1. Use the PCKSTP17 bit in the PCLKSTP1 register to select the clock (refer to 17.2.3 "Peripheral Clock Stop Register 1 (PCLKSTP1)"). When using wait mode, if the CM02 bit in the CM0 register is set to 1 (peripheral function clock f1 stops in wait mode) before entering wait mode, the main clock is also stopped. Therefore, when the PCKSTP17 bit is 1 and timer A or timer B is used while in wait mode, do not set the CM02 bit to 1. Table 17.5 Timer A Count Sources | | | Bit S | Setting Value | | Remarks | |-----------------|-------|-------|-----------------|--------------------|---------------------------------------------------------| | Count<br>Source | PCLK0 | TCS3 | TCS2 to<br>TCS0 | TCK1<br>to<br>TCK0 | | | Source | | TCS7 | TCS6 to<br>TCS4 | | | | f1TIMAB | 1 | 0 | - | 00b | f1 or fOCO-F <sup>(1)</sup> | | TTTIVIAD | ı | 1 | 000b | - | 11 01 10CO-F (1) | | f2TIMAB | 0 | 0 | - | 00b | f1 divided by 2 or fOCO-F divided by 2 <sup>(1)</sup> | | 12 I IIVIAD | | 1 | 000b | - | The divided by 2 of 1000-F divided by 2 (1) | | f8TIMAB | - | 0 | - | 01b | f1 divided by 8 or fOCO-F divided by 8 <sup>(1)</sup> | | IOTIVIAB | | 1 | 001b | - | The divided by 8 of 1000-redivided by 8 Vi | | f32TIMAB | - | 0 | 1 | 10b | f1 divided by 32 or fOCO-F divided by 32 <sup>(1)</sup> | | 132 I IIVIAD | | 1 | 010b | - | The divided by 32 of 1000-F divided by 32 (1) | | f64TIMAB | - | 1 | 011b | - | f1 divided by 64 or fOCO-F divided by 64 (1) | | fOCO-F | - | 1 | 100b | - | fOCO-F | | fOCO-S | - | 1 | 101b | - | fOCO-S | | fC32 | - | 0 | | 11b | fC32 | | 1032 | | 1 | 110b | - | 1002 | PCLK0: Bit in the PCLKR register TCS7 to TCS0: Bits in registers TACS0 to TACS2 TCK1 to TCK0: Bits in the TAiMR register (i = 0 to 4) Note: 1. Set the TCDIV00 bit in the TCKDIVC0 register to select f1 or fOCO-F. When in PLL operating mode, high-speed mode, medium-speed mode, or wait mode, the main clock can be used for the timer A and timer B count source instead of f1. Use the PCKSTP17 bit in the PCLKSTP1 register to select the clock (refer to 17.2.3 "Peripheral Clock Stop Register 1 (PCLKSTP1)"). #### 17.3.2 Timer Mode In timer mode, the timer counts an internally generated count source. Table 17.6 lists Timer Mode Specifications, Table 17.7 lists Registers and the Setting in Timer Mode, and Figure 17.5 shows an Operation Example in Timer Mode. Table 17.6 Timer Mode Specifications | Item | Specification | | | | |-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Count source | f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32 | | | | | Count operation | <ul> <li>Decrement</li> <li>When the timer underflows, it reloads the reload register value and continues counting.</li> </ul> | | | | | Counter cycles | (n + 1) fj n: set value of TAi register, 0000h to FFFFh fj: frequency of count source | | | | | Count start condition | Set the TAiS bit in the TABSR register to 1 (start counting). | | | | | Count stop condition | Set the TAiS bit to 0 (stop counting). | | | | | Interrupt request generation timing | Timer underflow | | | | | TAilN pin function | I/O port or gate input | | | | | TAiOUT pin function | I/O port or pulse output | | | | | Read from timer | The count value can be read by reading the TAi register. | | | | | Write to timer | <ul> <li>When not counting Value written to the TAi register is written to both the reload register and counter.</li> <li>When counting Value written to the TAi register is only written to reload register (transferred to counter when reloaded next).</li> </ul> | | | | | Selectable functions | <ul> <li>Gate function Counting can be started and stopped by an input signal to the TAilN pin.</li> <li>Pulse output function Whenever the timer underflows, the output polarity of the TAiOUT pin is inverted. When the TAiS bit is set to 0 (stop counting), the pin outputs a low-level signal.</li> <li>Output polarity control The output polarity of the TAiOUT pin is inverted. (While the TAiS bit is set to 0 (stop counting), a high-level signal is output.)</li> </ul> | | | | i = 0 to 4 Table 17.7 Registers and Settings in Timer Mode (1) | Register | Bit | Function and Setting | | |----------------|------------------|-------------------------------------------------------------------|--| | PCLKR | PCLK0 | Select the count source. | | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | | PCLKSTP1 | PCKSTP11 | Set to 0 when using f1 or main clock. | | | FOLKSTET | PCKSTP17 | Select the count source. | | | TCKDIVC0 | TCDIV00 | Select the clock used prior to timer AB frequency dividing. | | | PWMFS | PWMFSi | Set to 0. | | | TACS0 to TACS2 | 7 to 0 | Select the count source. | | | TAPOFS | POFSi | Select the output polarity when the MR0 bit in the TAiMR register | | | IAFOFS | POFSI | is 1 (pulse output). | | | TAOW | TAiOW | Set to 0. | | | TAi1 | 15 to 0 | - (does not need to be set) | | | TABSR | TAIS | Set to 1 when starting counting. | | | IABOR | IXIO | Set to 0 when stopping counting. | | | | TAiOS | Set to 0. | | | ONSF | TAZIE | Set to 0. | | | | TA0TGH to TA0TGL | Set to 00b. | | | TRGSR | TAITGH to TAITGL | Set to 00b. | | | UDF | TAiUD | Set to 0. | | | ODF | TAiP | Set to 0. | | | TAi | 15 to 0 | Set the counter value. | | | TAiMR | 7 to 0 | Refer to the TAiMR register below | | i = 0 to 4 Note: 1. This table does not describe a procedure. # TCK1-TCK0 (Count source select bit) (b7-b6) These bits are enabled when the TCS3 bit or TCS7 bit in registers TACS0 to TACS2 is set to 0 (TCK0 to TCK1 enabled). Set the PCLK0 bit in the PCLKR register to select f1TIMAB or f2TIMAB. Figure 17.5 Operation Example in Timer Mode # 17.3.3 Event Counter Mode (When Not Using Two-Phase Pulse Signal Processing) In event counter mode, the timer counts pulses from an external device, or overflows/underflows of other timers. Timers A2, A3, and A4 can count two-phase external signals. Refer to 17.3.4 "Event Counter Mode (When Processing Two-Phase Pulse Signal)" for details. Table 17.8 lists Event Counter Mode Specifications (When Not Using Two-Phase Pulse Signal Processing). Table 17.9 lists Registers and the Setting in Event Counter Mode (When Not Processing Two-Phase Pulse Signal). Figure 17.6 shows Operation Example in Event Counter Mode. Table 17.8 Event Counter Mode Specifications (When Not Using Two-Phase Pulse Signal Processing) | Item | Specification | | | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | • External signals input to the TAilN pin (active edge can be selected) | | | | Count source | Timer B2 overflows or underflows | | | | | • Timer Aj overflows or underflows (j = i - 1, except j = 4 if i = 0) | | | | | • Timer Ak overflows or underflows (k = i + 1, except k = 0 if i = 4) | | | | | • Increment or decrement can be selected by a program. | | | | Count operations | When the timer overflows or underflows, it reloads the reload register value and | | | | Count operations | continues counting. When selecting free-run type, the timer continues counting | | | | | without reloading. | | | | | When selecting reload type: | | | | Number of counts | • FFFFh - n + 1 for increment | | | | Number of counts | •n + 1 for decrement | | | | | n: setting value of the TAi register, 0000h to FFFFh | | | | Count start condition | Set the TAiS bit in the TABSR register to 1 (start counting). | | | | Count stop condition | Set the TAiS bit to 0 (stop counting). | | | | Interrupt request | Timer overflow or underflow | | | | generation timing | | | | | TAiIN pin function | I/O port or count source input | | | | TAiOUT pin function | I/O port or pulse output | | | | Read from timer | Count value can be read by reading the TAi register. | | | | | When not counting | | | | | Value written to the TAi register is written to both the reload register and | | | | Write to timer | counter. | | | | Trino to time. | When counting | | | | | Value written to the TAi register is written to only reload register | | | | | (transferred to counter when reloaded next). | | | | | Free-run count function | | | | | Even when the timer overflows or underflows, the reload register content is not | | | | Selectable functions | reloaded. | | | | | Pulse output function | | | | | Whenever the timer underflows or underflows, the output polarity of the | | | | | TAiOUT pin is inverted. When the TAiS bit is set to 0 (stop counting), the pin | | | | | outputs a low-level signal. | | | | | Output polarity control The state of the TAXOLT size is a state of AM the TAXOLT is a state of the TAXOLT in the TAXOLT in the TAXOLT is a state of the TAXOLT in th | | | | | The output polarity of the TAiOUT pin is inverted. (While the TAiS bit is set to 0 | | | | | (stop counting), a high-level signal is output.) | | | i = 0 to 4 Table 17.9 Registers and Settings in Event Counter Mode (When Not Using Two-Phase Pulse Signal Processing) (1) | Register | Bit | Function and Setting | | | |----------------|------------------|----------------------------------------------------------|--|--| | PCLKR | PCLK0 | - (setting unnecessary) | | | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | | | PCLKSTP1 | PCKSTP11 | - (setting unnecessary) | | | | FOLKSTET | PCKSTP17 | - (setting unnecessary) | | | | TCKDIVC0 | TCDIV00 | - (setting unnecessary) | | | | PWMFS | PWMFSi | Set to 0. | | | | TACS0 to TACS2 | 7 to 0 | - (setting unnecessary) | | | | TAPOFS | POFSi | Select the output polarity when the MR0 bit in the TAiMR | | | | IAFOFS | FOF3i | register is 1 (pulse output). | | | | TAOW | TAiOW | Set to 0. | | | | TAi1 | 15 to 0 | - (setting unnecessary) | | | | TABSR | TAIS | Set to 1 when starting counting. | | | | IADOR | | Set to 0 when stopping counting. | | | | | TAiOS | Set to 0. | | | | ONSF | TAZIE | Set to 0. | | | | | TA0TGH to TA0TGL | Select a count source. | | | | TRGSR | TAiTGH to TAiTGL | Select a count source. | | | | UDF | TAiUD | Select a count operation. | | | | UDF | TAiP | Set to 0. | | | | TAi | 15 to 0 | Set the counter value. | | | | TAiMR | 7 to 0 | Refer to the TAiMR register below. | | | i = 0 to 4 Note: 1. This table does not describe a procedure. ### MR1 (Count polarity select bit) (b3) This bit is enabled when bits TAiTGH to TAiTGL in the ONSF or TRGSR register are 00b (TAilN pin input). Figure 17.6 Operation Example in Event Counter Mode # 17.3.4 Event Counter Mode (When Processing Two-Phase Pulse Signal) Timers A2, A3, and A4 can be used to count two-phase pulse signals. Table 17.10 lists Event Counter Mode Specifications (When Processing Two-Phase Pulse Signal with Timers A2, A3, and A4). Table 17.11 lists Registers and the Setting in Event Counter Mode (When Processing Two-Phase Pulse Signal). Table 17.10 Event Counter Mode Specifications (When Processing Two-Phase Pulse Signal with Timers A2, A3, and A4) | Item | Specification | | | |-----------------------|---------------------------------------------------------------------------------------------------|--|--| | Count source | Two-phase pulse signals input to the TAiIN or TAiOUT pin | | | | | • Increment or decrement can be selected by a two-phase pulse signal. | | | | Count operations | When the timer overflows or underflows, it reloads the reload register value and | | | | | continues counting. When selecting free-run type, the timer continues counting without reloading. | | | | | When selecting reload type: | | | | Number of counts | • FFFFh - n + 1 when incrementing | | | | Number of counts | • n + 1 when decrementing | | | | | n: setting value of the TAi register, 0000h to FFFFh | | | | Count start condition | Set the TAiS bit in the TABSR register to 1 (start counting). | | | | Count stop condition | Set the TAiS bit to 0 (stop counting). | | | | Interrupt request | Timer overflow or underflow | | | | generation timing | Timer overnow or undernow | | | | TAilN pin function | Two-phase pulse input | | | | TAiOUT pin function | Two-phase pulse input | | | | Read from timer | Count value can be read by reading timer A2, A3, or A4 register. | | | | | When not counting | | | | | Value written to the TAi register is written to both the reload register and counter. | | | | Write to timer | When counting | | | | | Value written to the TAi register is written to only reload register | | | | | (transferred to counter when reloaded next). | | | | | Select normal or multiply-by-4 processing operation (timer A3). | | | | Selectable functions | Counter initialization by Z-phase input (timer A3) | | | | | The timer count value is initialized to 0 by Z-phase input. | | | i = 2 to 4 Table 17.11 Registers and Settings in Event Counter Mode (When Processing Two-Phase Pulse Signal) (1) | Register | Bit | Function and Setting | | |----------------|------------------|--------------------------------------------------|--| | PCLKR | PCLK0 | - (setting unnecessary) | | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | | PCLKSTP1 | PCKSTP11 | - (setting unnecessary) | | | FOLKSTET | PCKSTP17 | - (setting unnecessary) | | | TCKDIVC0 | TCDIV00 | - (setting unnecessary) | | | PWMFS | PWMFSi | Set to 0. | | | TACS0 to TACS2 | 7 to 0 | - (setting unnecessary) | | | TAPOFS | POFSi | Set to 0. | | | TAOW | TAiOW | Set to 0. | | | TAi1 | 15 to 0 | - (setting unnecessary) | | | TABSR | TAIS | Set to 1 when starting counting. | | | IADSIN | | Set to 0 when stopping counting. | | | | TAiOS Set to 0. | | | | ONSF | TAZIE | Set to 1 when using Z-phase input with timer A3. | | | | TA0TGH to TA0TGL | - (setting unnecessary) | | | TRGSR | TAITGH to TAITGL | Set to 00b. | | | UDF | TAiUD | Set to 0. | | | ODF | TAiP | Set to 1. | | | TAi | 15 to 0 | Set the counter value. | | | TAiMR | 7 to 0 | Refer to the TAiMR register below. | | i = 2 to 4 Note: 1. This table does not describe a procedure. #### TCK1 (Two-phase pulse signal processing operation type select bit) (b7) The TCK1 bit can be set only for timer A3. No matter how this bit is set, timers A2 and A4 always operate in normal processing mode and multiply-by-4 processing mode, respectively. # 17.3.4.1 Normal Processing The timer increments at rising edges or decrements at falling edges on the TAjIN pin when input signals to the TAjOUT (j = 2, 3) pin is high level. Figure 17.7 Normal Processing ### 17.3.4.2 Multiply-by-4 Processing If the phase relationship is such that the input signal to the TAkIN pin goes high while the input signal to the TAkOUT pin (k = 3, 4) is high, the timer increments at both rising and falling edges of the input signal to pins TAkOUT and TAkIN. If the phase relationship is such that the input signal to the TAkIN pin goes low while the input signal to the TAkOUT pin is high, the timer decrements at both rising and falling edges of the input signal to pins TAkOUT and TAkIN. Figure 17.8 Multiply-by-4 Processing # 17.3.4.3 Counter Initialization Using Two-Phase Pulse Signal Processing This function initializes the timer count value to 0000h using Z-phase (counter initialization) input during two-phase pulse signal processing. This function can only be used in timer A3 event counter mode during two-phase pulse signal processing, free-running type, multiply-by-4 processing, with Z-phase entered from the ZP pin. Counter initialization by Z-phase input is enabled by writing 0000h to the TA3 register and setting the TAZIE bit in the ONSF register to 1 (Z-phase input enabled). Counter initialization is accomplished by Z-phase input edge detection. The rising or falling edge can be selected as the active edge by setting the POL bit in the INT2IC register. The Z-phase pulse width must be equal to or greater than one clock cycle of the timer A3 count source. The counter is initialized at the next count timing after accepting Z-phase input. Figure 17.9 shows the Relationship between the Two-Phase Pulse (A-Phase and B-Phase) and the Z-Phase. When timer A3 overflow or underflow coincides with counter initialization by Z-phase input, a timer A3 interrupt request is generated twice in succession. Do not use the timer A3 interrupt when using this function. Figure 17.9 Relationship between the Two-Phase Pulse (A-Phase and B-Phase) and the Z-Phase ### 17.3.5 One-Shot Timer Mode In one-shot timer mode, the timer is activated only once per trigger. When the trigger occurs, the timer starts and continues operating for a given period. Table 17.12 lists One-Shot Timer Mode Specifications. Table 17.13 lists Registers and the Setting in One-Shot Timer Mode. Figure 17.10 shows Operation Example in One-Shot Timer Mode. Table 17.12 One-Shot Timer Mode Specifications | Item | Specification | | | |-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count source | f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32 | | | | Count operations | <ul> <li>Decrement</li> <li>When the timer counter reaches 0000h, it stops running after the reload register value is reloaded</li> <li>When a trigger occurs while counting, the reload register value is reloaded interpretation to continue counting</li> </ul> | | | | Pulse width | n: Set value of the TAi register, 0000h to FFFFh However, the counter does not run if 0000h is set. fj: Count source frequency | | | | Count start condition | The TAiS bit in the TABSR register is 1 (start counting) and one of the followin triggers occurs: • External trigger input from the TAiIN pin • Timer B2 overflow or underflow • Timer Aj overflow or underflow (j = i - 1, except j = 4 if i = 0) • Timer Ak overflow or underflow (k = i + 1, except k = 0 if i = 4) • The TAiOS bit in the ONSF register is set to 1 (one-shot timer start). | | | | Count stop condition | <ul> <li>When the counter is reloaded after reaching 0000h</li> <li>The TAiS bit is set to 0 (stop counting)</li> </ul> | | | | Interrupt request generation timing | When the counter reaches 0000h | | | | TAilN pin function | I/O port or trigger input | | | | TAiOUT pin function | I/O port or pulse output | | | | Read from timer | An undefined value is read when reading the TAi register. | | | | Write to timer | <ul> <li>When not counting and until the first count source is input after counting starts, the value written to the TAi register is written to both the reload register and counter.</li> <li>When counting (after the first count source input), the value written to the TAi register is written to only the reload register (transferred to the counter when reloaded next time).</li> </ul> | | | | Selectable functions | <ul> <li>Pulse output function The timer outputs a low-level signal when not counting and a high-level signal when counting.</li> <li>Output polarity control The output polarity of the TAiOUT pin is inverted. (While the TAiS bit is set to 0 (stop counting), a high-level signal is output.)</li> </ul> | | | i = 0 to 4 Table 17.13 Registers and Settings in One-Shot Timer Mode (1) | Register | Bit | Setting | | |----------------|---------------------------------------------------------------|-----------------------------------------------------------|--| | PCLKR | PCLK0 | Select the count source. | | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | | PCLKSTP1 | PCKSTP11 | Set to 0 when using f1 or main clock. | | | POLNSTPT | PCKSTP17 | Select the count source. | | | TCKDIVC0 | TCDIV00 | Select a clock used prior to dividing timer AB frequency. | | | PWMFS | PWMFSi | Set to 0. | | | TACS0 to TACS2 | 7 to 0 | Select the count source. | | | TAPOFS | DOES! | Select the output polarity when the MR0 bit in the TAiMR | | | IAPOFS | POFSi | register is 1 (pulse output). | | | TAOW | TAiOW | Set to 0. | | | TAi1 | 15 to 0 | - (setting unnecessary) | | | TABSR | TAIS | Set to 1 when starting counting. | | | IABSK | | Set to 0 when stopping counting. | | | | TAiOS Set to 1 when starting counting while the MR2 bit is 0. | | | | ONSF | TAZIE | Set to 0. | | | | TA0TGH to TA0TGL | Select a count trigger. | | | TRGSR | TAITGH to TAITGL | Select a count trigger. | | | UDF | TAiUD | Set to 0. | | | ODF | TAiP | Set to 0. | | | TAi | 15 to 0 | Set a high-level pulse width. (2) | | | TAiMR | 7 to 0 | Refer to the TAiMR register below. | | i = 0 to 4 ### Notes: - 1. This table does not describe a procedure. - 2. This applies when the POFSi bit in the TAPOFS register is 0. #### MR1 (External trigger select bit) (b3) This bit is enabled when the MR2 bit is 1 and bits TAiTGH to TAiTGL in the ONSF register or TRGSR register are set to 00b (TAilN pin input). #### TCK1 and TCK0 (Count source select bit) (b7-b6) These bits are enabled when the TCS3 bit or TCS7 bit in registers TACS0 to TACS2 is set to 0 (TCK0 to TCK1 enabled). Set the PCLK0 bit in the PCLKR register to select f1TIMAB or f2TIMAB. Figure 17.10 Operation Example in One-Shot Timer Mode # 17.3.6 Pulse Width Modulation (PWM) Mode In PWM mode, the timer outputs pulses of a given width in succession. The counter functions as either a 16-bit pulse width modulator or 8-bit pulse width modulator. Table 17.14 lists PWM Mode Specifications. Table 17.15 lists Registers and the Setting in PWM Mode. Figure 17.11 and Figure 17.12 show Operation Example in 16-Bit Pulse Width Modulation Mode and Operation Example in 8-Bit Pulse Width Modulation Mode, respectively. Table 17.14 PWM Mode Specifications | Item | Specification | | | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count sources | f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32 | | | | Count operations | <ul> <li>Decrement (operating as an 8-bit or a 16-bit pulse width modulator)</li> <li>The timer reloads the reload register value at a rising edge of PWM pulse and continues counting.</li> <li>The timer is not affected by a trigger that occurs during counting.</li> </ul> | | | | 16-bit PWM | • Pulse width $\frac{n}{fj}$ • Cycle time $\frac{(2^{16}-1)}{fj}$ n: set value of the TAi register fj: count source frequency | | | | 8-bit PWM | • Pulse width $\frac{n \times (m+1)}{fj}$ $\xrightarrow{n \times (m+1)}$ $\xrightarrow{(2^8-1)\times (m+1)}$ $\xrightarrow{(2^8-1)\times (m+1)}$ $\xrightarrow{fj}$ m: set value of the TAi register lower address n: set value of the TAi register upper address fj: count source frequency | | | | Count start condition | <ul> <li>The TAiS bit of the TABSR register is set to 1 (start counting).</li> <li>The TAiS bit is 1 and external trigger input from the TAiIN pin</li> <li>The TAiS bit is 1 and one of the following triggers occurs</li></ul> | | | | Count stop condition | The TAiS bit is set to 0 (stop counting). | | | | Interrupt request generation timing | On the falling edge of the PWM pulse | | | | TAilN pin function | I/O port or trigger input | | | | TAiOUT pin function | Pulse output | | | | Read from timer | An undefined value is read when reading the TAi register. | | | | Write to timer | <ul> <li>When not counting Value written to the TAi register is written to both the reload register and counter.</li> <li>When counting Value written to the TAi register is written to only the reload register (transferred to counter when reloaded next time).</li> </ul> | | | | Selectable functions | Output polarity control The output polarity of the TAiOUT pin is inverted. (While the TAiS bit is set to 0 (stop counting), a high-level signal is output). | | | i = 0 to 4 Table 17.15 Registers and Settings in PWM Mode (1) | Register | Bit | Setting | | |-----------------|------------------|-------------------------------------------------------------|--| | PCLKR | PCLK0 | Select the count source. | | | CPSRF CPSR | | Write 1 to reset the clock prescaler. | | | PCLKSTP1 | PCKSTP11 | Set to 0 when using f1 or main clock. | | | FOLKSIFI | PCKSTP17 | Select the count source. | | | TCKDIVC0 | TCDIV00 | Select the clock used prior to dividing timer AB frequency. | | | PWMFS | PWMFSi | Set to 0. | | | TACS0 to TACS2 | 7 to 0 | Select the count source. | | | TAPOFS | POFSi | Select the output polarity. | | | TAOW | TAiOW | Set to 0. | | | TAi1 | 15 to 0 | - (setting unnecessary) | | | TABSR | TAiS | Set to 1 when starting counting. | | | IADSIN | | Set to 0 when stopping counting. | | | TAiOS Set to 0. | | Set to 0. | | | ONSF | TAZIE | Set to 0. | | | | TA0TGH to TA0GL | Select a count trigger. | | | TRGSR | TAITGH to TAITGL | Select a count trigger. | | | UDF | TAiUD | Set to 0. | | | ODF | TAiP | Set to 0. | | | TAi | 15 to 0 | Select the PWM pulse width and cycles. | | | TAiMR | 7 to 0 | Refer to the TAiMR register below. | | i = 0 to 4 Note: 1. This table does not describe a procedure. ### MR1 (External trigger select bit) (b3) This bit is enabled when the MR2 bit is 1, and bits TAiTGH to TAiTGL in the ONSF register or TRGSR register are set to 00b (TAiIN pin input). #### TCK1 and TCK0 (Count source select bit) (b7-b6) These bits are enabled when the TCS3 bit or TCS7 bit in registers TACS0 to TACS2 is set to 0 (TCK0 to TCK1 enabled). Set the PCLK0 bit in the PCLKR register to select f1TIMAB or f2TIMAB. Figure 17.11 Operation Example in 16-Bit Pulse Width Modulation Mode Figure 17.12 Operation Example in 8-Bit Pulse Width Modulation Mode # 17.3.7 Programmable Output Mode (Timers A1, A2, and A4) In programmable output mode, the timer outputs low- and high-levels of pulse width successively. Table 17.16 lists Programmable Output Mode Specifications. Table 17.17 lists Registers and the Setting in Programmable Output Mode. Figure 17.13 shows Operation Example in Programmable Output Mode. **Table 17.16 Programmable Output Mode Specifications** | Item | Specification | | | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count sources | f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32 | | | | Count operations | <ul> <li>Decrement</li> <li>The timer reloads the reload register value at the rising edge of pulse and continues counting</li> <li>When a trigger occurs while counting, the timer is not affected.</li> </ul> | | | | Pulse width | • High-level pulse width $\frac{m}{fj}$ • Low-level pulse width $\frac{n}{fj}$ m: set value of the TAi register n: set value of the TAi1 register | | | | | fj: count source frequency | | | | Count start conditions | <ul> <li>The TAiS bit of the TABSR register is set to 1 (start counting).</li> <li>The TAiS bit is 1 and external trigger input from the TAiIN pin</li> <li>The TAiS bit is 1 and one of the following external triggers occurs: Timer B2 overflow or underflow Timer Aj overflow or underflow (j = i - 1) Timer Ak overflow or underflow (k = i + 1, except k = 0 if i = 4)</li> </ul> | | | | Count stop condition | The TAiS bit is set to 0 (stop counting). | | | | Interrupt request generation timing | At the rising edge of pulse | | | | TAiIN pin function | I/O port or trigger input | | | | TAiOUT pin function | Pulse output | | | | Read from timer | An undefined value is read when reading registers TAi and TAi1. | | | | Write to timer | <ul> <li>When writing to registers TAi and TAi1 while not counting, the value is written to both reload register and counter.</li> <li>When writing to registers TAi and TAi1 while counting, the value is written to the reload register. (transferred to the counter when reloaded next time).</li> </ul> | | | | Selectable functions | Output polarity control The output polarity of the TAiOUT pin is inverted. (While the TAiS bit is set to 0 (stop counting), a high-level signal is output.) | | | i = 1, 2, and 4 Table 17.17 Registers and Settings in Programmable Output Mode (1) | Register | Bit | Function and Setting | | |-----------------|------------------|-------------------------------------------------------------|--| | PCLKR | PCLK0 | Select the count source. | | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | | PCLKSTP1 | PCKSTP11 | Set to 0 when using f1 or main clock. | | | FOLKSTET | PCKSTP17 | Select the count source. | | | TCKDIVC0 | TCDIV00 | Select a clock used prior to dividing timer AB frequency. | | | PWMFS | PWMFSi | Set to 1. | | | TACS0 to TACS2 | 7 to 0 | Select the count source. | | | TAPOFS | POFSi | Select the output polarity. | | | TAOW | TAiOW | Set to 0 to disable output waveform change, and set to 1 to | | | IAOW | | enable output waveform change. | | | TAi1 | 15 to 0 | Set a low-level pulse width. (2) | | | TABSR | TAIS | Set to 1 when starting counting. | | | IADOK | | Set to 0 when stopping counting. | | | TAiOS Set to 0. | | Set to 0. | | | ONSF | TAZIE | Set to 0. | | | | TA0TGH to TA0TGL | Select a count trigger. | | | TRGSR | TAITGH to TAITGL | Select a count trigger. | | | UDF | TAiUD | Set to 0. | | | | TAiP | Set to 0. | | | TAi | 15 to 0 | Set a high-level pulse width. (2) | | | TAiMR | 7 to 0 | Refer to the TAiMR register below. | | i = 1, 2, and 4 #### Notes: - 1. This table does not describe a procedure. - 2. This applies when the POFSi bit in the TAPOFS register is 0. ### MR1 (External trigger select bit) (b3) This bit is enabled when the MR2 bit is 1, and bits TAiTGH to TAiTGL in the ONSF register or TRGSR register are set to 00b (TAiIN pin input). # TCK1 and TCK0 (Count source select bit) (b7-b6) These bits are enabled when the TCS3 bit or TCS7 bit in registers TACS0 to TACS2 is set to 0 (TCK0 to TCK1 enabled). Set the PCLK0 bit in the PCLKR register to select f1TIMAB or f2TIMAB. Figure 17.13 Operation Example in Programmable Output Mode ### 17.4 Interrupts Refer to individual operation examples for interrupt request generating timing. Refer to 14.7 "Interrupt Control" for details of interrupt control. Table 17.18 lists Timer A Interrupt Related Registers. Table 17.18 Timer A Interrupt Related Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------------|--------|-------------| | 0055h | Timer A0 Interrupt Control Register | TA0IC | XXXX X000b | | 0056h | Timer A1 Interrupt Control Register | TA1IC | XXXX X000b | | 0057h | Timer A2 Interrupt Control Register | TA2IC | XXXX X000b | | 0058h | Timer A3 Interrupt Control Register | TA3IC | XXXX X000b | | 0059h | Timer A4 Interrupt Control Register | TA4IC | XXXX X000b | The IR bit in the TAiIC register may become 1 (interrupt requested) when the TMOD1 bit in the TAiMR register is changed from 0 to 1 (change from timer mode or event counter mode to one-shot timer mode, PWM mode, or programmable output mode). Make sure to follow the procedure below when setting the TMOD1 bit to 1. Refer to 14.13 "Notes on Interrupts" for details. - (1) Set bits ILVL2 to ILVL0 in the TAilC register to 000b (interrupt disabled). - (2)Set the TAiMR register. - (3) Set the IR bit in the TAilC register to 0 (interrupt not requested). #### 17.5 Notes on Timer A #### 17.5.1 Common Notes on Multiple Modes #### 17.5.1.1 Register Setting The timer stops after reset. Set the mode, count source, counter value, etc., using registers TAiMR, TAi, TAi1, UDF, TRGSR, PWMFS, TACS0 to TACS2, TAPOFS, TCKDIVC0, PCLKR, and bits TAZIE, TA0TGL, and TA0TGH in the ONSF register before setting the TAiS bit in the TABSR register to 1 (count started) (i = 0 to 4). Set the TCDIV00 bit in the TCKDIVC0 register before setting other registers associated with timer A. After changing the TCDIV00 bit, set other registers associated with timer A again. Always make sure registers TAiMR, UDF, TRGSR, PWMFS, TACS0 to TACS2, TAPOFS, TCKDIVC0, PCLKR, and bits TAZIE, TA0TGL, TA0TGH in the ONSF register are modified while the TAiS bit is 0 (count stopped), regardless of whether after reset or not. #### 17.5.1.2 Event or Trigger When bits TAiTGH to TAiTGL in the registers ONSF or TRGSR are 01b, 10b, or 11b, an event or a trigger occurs when an interrupt request of the selected timer is generated. An event or trigger occurs while an interrupt is disabled because an interrupt request signal is generated regardless of the I flag, IPL, or interrupt control registers. For some modes of the timers selected using bits TAiTGH to TAiTGL, an interrupt request is generated by a source other than overflow or underflow. For example, when using pulse-period measurement mode or pulse-width measurement mode in timer B2, an interrupt request is generated at an active edge of the measurement pulse. For details, refer to the "Interrupt request generation timing" in each mode's specification table. #### 17.5.1.3 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/ $\overline{CTS2}/\overline{RTS2}/\overline{TA1IN/V}$ , P7\_4/TA2OUT/W, P7\_5/TA2IN/W, P8\_0/TA4OUT/RXD5/SCL5/U, P8\_1/TA4IN/CTS5/RTS5/U #### 17.5.1.4 Main Clock When using the main clock for the timer A and timer B count source (PCKSTP17 bit in the PCLKSTP1 register is 1), adhere the following: - Set the PCKSTP11 bit in the PCLKSTP1 register to 0 (f1 supply enabled). - The main clock can be used in PLL operating mode, high-speed mode, medium-speed mode, or wait mode. Do not use the main clock for the timer A and timer B count source in other modes. - When the PCKSTP17 bit is set to 1 and timer A or timer B operates in wait mode, set the CM02 bit to 0 (peripheral function clock f1 does not stop in wait mode). # 17.5.2 Timer A (Timer Mode) ### 17.5.2.1 Reading the Timer The counter value can be read from the TAi register at any time while counting. However, if the counter is read at the same time as it is reloaded, the read value is FFFFh. Also, if the counter is read before it starts counting, or after a value is set in the TAi register while not counting, the set value is read. # 17.5.3 Timer A (Event Counter Mode) ### 17.5.3.1 Reading the Timer While counting, the counter value can be read at any time by reading the TAi register. However, while reloading, FFFFh can be read in underflow, and 0000h in overflow. When the counter is read before it starts counting and after a value is set in the TAi register while not counting, the set value is read. ### 17.5.4 Timer A (One-Shot Timer Mode) ### 17.5.4.1 Stop While Counting When setting the TAiS bit to 0 (count stopped), the following occurs: - The counter stops counting and reload register values are reloaded. - The TAiOUT pin outputs a low-level signal when the POFSi bit in the TAPOFS register is 0, and outputs a high-level signal when it is 1. - After one cycle of the CPU clock, the IR bit in the TAilC register becomes 1 (interrupt requested). #### 17.5.4.2 Delay between the Trigger Input and Timer Output As the one-shot timer output is synchronized with an internally generated count source, when an external trigger is selected, a maximum 1.5 cycle delay of the count source occurs between the trigger input to the TAilN pin and timer output. #### 17.5.4.3 Changing Operating Modes The IR bit becomes 1 when the timer operating mode is set by any of the following: - Selecting one-shot timer mode after reset - Changing the operating mode from timer mode to one-shot timer mode - Changing the operating mode from event counter mode to one-shot timer mode To use the timer Ai interrupt (IR bit), set the IR bit to 0 after the changes listed above are made. #### 17.5.4.4 Retrigger When a trigger occurs while counting, the counter reloads the reload register to continue counting after generating a retrigger and decrementing once. To generate a trigger while counting, generate a retrigger after at least one cycle of the timer count source has elapsed following the previous trigger. When an external trigger is generated, do not generate a retrigger for 300 ns before the count value becomes 0000h. The one-shot timer may stop counting. # 17.5.5 Timer A (Pulse Width Modulation Mode) # 17.5.5.1 Changing Operating Modes The IR bit becomes 1 when setting a timer operating mode with any of the following: - Selecting PWM mode or programmable output mode after reset - Changing the operating mode from timer mode to PWM mode or programmable output mode - Changing the operating mode from event counter mode to PWM mode or programmable output mode To use the timer Ai interrupt (IR bit), set the IR bit to 0 by a program after the changes listed above are made. ### 17.5.5.2 Stop While Counting When setting the TAiS bit to 0 (count stopped) during PWM pulse output, the following occur: When the POFSi bit in the TAPOFS register is 0: - Counting stops - When the TAiOUT pin is high, the output level goes low and the IR bit becomes 1. - When the TAiOUT pin is low, both the output level and the IR bit remain unchanged. When the POFSi bit in the TAPOFS register is 1: - · Counting stops. - When the TAiOUT pin output is low, the output level goes high and the IR bit is set to 1. - When the TAiOUT pin output is high, both the output level and the IR bit remain unchanged. # 17.5.6 Timer A (Programmable Output Mode) ### 17.5.6.1 Changing the Operating Mode The IR bit becomes 1 when setting a timer operating mode with any of the following: - Selecting PWM mode or programmable output mode after reset - Changing the operating mode from timer mode to PWM mode or programmable output mode - Changing the operating mode from event counter mode to PWM mode or programmable output mode To use the timer Ai interrupt (IR bit), set the IR bit to 0 by a program after the changes listed above are made. ### 17.5.6.2 Stop While Counting When setting the TAiS bit to 0 (count stopped) during pulse output, the following occur: When the POFSi bit in the TAPOFS register is 0: - · Counting stops. - When the TAiOUT pin is high, the output level goes low. - When the TAiOUT pin is low, the output level remains unchanged. - The IR bit remains unchanged. When the POFSi bit in the TAPOFS register is 1: - Counting stops - When the TAiOUT pin output is low, the output level goes high. - When the TAiOUT pin output is high, the output level remains unchanged. - The IR bit remains unchanged. ### 18. Timer B #### 18.1 Introduction Timer B consists of timers B0 to B5. Each timer operates independently of the others. Table 18.1 lists Timer B Specifications, Figure 18.1 shows Timer A and B Count Sources, Figure 18.2 shows the Timer B Configuration, Figure 18.3 shows the Timer B Block Diagram, and Table 18.2 lists the I/O Ports. Table 18.1 Timer B Specifications | Item | Specification | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Configuration | 16-bit timer × 6 | | | Operating modes | <ul> <li>Timer mode The timer counts an internal count source. </li> <li>Event counter mode The timer counts pulses from an external device, or overflows and underflows of other timers. </li> <li>Pulse period/pulse width measurement modes The timer measures pulse periods or pulse widths of an external signal. </li> </ul> | | | Interrupt source | Overflow/underflow/active edge of measurement pulse × 6 | | Figure 18.1 Timer A and B Count Sources Figure 18.2 Timer B Configuration Figure 18.3 Timer B Block Diagram Table 18.2 I/O Ports | Pin Name | I/O | Function | |----------|----------------------|-------------------------------------------------------------------------------------------------------------------------------| | TBilN | Input <sup>(1)</sup> | Count source input (event counter mode) Measurement pulse input (pulse period measurement mode, pulse width measurement mode) | i = 0 to 5 Note: 1. When using the TBilN pin for input, set the port direction bit sharing the same pin to 0 (input mode). # 18.2 Registers Table 18.3 lists registers associated with timer B. Set the TCDIV00 bit in the TCKDIVC0 register before setting other registers associated with timer B. After changing the TCDIV00 bit, set other registers associated with timer B again. Refer to "registers and the setting" in each mode for registers and bit settings. Table 18.3 Registers | Address | Register | Symbol | Reset Value | |---------|----------------------------------------------------------------------|----------|-------------| | 0012h | Peripheral Clock Select Register | PCLKR | 0000 0011b | | 0015h | Clock Prescaler Reset Flag | CPSRF | 0XXX XXXXb | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 01C0h | Timer DO 4 Degister | TD04 | XXh | | 01C1h | - Timer B0-1 Register | TB01 | XXh | | 01C2h | Timer D4 4 Decister | TB11 | XXh | | 01C3h | - Timer B1-1 Register | IDII | XXh | | 01C4h | Timor P2 1 Pogistor | TB21 | XXh | | 01C5h | - Timer B2-1 Register | IDZI | XXh | | 01C6h | Pulse Period/Pulse Width Measurement Mode Function Select Register 1 | PPWFS1 | XXXX X000b | | 01C8h | Timer B Count Source Select Register 0 | TBCS0 | 00h | | 01C8h | Timer B Count Source Select Register 1 | TBCS1 | X0h | | 01C9h | Timer AB Division Control Register 0 | TCKDIVC0 | 0000 X000b | | 01E0h | Timer AB Division Control Register 0 | TCKDIVCO | XXh | | 01E1h | Timer B3-1 Register | TB31 | XXh | | 01E111 | | | XXh | | 01E3h | Timer B4-1 Register | TB41 | XXh | | 01E4h | | | XXh | | 01E5h | Timer B5-1 Register | TB51 | XXh | | OTESII | Pulse Period/Pulse Width Measurement | | AAH | | 01E6h | Mode Function Select Register 2 | PPWFS2 | XXXX X000b | | 01E8h | Timer B Count Source Select Register 2 | TBCS2 | 00h | | 01E9h | Timer B Count Source Select Register 3 | TBCS3 | X0h | | 0300h | Timer B3/B4/B5 Count Start Flag | TBSR | 000X XXXXb | | 0310h | - Timer B3 Register | TB3 | XXh | | 0311h | - Timer bo Register | 100 | XXh | | 0312h | - Timer B4 Register | TB4 | XXh | | 0313h | Timer by Register | 104 | XXh | | 0314h | Timer B5 Register | TB5 | XXh | | 0315h | | | XXh | | 031Bh | Timer B3 Mode Register | TB3MR | 00XX 0000b | | 031Ch | Timer B4 Mode Register | TB4MR | 00XX 0000b | | 031Dh | Timer B5 Mode Register | TB5MR | 00XX 0000b | | 0320h | Count Start Flag | TABSR | 00h | | 0330h | Timer B0 Register | TB0 | XXh | | 0331h | Timor Do Register | 150 | XXh | | 0332h | Timer B1 Register | TB1 | XXh | | 0333h | Times of Register | 101 | XXh | | 0334h | - Timer B2 Register | TB2 | XXh | | 0335h | - | | XXh | | 033Bh | Timer B0 Mode Register | TB0MR | 00XX 0000b | | 033Ch | Timer B1 Mode Register | TB1MR | 00XX 0000b | | 033Dh | Timer B2 Mode Register | TB2MR | 00XX 0000b | # 18.2.1 Peripheral Clock Select Register (PCLKR) Write to the PCLKR register after setting the PRC0 bit in the PRCR register to 1 (write enabled). # 18.2.2 Clock Prescaler Reset Flag (CPSRF) # 18.2.3 Peripheral Clock Stop Register 1 (PCLKSTP1) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register #### PCKSTP11 (Timer peripheral clock stop bit) (b1) When using f1 or the main clock for the timer A and timer B count source, set the PCKSTP11 bit to 0 (f1 provide enabled). To change the PCKSTP11 bit from 1 (f1 provide disabled) to 0, use following procedure: - (1) Stop timer A and timer B. - (2) Set the PCKSTP11 bit to 0. - (3) Set the registers for timer A and timer B again. To change the timer A and timer B count source from fOCO-F to f1, perform (1) and (2) above, and set the TCDIV00 bit in the TCKDIVC0 register from 1 (fOCO-F) to 0 (f1), then perform (3). #### PCKSTP17 (Timer clock source select bit) (b7) Change the PCKSTP17 bit when all of the following conditions are met: - Both f1 and the main clock are stably supplied. - Both timer A and timer B are stopped. The PCKSTP17 bit is used for supplying the main clock to timer A and timer B. When in PLL operating mode, high-speed mode, medium-speed mode, or wait mode, the main clock can be used for the timer A and timer B count source. Do not use the main clock for the timer A and timer B count source in other normal operating modes (refer to 9.3 "Clock"). ## 18.2.4 Timer Bi Register (TBi) (i = 0 to 5) Access this register in 16-bit units. #### **Event Counter Mode** The timer counts pulses from an external device, or overflows or underflows of other timers. #### Pulse Period Measurement Mode, Pulse Width Measurement Mode Set these modes when the TBiS bit in the TABSR or TBSR register is 0 (count stopped). These modes become read only (RO) when the TBiS bit in the TABSR or TBSR register is 1 (count started). The counter starts counting the count source at an active edge of the measurement pulse, transfers the count value to a register at the next active edge, and continues counting. The measurement result can be read by reading the TBi register when bits PPWFS12 to PPWFS10 in the PPWFS1 register and bits PPWFS22 to PPWFS20 in the PPWFS2 register are 0. While counting, the counter value can be read by reading the TBi register when bits PPWFS12 to PPWFS10 and bits PPWFS22 to PPWFS20 are 1. ## 18.2.5 Timer Bi-1 Register (TBi1) (i = 0 to 5) Access this register in 16-bit units. When bits PPWFS12 to PPWFS10 in the PPWFS1 register and bits PPWFS22 to PPWFS20 in the PPWFS2 register are 1, the measurement result can be read by reading the TBi-1 register. When these bits are 0, the value in this register is undefined. # 18.2.6 Pulse Period/Pulse Width Measurement Mode Function Select Register i (PPWFSi) (i = 1, 2) #### Pulse Period/Pulse Width Measurement Mode Function Select Register 1 Symbol Address Reset Value PPWFS1 XXXX X000b 01C6h Bit Symbol RW Bit Name **Function** 0: Measurement result is stored in the TB0 register. The TB01 register is not used Timer B0 pulse period/pulse PPWFS10 The counter value is read from the TB0 register. RW width measurement mode function select bit Measurement result is stored in the TB01 register 0: Measurement result is stored in the TB1 register. Timer B1 pulse period/pulse The TB11 register is not used PPWFS11 The counter value is read from the TB1 register. Measurement result is stored width measurement mode RW function select bit in the TB11 register 0: Measurement result is stored in the TB2 register. Timer B2 pulse period/pulse The TB21 register is not used PPWFS12 width measurement mode The counter value is read RW from the TB2 register. function select bit Measurement result is stored in the TB21 register No register bits. If necessary, set to 0. The read value is undefined. (b7-b3) ## Pulse Period/Pulse Width Measurement Mode Function Select Register 2 Enabled in pulse period measurement mode or pulse width measurement mode. ## 18.2.7 Timer B Count Source Select Register i (TBCSi) (i = 0 to 3) TBCS0 register: i = 0, j = 1; TBCS2 register: i = 3, j = 4 #### Timer B Count Source Select Register 1, Timer B Count Source Select Register 3 TCS2-TCS0 (TBi count source select bit) (b2-b0) TCS6-TCS4 (TBj count source select bit) (b6-b4) Select f1TIMAB or f2TIMAB by setting the PCLK0 bit in the PCLKR register. # 18.2.8 Timer AB Division Control Register 0 (TCKDIVC0) ## TCDIV00 (Clock select prior to timer AB division bit) (b0) Set the TCDIV00 bit while timers A and B are stopped. Set the TCDIV00 bit before setting other registers associated with timer B. After changing the TCDIV00 bit, set other registers associated with timer B again. # 18.2.9 Count Start Flag (TABSR) Timer B3/B4/B5 Count Start Flag (TBSR) # 18.2.10 Timer Bi Mode Register (TBiMR) (i = 0 to 5) | 57 b6 b5 b4 b3 b2 b1 b0 | Symbo<br>TB0MR to T<br>TB3MR to T | B2MR 033 | Address<br>Bh to 033Dh<br>Bh to 031Dh | Reset Value<br>00XX 0000b<br>00XX 0000b | |-------------------------|-----------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------| | | Bit Symbol | Bit Name | Function | RW | | <u></u> | TMOD0 | Operation made coloct hit | b1 b0<br>0 0: Timer mode<br>0 1: Event counter mode | RW | | | TMOD1 | Operation mode select bit | 0 : Pulse period measurement mode Pulse width measurement mode 1 1 : Do not set | | | | MR0 | | | | | | MR1 | Function varies with the opera | ation mode | RW | | | (b4) | No register bit. If necessary, | et to 0. The read value is unde | fined. — | | | MR3 | Function varies with the opera | ation mode | RO | | | TCK0 | | | RW | | TCK1 | | Count source select bit (function varies with the operation mode) | | ode) | ## 18.3 Operations ## 18.3.1 Common Operations #### 18.3.1.1 Operating Clock The count source for each timer acts as a clock, controlling such timer operations as counting and reloading. ## 18.3.1.2 Counter Reload Timing Timer Bi starts counting from the value (n) set in the TBi register. The TBi register consists of a counter and a reload register. The counter starts decrementing the count source from n, reloads a value in the reload register at the next count source after the value becomes 0000h, and continues decrementing. The value written in the TBi register is reflected in the counter and the reload register at the following timings. - When the count is stopped - Between when the count starts and the first count source is input The value written to the TBi register is immediately written to the counter and the reload register. - After the count starts and the first count source is input The value written to the TBi register is immediately written to the reload register. The counter continues counting and reloads the value in the reload register at the next count source after the value becomes 0000h. #### 18.3.1.3 **Count Source** Internal clocks are counted in timer mode, pulse period measurement mode, and pulse width measurement mode. Refer to Figure 18.1 "Timer A and B Count Sources" for details. Table 18.4 lists Timer B Count Sources. f1 is any of the clocks listed below. Refer to 8. "Clock Generator" for details. - Main clock divided by 1 (no division) - PLL clock divided by 1 (no division) - fOCO-S divided by 1 (no division) - fOCO-F divided by 1 (no division) When f1 or the main clock is used for the timer A and timer B count source, set the PCKSTP11 bit in the PCLKSTP1 register to 0 (f1 supply enabled). When the clock mode is PLL operating mode, high-speed mode, medium-speed mode, or wait mode, the main clock can be used for the timer A and timer B count source instead of f1. Use the PCKSTP17 bit in the PCLKSTP1 register to select the clock (refer to 18.2.3 "Peripheral Clock Stop Register 1 (PCLKSTP1)"). When using wait mode, if the CM02 bit in the CM0 register is set to 1 (peripheral function clock f1 stops in wait mode) before entering wait mode, the main clock is also stopped. Therefore, when the PCKSTP17 bit is 1 and timer A or timer B is used while in wait mode, do not set the CM02 bit to 1. Table 18.4 Timer B Count Sources | Count | Bit Setting Value | | | | | |--------------|-------------------|------|--------------|-------------------------------------------------------|---------------------------------------------------------| | Source | PCLK0 | TCS3 | TCS2 to TCS0 | TCK1 to | Remarks | | Source | Source PCLKO | | TCS6 to TCS4 | TCK0 | | | f1TIMAB | 1 | 0 | - | 00b | f1 or fOCO-F <sup>(1)</sup> | | TTTIVIAD | ' | 1 | 000b | - | 11 01 1000-F (1) | | f2TIMAB | 0 | 0 | - | 00b | f1 divided by 2 or fOCO-F divided by 2 <sup>(1)</sup> | | IZTIMAD | | 1 | 000b | - | The divided by 2 of 1000-F divided by 2 (1) | | f8TIMAB - | 0 | - | 01b | f1 divided by 8 or fOCO-F divided by 8 <sup>(1)</sup> | | | | _ | 1 | 001b | - | The divided by 8 of 1000-F divided by 8 Vi | | f32TIMAB | _ | 0 | - | 10b | f1 divided by 32 or fOCO-F divided by 32 (1) | | 132 I IIVIAD | - | 1 | 010b | - | 11 divided by 32 of 10CO-r divided by 32 (1) | | f64TIMAB | - | 1 | 011b | - | f1 divided by 64 or fOCO-F divided by 64 <sup>(1)</sup> | | fOCO-F | - | 1 | 100b | - | fOCO-F | | fOCO-S | - | 1 | 101b | - | fOCO-S | | fC32 | - | 0 | - | 11b | fC32 | | 1032 | | 1 | 110b | - | 1032 | PCLK0: Bit in the PCLKR register TCS7 to TCS0: Bits in registers TBCS0 to TBCS3 TCK1 to TCK0: Bits in the TBiMR register (i = 0 to 5) Note: 1. Select f1 or fOCO-F by setting the TCDIV00 bit in the TCKDIVC0 register. When in PLL operating mode, high-speed mode, medium-speed mode, or wait mode, the main clock can be used for the timer A and timer B count source instead of f1. Use the PCKSTP17 bit in the PCLKSTP1 register to select the clock (refer to 18.2.3 "Peripheral Clock Stop Register 1 (PCLKSTP1)"). #### 18.3.2 Timer Mode In timer mode, the timer counts an internally generated count source. Table 18.5 lists Timer Mode Specifications, Table 18.6 lists Registers and Setting in Timer Mode, and Figure 18.4 shows an Operation Example in Timer Mode. Table 18.5 Timer Mode Specifications | Item | Specification | | | | |-----------------------|--------------------------------------------------------------------------------------|--|--|--| | Count sources | f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32 | | | | | | Decrement | | | | | Count operations | • When the timer underflows, it reloads the reload register value and continues | | | | | | counting. | | | | | | | | | | | Counter cycles | (n+1) | | | | | | n: setting value of the TBi register 0000h to FFFFh | | | | | Count start condition | Set the TBiS bit to 1 (start counting). | | | | | Count stop condition | Set the TBiS bit to 0 (stop counting). | | | | | Interrupt request | Timer underflow | | | | | generation timing | Time: unuemow | | | | | TBiIN pin function | I/O port | | | | | Read from timer | Count value can be read by reading the TBi register. | | | | | | When not counting | | | | | | The value written to the TBi register is written to both the reload register and the | | | | | Write to timer | counter. | | | | | | When counting | | | | | | The value written to the TBi register is only written to the reload register | | | | | | (transferred to the counter when reloaded next). | | | | i = 0 to 5 TBiS: Bit in the TABSR or TBSR register Table 18.6 Registers and Settings in Timer Mode (1) | Davista | D'i | 5 | |----------------|------------|-------------------------------------------------------------| | Register | Bit | Function and Setting | | PCLKR | PCLK0 | Select the count source. | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | PCLKSTP1 | PCKSTP11 | Set to 0 when using f1 or main clock. | | POLNSTET | PCKSTP17 | Select the count source. | | TBi1 | 15 to 0 | - (setting unnecessary) | | | PPWFS12 to | | | PPWFS1 to | PPWFS10 | 00440 | | PPWFS2 | PPWFS22 to | Set to 0. | | | PPWFS20 | | | TCKDIVC0 | TCDIV00 | Select the clock used prior to timer AB frequency dividing. | | TBCS0 to TBCS3 | 7 to 0 | Select the count source. | | TABSR | TBiS | Set to 1 when starting counting. | | TBSR | IDIO | Set to 0 when stopping counting. | | TBi | 15 to 0 | Set the count value. | | TBiMR | 7 to 0 | Refer to the TBiMR register below. | i = 0 to 5 Note: 1. This table does not describe a procedure. ## TCK1 and TCK0 (Count source select bit) (b7-b6) These bits are enabled when the TCS3 or TCS7 bit in registers TBCS0 to TBCS3 is set to 0 (bits TCK0 to TCK1 enabled). Select f1TIMAB or f2TIMAB by the PCLK0 bit in the PCLKR register. Figure 18.4 Operation Example in Timer Mode #### 18.3.3 Event Counter Mode In event counter mode, the timer counts pulses from an external device, or overflows and underflows of other timers. Table 18.7 lists Event Counter Mode Specifications, Table 18.8 lists Registers and Settings in Event Counter Mode, and Figure 18.5 shows an Operation Example in Event Counter Mode. **Table 18.7 Event Counter Mode Specifications** | Item | Specification | | | | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Count sources | <ul> <li>External signals input to TBilN pin (active edge can be selected by a program: rising edge, falling edge, or both rising and falling edges)</li> <li>Timer Bj overflow or underflow</li> </ul> | | | | | Count operations | <ul> <li>Decrement</li> <li>When the timer underflows, it reloads the reload register value and continues counting.</li> </ul> | | | | | Number of counts | $\frac{1}{(n+1)}$ n: setting value of the TBi register 0000h to FFFFh | | | | | Count start condition | Set the TBiS bit to 1 (start counting). | | | | | Count stop condition | Set the TBiS bit to 0 (stop counting). | | | | | Interrupt request generation timing | Timer underflow | | | | | TBiIN pin function | Count source input | | | | | Read from timer | Count value can be read by reading the TBi register. | | | | | Write to timer | <ul> <li>When not counting The value written to the TBi register is written to both the reload register and the counter.</li> <li>When counting The value written to the TBi register is written to only reload register (transferred to counter when reloaded next).</li> </ul> | | | | i = 0 to 5 j = i - 1, except j = 2 if i = 0; j = 5 if i = 3 TBiS: Bit in the TABSR or TBSR register Table 18.8 Registers and Settings in Event Counter Mode (1) | Register | Bit | Function and Setting | | |----------------|--------------------|---------------------------------------|--| | PCLKR | PCLK0 | - (setting unnecessary) | | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | | PCLKSTP1 | PCKSTP11 | - (setting unnecessary) | | | FOLKSTET | PCKSTP17 | - (setting unnecessary) | | | TBi1 | 15 to 0 | - (setting unnecessary) | | | PPWFS1 to | PPWFS12 to PPWFS10 | Set to 0. | | | PPWFS2 | PPWFS22 to PPWFS20 | | | | TCKDIVC0 | TCDIV00 | - (setting unnecessary) | | | TBCS0 to TBCS3 | 7 to 0 | - (setting unnecessary) | | | TABSR | TBiS | Set to 1 when starting counting. | | | TBSR | 100 | Set to 0 when stopping counting. | | | TBi | 15 to 0 | Set the count value. | | | TBiMR | 7 to 0 | Refer to the TBiMR register below. | | i = 0 to 5 Note: 1. This table does not describe a procedure. ## MR1 and MR0 (Count polarity select bit) (b3-b2) These bits are enabled when the TCK1 bit is 0 (input from TBiIN pin). When the TCK1 bit is 1 (timer Bj), these bits can be set to 0 or 1. ## TCK1 (Event clock select bit) (b7) When the TCK1 bit is 1, an event occurs when an interrupt request of timer Bj (j = i - 1; however, j = 2 if i = 0, j = 5 if i = 3) is generated. An event occurs while an interrupt is disabled because an interrupt request signal is generated regardless of the I flag, IPL, or interrupt control registers Figure 18.5 Operation Example in Event Counter Mode #### 18.3.4 Pulse Period/Pulse Width Measurement Modes In pulse period and pulse width measurement modes, the timer measures the pulse period or pulse width of an external signal. Table 18.9 lists Specifications of Pulse Period/Pulse Width Measurement Modes, Table 18.10 lists Registers and Settings in Pulse Period/Pulse Width Measurement Modes, Figure 18.6 shows Operation Example in Pulse Period Measurement Mode, and Figure 18.7 shows an Operation Example in Pulse Width Measurement Mode. Table 18.9 Specifications of Pulse Period/Pulse Width Measurement Modes | Item | Specification | | | |-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count sources | f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32 | | | | Count operations | <ul> <li>Increment</li> <li>The counter value is transferred to the reload register at an active edge of the measurement pulse. The counter value becomes 0000h and count continues.</li> </ul> | | | | Count start condition | Set the TBiS bit to 1 (start counting). | | | | Count stop condition | Set the TBiS bit to 0 (stop counting). | | | | Interrupt request generation timing (3) | <ul> <li>When an active edge of measurement pulse is input <sup>(1)</sup></li> <li>Timer overflow. The MR3 bit in the TBiMR register becomes 1 (overflowed) at the same time an overflow occurs.</li> </ul> | | | | TBiIN pin function | Measurement pulse input | | | | Read from timer | When bits PPWFS12 to PPWFS10 and PPWFS22 to PPWFS20 in registers PPWFS1 and PPWFS2 are 0 • Value of the reload register (measurement result) can be read by reading the TBi register. (2) When bits PPWFS12 to PPWFS10 and PPWFS22 to PPWFS20 in registers PPWFS1 and PPWFS2 register are 1 • Value of the counter (counter value) can be read by reading the TBi register. • Value of the reload register (measurement result) can be read by reading the TBi1 register. | | | | Write to timer | When not counting, the value written to the TBi register is written to both the reload register and counter. | | | i = 0 to 5 TBiS: Bit in the TABSR or TBSR register #### Notes: - 1. No interrupt request is generated when the first active edge is input after the timer starts counting. - 2. The value read from the TBi register is undefined until the second active edge is input after the timer starts counting. - 3. When timer Bi in pulse-period measurement mode or pulse-width measurement mode is used as an event or trigger for timer A or timer B other than timer Bi, an event or trigger occurs at both the overflow and active edge of the measurement pulse. Table 18.10 Registers and Settings in Pulse Period/Pulse Width Measurement Modes (1) | Register | Bit | Function and Setting | |---------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PCLKR | PCLK0 | Select the count source. | | CPSRF | CPSR | Write 1 to reset the clock prescaler. | | PCLKSTP1 | PCKSTP11 | Set to 0 when using f1 or main clock. | | FOLKSTET | PCKSTP17 | Select the count source. | | TBi1 | 15 to 0 | Measurement result can be read when the bits in the PPWFS1 or PPWFS2 register corresponding to timer Bi are 1. | | PPWFS1 to<br>PPWFS2 | PPWFS12 to<br>PPWFS10<br>PPWFS22 to<br>PPWFS20 | Set to 1 to read the counter value while counting. | | TCKDIVC0 | TCDIV00 | Select the clock used prior to timer AB frequency dividing. | | TBCS0 to TBCS3 | 7 to 0 | Select the count source. | | TABSR<br>TBSR | TBiS | Set to 1 when starting counting. Set to 0 when stopping counting. | | TBi | 15 to 0 | Set the initial value. The measurement result can be read when the bits in the PPWFS1 or PPWFS2 register corresponding to timer Bi are 0. The counter value can be read when the bits in the PPWFS1 or PPWFS2 register corresponding to timer Bi are 1. | | TBiMR | 7 to 0 | Refer to the TBiMR register below. | i = 0 to 5 Note: 1. This table does not describe a procedure. #### MR3 (Timer Bi overflow flag) (b5) This bit is undefined after reset. The MR3 bit becomes 0 (no overflow) by writing to the TBiMR register. The MR3 bit cannot be set to 1 by a program. ## TCK1 and TCK0 (Count source select bit) (b7-b6) These bits are enabled when the TCS3 bit or TCS7 bit in registers TBCS0 to TBCS3 is set to 0 (TCK0, TCK1 enabled). Set the PCLK0 bit in the PCLKR register to select f1TIMAB or f2TIMAB. Figure 18.6 Operation Example in Pulse Period Measurement Mode Figure 18.7 Operation Example in Pulse Width Measurement Mode ## 18.4 Interrupts Refer to individual operation examples for interrupt request generating timing. Refer to 14.7 "Interrupt Control" for details of interrupt control. Table 18.11 lists Timer B Interrupt Related Registers. Table 18.11 Timer B Interrupt Related Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------------|--------|-------------| | 0045h | Timer B5 Interrupt Control Register | TB5IC | XXXX X000b | | 0046h | Timer B4 Interrupt Control Register | TB4IC | XXXX X000b | | 0047h | Timer B3 Interrupt Control Register | TB3IC | XXXX X000b | | 005Ah | Timer B0 Interrupt Control Register | TB0IC | XXXX X000b | | 005Bh | Timer B1 Interrupt Control Register | TB1IC | XXXX X000b | | 005Ch | Timer B2 Interrupt Control Register | TB2IC | XXXX X000b | | 0206h | Interrupt Source Select Register 2 | IFSR2A | 00h | Timers B3 and B4 share interrupt vectors and interrupt control registers with other peripheral functions. When using the timer B3 interrupt, set the IFSR26 bit in the IFSR2A register to 0 (timer B3). When using the timer B4 interrupt, set the IFSR27 bit in the IFSR2A register to 0 (timer B4). #### 18.5 Notes on Timer B #### 18.5.1 Common Notes on Multiple Modes #### 18.5.1.1 Register Setting The timer is stopped after reset. Set the mode, count source, etc., using registers TBiMR, TBCS0 to TBCS3, TBi, TCKDIVC0, PCLKR, PPWFS1, and PPWFS2 before setting the TBiS bit in the TABSR or TBSR register to 1 (count started) (i = 0 to 5). Rewrite registers TBiMR, TBCS0 to TBCS3, TCKDIVC0, PCLKR, PPWFS1, and PPWFS2 while the TBiS bit is 0 (count stopped), regardless of whether after reset or not. #### 18.5.1.2 Main Clock When using the main clock for the timer A and timer B count source (PCKSTP17 bit in the PCLKSTP1 register is 1), adhere the following: - Set the PCKSTP11 bit in the PCLKSTP1 register to 0 (f1 supply enabled). - The main clock can be used in PLL operating mode, high-speed mode, medium-speed mode, or wait mode. Do not use the main clock for the timer A and timer B count source in other modes. - When the PCKSTP17 bit is set to 1 and timer A or timer B operates in wait mode, set the CM02 bit to 0 (peripheral function clock f1 does not stop in wait mode). ## 18.5.2 Timer B (Timer Mode) #### 18.5.2.1 Reading the Timer While counting, the counter value can be read at any time by reading the TBi register. However, FFFFh is read while reloading. When the counter is read before it starts counting and after a value is set in the TBi register while not counting, the set value is read. ## 18.5.3 Timer B (Event Counter Mode) ## 18.5.3.1 Reading the Timer While counting, the counter value can be read at any time by reading the TBi register. However, FFFFh is read while reloading. When the counter is read before it starts counting and after a value is set in the TBi register while not counting, the set value is read. #### 18.5.3.2 Event When the TCK1 bit in the TBiMR register is 1, an event occurs when an interrupt request of the selected timer is generated. An event or trigger occurs while an interrupt is disabled because an interrupt request signal is generated regardless of the I flag, IPL, or interrupt control registers. When the timer selected by the TCK1 bit uses pulse-period measurement mode or pulse-width measurement mode, an interrupt request is generated at an active edge of the measurement pulse. ## 18.5.4 Timer B (Pulse Period/Pulse Width Measurement Modes) ## 18.5.4.1 MR3 Bit in the TBiMR Register To clear the MR3 bit to 0 by writing to the TBiMR register while the TBiS bit is 1 (count started), be sure to set the same value as previously set to bits TMOD0, TMOD1, MR0, MR1, TCK0, and TCK1, and set bit 4 to 0. ## **18.5.4.2** Interrupts The IR bit in the TBiIC register becomes 1 (interrupt requested) when an active edge of a measurement pulse is input, or timer Bi overflows (i = 0 to 5). The source of an interrupt request can be determined by setting the MR3 bit in the TBiMR register within the interrupt routine. Use the IR bit in the TBilC register to detect overflows only. Use the MR3 bit only to determine the interrupt source. #### 18.5.4.3 Event or Trigger When timer Bi in pulse-period measurement mode or pulse-width measurement mode is used as an event or trigger for timer A or timer B other than timer Bi, an event or trigger occurs at both the overflow and active edge of the measurement pulse. #### 18.5.4.4 Operations between Count Start and the First Measurement When a count is started and the first active edge is input, an undefined value is transferred to the reload register. At this time, a timer Bi interrupt request is not generated. The value of the counter is undefined after reset. If the count is started in this state, the MR3 bit may become 1 and a timer Bi interrupt request may be generated after the count starts before an active edge is input. When a value is set in the TBi register while the TBiS bit is 0 (count stopped), the same value is written to the counter. #### 18.5.4.5 Pulse Period Measurement Mode When an active edge and overflow are generated simultaneously, input is not recognized at the active edge because an interrupt request is generated only once. Use this mode so an overflow is not generated, or use pulse width measurement mode. #### 18.5.4.6 Pulse Width Measurement Mode In pulse width measurement, pulse widths are measured successively. Check whether the measurement result is a high-level width or a low-level width in the user program. When an interrupt request is generated, read the TBilN pin level in the interrupt routine, and check whether it is the edge of an input pulse or overflow. The TBilN pin level can be read from bits in the register of ports sharing a pin. ## 19. Three-Phase Motor Control Timer Function #### 19.1 Introduction Timers A1, A2, A4, and B2 can be used to output three-phase motor drive waveforms. Table 19.1 and Table 19.2 list Three-Phase Motor Control Timer Function Specifications. Three-Phase Motor Control Timer Function Block Diagrams are shown in Figure 19.1 and Figure 19.2. Table 19.3 lists I/O Ports. Table 19.1 Three-Phase Motor Control Timer Function Specifications (1/2) | Item | Specification | | | |--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Operation modes | <ul> <li>Triangular wave modulation three-phase mode 0 Three-phase PWM waveform of triangular wave modulation is output. Output data is updated every half cycle of the carrier wave, and an output waveform is generated.</li> <li>Triangular wave modulation three-phase mode 1 Three-phase PWM waveform of triangular wave modulation is output. Output data is updated every cycle of the carrier wave, and an output waveform is generated.</li> <li>Sawtooth wave modulation mode Three-phase PWM waveform of sawtooth wave modulation is output.</li> </ul> | | | | Three-phase PWM waveform output pins | 6 (U, Ū, V, ∇, W, Ѿ) | | | | Forced cutoff input | Input a low-level signal to the SD pin | | | | Used timers | Timers A4, A1, A2 (used in one-shot timer mode) Timer A4: U-/Ū-phase waveform control Timer A1: V-/V-phase waveform control Timer A2: W-/W-phase waveform control Timer B2 (used in timer mode) Carrier wave cycle control Dead time timer (three 8-bit timers and shared reload register) Dead time control | | | | Output waveform | Triangular wave modulation, sawtooth wave modulation • All high or low outputs for one cycle supported • Output logic of high- and low-side turn-on signals can be set separately. | | | | Carrier wave cycle | Triangular wave modulation : $\frac{(m+1)\times 2}{fi}$ Sawtooth wave modulation : $\frac{m+1}{fi}$ m: Setting value of the TB2 register, 0000h to FFFFh fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32) | | | Table 19.2 Three-Phase Motor Control Timer Function Specifications (2/2) | Item | Specification | | | |---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Three-phase PWM output width | Triangular wave modulation: $\frac{m+1-n+n'}{fi}$ | | | | | Sawtooth wave modulation : $\frac{n}{fi}$ n, n': Setting value of registers TA4, TA1, and TA2 (of registers TA4, TA41, TA1, TA11, TA2, and TA21 when setting the INV11 bit to 1), 0001h to FFFFh fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32) | | | | Dead time (width) | p: Setting value of the DTT register, 01h to FFh fi: Count source frequency (f1TIMAB, f2TIMAB, f1TIMAB divided by 2, f2TIMAB divided by 2) | | | | Active level | Selectable either active high or active low | | | | Simultaneous conduction prevention function | Simultaneous conduction prevention Simultaneous conduction detection | | | | Interrupt frequency | A timer B2 interrupt is generated every carrier wave cycle to every 15 carrier wave cycles. | | | Figure 19.1 Three-Phase Motor Control Timer Function Block Diagram 1 Figure 19.2 Three-Phase Motor Control Timer Function Block Diagram 2 Table 19.3 I/O Ports | Pin Name | I/O | Function | |-------------------------------------------------------------------------------------------------|----------------------|-------------------------------------| | $\overline{U}, \overline{\overline{U}}, V, \overline{\overline{V}}, W, \overline{\overline{W}}$ | Output | Three-phase PWM waveform output | | SD | Input <sup>(1)</sup> | Forced cutoff input | | IDU, IDV, IDW | Input (2) | Position-data-retain function input | #### Notes: - 1. Set the port direction bits which share pins to 0 (input mode). When not using the three-phase output forced cutoff function, input a high-level signal to the $\overline{SD}$ pin. - 2. Set the port direction bits which share pins to 0 (input mode). ## 19.2 Registers Refer to "registers and settings" in each mode for register and bit settings. Three-phase motor control timer function uses timers A1, A2, A4, and B2. For other registers related to timers A1, A2, A4, and B2, refer to 17. "Timer A" and 18. "Timer B". Table 19.4 Registers | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------------|--------|-------------| | 01DAh | Three-Phase Protect Control Register | TPRC | 00h | | 0302h | Timer A1-1 Register | TA11 | XXh | | 0303h | | | XXh | | 0304h | Timer A2-1 Register | TA21 | XXh | | 0305h | | | XXh | | 0306h | Timer A4-1 Register | TA41 | XXh | | 0307h | | | XXh | | 0308h | Three-Phase PWM Control Register 0 | INVC0 | 00h | | 0309h | Three-Phase PWM Control Register 1 | INVC1 | 00h | | 030Ah | Three-Phase Output Buffer Register 0 | IDB0 | XX11 1111b | | 030Bh | Three-Phase Output Buffer Register 1 | IDB1 | XX11 1111b | | 030Ch | Dead Time Timer | DTT | XXh | | 030Dh | Timer B2 Interrupt Generation Frequency Set Counter | ICTB2 | XXh | | 030Eh | Position-Data-Retain Function Control Register | PDRF | XXXX 0000b | | 0318h | Port Function Control Register | PFCR | 0011 1111b | | 0328h | Timer A1 Register | TA1 | XXh | | 0329h | | | XXh | | 032Ah | Timer A2 Register | TA2 | XXh | | 032Bh | | | XXh | | 032Eh | Timer A4 Register | TA4 | XXh | | 032Fh | | | XXh | | 0334h | Timer B2 Register | TB2 | XXh | | 0335h | | | XXh | | 033Eh | Timer B2 Special Mode Register | TB2SC | X000 0000b | ## 19.2.1 Timer B2 Register (TB2) Read and write in 16-bit units. The carrier wave cycle is determined by this counter. Timer B2 underflow is a one-shot trigger of timers A1, A2, and A4. In three-phase mode 1, the reload timing of the TB2 register can be selected by setting the PWCON bit in the TB2SC register. ## 19.2.2 Timer Ai, Ai-1 Register (TAi, TAi1) (i = 1, 2, 4) Write to these registers in 16-bit units. Use the MOV instruction to set registers TAi and TAi1. If the TAi or TAi1 register is set to 0000h, no counters start and no timer Ai interrupt is generated. The TAi or TAi1 register is used to determine waveforms of U-, V-, and W-phases. It is triggered by timer B2 underflow, and operates in one-shot timer mode. Registers TA1, TA2, and TA4 are used in sawtooth wave modulation mode and three-phase mode 0 of triangular wave modulation mode. Registers TA1, TA2, TA4, TA11, TA21, and TA41 are used in three-phase mode 1 of triangular wave modulation mode. When the INV15 bit in the INVC1 register is set to 0 (dead time enabled), some high- and low-side turnon signals, whose output level changes from inactive to active, switch the output level when the dead time timer stops. In three-phase mode 1, the value of the TAi1 register is counted first. Then, the values of registers TAi and TAi1 are counted alternately. #### Three-Phase PWM Control Register 0 Symbol b7 b6 b5 b4 b3 b2 b1 b0 Address Reset Value INVC0 0308h 00h Bit Symbol RW Bit Name **Function** b1 b0 INV00 0 0:` RW 1: Timer B2 underflow 0 ICTB2 count condition select 0: Timer B2 underflow when timer bit A1 reload control signal is 0 INV01 RW 1 : Timer B2 underflow when timer A1 reload control signal is 1 0: Three-phase motor control timer function not Three-phase motor control INV02 RWtimer function enable bit 1 : Three-phase motor control timer function used Three-phase motor control 0: Three-phase motor control timer output disabled INV03 RW timer output control bit 1: Three-phase motor control timer output enabled High- and low-side 0 : Simultaneous turn-on enabled INV04 simultaneous turn-on disable RW 1 : Simultaneous turn-on disabled bit High- and low-side 0: Not detected INV05 simultaneous turn-on detect RW 1: Detected flag 0: Triangular wave modulation mode RW INV06 Modulation mode select bit 1 : Sawtooth wave modulation mode A transfer trigger is generated when the INV07 bit is set to 1. A trigger to the dead INV07 Software trigger select bit RW time timer is also generated when setting the INV06 bit to 1. The read value is 0. #### 19.2.3 Three-Phase PWM Control Register 0 (INVC0) Set the INVC0 register after the PRC1 bit in the PRCR register is set to 1 (write enabled). Rewrite bits INV00 to INV02, INV04, and INV06 when timers A1, A2, A4, and B2 are stopped. #### INV01 and INV00 (ICTB2 count condition select bit) (b1-b0) Bits INV00 and INV01 are enabled only when the INV11 bit in the INVC1 register is 1 (three-phase mode 1). To set the INV01 bit to 1, set the ICTB2 register first, and then set the INV01 bit to 1. Set the TA1S bit in the TABSR register (timer A1 count start flag) to 1 prior to the first timer B2 underflow. When the INV11 bit is 0 (three-phase mode 0), the timer B2 underflow is counted regardless of the values of bits INV01 to INV00. ## INV02 (Three-phase motor control timer function enable bit) (b2) Set the INV02 bit to 1 to operate the dead time timer, U-, V- and, W-phase output control circuits, and the ICTB2 counter. ## INV03 (Three-phase motor control timer output control bit) (b3) Conditions to become 0: - The INV04 bit is 1 (simultaneous turn-on disabled) and the INV05 bit is 1 (simultaneous turn-on detected). - The INV03 bit is set to 0 by a program. - The signal applied to the SD pin is low. #### INV05 (High- and low-side simultaneous turn-on detect flag) (b5) The INV05 bit cannot be set to 1 by a program. Set the INV04 bit to 0 when setting the INV05 bit to 0. #### INV06 (Modulation mode select bit) (b6) The following table lists items influenced by the INV06 bit. Table 19.5 Influence of the INV06 Bit | Item | INV06 is 0 | INV06 is 1 | |-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------| | Mode | Triangular wave modulation mode | Sawtooth wave modulation mode | | Transfer timing from registers IDB0 and IDB1 to three-phase output shift register | Transferred once by generating a transfer trigger after setting registers IDB0 and IDB1 | Transferred every time a transfer trigger is generated | | Trigger timing of the dead time timer when the INV16 bit is 0 | Falling edge of a one-shot pulse of the timers A1, A2, or A4 | <ul><li>Falling edge of a one-shot pulse of the<br/>timer A1, A2, or A4</li><li>Transfer trigger</li></ul> | | INV13 bit | Enabled when the INV11 bit is 1 and the INV06 bit is 0 | Disabled | One of the following conditions must be met to trigger a transfer: - Timer B2 underflows. - A value is written to the INV07 bit. - A value is written to the TB2 register during timer B2 stop when the INV10 bit is 1. INV16, INV13, INV11: Bits in the INVC1 register #### Three-Phase PWM Control Register 1 b7 b6 b5 b4 b3 b2 b1 b0 Symbol Address Reset Value 0 INVC1 0309h 00h Bit Symbol Rit Name Function RW 0: Timer B2 underflow Timer A1, A2 and A4 start INV10 1: Timer B2 underflow and write to the TB2 RW trigger select bit register when timer B2 stops Timer A1-1, A2-1 and A4-1 0: Three-phase mode 0 INV11 RW control bit 1: Three-phase mode 1 0: f1TIMAB or f2TIMAB Dead time timer count INV12 1: f1TIMAB divided by 2 or RW source select bit f2TIMAB divided by 2 Carrier wave rise/fall detect 0: Timer A1 reload control signal is 0 INV13 RO flag 1: Timer A1 reload control signal is 1 0: Active low INV14 Active level control bit RW 1: Active high 0: Dead time enabled INV15 Dead time disable bit RW 1: Dead time disabled 0 : Falling edge of one-shot pulse of timer Dead time timer trigger (A4, A1, and A2) INV16 RW 1 : Rising edge of the three-phase output select bit shift register (U-, V-, W-phase) output Reserved bit Set to 0 RW (b7) ## 19.2.4 Three-Phase PWM Control Register 1 (INVC1) Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. Rewrite the INVC1 register while timers A1, A2, A4, and B2 are stopped. INV11 (Timer A1, A2, and A4 start trigger select bit) (b1) The following table lists items influenced by the INV11 bit. Table 19.6 INV11 Bit | Item | INV11 = 0 | INV11 = 1 | |-------------------------------------------|---------------------------------------------------------------------|----------------------------------------| | Mode | Three-phase mode 0 | Three-phase mode 1 | | Registers TA11, TA21 and TA41 | Not used | Used | | Bits INV00 to INV01 in the INVC0 register | Disabled The ICTB2 counter decrements whenever timer B2 underflows. | Enabled | | INV13 bit | Disabled | Enabled when INV11 is 1 and INV06 is 0 | When the INV06 bit is 1 (sawtooth wave modulation mode), set the INV11 bit to 0 (three-phase mode 0). Also, when the INV11 bit is 0, set the PWCON bit in the TB2SC register to 0 (timer B2 is reloaded when timer B2 underflows). ## INV13 (Carrier wave rise/fall detect flag) (b3) The INV13 bit is enabled only when the INV06 bit is set to 0 (triangular wave modulation mode) and the INV11 bit to 1 (three-phase mode 1). ## INV16 (Dead time timer trigger select bit) (b6) If both of the following conditions are met, set the INV16 bit to 1 (rising edge of the three-phase output shift register output). - The INV15 bit is 0 (dead time timer enabled) - Bits Dij and DiBj always have different values when the INV03 bit is set to 1 (three-phase control timer output enabled). The high- and low-side signals always output opposite level signals at any time except dead time. (i = U, V, or W; j = 0, 1). If either of the above conditions is not met, set the INV16 bit to 0 (dead time timer is triggered on the falling edge of a one-shot pulse of timers). #### Three-Phase Output Buffer Register i (i = 0, 1) Symbol Address Reset Value IDB0 030Ah XX11 1111b IDB1 030Bh XX11 1111b Bit Symbol RW Bit Name **Function** DHi RW U-phase output buffer i DUBi RW U-phase output buffer i Set the output logical value of the threephase output shift registers. The set value is reflected in each turn-on signal as RW DVi V-phase output buffer i follows: 0: Active (on) DVBi RW ∇-phase output buffer i 1: Inactive (off) When read, the values of the three-phase DWi W-phase output buffer i RW output shift registers are read. **DWBi** W-phase output buffer i RW No register bits. If necessary, set to 0. The read value is undefined. (b7-b6) #### 19.2.5 Three-Phase Output Buffer Register i (IDBi) (i = 0, 1) Values of registers IDB0 and IDB1 are transferred to the three-phase output shift registers in response to a transfer trigger. After the transfer trigger occurs, the IDB0 register value determines each phase output signal (internal signal) first. Then, the IDB1 register value on the falling edge of timers A1, A2, and A4 one-shot pulse determines each phase output signal (internal signal). ## 19.2.6 Dead Time Timer (DTT) Use the MOV instruction to set the DTT register. The DTT register acts as a one-shot timer which delays the timing for a turn-on signal to be switched to its active level in order to prevent the upper and lower transistors from being turned on simultaneously. The DTT register is enabled when the INV15 bit in the INVC1 register is set to 0 (dead time enabled). No dead time can be set when the INV15 bit is set to 1 (dead time disabled). Select a trigger by the INV16 bit in the INVC1 register, and a count source by the INV12 bit in the INVC1 register. ## 19.2.7 Timer B2 Interrupt Generation Frequency Set Counter (ICTB2) Use the MOV instruction to set the ICTB2 register. If the INV01 bit in the INVC0 register is 1, set the ICTB2 register when the TB2S bit in the TABSR register is set to 0 (timer B2 counter stopped). If the INV01 bit is 0 and the TB2S bit to 1 (timer B2 counter start), do not set the ICTB2 register when timer B2 underflows. When bits INV01 to INV00 are 11b, the first interrupt is generated when timer B2 underflows n-1 times if a setting value in the ICTB2 counter is n. Subsequent interrupts are generated every n times timer B2 underflows. #### Timer B2 Special Mode Register Symbol o7 b6 b5 b4 b3 b2 b1 b0 Address Reset Value X|0|0|0|0|0|TB2SC 033Eh X000 0000b Bit Symbol Bit Name **Function** RW 0: Timer B2 underflow Timer B2 reload timing **PWCON** 1: Timer A output at odd-numbered RW switch bit occurrences 0: Three-phase output forced cutoff by Three-phase output port SD SD input (high-impedance) disabled IVPCR1 RW control bit 1 1 : Three-phase output forced cutoff by $\overline{\text{SD}}$ input (high-impedance) enabled Set to 0 RW Reserved bits (b6-b2) No register bit. If necessary, set to 0. The read value is undefined. (b7) #### 19.2.8 Timer B2 Special Mode Register (TB2SC) Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. ## PWCON (Timer B2 reload timing switch bit) (b0) If the INV11 bit in the INVC1 register is 0 (three-phase mode 0) or the INV06 bit in the INVC0 register is 1 (sawtooth wave modulation mode), set the PWCON bit to 0 (timer B2 underflow). # IVPCR1 (Three-phase output port SD control bit 1) (b1) Related pins are U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ . If a low-level signal is applied to the $\overline{SD}$ pin when the IVPCR1 bit is 1, three-phase motor control timer output is disabled (INV03 bit in the INVC0 register becomes 0). Then, the target pins become high-impedance regardless of the functions those pins are using. After a forced cutoff, input a high-level signal to the $\overline{SD}$ pin and set the IVPCR1 bit to 0 to cancel the forced cutoff. ## 19.2.9 Position-Data-Retain Function Control Register (PDRF) This register is only enabled in three-phase mode. #### Port Function Control Register Symbol Address Reset Value **PFCR** 0318h 0011 1111b Bit Symbol Bit Name **Function** RW 0: I/O port P8\_0 Port P8\_0 output function PFC0 1: Three-phase PWM output (U-phase RW select bit output) 0: I/O port P8\_1 Port P8\_1 output function PFC1 1: Three-phase PWM output (U-phase RW select bit output) 0: I/O port P7\_2 Port P7\_2 output function PFC2 RW 1: Three-phase PWM output (V-phase select bit output) 0: I/O port P7\_3 Port P7\_3 output function PFC3 RW 1: Three-phase PWM output ( $\overline{V}$ -phase select bit output) 0: I/O port P7\_4 Port P7\_4 output function PFC4 1: Three-phase PWM output (W-phase RW select bit output) 0: I/O port P7\_5 Port P7\_5 output function PFC5 1: Three-phase PWM output (W-phase RWselect bit output) ## 19.2.10 Port Function Control Register (PFCR) This register is enabled only when the INV03 bit in the INVC0 register is set to 1 (three-phase motor control timer output enabled). Set the TPRC0 bit in the TPRC register to 1 (write enabled) before rewriting this register. No register bits. If necessary, set to 0. The read value is 0. ## 19.2.11 Three-Phase Protect Control Register (TPRC) (b7-b6) Once the TPRC0 bit is set to 1 (write enabled) by a program, the set value 1 is retained. To change the register protected by this bit, follow these steps: - (1) Set the TPRC0 bit to 1. - (2) Set a value to the PFCR register. - (3) Set the TPRC0 bit to 0 (write disabled). #### 19.3 Operations ## 19.3.1 Common Operations in Multiple Modes ## 19.3.1.1 Carrier Wave Cycle Control Timer B2 controls the cycle of the carrier wave. In triangular wave modulation mode, the cycle of the carrier wave is double the cycle of timer B2 underflow. In sawtooth wave modulation mode, the cycle of the carrier wave is equal to the cycle of timer B2 underflow. Figure 19.3 shows the Relationship between the Carrier Wave Cycle and Timer B2. Timer B2 underflow is a start trigger for timers A1, A2, and A4, which control the three-phase PWM waveform. However, when the INV10 bit in the INVC1 register is 1, writing to the TB2 register while timer B2 is stopped also generates a trigger for timers A1, A2, and A4. The frequency of timer B2 interrupt requests can be selected for three-phase motor control timers. In triangular wave modulation three-phase mode 0 and sawtooth wave modulation mode, when the setting value in the ICTB2 register is n, a timer B2 interrupt request is generated every nth count of timer B2 underflow. In triangular wave modulation three-phase mode 1, when the setting value in the ICTB2 register is n, a timer B2 interrupt request is generated every nth time of the timing selected by bits INV01 to INV00 in the INVC0 register. However, when bits INV01 to INV00 are 11b, the first interrupt is generated at the n-1 time of timer B2 underflow. Figure 19.3 Relationship between the Carrier Wave Cycle and Timer B2 #### 19.3.1.2 Three-Phase PWM Wave Control Timer A4 controls U- and $\overline{\text{U}}$ -phase waveforms, timer A1 controls V- and $\overline{\text{V}}$ -phase waveforms, and timer A2 controls W- and $\overline{\text{W}}$ -phase waveforms. Timer Ai (i = 1, 2, 4) starts counting by a trigger selected by the INV10 bit in the INVC1 register, and generates a one-shot pulse (internal signal). The output signal of each phase changes at the falling edge of the one-shot pulse. Triangular wave modulation three-phase mode 1 counts values in the TAi1 register and TAi register alternately, and generates a one-shot pulse. #### 19.3.1.3 Dead Time Control Due to delays in the transistors turning off, the upper and lower transistors are turned on simultaneously. To prevent this, there are three 8-bit dead time timers, one in each phase. The reload resistor is shared. When the INV15 bit in the INVC1 register is 0 (dead time enabled), the dead time set in the DTT register is enabled. When the INV15 bit is 1 (dead time disabled), no dead time is set. Select a count source for the dead time timer by setting the INV12 bit in the INVC1 register. A trigger for the dead time timer can be selected by setting the INV16 bit in the INVC1 register. When both of the following conditions are met, set the INV16 bit to 1 (the rising edge of the three-phase output shift register is a trigger for the dead time timer): - The INV15 bit is 0 (dead time enabled). - Bits Dij and DiBj in the IDBj register have different values when the INV03 bit in the INVC0 register is 1 (three-phase motor control timer output enabled) (i = U, V or W; j = 0, 1). (During the period other than dead time, the high- and low-side output signals always output opposite level signals.) If either of the conditions above is not met, set the INV16 bit to 0 (a trigger for the dead time timer is the falling edge of one-shot pulse of the timer). In sawtooth wave modulation mode, the generation of a transfer trigger causes a trigger for the dead time timer. ## 19.3.1.4 Output Level of Three-Phase PWM Output Pins Set values to registers IDB0 and IDB1 to select the state of each high- or low-side output signal (either active (on) or not active (off)). The values of registers IDB0 and IDB1 are transferred to the three-phase output shift registers by a transfer trigger. After a transfer trigger is generated, the value set in the IDB0 register becomes the first output signal of each phase (internal signal), and then at the falling edge of a timer A1, A2, or A4 (internal signal) one-shot pulse, the value set in the IDB1 register becomes the output signal of each phase. A transfer trigger is generated under any of the following conditions: - At the first timer B2 underflow after registers IDB0 and IDB1 are written (in triangular wave modulation mode) - Each time timer B2 underflows (in sawtooth wave modulation mode) - Writing to the TB2 register while timer B2 is stopped (when the INV10 bit in the INVC1 register is 1) - Setting the INV07 bit in the INVC0 register to 1 (software trigger) The active level can be selected by the INV14 bit in the INVC1 register. Table 19.7 Output Level of Three-Phase PWM Output Pins | Value Set in Registers | ue Set in Registers Output Signal of Each Value Set to the INV14 Bit in the INVC1 Registe | | Bit in the INVC1 Register | |------------------------|-------------------------------------------------------------------------------------------|-----------------------|---------------------------| | IDB0 and IDB1 | Phase (Internal Signal) | 0 (active, low level) | 1 (active, high level) | | 0 (active (on)) | 0 | Low | High | | 1 (not active (off)) | 1 | High | Low | #### 19.3.1.5 Simultaneous Conduction Prevention This function prevents the upper and lower output signals from being active simultaneously due to program errors or unexpected program operation. When the high- and low-side output signals become active at the same time while the simultaneous conduction is disabled by the INV04 bit in the INVC0 register, the following occur: - The INV03 bit in the INVC0 register becomes 0 (three-phase motor control timer output disabled). - The INV05 bit in the INVC0 register becomes 1 (simultaneous conduction detected). - Pins U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ become high-impedance. #### 19.3.1.6 Three-Phase PWM Waveform Output Pins Pins U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ output a PWM waveform under the following conditions: - The INVC02 bit in the INVC0 register is 1 (three-phase motor control timer function). - The INVC03 bit in the INVC0 register is 1 (three-phase motor control timer output enabled). - Bits PFC5 to PFC0 in the PFCR register are 1 (three-phase PWM output (selected independently for each pin)). The three-phase output forced cutoff by the $\overline{\text{SD}}$ pin is available. #### 19.3.1.7 Three-Phase PWM Output Pin Select Pins U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ output a three-phase PWM waveform when the PFCi bit (i = 0 to 5) in the PFCR register is 1 (three-phase PWM output). When the PFCi bit is 0 (I/O port), these pins are used as I/O ports (or other peripheral function I/O ports). Therefore, while some of the six pins output a three-phase PWM waveform, the other pins can be used as I/O ports (or other peripheral function I/O ports). The PFCR register can be rewritten when the TPRC0 bit in the TPRC register is 1 (write to the PFCR register enabled). The functions of the three-phase PWM waveform output pins can be protected from being rewritten due to an unexpected program operation. To prevent rewrite, follow these steps: - (1) Set the TPRC0 bit to 1. - (2) Rewrite the PFCR register. - (3) Set the TPRC0 bit to 0 (write to the PFCR register disabled). Figure 19.4 shows Three-Phase Output and I/O Port Switch Function Operation. Figure 19.4 Three-Phase Output and I/O Port Switch Function Operation #### 19.3.1.8 Three-Phase Output Forced Cutoff Function While the INV02 bit in the INVC0 register is 1 (three-phase motor control timer function) and the INV03 bit is 1 (three-phase motor control timer output enabled), when a low-level signal is applied to the $\overline{SD}$ pin, the INV03 bit in the INVC0 register becomes 0 (three-phase motor control timer output disabled), and pins corresponding to U, $\overline{U}$ , V, $\overline{V}$ , W and $\overline{W}$ outputs change concurrently as follows: - When the IVPCR1 bit in the TB2SC register is 1 (three-phase output forced cutoff enabled) High-impedance - When the IVPCR1 bit in the TB2SC register is 0 (three-phase output forced cutoff disabled) I/O ports or other peripheral function I/O ports However, applying a low-level signal to the $\overline{SD}$ pin while the IVPCR1 bit is 1 places the pins in a high-impedance state even when the pins are used as functions other than U, $\overline{U}$ , V, $\overline{V}$ , W and $\overline{W}$ outputs. Table 19.8 lists State of Pins U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ . Table 19.8 State of Pins U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ (1) | State of Bit and Pin | | | |----------------------------------|--------------|----------------------------------------------------------------------------------------| | IVPCR1 bit in the TB2SC register | SD pin input | Function or State of Pins U, $\overline{U}$ , V, $\overline{V}$ , W and $\overline{W}$ | | 1 | High | Three-phase PWM output | | | Low | High-impedance | | 0 | High | Three-phase PWM output | | | Low | I/O port or other peripheral functions | #### Note: 1. The above assumes bits INVC02, INVC03, and PFCi are all 1. The digital filter is available for the $\overline{SD}$ pin. When the value of bits NMIDF2 to NMIDF0 in the NMIDF register is not 000b (digital filter enabled), $\overline{SD}$ pin input is sampled for every sampling clock. When the same sampled level is detected three times in a row, the level is transferred to the internal circuit. Refer to 13.4.3 " $\overline{NMI/SD}$ Digital Filter". To return the pin function to three-phase PWM output after a forced cutoff, follow these steps: - (1) Apply a high-level signal to the $\overline{SD}$ pin. - (2) Wait for more than three cycles of the digital filter sampling clock. - (3) Set the INV03 bit in the INVC0 register to 1 (three-phase motor control timer output enabled). - (4) Confirm that the INV03 bit is 1. If the bit is 0, return to step (3). - (5) Set the IVPCR1 bit to 0 (three-phase output forced cutoff disabled). - (6) Set the IVPCR1 bit to 1 (when enabling three-phase output forced cutoff again). When not using the three-phase output forced cutoff function, set a port direction bit which shares the pin with $\overline{SD}$ input to 0 (input port), and apply a high-level signal to the $\overline{SD}$ pin. The same pin is used for both $\overline{SD}$ input and $\overline{NMI}$ input. To disable the $\overline{NMI}$ interrupt, set the PM24 bit in the PM2 register to 0 ( $\overline{NMI}$ interrupt disabled). #### 19.3.1.9 Position-Data-Retain Function The position-data-retain function employs three position-data input pins: U-, V-, and W-phase. Input levels of IDU, IDV, and IDW inputs are retained. The falling edge or rising edge of the high-side output signal of each phase can be selected by setting the PDRT bit in the PDRF register as a position-data-retain trigger. For example, in the case of U-phase, when the U-phase trigger is generated, the state of the IDU pin is transferred to the PDRU bit in the PDRF register. The value is retained until the next trigger of the U-phase waveform output. Figure 19.5 shows Position-Data-Retain Function (U-Phase) Operation. Figure 19.5 Position-Data-Retain Function (U-Phase) Operation ## 19.3.2 Triangular Wave Modulation Three-Phase Mode 0 Triangular wave modulation uses the timer B2 cycle as a reference cycle. Table 19.9 lists Three-Phase Mode 0 Specifications, and Figure 19.6 shows Example of Three-Phase Mode 0 Operation. Table 19.9 Three-Phase Mode 0 Specifications | | Item | Specification | |--------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Carrier wave cycle | | (m+1)×2<br>fi<br>m: Setting value of the TB2 register, 0000h to FFFFh<br>fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB,<br>f64TIMAB, fOCO-F, fOCO-S, fC32) | | Three-phase PWM output width | | n, n': Setting value of the TAi register, 0001h to FFFFh fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32) | | | Reference cycle | Timer B2 cycle (one-half cycle of the carrier wave) | | | Timer B2 reload timing | Timer B2 underflow | | from | Three-phase PWM waveform control | Counts the value of the TAi register every time a timer Ai start trigger is generated (the TAi1 register is not used). | | Differences from<br>three-phase mode | Timer B2 interrupt | When the setting value in the ICTB2 register is n, a timer B2 interrupt request is generated every nth time of timer B2 underflow (not influenced by bits INV00 and INV01 in the INVC0 register). | | · | Detection of a carrier wave cycle (first half or last half) | Not detected (the INV13 bit in the INVC1 register is disabled). | i = 1, 2, 4 Table 19.10 Registers and Settings in Three-Phase Mode 0 (1/2) (1) | Register | Bit | Function and Setting | |------------------|---------------------|-------------------------------------------------------------------------------| | | INV00 | Dischlad (Despite the potting the ICTD) register county times DO underflow | | | INV01 | Disabled (Despite the setting, the ICTB2 register counts timer B2 underflow.) | | | INV02 | Set to 1 (three-phase motor control timer function used). | | INVC0 | INV03 | Set to 1 (three-phase motor control timer output enabled). | | INVCO | INV04 | Select simultaneous conduction enabled or disabled. | | | INV05 | Simultaneous conduction detect flag | | | INV06 | Set to 0 (triangular wave modulation mode). | | | INV07 | Software trigger bit | | | INV10 | Select a start trigger for timers A1, A2, and A4. | | | INV11 | Set to 0 (three-phase mode 0). | | | INV12 | Select a count source for the dead time timer. | | INVC1 | INV13 | Disabled | | INVCI | INV14 | Select the active level (either active high or active high). | | | INV15 | Select dead time enabled or disabled. | | | INV16 | Select a trigger for the dead time timer. | | | 7 | Set to 0. | | IDB0, IDB1 | 5 to 0 | Set the output logic of the three-phase output shift registers. | | DTT | 7 to 0 | Set the dead time. | | ICTB2 | 3 to 0 | Set the frequency of the timer B2 interrupt request. | | | PWCON | Set to 0 (timer B2 underflow). | | TB2SC | IVPCR1 | Select three-phase output forced cutoff enabled or disabled. | | | b7 to b2 | Set to 0. | | PDRF | PDRU, PDRV,<br>PDRW | Position-data-retain bit | | | PDRT | Select a position-data-retain trigger. | | PFCR | PFC5 to PFC0 | Select I/O port or three-phase PWM output. | | TPRC | TPRC0 | Set to 1 when writing to the PFCR register, or to 0 when not writing to it. | | TA1, TA2, TA4 | 15 to 0 | Set the one-shot pulse width. | | TA11, TA21, TA41 | 15 to 0 | Not used. | | TB2 | 15 to 0 | Set one-half cycle of the carrier wave. | | | TA1TGH to<br>TA1TGL | Set to 01b (when using V-phase output control circuit). | | TDCCD | TA2TGH to<br>TA2TGL | Set to 01b (when using W-phase output control circuit). | | TRGSR | TA3TGH to<br>TA3TGL | Not used for three-phase motor control timer. | | | TA4TGH to<br>TA4TGL | Set to 01b (when using U-phase output control circuit). | Note: 1. This table does not describe a procedure. Table 19.11 Registers and Settings in Three-Phase Mode 0 (2/2) (1) | Register | Bit | Function and Setting | |-------------------|-------------------|-------------------------------------------------------------------| | | TA0S | Not used for three-phase motor control timer. | | | TA1S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TA2S | Set to 1 when starting counting, and to 0 when stopping counting. | | TABSR | TA3S | Not used for three-phase motor control timer. | | IABSK | TA4S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TB0S | Not used for three-phase motor control timer. | | | TB1S | Not used for three-phase motor control timer. | | | TB2S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TMOD1 to<br>TMOD0 | Set to 10b (one-shot timer mode). | | TA1MR, | MR0 | Set to 0. | | TA2MR, | MR1 | Set to 0. | | TA4MR | MR2 | Set to 1 (select a trigger by setting bits TAiTGH and TAiTGL). | | | MR3 | Set to 0. | | | TCK1 to TCK0 | Select a count source. | | | TMOD1 to<br>TMOD0 | Set to 00b (timer mode). | | TROLIR | MR1 to MR0 | Set to 00b. | | TB2MR | 4 | Set to 0. | | | MR3 | Set to 0. | | | TCK1 to TCK0 | Select a count source. | | PCLKR | PCLK0 | Select a count source. | | PCLKSTP1 | PCKSTP11 | Set to 0 when using f1 or main clock. | | FOLKSTET | PCKSTP17 | Select the count source. | | TCKDIVC0 | TCDIV00 | Select the clock prior to timer AB division. | | TACS0 to<br>TACS2 | 7 to 0 | Select a count source. | | TBCS1 | TCS3 to TCS0 | Select a count source. | | TAPOFS | POFSi | Set to 0. | | UDF | TAiP | Set to 0. | | i = 1, 2, 4 | | | i = 1, 2, 4 Note: 1. This table does not describe a procedure. Figure 19.6 Example of Three-Phase Mode 0 Operation #### 19.3.2.1 Three-Phase PWM Wave Output Timing Control In three-phase mode 0, when a start trigger for timers A1, A2, and A4 is generated, the counter starts counting the value of the TAi register (i = 1, 2, 4). #### 19.3.2.2 Three-Phase PWM Waveform Output Level Control In triangular wave modulation mode, the output levels set in registers IDB0 and IDB1 are transferred to the three-phase output shift registers by a transfer trigger. After a transfer trigger is generated, first the value set in the IDB0 register becomes the output signal for each phase (internal signal), then at the falling edge of one-shot pulse for timers A1, A2, and A4, followed by the values set in the IDB1 register. Consequently, the three-phase PWM output changes. Afterward, the values in registers IDB0 and IDB1 alternately become output signals for each phase at every falling edge of the one-shot pulse for timers A1, A2, and A4. When the INV15 bit in the INVC1 register is 0 (dead time enabled), a phase changing from active to nonactive changes simultaneously with output signals for each phase (internal signal), while a phase changing from nonactive to active changes when the dead time timer stops. A transfer trigger is generated under the following conditions: - The first timer B2 underflow after registers IDB0 and IDB1 are written. - Writing to the TB2 register when timer B2 is stopped (when the INV10 bit in the INVC1 register is 1). - Setting the INV07 bit in the INVC0 register to 1 (software trigger). ## 19.3.3 Triangular Wave Modulation Three-Phase Mode 1 Triangular wave modulation uses twice the cycles of timer B2 as a reference cycle. Table 19.12 lists Three-Phase Mode 1 Specifications, and Figure 19.7 shows Example of Three-Phase Mode 1 Operation. Table 19.12 Three-Phase Mode 1 Specifications | | Item | Specification | | |----------------------------------------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Carrier wave cycle | | (m+1)×2<br>fi<br>m: Setting value of the TB2 register, 0000h to FFFFh<br>fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB,<br>f64TIMAB, fOCO-F, fOCO-S, fC32) | | | Three-phase PWM output width | | n, n': Setting value of the TAi register, 0001h to FFFFh fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32) | | | | Reference cycle | Twice the cycle of timer B2 (cycle of the carrier wave) | | | | Timer B2 reload timing | Select either of the following: • Timer B2 underflow • Timer A output at an odd number of times | | | | Three-phase PWM | Counts the values of registers TAi and TAi1 alternately every time a | | | ر<br>ھو ( | waveform control | timer Ai start trigger is generated | | | Differences from<br>three-phase mode 0 | Timer B2 interrupt | Select a count timing for the ICTB2 register by bits INV01 to INV00 in the INVC0 register: • Timer B2 underflow (each time) • Timer B2 underflow when the INV13 bit in the INVC1 register is 0 • Timer B2 underflow when the INV13 bit is 1 When the setting value in the ICTB2 register is n, a timer B2 interrupt request is generated every nth time of the timing selected by setting bits INV01 to INV00. | | | | Detection of a carrier wave cycle (first half or last half) | Detected (The INV13 bit in the INVC1 register is enabled.) | | i = 1, 2, 4 Table 19.13 Registers and Settings in Three-Phase Mode 1 (1/2) (1) | Register | Bit | Functions and Setting | |---------------------|---------------------|-----------------------------------------------------------------------------| | | INV00 | Select the timing that the ICTB2 register starts counting. | | | INV01 | Select the tilling that the ICTB2 register starts counting. | | | INV02 | Set to 1 (three-phase motor control timer function used). | | INVC0 | INV03 | Set to 1 (three-phase motor control timer output enabled). | | IIIVCO | INV04 | Select simultaneous conduction enabled or disabled. | | | INV05 | Simultaneous conduction detect flag | | | INV06 | Set to 0 (triangular wave modulation mode). | | | INV07 | Software trigger bit | | | INV10 | Select a start trigger for timers A1, A2, and A4. | | | INV11 | Set to 1 (three-phase mode 1). | | | INV12 | Select a count source for the dead time timer. | | INVC1 | INV13 | Carrier wave state detect flag | | INVCT | INV14 | Select the active level (either active high or active high). | | | INV15 | Select dead time enabled or disabled. | | | INV16 | Select a trigger for the dead time timer. | | | 7 | Set to 0. | | IDB0, IDB1 | 5 to 0 | Set an output logic of the three-phase output shift registers. | | DTT | 7 to 0 | Set the dead time. | | ICTB2 | 3 to 0 | Set the frequency of the timer B2 interrupt request. | | | PWCON | Select timer B2 reload timing. | | TB2SC | IVPCR1 | Select three-phase output forced cutoff enabled or disabled. | | | b7 to b2 | Set to 0. | | PDRF | PDRU, PDRV,<br>PDRW | Position-data-retain bit | | | PDRT | Select a position-data-retain trigger. | | PFCR | PFC5 to PFC0 | Select I/O port or three-phase PWM output. | | TPRC | TPRC0 | Set to 1 when writing to the PFCR register, or to 0 when not writing to it. | | TA1, TA2,<br>TA4 | 15 to 0 | Set the one-shot pulse width. | | TA11, TA21,<br>TA41 | 15 to 0 | Set the one-shot pulse width. | | TB2 | 15 to 0 | Set one-half cycle of the carrier wave. | i = 1, 2, 4 Note: 1. This table does not describe a procedure. Table 19.14 Registers and Settings in Three-Phase Mode 1 (2/2) (1) | | | <u> </u> | |-------------------|---------------------|-------------------------------------------------------------------| | Register | Bit | Function and Setting | | | TA1TGH to<br>TA1TGL | Se to 01b (when using V-phase output control circuit). | | TRGSR | TA2TGH to<br>TA2TGL | Set to 01b (when using W-phase output control circuit). | | INGSN | TA3TGH to<br>TA3TGL | (Not used for three-phase motor control timer.) | | | TA4TGH to<br>TA4TGL | Set to 01b (when using U-phase output control circuit). | | | TA0S | Not used for three-phase motor control timer. | | | TA1S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TA2S | Set to 1 when starting counting, and to 0 when stopping counting. | | TABSR | TA3S | Not used for three-phase motor control timer. | | IABSK | TA4S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TB0S | Not used for three-phase motor control timer. | | | TB1S | Not used for three-phase motor control timer. | | | TB2S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TMOD1 to<br>TMOD0 | Set to 10b (one-shot timer mode). | | TA1MR, | MR0 | Set to 0. | | TA2MR, | MR1 | Set to 0. | | TA4MR | MR2 | Set to 1 (select a trigger by setting bits TAiTGH and TAiTGL.). | | | MR3 | Set to 0. | | | TCK1 to TCK0 | Select a count source. | | | TMOD1 to<br>TMOD0 | Set to 00b (timer mode). | | | MR1 to MR0 | Set to 00b. | | TB2MR | 4 | Set to 0. | | | MR3 | Set to 0. | | | TCK1 to TCK0 | Select a count source. | | PCLKR | PCLK0 | Select a count source. | | DOLKOTO: | PCKSTP11 | Set to 0 when using f1 or main clock. | | PCLKSTP1 | PCKSTP17 | Select the count source. | | TCKDIVC0 | TCDIV00 | Select the clock prior to timer AB division. | | TACS0 to<br>TACS2 | 7 to 0 | Select a count source. | | TBCS1 | TCS3 to TCS0 | Select a count source. | | TAPOFS | POFSi | Set to 0. | | UDF | TAiP | Set to 0. | | i = 1 2 1 | | · | i = 1, 2, 4 Note: 1. This table does not describe a procedure. Figure 19.7 Example of Three-Phase Mode 1 Operation ## 19.3.3.1 INV13 Bit in the INVC1 Register In three-phase mode 1, the INV13 bit can be used to detect whether the cycle of the carrier wave is the first half or the last half. The INV13 bit is a flag which checks the state of timer A1 reload control signals. The timer A1 reload control signal becomes 0 while timer A1 is stopped, and the value is inverted at every start trigger signal for timers A1, A2, and A4. Thus, if the cycle of the carrier wave starts at the first timer B2 underflow, the first half comes when the INV13 bit is 1, and the last half comes when it is 0. Table 19.15 lists Relations of the INV13 Bit with Other Factors. Table 19.15 Relations of the INV13 Bit with Other Factors | INV13 bit | 1 | 0 | |--------------------------------|---------------------------|----------------------------| | Timer A1 reload control signal | 1 | U | | One-shot pulse count value | TAi1 register value | TAi register value | | Timer B2 underflow | At an odd number of times | At an even number of times | | Carrier wave | First half | Last half | i = 1, 2, 4 ## 19.3.3.2 Three-Phase PWM Waveform Output Timing Control In three-phase mode 1, when a start trigger for timers A1, A2, and A4 is generated, the value set in the TAi1 register is counted first. Afterward, the values in registers TAi1 and TAi are alternately counted every time a start trigger for timers A1, A2, and A4 is generated. When the values in registers TAi1 and TAi are rewritten during processing, the updated value is output from the next carrier wave cycle. Figure 19.8 shows Update Timing of Registers TAi and TAi1 in Three-Phase Mode 1. Figure 19.8 Update Timing of Registers TAi and TAi1 in Three-Phase Mode 1 #### 19.3.3.3 Carrier Wave Control In three-phase mode 1, the reload timing of the TB2 register can be selected by setting the PWCON bit in the TB2SC register. #### 19.3.3.4 Three-Phase PWM Waveform Output Level Control In triangular wave modulation mode, the output levels set in registers IDB0 and IDB1 are transferred to the three-phase output shift registers by a transfer trigger. After a transfer trigger is generated, first the value set in the IDB0 register, and then, at the falling edge of one-shot pulse for timers A1, A2, and A4, the values set in the IDB1 register become output signals for each phase (internal signal) and consequently the three-phase PWM output changes. Afterward, the values in registers IDB0 and IDB1 alternately become an output signal for each phase at every falling edge of one-shot pulse for timers A1, A2, and A4. When the INV15 bit in the INVC1 register is 0 (dead time enabled), a phase changing from active to nonactive changes simultaneously with output signals for each phase (internal signal), while a phase changing from nonactive to active changes when the dead time timer stops. A transfer trigger is generated under the following conditions: - The first timer B2 underflow after registers IDB0 and IDB1 are written. - Writing to the TB2 register when timer B2 is stopped (when the INV10 bit in the INVC1 register is 1). - Setting the INV07 bit in the INVC0 register to 1 (software trigger). ## 19.3.4 Sawtooth Wave Modulation Mode In this mode, the sawtooth wave is modulated. Table 19.16 lists Sawtooth Wave Modulation Mode Specifications, and Figure 19.9 shows Example of Sawtooth Wave Modulation Mode Operation. Table 19.16 Sawtooth Wave Modulation Mode Specifications | | Item | Specification | |-----------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Carrier | wave cycle | m + 1<br>fi<br>m: Setting value of the TB2 register, 0000h to FFFFh<br>fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB,<br>f64TIMAB, fOCO-F, fOCO-S, fC32) | | Three- <sub>I</sub> | phase PWM output width | n: Setting value of the TAi register, 0001h to FFFFh fi: Count source frequency (f1TIMAB, f2TIMAB, f8TIMAB, f32TIMAB, f64TIMAB, fOCO-F, fOCO-S, fC32) | | | Reference cycle | Timer B2 cycle (cycle of the carrier wave) | | 4) | Timer B2 reload timing | Timer B2 underflow | | эрош | Three-phase PWM waveform control | Counts the value of the TAi register every time a timer Ai start trigger is generated (the TAi1 register is not used). | | rom<br>Ilation | | The output levels set in registers IDB0 and IDB1 are transferred to the three-phase output shift register at every timer B2 underflow. | | Differences from<br>triangular wave modulation mode | Timer B2 interrupt | When the setting value in the ICTB2 register is n, a timer B2 interrupt request is generated every nth time of timer B2 underflow (not influenced by bits INV00 and INV01 in the INVC0 register). | | | Dead time timer trigger | Both of the following: • Transfer trigger (generated at every timer B2 underflow) • Falling edge of timer Ai one-shot pulse | | tria | Detection of a carrier wave cycle (first half or last half) | - | i = 1, 2, 4 Table 19.17 Registers and Settings in Sawtooth Wave Modulation Mode (1/2) (1) | Register | Bit | Function and Setting | |---------------------|---------------------|--------------------------------------------------------------------------------| | | INV00 | D: 11 1/D :: 11 10TD0 :: 1 1: D0 1 (1 ) | | | INV01 | Disabled (Despite the settings, the ICTB2 register counts timer B2 underflow.) | | | INV02 | Set to 1 (three-phase motor control timer function used). | | INIV (CO | INV03 | Set to 1 (three-phase motor control timer output enabled). | | INVC0 | INV04 | Select simultaneous conduction enabled or disabled. | | | INV05 | Simultaneous conduction detect flag | | | INV06 | Set to 1 (sawtooth wave modulation mode). | | | INV07 | Software trigger bit | | | INV10 | Select a start trigger for timers A1, A2, and A4. | | | INV11 | Set to 0. | | | INV12 | Select a count source for the dead time timer. | | INVC1 | INV13 | Disabled | | INVCT | INV14 | Select the active level (either active high or active high). | | | INV15 | Select dead time enabled or disabled. | | | INV16 | Select a trigger for the dead time timer. | | | 7 | Set to 0. | | IDB0, IDB1 | 5 to 0 | Set an output logic of the three-phase output shift register. | | DTT | 7 to 0 | Set the dead time. | | ICTB2 | 3 to 0 | Set the frequency of timer B2 interrupt request. | | | PWCON | Set to 0 (timer B2 underflow). | | TB2SC | IVPCR1 | Select three-phase output forced cutoff enabled or disabled. | | | b7 to b2 | Set to 0. | | PDRF | PDRU, PDRV,<br>PDRW | Position-data-retain bit | | | PDRT | Select a position-data-retain trigger. | | PFCR | PFC5 to PFC0 | Select I/O port or three-phase PWM output. | | TPRC | TPRC0 | Set to 1 when writing to the PFCR register, or to 0 when not writing to it. | | TA1, TA2,<br>TA4 | 15 to 0 | Set the one-shot pulse width. | | TA11, TA21,<br>TA41 | 15 to 0 | Not used | | | | Set the cycle of the carrier wave. | i = 1, 2, 4 Note: 1. This table does not describe a procedure. Table 19.18 Registers and Settings in Sawtooth Wave Modulation Mode (2/2) (1) | Register | Bit | Function and Setting | |-------------------|---------------------|-------------------------------------------------------------------| | | TA1TGH to<br>TA1TGL | Set to 01b (when using V-phase output control circuit). | | TRGSR | TA2TGH to<br>TA2TGL | Set to 01b (when using W-phase output control circuit). | | INGON | TA3TGH to<br>TA3TGL | (Not used for three-phase motor control timer.) | | | TA4TGH to<br>TA4TGL | Set to 01b (when using U-phase output control circuit). | | | TA0S | Not used for three-phase motor control timer. | | | TA1S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TA2S | Set to 1 when starting counting, and to 0 when stopping counting. | | TADOD | TA3S | Not used for three-phase motor control timer. | | TABSR | TA4S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TB0S | Not used for three-phase motor control timer. | | | TB1S | Not used for three-phase motor control timer. | | | TB2S | Set to 1 when starting counting, and to 0 when stopping counting. | | | TMOD1 to<br>TMOD0 | Set to 10b (one-shot timer mode). | | TA1MR, | MR0 | Set to 0. | | TA2MR, | MR1 | Set to 0. | | TA4MR | MR2 | Set to 1 (select a trigger by setting bits TAiTGH and TAiTGL). | | | MR3 | Set to 0. | | | TCK1 to TCK0 | Select a count source. | | | TMOD1 to<br>TMOD0 | Set to 00b (timer mode). | | TDCL | MR1 to MR0 | Set to 00b. | | TB2MR | 4 | Set to 0. | | | MR3 | Set to 0. | | | TCK1 to TCK0 | Select a count source. | | PCLKR | PCLK0 | Select a count source. | | DOLKOTD4 | PCKSTP11 | Set to 0 when using f1 or main clock. | | PCLKSTP1 | PCKSTP17 | Select the count source. | | TCKDIVC0 | TCDIV00 | Select the clock prior to timer AB division. | | TACS0 to<br>TACS2 | 7 to 0 | Select a count source. | | TBCS1 | TCS3 to TCS0 | Select a count source. | | TAPOFS | POFSi | Set to 0. | | UDF | TAiP | Set to 0. | | i = 1 2 1 | | · | i = 1, 2, 4 Note: 1. This table does not describe a procedure. Figure 19.9 Example of Sawtooth Wave Modulation Mode Operation ## 19.3.4.1 Three-Phase PWM Waveform Output Timing Control In sawtooth wave modulation mode, when a start trigger for timers A1, A2, and A4 is generated, the counter starts counting the value in the TAi register (i = 1, 2, 4). #### 19.3.4.2 Three-Phase PWM Waveform Output Level Control In sawtooth wave modulation mode, the output levels set in registers IDB0 and IDB1 are transferred to the three-phase output shift register by a transfer trigger. After a transfer trigger is generated, first the value set in the IDB0 register, and then at the falling edge of one-shot pulse for timers A1, A2, and A4, the value set in the IDB1 register become output signals for each phase (internal signal) and consequently the three-phase PWM output changes. Then, the following two actions are repeated: (1) The setting levels are transferred to the three-phase output shift register by a transfer trigger generated at timer B2 underflow, and therefore, the value in the IDB0 register becomes output signals for each phase. (2) The values set in the IDB1 register become output signals for each phase at the falling edge of one-shot pulse for timers A1, A2, and A4. When the INV15 bit in the INVC1 register is 0 (dead time enabled), a phase changing from active to nonactive changes simultaneously with output signals for each phase (internal signal), while a phase changing from nonactive to active changes when the dead time timer stops. A transfer trigger is generated under the following conditions: - Timer B2 underflow (each time). - Writing to the TB2 register when timer B2 is stopped (when the INV10 bit in the INVC1 register is 1). - Setting the INV07 bit in the INVC0 register to 1 (software trigger). #### 19.4 Interrupts The timer B2 interrupt and timer A1, A2, and A4 interrupts can be used with the three-phase motor control timer. ## 19.4.1 Timer B2 Interrupt When the setting value in the ICTB2 register is n, a timer B2 interrupt request is generated at the timings below. For details, refer to the specifications and usage examples of each mode. In triangular wave modulation three-phase mode 0 and sawtooth wave modulation mode, an interrupt request is generated at the nth count of timer B2 underflow. In triangular wave modulation three-phase mode 1, an interrupt request is generated at the nth count of timing selected by setting bits INV01 to INV00 in the INVC0 register. Refer to 14.7 "Interrupt Control" for details of interrupt control. Table 19.19 lists the Timer B2 Interrupt Related Register. Table 19.19 Timer B2 Interrupt Related Register | Address | Register | Symbol | Reset Value | |---------|-------------------------------------|--------|-------------| | 005Ch | Timer B2 Interrupt Control Register | TB2IC | XXXX X000b | #### 19.4.2 Timer A1, A2, and A4 Interrupts A timer Ai interrupt request is generated at the falling edge of timer Ai one-shot pulse (internal signal) (i = 1, 2, 4). Refer to 14.7 "Interrupt Control" for details of interrupt control. Table 19.20 lists Timer A1, A2, and A4 Interrupt Related Registers. Table 19.20 Timer A1, A2, and A4 Interrupt Related Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------------|--------|-------------| | 0056h | Timer A1 Interrupt Control Register | TA1IC | XXXX X000b | | 0057h | Timer A2 Interrupt Control Register | TA2IC | XXXX X000b | | 0059h | Timer A4 Interrupt Control Register | TA4IC | XXXX X000b | In the timer Ai interrupt, when the TMOD1 bit in the TAiMR register is changed from 0 to 1 (from timer mode or event counter mode to one-shot timer mode, PWM mode, or programmable output mode), the IR bit in the TAilC register is occasionally becomes 1 (interrupt requested). Thus, when changing the TMOD1 bit, follow the steps below. Also refer to 14.13 "Notes on Interrupts". - (1) Set bits ILVL2 to ILVL0 in the TAilC register to 000b (interrupt disabled). - (2) Set the TAiMR register. - (3) Set the IR bit in the TAilC register to 0 (interrupt not requested). ## 19.5 Notes on Three-Phase Motor Control Timer Function #### 19.5.1 Timer A and Timer B Refer to 17.5 "Notes on Timer A" and 18.5 "Notes on Timer B". ## 19.5.2 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/ $\overline{CTS2}/\overline{RTS2}/\overline{TA1IN/V}$ , P7\_4/TA2OUT/W, P7\_5/TA2IN/ $\overline{W}$ , P8\_0/TA4OUT/RXD5/SCL5/U, P8\_1/TA4IN/ $\overline{CTS5}/\overline{RTS5}/\overline{U}$ ## 20. Real-Time Clock #### 20.1 Introduction The real-time clock generates a 1-second signal from a count source and counts seconds, minutes, hours, a.m./p.m., a day, and a week. It also detects matches with specified seconds, minutes, and hours. Table 20.1 lists Real-Time Clock Specifications, Figure 20.1 shows a Real-Time Clock Block Diagram, and Table 20.2 lists the I/O Port. Table 20.1 Real-Time Clock Specifications | Item | Specification | | | |-------------------------------------|----------------------------------------------------------------------------------------|--|--| | Count source | f1, fC | | | | | • Increment | | | | | Compare mode 1 or not using compare mode | | | | | The count value is continuously used, and the count continues. | | | | | Compare mode 2 | | | | Count operation | When a compare match is detected, the count value is set to 0 and the count continues. | | | | | Compare mode 3 | | | | | When a compare match is detected, the count value is set to 0 and the count stops. | | | | Count start condition | 1 (count started) is written to the TSTART bit in the RTCCR1 | | | | Count start condition | register. | | | | Count stop condition | 0 (count stopped) is written to the TSTART bit in the RTCCR1 | | | | Court stop containen | register. | | | | | Select one of the following: | | | | | Update second data | | | | | Update minute data | | | | Interrupt request generation timing | Update hour data | | | | | Update day data | | | | | • When day data is set to 000b | | | | | When time data and compare data match | | | | RTCOUT pin function | Programmable I/O port or compare output | | | | | When the RTCSEC, RTCMIN, RTCHR, or RTCWK register is read, | | | | Read from timer | the count value can be read. The values read from registers | | | | | RTCSEC, RTCMIN, and RTCHR are represented by the BCD code. | | | | | When bits TSTART and TCSTF in the RTCCR1 register are 0 (count | | | | Write to timer | stopped), the RTCSEC, RTCMIN, RTCHR, and RTCWK registers | | | | | are write enabled. Values written to registers RTCSEC, RTCMIN, | | | | | and RTCHR are represented by the BCD code. | | | | Selectable functions | • 12-/24-hour mode switch function | | | | | Compare output | | | #### Note: In this manual, day refers to one day of the week. Refer to 20.2.4 "Real-Time Clock Day Data Register (RTCWK)" for details. Figure 20.1 Real-Time Clock Block Diagram Table 20.2 I/O Port | Pin Name | I/O | Function | |----------|--------|----------------| | RTCOUT | Output | Compare output | ## 20.2 Registers Refer to 8.2.6 "Peripheral Clock Stop Register 1 (PCLKSTP1)" for the explanation of the PCLKSTP1 register. Table 20.3 Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------------|----------|-------------| | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 0340h | Real-Time Clock Second Data Register | RTCSEC | 00h | | 0341h | Real-Time Clock Minute Data Register | RTCMIN | X000 0000b | | 0342h | Real-Time Clock Hour Data Register | RTCHR | XX00 0000b | | 0343h | Real-Time Clock Day Data Register | RTCWK | XXXX X000b | | 0344h | Real-Time Clock Control Register 1 | RTCCR1 | 0000 X00Xb | | 0345h | Real-Time Clock Control Register 2 | RTCCR2 | X000 0000b | | 0346h | Real-Time Clock Count Source Select<br>Register | RTCCSR | XXX0 0000b | | 0348h | Real-Time Clock Second Compare Data<br>Register | RTCCSEC | X000 0000b | | 0349h | Real-Time Clock Minute Compare Data<br>Register | RTCCMIN | Х000 0000Ь | | 034Ah | Real-Time Clock Hour Compare Data<br>Register | RTCCHR | X000 0000b | ## 20.2.1 Real-Time Clock Second Data Register (RTCSEC) SC03 to SC00 (First digit of second count bit) (b3-b0) SC12 to SC10 (Second digit of second count bit) (b6-b4) Set a value between 00 and 59 by the BCD code. These bits become 00 at compare match in compare mode 2 and compare mode 3. Write to bits SC12 to SC10 and SC03 to SC00 in the RTCSEC register when bits TSTART and TCSTF in the RTCCR1 register are both 0 (count stopped). Read these bits when the BSY bit is 0 (not while data is updated). #### BSY (Real-time clock busy flag) (b7) This bit is 1 while data is updated. Read the following bits when the BSY bit is 0 (not while data is updated): - Bits SC12 to SC10 and SC03 to SC00 in the RTCSEC register - Bits MN12 to MN10 and MN03 to MN00 in the RTCMIN register - Bits HR11 to HR10 and HR03 to HR00 in the RTCHR register - Bits WK2 to WK0 in the RTCWK register - The RTCPM bit in the RTCCR1 register ## 20.2.2 Real-Time Clock Minute Data Register (RTCMIN) MN03 to MN00 (First digit of minute count bit) (b3-b0) MN12 to MN10 (Second digit of minute count bit) (b6-b4) Set a value between 00 and 59 by the BCD code. When the digit increments from the RTCSEC register, 1 is added. These bits become 00 at compare match in compare mode 2 and compare mode 3. Write to bits MN12 to MN10 and MN03 to MN00 in the RTCMIN register when bits TSTART and TCSTF in the RTCCR1 register are both 0 (count stopped). Read these bits when the BSY bit in the RTCSEC is 0 (not while data is updated). ## 20.2.3 Real-Time Clock Hour Data Register (RTCHR) HR03 to HR00 (First digit of hour count bit) (b3-b0) HR11 and HR10 (Second digit of hour count bit) (b5-b4) When the H12H24 bit in the RTCCR1 register is 0 (12-hour mode), set a value between 00 and 11 by BCD code. When the H12H24 bit in the RTCCR1 register is 1 (24-hour mode), set a value between 00 and 23 by the BCD code. When the digit increments from the RTCMIN register, 1 is added. These bits become 00 at compare match in compare mode 2 and compare mode 3. Write to bits HR11 to HR10 and HR03 to HR00 in the RTCHR register when bits TSTART and TCSTF in the RTCCR1 register are both 0 (count stopped). Read these bits when the BSY bit in the RTCSEC register is 0 (not while data is updated). ## 20.2.4 Real-Time Clock Day Data Register (RTCWK) #### WK2 to WK0 (Day count bit) (b2-b0) A week is counted by counting from 000b (Day 1) to 110b (Day 7) repeatedly. Do not set these bits to 111b. When the digit increments from the RTCHR register, 1 is added. These bits become 000b at compare match in compare mode 2 and compare mode 3. Write to bits WK2 to WK0 in the RTCWK register when bits TSTART and TCSTF in the RTCCR1 register are both 0 (count stopped). Read these bits when the BSY bit in the RTCSEC register is 0 (not while data is updated). ## 20.2.5 Real-Time Clock Control Register 1 (RTCCR1) # TCSTF (Real-time clock count status flag) (b1) TSTART (Real-time clock count start bit) (b7) The real-time clock uses the TSTART bit to instruct the count to start or stop, and use the TCSTF bit to indicate count start or stop. The real-time clock starts counting and the TCSTF bit becomes 1 (count started) when the TSTART bit is set to 1 (count started). It takes up to two cycles of the count source until the TCSTF bit becomes 1 after setting the TSTART bit to 1. During this time, do not access registers associated with the real-time clock (1) other than the TCSTF bit. Also, when setting the TSTART bit to 0 (count stopped), the real-time clock stops counting and the TCSTF bit becomes 0 (count stopped). It takes the time for up to three cycles of the count source until the TCSTF bit becomes 0 after setting the TSTART bit to 0. During this time, do not access registers associated with the real-time clock (1) other than the TCSTF bit. #### Note: 1. Registers associated with the real-time clock: RTCSEC, RTCMIN, RTCHR, RTCWK, RTCCR1, RTCCR2, RTCCSR, RTCCSEC, RTCCMIN, and RTCCHR. ## RTCRST (Real-Time clock reset bit) (b4) When setting this bit to 0 after setting it to 1, the following are set automatically: - The values are reset in registers RTCSEC, RTCMIN, RTCHR, RTCWK, RTCCR2, RTCCSR, RTCCSEC, RTCCMIN, and RTCCHR. - Bits TCSTF, RTCPM, H12H24, and TSTART in the RTCCR1 register become 0. #### RTCPM (a.m./p.m. bit) (b5) Write to the RTCPM bit when bits TSTART and TCSTF in the RTCCR1 register are both 0 (count stopped). Read this bit when the BSY bit in the RTCSEC register is 0 (not while data is updated). The RTCPM bit is enabled when the H12H24 bit is 0 (12-hour mode) or 1 (24-hour mode). Set the RTCPM bit as shown below to set the time while the H12H24 bit is 1: - Set the RTCPM bit to 0 when bits HR11 to HR10 and HR03 to HR00 in the RTCHR register are 00 to 11. - Set the RTCPM bit to 1 when bits HR11 to HR10 and HR03 to HR00 in the RTCHR register are 12 to 23 The RTCPM bit changes as follows while counting: - Becomes 0 when the RTCPM bit is 1 (p.m.) while the clock increments from 11:59:59 (23:59:59 for 24-hour mode) to 00:00:00. - Becomes 1 when the RTCPM bit is 0 (a.m.) while the clock increments from 11:59:59 to 00:00:00 (12:00:00 for 24-hour mode). Figure 20.2 shows Time Representation. Figure 20.2 Time Representation #### H12H24 (Operating mode select bit) (b6) Write to the H12H24 bit when bits TSTART and TCSTF in the RTCCR1 register are both 0 (count stopped). ## 20.2.6 Real-Time Clock Control Register 2 (RTCCR2) Write to the RTCCR2 register when bits TSTART and TCSTF in the RTCCR1 register are both 0 (count stopped). While bits RTCCMP1 to RTCCMP0 are 00b (no compare mode), an interrupt request can be generated every second, minute, hour, day, or week. To generate an interrupt request, set one of the following bits to 1 (interrupt enabled): SEIE, MNIE, HRIE, DAYIE, or WKIE. (Do not set more than one bit to 1.) Table 20.4 lists Periodic Interrupt Sources. Table 20.4 Periodic Interrupt Sources | Factor | Interrupt Source | Interrupt Enable Bit | |-------------------------------------------|--------------------------------------------------------|----------------------| | Periodic interrupt triggered every week | Value in RTCWK register is set to 000b (1-week period) | WKIE | | Periodic interrupt triggered every day | RTCWK register is updated (1-day period) | DYIE | | Periodic interrupt triggered every hour | RTCHR register is updated (1-hour period) | HRIE | | Periodic interrupt triggered every minute | RTCMIN register is updated (1-minute period) | MNIE | | Periodic interrupt triggered every second | RTCSEC register is updated (1-second period) | SEIE | When bits RTCCMP1 to RTCCMP0 are 01b, 10b, or 11b (any compare mode), set the following according to which registers are compared: - When comparing to the RTCCSEC register, set the SEIE bit to 1 (interrupt enabled). - When comparing to the RTCCMIN register, set bits SEIE and MNIE to 1. - When comparing to the RTCCHR register, set bits SEIE, MNIE, and HRIE to 1. ### 20.2.7 Real-Time Clock Count Source Select Register (RTCCSR) When bits RCS1 to RCS0 are 10b (fC), set bits RCS4 to RCS2 to 000b. When bits RCS1 to RCS0 are 00b (f1), select a frequency matched to f1 by bits RCS4 to RCS2. Write to the RTCCSR register when both bits TSTART and TCSTF in the RTCCR1 register are 0 (count stopped). When using fC, set the PM25 bit in the PM2 register to 1 (peripheral clock fC provided). Refer to 8. "Clock Generator" for details on fC. ## 20.2.8 Real-Time Clock Second Compare Data Register (RTCCSEC) The RTCCSEC register is enabled when bits RTCCMP1 to RTCCMP0 in the RTCCR2 register are 01b, 10b, or 11b (any compare mode). SCMP03 to SCMP00 (First digit of second compare data bit) (b3-b0) SCMP12 to SCMP10 (Second digit of second compare data bit) (b6-b4) Set a value between 00 and 59 by the BCD code. Write to these bits when the BSY bit in the RTCSEC register is 0 (not while data is updated). ## 20.2.9 Real-Time Clock Minute Compare Data Register (RTCCMIN) The RTCCMIN register is enabled when bits RTCCMP1 to RTCCMP0 in the RTCCR2 register are 01b, 10b, or 11b (any compare mode). MCMP03 to MCMP00 (First digit of minute compare data bit) (b3-b0) MCMP12 to MCMP10 (Second digit of minute compare data bit) (b6-b4) Set a value between 00 and 59 by the BCD code. Write to these bits when the BSY bit in the RTCSEC register is 0 (not while data is updated). ### 20.2.10 Real-Time Clock Hour Compare Data Register (RTCCHR) The RTCCHR register is enabled when bits RTCCMP1 to RTCCMP0 in the RTCCR2 register are 01b, 10b, or 11b (any compare mode). HCMP03-HCMP00 (First digit of hour compare data bit) (b3-b0) HCMP11-HCMP10 (Second digit of hour compare data bit) (b5-b4) When the H12H24 bit in the RTCCR1 register is 0 (12-hour mode), set a value between 00 and 11 by the BCD codes. When the H12H24 bit in the RTCCR1 register is 1 (24-hour mode), set a value between 00 and 23 by the BCD codes. Write to these bits when the BSY bit in the RTCSEC register is 0 (not while data is updated). #### PMCMP (a.m./p.m compare bit) (b6) This bit is enabled when the H12H24 bit in the RTCCR1 register is either 0 (12-hour mode) or 1 (24-hour mode). When the H12H24 bit is 1, set the following: - When bits HCMP11 to HCMP10 and HCMP03 to HCMP00 are 00 to 11, set the PMCMP bit to 0. - When bits HCMP11 to HCMP10 and HCMP03 to HCMP00 are 12 to 23, set the PMCMP bit to 1. Write to this bit when the BSY bit in the RTCSEC register is 0 (not while data is updated). #### 20.3 Operations ### 20.3.1 Basic Operation The real-time clock generates a 1-second signal from the count source selected in the RTCCSR register and counts seconds, minutes, hours, a.m./p.m., a day, and a week. The day and time to start the count can be set using registers RTCSEC, RTCMIN, RTCHR, RTCWK, and the RTCPM bit in the RTCCR1 register. Current time and day are read from registers RTCSEC, RTCMIN, RTCHR, RTCWK, and the RTCPM bit in the RTCCR1 register. However, do not read these registers when the BSY bit in the RTCSEC register is 1 (while data is updated). An interrupt request can be generated every second, minute, hour, day, or week. While bits RTCCMP1 to RTCCMP0 in the RTCCR2 register are 00b (no compare mode), use the RTCCR2 register to enable one of the periodic interrupts triggered every second, minute, hour, day and week. When a periodic interrupt is generated, the IR bit in the RTCTIC register becomes 1 (interrupt request). Figure 20.3 shows Real-Time Clock Basic Operating Example, Figure 20.4 shows Time and Day Change Procedure (No Compare Mode or Compare Mode 1), and Figure 20.5 shows Time and Day Change Procedure (Compare Mode 2 or Compare Mode 3). Figure 20.3 Real-Time Clock Basic Operating Example Figure 20.4 Time and Day Change Procedure (No Compare Mode or Compare Mode 1) Figure 20.5 Time and Day Change Procedure (Compare Mode 2 or Compare Mode 3) #### 20.3.2 Compare Mode In compare mode, time data <sup>(1)</sup> and compare data <sup>(2)</sup> are compared, and a compare match is detected. When a match is detected, the following occur: Compare interrupt request Refer to 20.4 "Interrupts" for details. RTCOUT pin output level inversion When the TOENA bit in the RTCCR1 register is 1 (compare output enabled), if a compare match is detected, the RTCOUT pin output level is inverted. #### Notes: 1. Bits for time data are as follows: Bits SC12 to SC10 and SC03 to SC00 in the RTCSEC register Bits MN12 to MN10 and MN03 to MN00 in the RTCMIN register Bits HR11 to HR10 and HR03 to HR00 in the RTCHR register The RTCPM bit in the RTCCR1 register 2. Bits for compare data are as follows: Bits SCMP12 to SCMP10 and SCMP03 to SCMP00 in the RTCCSEC register Bits MCMP12 to MCMP10 and MCMP03 to MCMP00 in the RTCCMIN register Bits HCMP11 to HCMP10 and HCMP03 to HCMP00 in the RTCCHR register The PMCMP bit in the RTCCHR register In compare mode, set the SEIE, MNIE, or HRIE bit in the RTCCR2 register to 1 (interrupt enabled) according to compare data (second, minute, or hour). Refer to 20.2.6 "Real-Time Clock Control Register 2 (RTCCR2)" for details. Compare mode has three modes: compare mode 1, compare mode 2, and compare mode 3. Operation after a compare match differs depending on the compare mode. Compare mode 1 The time data is used continuously and counting continues. Compare mode 2 The reset value is used as the time data and counting continues. Compare mode 3 The reset value is used as the time data and counting stops. Figure 20.6 shows Difference between Compare Modes, Figure 20.7 shows Count Start/Stop Operating Example, Figure 20.8 shows Compare Mode 1 Operating Example, Figure 20.9 shows Compare Mode 2 Operating Example, and Figure 20.10 shows Compare Mode 3 Operating Example. Figure 20.6 Difference between Compare Modes Figure 20.7 Count Start/Stop Operating Example Figure 20.8 Compare Mode 1 Operating Example Figure 20.9 Compare Mode 2 Operating Example Figure 20.10 Compare Mode 3 Operating Example RTCPM bit: Bit in RTCCR1 register ### 20.4 Interrupts The real-time clock generates two types of interrupt: - Periodic interrupts triggered every second, minute, hour, day, and week - Compare match interrupt See Table 20.4 Periodic Interrupt Sources for details on periodic interrupt sources, individual mode specifications and an operating example for the interrupt request generating timing. Refer to 14.7 "Interrupt Control" for details of interrupt control. Table 20.5 lists Real-Time Clock Interrupt-Associated Registers. Table 20.5 Real-Time Clock Interrupt-Associated Registers | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------------|--------|-------------| | 006Eh | Real-Time Clock Periodic Interrupt Control Register | RTCTIC | XXXX X000b | | 006Fh | Real-Time Clock Compare Interrupt Control Register | RTCCIC | XXXX X000b | | 0205h | Interrupt Source Select Register 3 | IFSR3A | 00h | The real-time clock shares interrupt vectors and interrupt control registers with other peripheral functions. To use period interrupts, set the IFSR35 bit in the IFSR3A register to 1 (real-time clock cycle). To use compare interrupts, set the IFSR36 bit in the IFSR3A register to 1 (real-time clock compare). #### 20.5 Notes on Real-Time Clock ### 20.5.1 Starting and Stopping the Count The real-time clock uses the TSTART bit for instructing the count to start or stop, and the TCSTF bit which indicates count started or stopped. Bits TSTART and TCSTF are in the RTCCR1 register. The real-time clock starts counting and the TCSTF bit becomes 1 (count started) when the TSTART bit is set to 1 (count started). It takes up to two cycles of the count source until the TCSTF bit becomes 1 after setting the TSTART bit to 1. During this time, do not access registers associated with the real-time clock (1) other than the TCSTF bit. Similarly, when setting the TSTART bit to 0 (count stopped), the real-time clock stops counting and the TCSTF bit becomes 0 (count stopped). It takes up to three cycles of the count source until the TCSTF bit becomes 0 after setting the TSTART bit to 0. During this time, do not access registers associated with the real-time clock other than the TCSTF bit. #### Note: 1. Registers associated with the real-time clock: RTCSEC, RTCMIN, RTCHR, RTCWK, RTCCR1, RTCCR2, RTCCSR, RTCCSEC, RTCCMIN, and RTCCHR. ### 20.5.2 Register Settings (Time Data, etc.) Write to the following registers/bits when the real-time clock is stopped: - Registers RTCSEC, RTCMIN, RTCHR, RTCWK, and RTCCR2 - Bits H12H24 and RTCPM in the RTCCR1 register - Bits RCS0 to RCS4 in the RTCCSR register The real-time clock is stopped when bits TSTART and TCSTF in the RTCCR1 register are 0 (real-time clock stopped). Set the RTCCR2 register after setting the registers and bits mentioned above (immediately before the real-time clock count starts). Figure 20.4 shows Time and Day Change Procedure (No Compare Mode or Compare Mode 1), and Figure 20.5 shows Time and Day Change Procedure (Compare Mode 2 or Compare Mode 3). ### 20.5.3 Register Settings (Compare Data) Write to the following registers when the BSY bit in the RTCSEC register is 0 (not while data is updated). Registers RTCCSEC, RTCCMIN, and RTCCHR ### 20.5.4 Time Reading Procedure in Real-Time Clock Mode In real-time clock mode, read time data bits <sup>(1)</sup> when the BSY bit in the RTCSEC register is 0 (not while data is updated). When reading multiple registers, if data is rewritten between reading registers, an errant time will be read. To prevent this, use one of the following steps when reading: - Using an interrupt - In the real-time clock periodic interrupt routine, read the values necessary from the appropriate time data bits. - Monitoring by a program 1 Monitor the IR bit in the RTCTIC register by a program and read necessary values of time data bits after the IR bit becomes 1 (periodic interrupt requested). - Monitoring by a program 2 Read the time data according to Figure 20.11 "Time Data Reading". Figure 20.11 Time Data Reading - Using read results if they are the same value twice - (1) Read the values necessary from time data bits. - (2) Read the same bit as (1) and compare the contents. - (3) If the contents match, adopt that value as the correct value. If the contents do not match, repeat until the read contents match with the previous contents. Also, when reading multiple registers, read them as continuously as possible. #### Note: Time data bits are as follows: Bits SC12 to SC10 and SC03 to SC00 in the RTCSEC register Bits MN12 to MN10 and MN03 to MN00 in the RTCMIN register Bits HR11 to HR10 and HR03 to HR00 in the RTCHR register Bits WK2 to WK0 in the RTCWK register The RTCPM bit in the RTCCR1 register # 21. Pulse Width Modulator ### 21.1 Introduction The pulse width modulator (PWM) consists of two independent PWM circuits. Table 21.1 lists PWM Specifications, Figure 21.1 shows Block Diagram of PWM, and Table 21.2 lists I/O Ports. Table 21.1 PWM Specifications | Item | Specification | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | Resolution | 8 bits | | Count source | f1 divided by 2, 4, 8, or 16 | | PWM Cycle | $\frac{(2^8-1)\times(m+1)}{fj}$ (Unit: s) m: PWMPREi register setting value fj: Count source frequency (Unit: Hz) | | High-level pulse width | $\frac{(m+1)\times n}{fj}$ (Unit: s) m: PWMPREi register setting value n: PWMREGi register setting value fj: Count source frequency (Unit: Hz) | | Selectable function | Select output pin: P4 or P9 | i = 0, 1 Figure 21.1 Block Diagram of PWM Table 21.2 I/O Ports | Port | I/O | Function | |------|------------|----------------| | PWM0 | Output (1) | PWM output | | PWM1 | Output (1) | F vvivi output | Note: 1. Set the direction bit corresponding to selected pin to 1 (output mode) ### 21.2 Registers Refer to 8.2.6 "Peripheral Clock Stop Register 1 (PCLKSTP1)" for the explanation of the PCLKSTP1 register. Table 21.3 Registers | Address | Register | Symbol | Reset Value | |---------|----------------------------------|----------|-------------| | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 0370h | PWM Control Register 0 | PWMCON0 | 00h | | 0372h | PWM0 Prescaler | PWMPRE0 | 00h | | 0373h | PWM0 Register | PWMREG0 | 00h | | 0374h | PWM1 Prescaler | PWMPRE1 | 00h | | | PWM1 Register | PWMREG1 | 00h | | 0376h | PWM Control Register 1 | PWMCON1 | 00h | ### 21.2.1 PWM Control Register 0 (PWMCON0) Set bits PWMSELi and PWMCLKi (i = 0, 1) in the PWMCON0 register when the PWMENi bit in the PWMCON1 register is 0 (PWMi output disabled). PWMSEL0 (PWM0 output pin select bit) (b0) PWMSEL1 (PWM1 output pin select bit) (b1) Set these bits to select PWM output pins. See Table 21.4 "PWM Pin and Bit Setting". ### PWMCLK1-PWMCLK0 (PWM count source select bit) (b7-b6) Set these bits to select a count source for the PWMi prescaler. Prescalers PWM0 and PWM1 share the same count source. ### 21.2.2 **PWMi Prescaler (PWMPREi) (i = 0, 1)** ### 21.2.3 PWMi Register (PWMREGi) (i = 0, 1) The PWMi register (i = 0, 1) sets the PWMi cycle (i = 0, 1) and high-level pulse width. The PWM cycle and high-level pulse width are given by: PWM cycle = $$\frac{(2^8 - 1) \times (m + 1)}{fj}$$ (Units: s) High level pulse width = $\frac{(m+1) \times n}{f_i}$ (Units: s) fj: PWM count source frequency (Unit: Hz) m: PWMPREi register setting n: PWMREGi register setting The value written in the PWMPREi register is written to the PWMi prescaler prelatch. At the beginning of the next PWM cycle, the PWMi prescaler prelatch value is transferred to the PWMi prescaler latch and the PWMi prescaler, and then the associated PWMi waveform is output. The value written in the PWMREGi register is written to the PWMi register prelatch. At the beginning of the next PWM cycle, the PWMi register prelatch value is transferred to the PWMi register latch and the PWMi register, and then the associated PWMi waveform is output. When rewriting the PWMPREi and PWMREGi register values while the PWMENi bit in the PWMCON1 register is 0 (PWMi output disabled), after the PWMENi bit is set to 1 (PWMi output enabled), the values prior to being rewritten are reflected in the first cycle of PWM output. Refer 21.3.2 "Operation Example" for output waveforms and transfer timings. When reading the PWMPREi register while the PWMENi bit is 0 (PWMi output disabled), the PWMi prescaler prelatch value is read. Also, when reading the PWMREGi register, the PWMi register latch value is read (See Figure 21.1 "Block Diagram of PWM"). When reading registers PWMPREi and PWMREGi while the PWMENi bit is 1 (PWMi output enabled), an undefined value is read. ## 21.2.4 PWM Control Register 1 (PWMCON1) PWMEN0 (PWM0 output enable bit) (b0) PWMEN1 (PWM1 output enable bit) (b1) Set these bits to start PWM output. See Table 21.4 "PWM Pin and Bit Setting" for details. PWMPORT0 (PWM0 port switch bit) (b2) PWMPORT1 (PWM1 port switch bit) (b3) Set these bits to select a PWM output pin. See Table 21.4 "PWM Pin and Bit Setting" for details. Table 21.4 PWM Pin and Bit Setting | Bit | Setting | | | Din Euneti | on or State | | |------------------|-----------------|-------------|----------------------------------|------------------------------|-------------------------------------------------|------------------------------| | PWMCON0 register | PWMCON | N1 register | | FIII FUIICII | on or state | | | PWMSELi bit | PWMPORTi<br>bit | PWMENi bit | P9_3 | P9_4 | P4_6 | P4_7 | | | 0 | 0 or 1 | | oin for other<br>al function | I/O port or a | ain for other | | 0 | 1 (1) | 0 | PWMi output level maintained (2) | | I/O port or pin for othe<br>peripheral function | | | | | 1 | PWMi pulse output | | | | | | 0 | 0 or 1 | I/O port or a | oin for other | | pin for other<br>al function | | 1 | | 0 | | oin for other<br>al function | PWMi ou | itput level | | | 1 (1) | benpin | | ai iuiiciioii | maintained (2) | | | | | 1 | | | PWMi pu | lse output | i = 0, 1Notes: - 1. Set the direction bit corresponding to the selected pin to 1 (output mode). - 2. Even if the PWMENi bit is set from 1 to 0 during PWMi output, the PWMi output remains unchanged. The PWM output signal is low immediately after the MCU is reset. #### 21.3 Operations ### 21.3.1 Setting Procedure Follow the procedure below to set individual registers in order to start PWMi (i = 0, 1) output. (All SFRs are assumed to be reset. Refer the register descriptions to access registers or bits.) - (1) Write output data of the port corresponding to the pin for PWMi output to the P9 or P4 register. Then, set the direction bit for the corresponding port to 1 (output mode). - (2) Set the PWMSELi bit in the PWMCON0 register to select a pin for PWMi output. Set the PWMCLKi bit to select the count source. - (3) Set registers PWMPREi and PWMREGi to set the PWM cycle and high-level pulse width. - (4) Set the PWMPORTi bit in the PWMCON1 register to 1 (PWMi function) and the PWMENi bit to 1 (PWM output enabled). ### 21.3.2 Operation Example The values written to registers PWMPREi and PWMREGi during PWMi (i = 0, 1) output are not reflected until the next cycle of PWMi output begins. The PWM output signal is low immediately after the MCU is reset. Then, the associated waveform output starts. The PWMi output level remains unchanged even if the PWMENi bit in the PWMCON1 register is changed from 1 (PWMi output enabled) to 0 (PWMi output disabled) during PWMi output. Registers PWMPREi and PWMREGi retain the value before the PWMi output is disabled. When setting the PWMENi bit to 1 after registers PWMPREi and PWMREGi are rewritten while PWMi output is disabled, the values of registers PWMPREi and PWMREGi prior to the change are reflected for the first cycle of PWM output. The rewritten register values are reflected in the following PWMi cycle. Figure 21.2 to Figure 21.4 shows PWMi output examples. Figure 21.2 PWMi Output Example (After Reset and During PWM Output) Figure 21.3 PWMi Output Example (Duty 0%, Duty 100%) Figure 21.4 PWMi Output Example (PWM Output Disabled and PWM Output Resumed) # 22. Remote Control Signal Receiver ### 22.1 Introduction The remote control signal receiver has two circuits for checking the width and period of an of external pulse. Table 22.1 lists Remote Control Receiver Specifications, Figure 22.1 to Figure 22.3 show remote control signal receiver block diagrams, and Table 22.2 lists the I/O Ports. **Table 22.1** Remote Control Receiver Specifications | | tom | Con | tent | | |--------------------|-------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------|--| | ' | tem | PMC0 circuit | PMC1 circuit | | | | | One of the following: | One of the following: | | | | Clock sources | • fC | •fC | | | Count courses | | •f1 | •f1 | | | Count sources | | <ul><li>Timer B2 underflow</li></ul> | <ul><li>Timer B1 underflow</li></ul> | | | | | <ul><li>Count source of PMC1</li></ul> | Timer B2 underflow | | | | Division | No division, divided-by-8, divided | d-by-32, or divided-by-64 | | | Count operation | | Increment | | | | | | Pattern match mode | | | | Operation modes | | Determines that external pulse | e matches specified pattern | | | Operation modes | | <ul> <li>Input capture mode</li> </ul> | | | | | | Measures width and period of | external pulse | | | | | • Header | | | | | Detect patterns | Data 0 | | | | | Detect patterns | Data 1 | | | | | | Special data | | | | | Receive buffer | 6 bytes (48 bits) | None | | | | | Receive error | | | | Pattern match | | <ul> <li>Completion of data reception</li> </ul> | • Doggive orrer | | | mode | Into we set we see a set | <ul><li>Header match</li></ul> | • Receive error | | | | Interrupt request generation timing | <ul><li>Data 0/1 match</li></ul> | <ul><li>Completion of data reception</li><li>Header match</li></ul> | | | | generation timing | <ul> <li>Special data match</li> </ul> | Data 0/1 match | | | | | <ul> <li>Receive buffer full</li> </ul> | Data 0/1 match | | | | | <ul><li>Compare match</li></ul> | | | | | Selectable functions | Input signal inversion | | | | | Selectable functions | Digital filter | | | | | | • Pulse period (between rising e | dge and rising edge) | | | | Measurement items | Pulse period (between falling edge and falling edge) | | | | | | • Pulse width | | | | Innut conture | Interrupt request | • Timer measurement | | | | Input capture mode | generation timing | <ul> <li>Counter overflow</li> </ul> | | | | | | Input signal inversion | | | | | Selectable functions | Digital filter | | | | | Selectable fullctions | Individual count of PMC0 and PMC1 inputs or simultaneous | | | | | | count of PMC0 and PMC1 inpu | uts | | Figure 22.1 Remote Control Signal Receiver Block Diagram (1/3) Figure 22.2 Remote Control Signal Receiver Block Diagram (2/3) (PMCi Input) Figure 22.3 Remote Control Signal Receiver Block Diagram (3/3) (PMCi Count Source) Table 22.2 I/O Ports | Pin Name | I/O | Function | |----------|----------------------|----------------------| | PMC0 | Input <sup>(1)</sup> | External pulse input | | PMC1 | input (1) | External pulse input | ### Note: 1. Set the port direction bits sharing pins to 0 (input mode). # 22.2 Registers Refer to 8.2.6 "Peripheral Clock Stop Register 1 (PCLKSTP1)" for the explanation of the PCLKSTP1 register. Table 22.3 Registers (PMC0 and PMC1 Circuits) | Address | Register | Symbol | Reset Value | |---------|----------------------------------|----------|-------------| | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | Table 22.4 Registers (PMC0 Circuit) | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------|-----------------|-------------| | 01F0h | PMC0 Function Select Register 0 | PMC0CON0 | 00h | | 01F1h | PMC0 Function Select Register 1 | PMC0CON1 | 000XX 0000b | | 01F2h | PMC0 Function Select Register 2 | PMC0CON2 | 0000 00X0b | | 01F3h | PMC0 Function Select Register 3 | PMC0CON3 | 00h | | 01F4h | PMC0 Status Register | PMC0STS | 00h | | 01F5h | PMC0 Interrupt Source Select Register | PMC0INT | 00h | | 01F6h | PMC0 Compare Control Register | PMC0CPC | XXX0 X000b | | 01F7h | PMC0 Compare Data Register | PMC0CPD | 00h | | D080h | - PMC0 Header Pattern Set Register (Min) | PMC0HDPMIN | 0000 0000b | | D081h | Frido Header Falletti Set Register (Mill) | FIVICOLIDEIVIIN | XXXX X000b | | D082h | PMC0 Header Pattern Set Register (Max) | PMC0HDPMAX | 0000 0000b | | D083h | Frinco Header Falletti Set Register (Max) | PIVICUITOPIVIAX | XXXX X000b | | D084h | PMC0 Data 0 Pattern Set Register (Min) | PMC0D0PMIN | 00h | | D085h | PMC0 Data 0 Pattern Set Register (Max) | PMC0D0PMAX | 00h | | D086h | PMC0 Data 1 Pattern Set Register (Min) | PMC0D1PMIN | 00h | | D087h | PMC0 Data 1 Pattern Set Register (Max) | PMC0D1PMAX | 00h | | D088h | - PMC0 Measurements Register | PMC0TIM | 00h | | D089h | FINOU Measurements Register | FIVICUTIIVI | 00h | | D08Ch | PMC0 Receive Data Store Register 0 | PMC0DAT0 | 00h | | D08Dh | PMC0 Receive Data Store Register 1 | PMC0DAT1 | 00h | | D08Eh | PMC0 Receive Data Store Register 2 | PMC0DAT2 | 00h | | D08Fh | PMC0 Receive Data Store Register 3 | PMC0DAT3 | 00h | | D090h | PMC0 Receive Data Store Register 4 | PMC0DAT4 | 00h | | D091h | PMC0 Receive Data Store Register 5 | PMC0DAT5 | 00h | | D092h | PMC0 Receive Bit Count Register | PMC0RBIT | XX00 0000b | Table 22.5 Registers (PMC1 Circuit) | Address | Register | Symbol | Reset Value | |---------|--------------------------------------------|----------------|-------------| | 01F8h | PMC1 Function Select Register 0 | PMC1CON0 | XXX0 X000b | | 01F9h | PMC1 Function Select Register 1 | PMC1CON1 | XXXX 0X00b | | 01FAh | PMC1 Function Select Register 2 | PMC1CON2 | 0000 00X0b | | 01FBh | PMC1 Function Select Register 3 | PMC1CON3 | 00h | | 01FCh | PMC1 Status Register | PMC1STS | X000 X00Xb | | 01FDh | PMC1 Interrupt Source Select Register | PMC1INT | X000 X00Xb | | D094h | PMC1 Header Pattern Set Register (Min) | PMC1HDPMIN | 0000 0000b | | D095h | Pivic i Header Pattern Set Register (will) | PIVICIDEIVIIN | XXXX X000b | | D096h | PMC1 Header Pattern Set Register (Max) | PMC1HDPMAX | 0000 0000b | | D097h | Fino i fleader Falletti Set Register (Max) | FINICITIDENIAX | XXXX X000b | | D098h | PMC1 Data 0 Pattern Set Register (Min) | PMC1D0PMIN | 00h | | D099h | PMC1 Data 0 Pattern Set Register (Max) | PMC1D0PMAX | 00h | | D09Ah | PMC1 Data 1 Pattern Set Register (Min) | PMC1D1PMIN | 00h | | D09Bh | PMC1 Data 1 Pattern Set Register (Max) | PMC1D1PMAX | 00h | | D09Ch | DMC1 Magauromenta Register | PMC1TIM | 00h | | D09Dh | PMC1 Measurements Register | FIVICITIIVI | 00h | ### 22.2.1 PMCi Function Select Register 0 (PMCiCON0) (i = 0, 1) ### EN (PMCi operation enable bit) (b0) The EN bit is used to control start/stop of PMCi operation. Confirm that the operation has started or stopped by the ENFLG bit in the PMCiCON2 register. ### EHOLD (Error flag hold bit) (b3) When a receive error occurs, the period when the REFLG bit in the PMC0STS register retains 1 (receive error) can be selected. Refer to "REFLG (Receive error flag) (b1)" in 22.2.5 "PMCi Status Register (PMCiSTS) (i = 0, 1)" for details. ### HDEN (Header pattern enable bit) (b4) While the HDEN bit is 1 (header enabled), after data reception starts (DRFLG flag is 1), if data 0, data 1, or special data is detected before the header is detected, the following occur: - The REFLG bit in the PMCiSTS register becomes 1 (error occurs) - Bits PTD0FLG, PTD1FLG, and SDFLG in the PMCiSTS register remain unchanged. - Registers PMC0DAT0 to PMC0DAT5 are not rewritten. ### DRINT1-DRINT0 (Receive interrupt control bit) (b7-b6) Set these bits to select a condition for generating a data reception complete interrupt request. Set the DRINT bit in the PMC0INT register to 1 (reception complete interrupt enabled) after setting these bits. When setting the DRINT1 bit to 1, set the EHOLD bit in the PMC0CON0 register to 1 (hold the REFLG bit state after next data received). ### 22.2.2 PMCi Function Select Register 1 (PMCiCON1) (i = 0, 1) EXSDEN (Special pattern detect block select bit) (b6) EXHDEN (Header pattern detect block select bit) (b7) Use these bits when PMC0 and PMC1 are linked and operated in pattern match mode. Otherwise, set them to 0. Set bits EXHDEN to EXSDEN to 01b or 10b when setting the HDEN bit in the PMC0CON0 register to 1 (header enabled) and SDEN bit to 1 (special data pattern enabled). Refer to 22.3.3.2 "Header and Special Data Detection". # 22.2.3 PMCi Function Select Register 2 (PMCiCON2) (i = 0, 1) | 07 b6 b5 b4 b3 b2 b | b1 b0 | Symbol<br>PMC0CON | Address<br>2 01F2h | Reset \ 0000 00 | | |---------------------|------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------| | | ] | Bit Symbol | Bit Name | Function | RW | | | | ENFLG | | 0: Stops<br>1: Operating | RO | | | ! <u>[</u> | <br>(b1) | Reserved bit | Read as undefined value | RO | | | | <br>(b2) | Reserved bit | Set to 0 | RW | | | | INFLG | | PMC0 internal input signal level is low PMC0 internal input signal level is high | RO | | | | CEFLG | I Counter overtion than I | 0: No overflow<br>1: Overflows | RO | | | | CEINT | | 0: Disabled<br>1: Enabled | RW | | | | PSEL0 | Input pin select bit | 07 b6<br>0 0 : Same as PMC1<br>(Set bits PSEL1 to PSEL0 in the<br>PMC1CON2 register to select) | RW | | | | PSEL1 | | 0 1 : PMC0 pin<br>1 0 : Do not set | | | PMC1 Function | on Se | elect Regis | | 1 1 : Do not set | | | PMC1 Function | | Symbol<br>PMC1CON | ster 2 | 1 1 : Do not set Reset \ 0000 00 | | | o7 b6 b5 b4 b3 b2 b | | Symbol | ster 2 | Reset \ | | | o7 b6 b5 b4 b3 b2 b | | Symbol<br>PMC1CON | Address 2 01FAh | Reset \<br>0000 00 | OX0b | | o7 b6 b5 b4 b3 b2 b | | Symbol<br>PMC1CON<br>Bit Symbol | Address 2 O1FAh Bit Name | Reset \ 0000 00 Function 0: Stops | 0X0b<br>RW | | o7 b6 b5 b4 b3 b2 b | | Symbol<br>PMC1CON<br>Bit Symbol<br>ENFLG | Address 2 O1FAh Bit Name PMC1 status flag | Function 0: Stops 1: Operating | RW<br>RO | | o7 b6 b5 b4 b3 b2 b | | Symbol PMC1CON Bit Symbol ENFLG (b1) | Address 2 Address 2 01FAh Bit Name PMC1 status flag Reserved bit | Function 0: Stops 1: Operating Read as undefined value | RW<br>RO<br>RO | | o7 b6 b5 b4 b3 b2 b | | Symbol PMC1CON Bit Symbol ENFLG (b1) (b2) | Address 2 Address 2 01FAh Bit Name PMC1 status flag Reserved bit Reserved bit | Function 0: Stops 1: Operating Read as undefined value Set to 0 0: PMC1 internal input signal level is low | RW<br>RO<br>RO<br>RW | | o7 b6 b5 b4 b3 b2 b | | Symbol PMC1CON Bit Symbol ENFLG (b1) (b2) INFLG | Address 2 Address 2 O1FAh Bit Name PMC1 status flag Reserved bit Reserved bit Input signal flag | Function 0: Stops 1: Operating Read as undefined value Set to 0 0: PMC1 internal input signal level is low 1: PMC1 internal input signal level is high 0: No overflow | RW RO RW RO | | o7 b6 b5 b4 b3 b2 b | | Symbol PMC1CON Bit Symbol ENFLG (b1) (b2) INFLG CEFLG | Address 2 Address 2 O1FAh Bit Name PMC1 status flag Reserved bit Reserved bit Input signal flag Counter overflow flag Counter overflow interrupt | Function 0: Stops 1: Operating Read as undefined value Set to 0 0: PMC1 internal input signal level is low 1: PMC1 internal input signal level is high 0: No overflow 1: Overflows 0: Disabled | RW RO RO RO | ## CEFLG (Counter overflow flag) (b4) Conditions to become 0: - The EN bit in the PMCiCON0 register is 0 (PMCi operation stops) - Measurement timing selected by bits TYP1 to TYP0 in the PMCiCON1 register Condition to become 1: • Counter overflow (the counter becomes 0000h from FFFFh) ### PSEL1-PSEL0 (Input pin select bit) (b7-b6) Change these bits when the EN bit in the PMCiCON0 register and the ENFLG bit in the PMCiCON2 register are both 0 (PMCi stops). Refer to Figure 22.2 "Remote Control Signal Receiver Block Diagram (2/3) (PMCi Input)" and 22.3.1.2 "PMCi Input". ### 22.2.4 PMCi Function Select Register 3 (PMCiCON3) (i = 0, 1) ### CDIV1-CDIV0 (Clock source divisor select bit) (b7-b6) When bits CSRC1 to CSRC0 in the PMC0CON3 register are set to 00b (same as PMC1), set bits CDIV1 to CDIV0 in the PMC0CON3 register to 00b (no division). #### 22.2.5 PMCi Status Register (PMCiSTS) (i = 0, 1) Each bit in the PMCiSTS register changes at a measurement edge of the PMCi internal input signal. However, the DRFLG bit also changes according to the counter value judgement. #### CPFLG (Compare match flag) (b0) This bit is enabled when the CPEN bit in the PMC0CPC register is set to 1 (compare enabled). Conditions to become 0: - When the EN bit in the PMCiCON0 register is 0 (PMCi operation disabled). - When the DRFLG bit in the PMC0STS register changes from 0 to 1 (next frame reception starts). - When the 48th bit is received after the CPFLG bit becomes 1, and then (the DRFLG bit remains 1 (receiving)) no compare match occurs after receiving bit n (n = value set by bits CPN2 to CPN0 in the PMC0CPC register). #### Condition to become 1: • The PMC0CPD register matches the PMC0DAT0 register (when the setting value of bits CPN2 to CPN0 in the PMC0CPC register is n, bits n to 0 in the PMC0CPD register match bits n to 0 in the PMC0DAT0 register). #### REFLG (Receive error flag) (b1) The REFLG bit is a flag indicating a receive error. Conditions for changing the REFLG bit are affected by the HDEN bit in the PMCiCON0 register and bits EHOLD and SDEN in the PMC0CON0 register. Table 22.6 lists Conditions for Changing the REFLG Bit. Table 22.6 Conditions for Changing the REFLG Bit | Bit Set | ting <sup>(1)</sup> | Conditions for Changing the REFLG Bit | Conditions for Changing the REFLG bit | |---------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------| | EHOLD | HDEN | to 1 <sup>(2)</sup> | to 0 (2, 3) | | 0 | 0 | Input signal width is not data 0 or data 1 (or special data) | Receive data 0 or data 1 (or special data) | | 0 | 1 | <ul> <li>Input signal width is not the header,<br/>data 0, or data 1 (or special data)</li> <li>Detect data 0 or data 1 (or special<br/>data) prior to header</li> </ul> | Receive header Receive header prior to data 0 or data 1 (or special data) | | 1 | 0 | Input signal width is not data 0 or data 1 (or special data) | - | | 1 | 1 | <ul> <li>Input signal width is not the header,<br/>data 0, or data 1 (or special data)</li> <li>Detect data 0 or data 1 (or special<br/>data) prior to header</li> </ul> | • Receive header | EHOLD: Bit in the PMC0CON0 register HDEN: Bit in the PMCiCON0 register (i = 0, 1) #### Notes: - 1. For the REFLG bit of PMC1, refer to settings where the EHOLD bit is 0. - 2. Special data is added to the conditions when the SDEN bit in the PMC0CON0 register is 1 (special data pattern enabled). - 3. The REFLG bit becomes 0 regardless of bits HDEN and EHOLD under the following conditions: - The EN bit in the PMCiCON0 register is 0 (PMCi stops). - The DRFLG bit in the PMCiSTS register changes from 0 to 1. ### DRFLG (Data receiving flag) (b2) The DRFLG bit indicates the receiving state of the remote control signal. The bit is 1 while receiving one frame. When data reception ends, the bit becomes 0. #### Conditions to become 0: - The EN bit in the PMCiCON0 register is 0 (PMCi operation disabled). - The counter value is larger than values of registers PMCiHDPMAX, PMCiD0PMAX, and PMCiD1PMAX (if the counter value is larger than these register values, this bit becomes 0 after waiting one to two cycles of the count source). #### Conditions to become 1: The condition to become 1 is dependent on bits TYP1 to TYP0 in the PMCiCON1 register (receive mode select). - When bits TYP1 to TYP0 are 00b (pulse period measurement) or 01b (high level width measurement): - rising edge of the PMCi internal input signal - When bits TYP1 to TYP0 are 10b (pulse width measurement): rising edge and falling edge of the PMCi internal input signal #### BFULFLG (Receive buffer full flag) (b3) Conditions to become 0: - The EN bit in the PMCiCON0 register is 0 (PMCi operation disabled). - The DRFLG bit in the PMCiSTS register changes from 0 to 1. - The value of the PMC0RBIT register changes from 48 to 1. #### Condition to become 1: • The value of the PMC0RBIT register changes from 47 to 48. PTHDFLG (Header pattern match flag) (b4), PTD0FLG (Data 0 pattern match flag) (b5), PTD1FLG (Data 1 pattern match flag) (b6), SDFLG (Special pattern match flag) (b7) #### Conditions to become 0: - The EN in the PMCiCON0 register bit is 0 (PMCi stops). - The DRFLG bit in the PMCiSTS register changes from 0 to 1. - See Table 22.7 "Measurements and Flags". - The REFLG bit changes from 0 to 1. #### Condition to become 1: • See Table 22.7 "Measurements and Flags". #### Table 22.7 Measurements and Flags | Value (Measurements) of the PMCiTIM Register | Flag | | | | | |-------------------------------------------------|---------|---------|---------|-------|--| | value (ineasurements) of the Finorthin Register | PTHDFLG | PTD0FLG | PTD1FLG | SDFLG | | | Between PMCiHDPMIN and PMCiHDPMAX | 1 | 0 | 0 | 0 | | | (header measurement in PMCi) | ı | 0 | O | 0 | | | Between PMCiD0PMIN and PMCiD0PMAX | 0 | 1 (1) | 0 | 0 | | | Between PMCiD1PMIN and PMCiD1PMAX | 0 | 0 | 1 (1) | 0 | | | Between PMCiHDPMIN and PMCiHDPMAX | 0 | 0 | 0 | 1 (1) | | | (special data measurement in PMCi) | U | O | U | 1 (1) | | | Values not listed above | 0 | 0 | 0 | 0 | | #### Note: When the HDEN bit in the PMCiCON0 register is 1 (header enabled), PTD0FLG, PTD1FLG, and SDFLG remain unchanged until header is detected. # 22.2.6 PMCi Interrupt Source Register (PMCiINT) (i = 0, 1) | 07 b6 b5 b4 b3 b2 b1 b0 | Symbol<br>PMC0INT | Address<br>01F5h | | t Value<br>0h | |-------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | | Bit Symbol | Bit Name | Function | RW | | | CPINT | Compare match flag interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | | REINT | Receive error flag interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | | DRINT | Data reception complete interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | | BFULINT | Receive buffer full flag interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | | PTHDINT | Header match flag interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | | PTDINT | Data 0/1 match flag interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | ļ | TIMINT | Timer measure interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | į | | Special data match flag | O. Dischlad | | | PMC1 Interrupt So | SDINT Durce Regi | interrupt enable bit | 0: Disabled<br>1: Enabled | RW | | PMC1 Interrupt Sc | | interrupt enable bit | 1: Enabled | t Value | | • | ource Regi | ster Address | 1: Enabled | t Value<br>X00Xb | | • | Symbol<br>PMC1INT | ster Address 01FDh Bit Name | 1: Enabled Rese X000 | t Value<br>X00Xb | | • | Symbol PMC1INT Bit Symbol — | ster Address 01FDh Bit Name | 1: Enabled Rese X000 | t Value<br>X00Xb | | • | Symbol PMC1INT Bit Symbol — (b0) | ster Address 01FDh Bit Name No register bit. If necessary, Receive error flag interrupt | 1: Enabled Rese X000 Function set to 0. Read as undefined value. 0: Disabled | t Value<br>X00Xb | | • | Symbol PMC1INT Bit Symbol (b0) REINT | Ster Address 01FDh Bit Name No register bit. If necessary, Receive error flag interrupt enable bit Data reception complete interrupt enable bit | 1: Enabled Rese X000 Function set to 0. Read as undefined value. 0: Disabled 1: Enabled 0: Disabled | t Value<br>X00Xb<br>RW<br>— | | • | Symbol PMC1INT Bit Symbol (b0) REINT DRINT | Ster Address 01FDh Bit Name No register bit. If necessary, Receive error flag interrupt enable bit Data reception complete interrupt enable bit | Rese X000 Function set to 0. Read as undefined value. 0: Disabled 1: Enabled 0: Disabled 1: Enabled | t Value<br>X00Xb<br>RW<br>— | | • | Symbol PMC1INT Bit Symbol (b0) REINT DRINT (b3) | Address 01FDh Bit Name No register bit. If necessary, Receive error flag interrupt enable bit Data reception complete interrupt enable bit No register bit. If necessary, Header match flag interrupt | Rese X000 Function set to 0. Read as undefined value. 0: Disabled 1: Enabled 0: Disabled 1: Enabled set to 0. Read as undefined value. 0: Disabled | t Value<br>X00Xb<br>RW<br> | | • | Bit Symbol — (b0) REINT DRINT — (b3) PTHDINT | Ster Address 01FDh Bit Name No register bit. If necessary, Receive error flag interrupt enable bit Data reception complete interrupt enable bit No register bit. If necessary, Header match flag interrupt enable bit Data 0/1 match flag | Rese X000 Function set to 0. Read as undefined value. 0: Disabled 1: Enabled 0: Disabled 1: Enabled set to 0. Read as undefined value. 0: Disabled 1: Enabled 0: Disabled 0: Disabled 1: Enabled 0: Disabled 1: Enabled | t Value<br>X00Xb<br>RW<br> | # 22.2.7 PMCi Header Pattern Set Register (MIN) (PMCiHDPMIN) (i = 0, 1) PMCi Header Pattern Set Register (MAX) (PMCiHDPMAX) (i = 0, 1) When using a header or special data detection, set the minimum width of header or special data pattern to the PMCiHDPMIN register and the maximum width to the PMCiHDPMAX register. Set different values from data 0 or data 1 to these registers. Each value must meet following: - PMCiHDPMIN register value < PMCiHDPMAX register value</li> - The value other than 0000h See Figure 22.4 "Setting Values of the Header Pattern and Data Patterns". When not using a header or special data detection, set registers PMCiHDPMIN and PMCiHDPMAX to 0000h. The above shows the case for independent operation. For independent operation, the ranges between minimum and maximum values of header, data 0, and data 1 patterns should not overlap each other. For combined operation, the ranges between minimum and maximum values of header, data 0, data 1, and special patterns should not overlap each other. Figure 22.4 Setting Values of the Header Pattern and Data Patterns # 22.2.8 PMCi Data 0 Pattern Set Register (MIN) (PMCiD0PMIN) (i = 0, 1) PMCi Data 0 Pattern Set Register (MAX) (PMCiD0PMAX) (i = 0, 1) PMCi Data 1 Pattern Set Register (MIN) (PMCiD1PMIN) (i = 0, 1) PMCi Data 1 Pattern Set Register (MAX) (PMCiD1PMAX) (i = 0, 1) When detecting data 0, set the minimum width of the data 0 pattern to the PMCiD0PMIN register and the maximum width to the PMCiD0PMAX register. Also when detecting data 1, set the minimum width of the data 1 pattern to the PMCiD1PMIN register and the maximum width to the PMCiD1PMAX register. Setting value n = $$\frac{\text{minimum width (maximum width) of data 0/1 pattern}}{\text{count source}}$$ Data 0, data 1, and header or special data pattern must be different values. Also, each value must meet following: - PMCiD0PMIN register value < PMCiD0PMAX register value - PMCiD1PMIN register value < PMCiD1PMAX register value</li> - Value other than 0000h See Figure 22.4 "Setting Values of the Header Pattern and Data Patterns". When not detecting data 0, set registers PMCiD0PMIN and PMCiD0PMAX to 00h. When not detecting data 1, set registers PMCiD1PMIN and PMCiD1PMAX to 00h. When in combined operation, set registers PMC1D0PMIN, PMC1D0PMAX, PMC1D1PMIN, and PMC1D1PMAX to 00h. #### 22.2.9 PMCi Measurements Register (PMCiTIM) (i = 0, 1) When the EN bit in the PMCiCON0 register is 0 (PMCi operation disabled), the PMCiTIM register becomes 0000h. #### 22.2.10 PMC0 Receive Bit Count Register (PMC0RBIT) The bit position of the storing buffer is specified by counting detected data 0 or data 1. When the receive bit count exceeds 48, it returns to 1. The header and special data are not counted. The PMC0RBIT register becomes 0 when: - The EN bit in the PMC0CON0 register is 0 (PMCi operation disabled). - The DRFLG bit in the PMC0STS register changes from 0 to 1. ## 22.2.11 PMC0 Receive Data Store Register i (PMC0DATi) (i = 0 to 5) When detecting data 0 or data 1, the result is stored bit by bit according to the PMC0RBIT register setting. The data is stored to the PMC0DATi register starting from bit 0 in the PMC0DAT0 register. Table 22.8 lists Order of Storing Data. When the data exceeds 48 bits, the PMC0DATi register is sequentially overwritten from the first bit in the PMC0DAT0 register. Also, after the DRFLG bit in the PMCiSTS register changes from 0 to 1 (next frame reception starts), the PMC0DATi register is sequentially overwritten from the first bit in the PMC0DAT0 register. The header and special data are not stored. When the EN bit in the PMCiCON0 register is 0 (PMCi operation disabled), the PMC0DATi register becomes 00h. Table 22.8 Order of Storing Data | Register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |----------|----|----|----|----|----|----|----|----| | PMC0DAT0 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | PMC0DAT1 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | | PMC0DAT2 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | | PMC0DAT3 | 32 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | | PMC0DAT4 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | | PMC0DAT5 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | #### 22.2.12 PMC0 Compare Control Register (PMC0CPC) #### CPN2-CPN0 (Compare bit specify bit) (b2-b0) These bits are enabled when the CPEN bit is 1 (compare enabled). When the setting value of bits CPN2 to CPN0 is n, bits n to 0 are compared. e.g.1 Setting value = 0 Bit 0 in the PMC0CPD register and bit 0 in the PMC0DAT0 register are compared. e.g.2 Setting value = 7 Bits 7 to 0 in the PMC0CPD register and bits 7 to 0 in the PMC0DAT0 register are compared. #### CPEN (Compare enable bit) (b4) When the CPEN bit is 1 (compare enabled), values from registers PMC0CPD and PMC0DAT0 are compared. When storing received data, if the compared results match, the CPFLG bit in the PMC0STS register becomes 1 (compare match). # 22.2.13 PMC0 Compare Data Register (PMC0CPD) This register is enabled when the CPEN bit in the PMC0CPC register is 1 (compare enabled). Bits to be compared are selected by bits CPN2 to CPN0 in the PMC0CPC register. #### 22.3 Operations #### 22.3.1 Common Operations in Multiple Modes #### **22.3.1.1 Count Source** The clock source and divisor of the count source can be selected by bits CSRC1 to CSRC0 and bits CDIV1 to CDIV0 in the PMCiCON3 register (see Figure 22.3 "Remote Control Signal Receiver Block Diagram (3/3) (PMCi Count Source)"). When using fC, set the PM25 bit in the PM2 register to 1 (peripheral clock fC provided). Refer to 8. "Clock Generator" for details of fC. When using timer B1 or B2 underflow, one cycle of the count source consists of one timer B1 or B2 underflow cycle. Use timer B1 or B2 in timer mode. Refer to 18. "Timer B" for details. To use the same count source in PMC0 and PMC1, set bits CSRC1 to CSRC0 in the PMC0CON3 register to 00b (same count source as PMC1), and bits CDIV1 to CDIV0 in the PMC0CON3 register to 00b (no division). #### 22.3.1.2 **PMCi Input** The options below can be selected in PMCi input (see Figure 22.2 "Remote Control Signal Receiver Block Diagram (2/3) (PMCi Input)"). - Input pin - Input polarity - Digital filter A pin to which the PMCi signal is input is selected by setting bits PSEL1 to PSEL0 in the PMCiCON2 register. To process the signal input to the PMC0 pin in the PMC1 circuit, or to process the signal input to the PMC1 pin in the PMC0 circuit, use the same count source in PMC0 and PMC1. (refer to 22.3.1.1 "Count Source"). Input polarity of the PMCi pin can be inverted. Whether to invert or not can be selected by setting the SINV bit in the PMCiCON0 register. If the signal input to the PMCi pin holds the same level for four sequential cycles when the FIL bit in the PMCiCON0 register is 1 (digital filter enabled), that level is transferred to the internal circuit. The sampling clock of the digital filter is the count source. Select bits CSRC1 to CSRC0 (count source) in the PMC0CON3 register and bits CDIV1 to CDIV0 (count source divisor) before selecting bits PSEL1 to PSEL0 (input pin), the FIL bit (digital filter), and the SINV bit (input signal polarity invert). Input to the PMCi pin is transferred to the internal circuit in synchronization with the count source. Internal processing causes a delay. Figure 22.5 shows PMCi Input Delay. Figure 22.5 PMCi Input Delay # 22.3.2 Pattern Match Mode (PMC0 and PMC1 Operate Independently) Pattern match mode determines whether an external pulse matches a specified pattern. The header, data 0, and data 1 patterns can be measured in PMC0 and PMC1 separately. **Table 22.9 Pattern Match Mode Specifications (Independent Operation)** | Ite | m | Con | tents | |-------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------| | item | | PMC0 Circuit | PMC1 Circuit | | Clask | | One of the following: | One of the following: | | | | •fC | •fC | | Count | Clock | •f1 | •f1 | | sources | Sources | Timer B2 underflow | Timer B1 underflow | | | | Count source of PMC1 | • Timer B2 underflow | | | Division | No division, divided-by-8, divided-by-3 | 32, or divided-by-64 | | Count operation | on | Increment | | | | | Header or special data | • Header | | Detect pattern | s | Data 0 | Data 0 | | | | Data 1 | Data 1 | | Receive buffer | r | 6 bytes (48 bits) | None | | Interrupt request generation timing | | <ul> <li>Receive error</li> <li>Completion of data reception</li> <li>Header match</li> <li>Data 0/1 match</li> <li>Special data match</li> <li>Receive buffer full</li> <li>Compare match</li> </ul> | <ul> <li>Receive error</li> <li>Completion of data reception</li> <li>Header match</li> <li>Data 0/1 match</li> </ul> | | Selectable functions | | <ul><li>Input signal inversion</li><li>Digital filter</li></ul> | | Table 22.10 Registers and Setting Values in Pattern Match Mode (Independent Operation) (1/2) (1) | Decistan | Dit | Function | | | | |-----------|---------|--------------------------------|-------------------------------|--|--| | Register | Bit | PMC0 | PMC1 | | | | | EN | Set to 1. | Set to 1. | | | | | SINV | Select input signal polarity. | Select input signal polarity. | | | | | FIL | Select filter enabled or | Select filter enabled or | | | | | FIL | disabled. | disabled. | | | | | EHOLD | Select receive error holding | _ | | | | PMCiCON0 | LITOLD | period. | - | | | | 1 WOIOONO | HDEN | Select header enabled or | Select header enabled or | | | | | TIDEIV | disabled. | disabled. | | | | | SDEN | Select special data enabled or | _ | | | | | | disabled. | | | | | | DRINT0 | Select receive interrupt | _ | | | | | DRINT1 | generating condition. | | | | | | TYP0 | Select measuring object. | Select measuring object. | | | | | TYP1 | - , | Coloot mododing object. | | | | PMCiCON1 | CSS | Set to 0. | - | | | | | EXSDEN | Set to 0. | - | | | | | EXHDEN | Set to 0. | - | | | | | ENFLG | Flag indicating PMC0 | Flag indicating PMC1 | | | | | | operated/stopped. | operated/stopped. | | | | | INFLG | Input signal flag | Input signal flag | | | | PMCiCON2 | CEFLG | Not used. | Not used. | | | | | CEINT | Set to 0. | Set to 0. | | | | | PSEL0 | Set to 01b. | Select input pin. | | | | | PSEL1 | | | | | | | CRE | Set to 0. | Set to 0. | | | | | CFR | Set to 0. | Set to 0. | | | | | CST | Set to 0. | Set to 0. | | | | PMCiCON3 | PD | Set to 0. | Set to 0. | | | | I WOOONO | CSRC0 | Select clock source | Select clock source | | | | | CSRC1 | Coloot Glook Source | Coloot Glock Source | | | | | CDIV0 | Select count source divisor. | Select count source divisor. | | | | | CDIV1 | Select count source divisor. | Defect court source divisor. | | | | | CPFLG | Compare match flag | - | | | | | REFLG | Receive error flag | Receive error flag | | | | | DRFLG | Data receiving flag | Data receiving flag | | | | PMCiSTS | BFULFLG | Receive buffer full flag | - | | | | FIVIOIOTO | PTHDFLG | Header pattern match flag | Header pattern match flag | | | | | PTD0FLG | Data 0 pattern match flag | Data 0 pattern match flag | | | | | PTD1FLG | Data 1 pattern match flag | Data 1 pattern match flag | | | | | SDFLG | Special pattern match flag | - | | | i = 0, 1 Note: <sup>-:</sup> Unimplemented bits in PMC1 Table 22.11 Registers and Setting Values in Pattern Match Mode (Independent Operation) (2/2) (1) | <del> </del> | | - | .0 | |-----------------------------------------|---------|---------------------------------------------------------|------------------------------------------------------| | Register | Bit | | ction | | <b>9</b> | - | PMC0 | PMC1 | | | CPINT | Set to 1 when using compare match flag interrupt. | - | | | REINT | Set to 1 when using receive | Set to 1 when using receive | | | KEINI | error flag interrupt. | error flag interrupt. | | | DRINT | Set to 1 when using data | Set to 1 when using data | | | DRINI | reception complete interrupt. | reception complete interrupt. | | PMCiINT | BFULINT | Set to 1 when using receive buffer full flag interrupt. | - | | | PTHDINT | Set to 1 when using header match flag interrupt. | Set to 1 when using header match flag interrupt. | | | PTDINT | Set to 1 when using data 0/1 match flag interrupt. | Set to 1 when using data 0/1 match flag interrupt. | | | TIMINT | Set to 0. | Set to 0. | | | | Set to 1 when using special | | | | SDINT | data match flag interrupt. | - | | | CPN0 | | | | | CPN1 | Select bits to be compared | - | | PMC0CPC | CPN2 | when using compare function. | | | | | Set to 1 when using compare | | | | CPEN | function. | - | | PMC0CPD | 0 to 7 | Set compare value when using | | | FINICOCED | 0 10 7 | compare function. | - | | PMCiHDPMIN | 0 to 10 | Set minimum value of header | Set minimum value of header | | T WOITED WIN | 0 10 10 | pattern. | pattern. | | PMCiHDPMAX | 0 to 10 | Set maximum value of header | Set maximum value of header | | 1 1010111111111111111111111111111111111 | 0.0.10 | pattern. | pattern. | | PMCiD0PMIN | 0 to 7 | Set minimum value of data 0 pattern. | Set minimum value of data 0 pattern. | | PMCiD0PMAX | 0 to 7 | Set maximum value of data 0 pattern. | Set maximum value of data 0 pattern. | | | | Set minimum value of data 1 | Set minimum value of data 1 | | PMCiD1PMIN | 0 to 7 | pattern. | pattern. | | PMCiD1PMAX | 0 to 7 | Set maximum value of data 1 pattern. | Set maximum value of data 1 pattern. | | PMCiTIM | 0 to 15 | Measured value of pulse period or width can be read. | Measured value of pulse period or width can be read. | | PMC0DAT0 to<br>PMC0DAT5 | 0 to 7 | Received data can be read. | - | | PMC0RBIT | 0 to 5 | Received bit count can be read. | - | i = 0, 1 Note: <sup>-:</sup> Unimplemented bits in PMC1 Figure 22.6 Operations in Pattern Match Mode Figure 22.7 Flag Operation Example #### 22.3.2.1 Header Detection (PMC0, PMC1) While the HDEN bit in the PMCiCON0 register is 1 (header enabled), after data reception starts (DRFLG flag is 1), when signal other than the header pattern is detected before the header is detected, the following occur: - The REFLG bit in the PMCiSTS register becomes 1 (error occurs). - Bits PTD0FLG, PTD1FLG, and SDFLG in the PMCiSTS register remain unchanged even if the detected signal is data 0, data 1, or special data. - Registers PMC0DAT0 to PMC0DAT5 remain unchanged. When detecting the header in PMC0, set the SDEN bit in the PMC0CON0 register to 0 (special data disabled). #### 22.3.2.2 Special Data Detection (PMC0) When the SDEN bit in the PMC0CON0 register is 1 (special data enabled), special data can be detected. When detecting special data, set the HDEN bit in the PMC0CON0 register to 0 (header disabled). #### 22.3.2.3 Receive Data Buffer (PMC0) There is a 6-byte (48-bit) buffer for storing received data. When the data exceeds 48 bits, the buffer is sequentially overwritten from the first bit. Refer to 22.2.11 "PMC0 Receive Data Store Register i (PMC0DATi) (i = 0 to 5)" and 22.2.10 "PMC0 Receive Bit Count Register (PMC0RBIT)". #### 22.3.2.4 Compare Function (PMC0) Values for registers PMC0CPD and PMC0DAT0 are compared. As a result, it can be detected that the first 1 to 8 bits of the remote control signal are the specific values. When using the compare function, set the following: - Set the CPEN bit in the PMC0CPC register to 1 (compare enabled). - Select bits to be compared by setting bits CPN2 to CPN0 in the PMC0CPC register (when the setting value is n, bits n to 0 are compared. n: 0 to 7). - Set the compare data in the PMC0CPD register. When storing received data, if the compared results match, the CPFLG bit in the PMC0STS register becomes 1 (compare match). Figure 22.8 Receive Buffer and Compare Function # 22.3.3 Pattern Match Mode (Combined Operation of PMC0 and PMC1) PMC0 and PMC1 are combined and one remote control signal can be received. In a combined operation, data 0 and data 1 are detected in PMC0. Whether to detect the header and special data in PMC0 or PMC1 can be selected. Select count source and remote control signal input pins in PMC1. **Table 22.12 Pattern Match Mode Specifications (Combined Operation)** | | Item | C | Content | |--------------|-------------------|--------------------------------------------------|-------------------------------------| | | item | PMC0 Circuit | PMC1 Circuit | | | | | One of the following: | | | | | •fC | | Count | Clock sources | Count source of PMC1 | •f1 | | sources | | | • Timer B1 underflow | | Sources | | | • Timer B2 underflow | | | Division | No division | No division, divided-by-8, divided- | | | | TWO GIVISION | by-32, or divided-by-64 | | Count ope | ration | Increment | | | | | • Header | • Header | | Detect pat | terne | Data 0 | | | Detect pati | icinis | Data 1 | | | | | Special data | Special data | | Receive bu | uffer | 6 bytes (48 bits) | None | | | | Receive error | | | | | <ul> <li>Completion of data reception</li> </ul> | | | Interrupt re | equest generation | Header match | | | timing | equest generation | Data 0/1 match | Not used | | l IIIIII | | Special data match | | | | | Receive buffer full | | | | | Compare match | | | Selectable | functions | Input signal inversion | | | Selectable | TUTICUUTIS | Digital filter | | Table 22.13 Registers and Setting Values in Pattern Match Mode (Combined Operation) (1/2) (1) | Danistan | D:4 | Function | | | | |------------|---------|----------------------------------|---------------------------------|--|--| | Register | Bit | PMC0 | PMC1 | | | | | EN | Set to 1. Refer to 22.3.3.1 | Set to 1. Refer to 22.3.3.1 | | | | | □IN | "Setting Procedure". | "Setting Procedure". | | | | | SINV | Set to 0. | Select input signal polarity. | | | | | FIL | Set to 0. | Select filter enabled/disabled. | | | | | EHOLD | Select receive error holding | | | | | PMCiCON0 | EHOLD | period. | - | | | | PIVICICONO | HDEN | Select header | Set to 1. | | | | | HDLN | enabled/disabled. | Set to 1. | | | | | SDEN | Select special data | _ | | | | | | enabled/disabled. | _ | | | | | DRINT0 | Select receive interrupt | _ | | | | | DRINT1 | generating condition. | _ | | | | | TYP0 | Select measuring object. | Select measuring object. Set | | | | | TYP1 | - Select measuring object. | the same value as PMC0. | | | | PMCiCON1 | CSS | Set to 0. | - | | | | | EXSDEN | Select block in which header | | | | | | EXHDEN | and special pattern is detected. | - | | | | | ENFLG | Flag indicating PMCi | Not used. | | | | | LINIFLG | operated/stopped. | | | | | | INFLG | Input signal flag Not used. | | | | | PMCiCON2 | CEFLG | Not used. | Not used. | | | | | CEINT | Set to 0. | Set to 0. | | | | | PSEL0 | Set to 00b. | Select input pin. | | | | | PSEL1 | Set to oob. | Select input pin. | | | | | CRE | Set to 0. | Set to 0. | | | | | CFR | Set to 0. | Set to 0. | | | | | CST | Set to 0. | Set to 0. | | | | PMCiCON3 | PD | Set to 0. | Set to 0. | | | | FIVICICONS | CSRC0 | Set to 00b. | Select clock source. | | | | | CSRC1 | - Set to oob. | Select clock source. | | | | | CDIV0 | Sat to OOb | Select count source divisor. | | | | | CDIV1 | Set to 00b. | Select count source divisor. | | | | | CPFLG | Compare match flag | - | | | | | REFLG | Receive error flag | Not used | | | | | DRFLG | Data receiving flag | Not used | | | | DMC:CTC | BFULFLG | Receive buffer full flag | - | | | | PMCiSTS | PTHDFLG | Header pattern match flag | Not used | | | | | PTD0FLG | Data 0 pattern match flag | Not used | | | | | PTD1FLG | Data 1 pattern match flag | Not used | | | | | SDFLG | Special pattern match flag | _ | | | i = 0, 1 Note: <sup>-:</sup> Unimplemented bit in PMC1 Table 22.14 Registers and Setting Values in Pattern Match Mode (Combined Operation) (2/2) (1) | Pogistor Pit | | Function | | | | |-------------------------|---------|-----------------------------------------------------------------------------------|--------------------------------------------------------------|--|--| | Register | Bit | PMC0 | PMC1 | | | | | CPINT | Set to 1 when using compare match flag interrupt. | - | | | | | REINT | Set to 1 when using receive error flag interrupt. | Set to 0. | | | | | DRINT | Set to 1 when using data reception complete interrupt. | Set to 0. | | | | PMCiINT | BFULINT | Set to 1 when using receive buffer full flag interrupt. | - | | | | | PTHDINT | Set to 1 when using header match flag interrupt. | Set to 0. | | | | | PTDINT | Set to 1 when using data 0/1 match flag interrupt. | Set to 0. | | | | | TIMINT | Set to 0. | Set to 0. | | | | | SDINT | Set to 1 when using special data match flag interrupt. | - | | | | | CPN0 | Calact hits to be compared | | | | | | CPN1 | <ul><li>Select bits to be compared</li><li>when using compare function.</li></ul> | - | | | | PMC0CPC | CPN2 | when using compare function. | | | | | | CPEN | Set to 1 when using compare function. | - | | | | PMC0CPD | 0 to 7 | Set compare value when using compare function. | - | | | | PMCiHDPMIN | 0 to 10 | Set minimum value of header pattern or special data pattern. | Set minimum value of header pattern or special data pattern. | | | | PMCiHDPMAX | 0 to 10 | Set maximum value of header pattern or special data pattern. | Set maximum value of header pattern or special data pattern. | | | | PMCiD0PMIN | 0 to 7 | Set minimum value of data 0 pattern. | Set to 00h. | | | | PMCiD0PMAX | 0 to 7 | Set maximum value of data 0 pattern. | Set to 00h. | | | | PMCiD1PMIN | 0 to 7 | Set minimum value of data 1 pattern. | Set to 00h. | | | | PMCiD1PMAX | 0 to 7 | Set maximum value of data 1 pattern. | Set to 00h. | | | | PMCiTIM | 0 to 15 | Measured value of pulse period or width can be read. | Not used. | | | | PMC0DAT0 to<br>PMC0DAT5 | 0 to 7 | Received data can be read. | - | | | | PMC0RBIT | 0 to 5 | Received bit count can be read. | - | | | i = 0, 1 Note: <sup>-:</sup> Unimplemented bit in PMC1 #### 22.3.3.1 Setting Procedure To start or stop counting, follow these steps: - (1) Set bits CSRC1 to CSRC0 and bits CDIV1 to CDIV0 in the PMCiCON3 register. - (2) Set bits PSEL1 to PSEL0 in the PMCiCON2 register and bits FIL and SINV in the PMCiCON0 register. - (3) Wait for four cycles of count source. - (4) Set the EN bit in the PMC1CON0 register to 1 (0 to stop). - (5) Set the EN bit in the PMC0CON0 register to 1 (0 to stop). - (6) Wait for two cycles of count source. - (7) Confirm that the ENFLG bit in the PMC0CON2 register is 1 (0 to stop). (The ENFLG bit in the PMC1CON2 register is disabled) #### 22.3.3.2 Header and Special Data Detection The header and special data can be detected. Table 22.15 lists Selection of Header and Special Data Detecting Block. Table 22.15 Selection of Header and Special Data Detecting Block | Detected Item | | Bit Setting (1) | | | | | |---------------|--------------|-----------------|-------------|------------|-------------|--| | PMC0 | PMC1 | PMC0CON | N0 register | PMC0CON | N1 register | | | FIVICO | FIVICT | HDEN bit | SDEN bit | EXHDEN bit | EXSDEN bit | | | - | Header | 1 | 0 | 1 | 0 | | | - | Special data | 0 | 1 | 0 | 1 | | | Header | Special data | 1 | 1 | 0 | 1 | | | Special data | Header | 1 | 1 | 1 | 0 | | <sup>-:</sup> Neither header nor special data is detected #### Note: 1. Only set the values listed in this table. When the header is enabled, after data reception starts (DRFLG flag is 1), if data 0, data 1, or special data is detected before the header is detected, the following occur: - The REFLG bit in the PMC0STS register becomes 1 (error occurs). - Bits PTD0FLG, PTD1FLG, and SDFLG in the PMC0STS register remain unchanged. - Registers PMC0DAT0 to PMC0DAT5 remain unchanged. #### 22.3.3.3 Status Flag and Interrupt When connecting PMC0 and PMC1, use flags and the interrupt control in PMC0. The corresponding bits are as follows: Each bit in the PMC0STS register Each bit in the PMC0INT register The INFLG bit in the PMC0CON2 register Even when detecting the header or special data in PMC1, the result including that data can be detected in the above registers. #### 22.3.3.4 Receive Data Buffer (PMC0) There is a 6-byte (48-bit) buffer for storing received data. When the data exceeds 48 bits, the buffer is sequentially overwritten from the first bit. Refer to 22.2.11 "PMC0 Receive Data Store Register i (PMC0DATi) (i = 0 to 5)" and 22.2.10 "PMC0 Receive Bit Count Register (PMC0RBIT)". #### 22.3.3.5 Compare Function (PMC0) Values from registers PMC0CPD and PMC0DAT0 are compared. From the result, reception of the specified value which is selected from the first 1 to 8 bits of the remote control signal can be detected. When using the compare function, set the following: - Set the CPEN bit in the PMC0CPC register to 1 (compare enabled). - Select bits to be compared by setting bits CPN2 to CPN0 in the PMC0CPC register (when setting value is n, bits n to 0 are compared; n: 0 to 7). - Set the compare data in the PMC0CPD register. When storing received data, if the compared results match, the CPFLG bit in the PMC0STS register becomes 1 (compare match). # 22.3.4 Input Capture Mode (Operating PMC0 and PMC1 Independently) The input capture mode measures width or period of external pulse. PMC0 and PMC1 can be measured independently. **Table 22.16 Input Capture Mode Specifications (Independent Operation)** | | Item | Cor | Content | | | |------------------------------|---------------|------------------------------------------------------------|-----------------------|--|--| | | петт | PMC0 Circuit | PMC1 Circuit | | | | | | One of the following: | One of the following: | | | | | | •fC | •fC | | | | Count | Clock sources | •f1 | •f1 | | | | sources | | • Timer B2 underflow | • Timer B1 underflow | | | | | | Count source of PMC1 | • Timer B2 underflow | | | | | Division | No division, divided-by-8, divided-by-32, or divided-by-64 | | | | | Count ope | eration | Increment | | | | | | | One of the following: | | | | | Measured | itomo | Pulse period (between rising edge and rising edge) | | | | | Measureu | items | Pulse period (between falling edge and falling edge) | | | | | | | Pulse width (both high level and low level) | | | | | Interrupt request generation | | Timer measurement | | | | | timing | | Counter overflow | | | | | Calaatabla | functions | • Input signal inversion | | | | | Selectable | e functions | • Digital filter | | | | Table 22.17 Registers and Setting Values in Input Capture Mode (Independent Operation) (1/2) (1) | Decistor Dit | | Function | | | | |--------------|---------|------------------------------------|------------------------------------|--|--| | Register | Bit | PMC0 | PMC1 | | | | | EN | Set to 1. | Set to 1. | | | | | SINV | Select input signal polarity. | Select input signal polarity. | | | | | FIL | Select filter enabled or disabled. | Select filter enabled or disabled. | | | | DMC:CONO | EHOLD | Set to 0. | - | | | | PMCiCON0 | HDEN | Set to 0. | Set to 0. | | | | | SDEN | Set to 0. | - | | | | | DRINT0 | Cat to OOk | - | | | | | DRINT1 | Set to 00b. | | | | | | TYP0 | Out of the state of the state of | | | | | | TYP1 | Select measuring object. | Select measuring object. | | | | PMCiCON1 | CSS | Set to 0. | - | | | | | EXSDEN | Set to 0. | - | | | | | EXHDEN | Set to 0. | - | | | | | ENFLG | Flag indicating PMC0 | Flag indicating PMC1 | | | | | ENFLG | operated/stopped. | operated/stopped. | | | | | INFLG | Input signal flag. | Input signal flag. | | | | PMCiCON2 | CEFLG | Counter overflow flag. | Counter overflow flag. | | | | FIVICICOINZ | CEINT | Set to 1 when using counter | Set to 1 when using counter | | | | | OLINI | overflow interrupt. | overflow interrupt. | | | | | PSEL0 | Set to 01b. | Set to 10b. | | | | | PSEL1 | | | | | | | CRE | Set to 1. | Set to 1. | | | | | CFR | Set to 1. | Set to 1. | | | | | CST | Set to 1. | Set to 1. | | | | PMCiCON3 | PD | Set to 1. | Set to 1. | | | | 1 WOOONS | CSRC0 | Select clock source. | Select clock source. | | | | | CSRC1 | Coloct clock course. | Colost Glock Souloc. | | | | | CDIV0 | Select count source divisor. | Select count source divisor. | | | | | CDIV1 | | | | | | | CPFLG | Not used (read as undefined value) | - | | | | PMCiSTS | REFLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | DRFLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | BFULFLG | Not used (read as undefined value) | - | | | | 1 MOIOTO | PTHDFLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | PTD0FLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | PTD1FLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | SDFLG | Not used (read as undefined value) | - | | | i = 0, 1 Note: <sup>-:</sup> Unimplemented bits in PMC1 Table 22.18 Registers and Setting Values in Input Capture Mode (Independent Operation) (2/2) (1) | Deriotor | D:4 | Function | | | |-------------------------|---------|------------------------------------------------------|------------------------------------------------------|--| | Register | Bit | PMC0 | PMC1 | | | | CPINT | Set to 0. | - | | | | REINT | Set to 0. | Set to 0. | | | | DRINT | Set to 0. | Set to 0. | | | | BFULINT | Set to 0. | - | | | PMCiINT | PTHDINT | Set to 0. | Set to 0. | | | | PTDINT | Set to 0. | Set to 0. | | | | TIMINT | Set to 1 when using timer measure interrupt. | Set to 1 when using timer measure interrupt. | | | | SDINT | Set to 0. | - | | | | CPN0 | | | | | DMCOCDC | CPN1 | Set to 000b. | - | | | PMC0CPC | CPN2 | 1 | | | | | CPEN | Set to 0. | - | | | PMC0CPD | 0 to 7 | Set to 00h. | - | | | PMCiHDPMIN | 0 to 10 | Set to 0000h. | Set to 0000h. | | | PMCiHDPMAX | 0 to 10 | Set to 0000h. | Set to 0000h. | | | PMCiD0PMIN | 0 to 7 | Set to 00h. | Set to 00h. | | | PMCiD0PMAX | 0 to 7 | Set to 00h. | Set to 00h. | | | PMCiD1PMIN | 0 to 7 | Set to 00h. | Set to 00h. | | | PMCiD1PMAX | 0 to 7 | Set to 00h. | Set to 00h. | | | PMCiTIM | 0 to 15 | Measured value of pulse period or width can be read. | Measured value of pulse period or width can be read. | | | PMC0DAT0 to<br>PMC0DAT5 | 0 to 7 | Not used. | Not used. | | | PMC0RBIT | 0 to 5 | Not used. | Not used. | | i = 0, 1 #### Note: <sup>-:</sup> Unimplemented bits in PMC1 #### 22.3.4.1 Count Operation In input capture mode, the counter counts from 0000h to FFFFh, and then returns to 0000h to continue counting. When the counter becomes 0000h after FFFFh, the CEFLG bit in the PMCiCON2 register becomes 1 (counter overflow) and stays 1 until the next measurement timing. # 22.3.5 Input Capture Mode (Simultaneous Count Operation of PMC0 and PMC1) PMC0 and PMC1 inputs can be measured simultaneously in input capture mode. **Table 22.19 Input Capture Mode Specifications (Simultaneous Count Operation)** | Item | | Content | | | |------------------------------|---------------|------------------------------------------------------|--------------------------------------|--| | | | PMC0 Circuit | PMC1 Circuit | | | | | | One of the following: | | | | | | •fC | | | Count | Clock sources | Count source of PMC1 | •f1 | | | Count | | | <ul><li>Timer B1 underflow</li></ul> | | | Sources | | | <ul><li>Timer B2 underflow</li></ul> | | | | Division | No division | No division, divided-by-8, divided- | | | | | NO division | by-32, or divided-by-64 | | | Count ope | ration | Increment | | | | | | One of the following: | | | | Measured | items | Pulse period (between rising edge and rising edge) | | | | Wicasarca | items | Pulse period (between falling edge and falling edge) | | | | | | Pulse width (both high level and low level) | | | | Interrupt request generation | | Timer measurement | | | | timing | | Counter overflow | | | | Selectable functions | | Input signal inversion | | | | | | Digital filter | | | Table 22.20 Registers and Setting Values in Input Capture Mode (Simultaneous Count Operation) (1/2) (1) | | | Function | | | | |------------|---------|---------------------------------------|---------------------------------------|--|--| | Register | Bit | PMC0 | PMC1 | | | | | | Set to 1. (Refer to 22.3.5.1 "Setting | Set to 1. (Refer to 22.3.5.1 "Setting | | | | | EN | Procedure"). | Procedure"). | | | | | SINV | Select input signal polarity. | Select input signal polarity. | | | | | FIL | Select filter enabled/disabled. | Select filter enabled/disabled. | | | | PMCiCON0 | EHOLD | Set to 0. | - | | | | | HDEN | Set to 0. | Set to 0. | | | | | SDEN | Set to 0. | - | | | | | DRINT0 | 0 | | | | | | DRINT1 | Set to 00b. | - | | | | | TYP0 | Colort management in a literat | Calactica accomic model in at | | | | | TYP1 | Select measuring object. | Select measuring object. | | | | PMCiCON1 | CSS | Set to 1. | - | | | | | EXSDEN | Set to 0. | - | | | | | EXHDEN | Set to 0. | - | | | | | ENELO | Flag indicating PMCi | Not used | | | | | ENFLG | operated/stopped. | Not used. | | | | | INFLG | Input signal flag | Input signal flag | | | | PMCiCON2 | CEFLG | Counter overflow flag | Counter overflow flag | | | | FIVICICONZ | CEINT | Set to 1 when using counter | Set to 1 when using counter | | | | | | overflow interrupt. | overflow interrupt. | | | | | PSEL0 | Set to 01b. | Set to 10b. | | | | | PSEL1 | | Set to Top. | | | | | CRE | Set to 1. | Set to 1. | | | | | CFR | Set to 1. | Set to 1. | | | | | CST | Set to 1. | Set to 1. | | | | PMCiCON3 | PD | Set to 1. | Set to 1. | | | | 1000000 | CSRC0 | Set to 00b | Select clock source. | | | | | CSRC1 | 001.000 | 25.53. 5.55. 554. 554. | | | | | CDIV0 | Set to 00b. | Select count source divisor. | | | | | CDIV1 | | Color Count Source divisor. | | | | PMCiSTS | CPFLG | Not used (read as undefined value) | - | | | | | REFLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | DRFLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | BFULFLG | Not used (read as undefined value) | - | | | | | PTHDFLG | Not used (read as undefined value) | , | | | | | PTD0FLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | PTD1FLG | Not used (read as undefined value) | Not used (read as undefined value) | | | | | SDFLG | Not used (read as undefined value) | - | | | i = 0, 1 Note: <sup>-:</sup> Unimplemented bits in PMC1 Table 22.21 Registers and Setting Values in Input Capture Mode (Simultaneous Count Operation) (2/2) (1) Function | Dogistor | Bit | Function | | | | |-------------------------|---------|------------------------------------------------------|------------------------------------------------------|--|--| | Register | DIL | PMC0 | PMC1 | | | | | CPINT | Set to 0. | - | | | | | REINT | Set to 0. | Set to 0. | | | | | DRINT | Set to 0. | Set to 0. | | | | | BFULINT | BFULINT Set to 0. | | | | | PMCiINT | PTHDINT | Set to 0. | Set to 0. | | | | | PTDINT | Set to 0. | Set to 0. | | | | | TIMINT | Set to 1 when using timer measure interrupt. | Set to 1 when using timer measure interrupt. | | | | | SDINT | Set to 0. | - | | | | | CPN0 | | | | | | PMC0CPC | CPN1 | Set to 000b. | - | | | | PIVICUCPC | CPN2 | | | | | | | CPEN | Set to 0. | - | | | | PMC0CPD | 0 to 7 | Set to 00h. | - | | | | PMCiHDPMIN | 0 to 10 | Set to 0000h. | Set to 0000h. | | | | PMCiHDPMAX | 0 to 10 | Set to 0000h. | Set to 0000h. | | | | PMCiD0PMIN | 0 to 7 | Set to 00h. | Set to 00h. | | | | PMCiD0PMAX | 0 to 7 | Set to 00h. | Set to 00h. | | | | PMCiD1PMIN | 0 to 7 | Set to 00h. | Set to 00h. | | | | PMCiD1PMAX | 0 to 7 | Set to 00h. | Set to 00h. | | | | PMCiTIM | 0 to 15 | Measured value of pulse period or width can be read. | Measured value of pulse period or width can be read. | | | | PMC0DAT0 to<br>PMC0DAT5 | 0 to 7 | Not used. | Not used. | | | | PMC0RBIT | 0 to 5 | Not used. | Not used. | | | i = 0, 1 #### Note: 1. This table does not describe a procedure. #### 22.3.5.1 Setting Procedure To start or stop counting, follow these steps: - (1) Set bits CSRC1 to CSRC0 and bits CDIV1 to CDIV0 in the PMCiCON3 register. - (2) Set bits PSEL1 to PSEL0 in the PMCiCON2 register and bits FIL and SINV in the PMCiCON0 register. - (3) Wait for four cycles of the count source. - (4) Set the EN bit in the PMC1CON0 register to 1 (0 to stop). - (5) Set the EN bit in the PMC0CON0 register to 1 (0 to stop). - (6) Wait for two cycles of the count source. - (7) Confirm that the ENFLG bit in the PMC0CON2 register is 1 (0 to stop). (The ENFLG bit in the PMC1CON2 register is disabled) #### 22.3.5.2 Count Operation In input capture mode, the counter counts from 0000h to FFFFh, and then returns to 0000h to continue counting. When the counter becomes 0000h after FFFFh, the CEFLG bit in the PMCiCON2 register becomes 1 (counter overflow) and stays 1 until the next measurement. <sup>-:</sup> Unimplemented bits in PMC1 #### 22.4 Interrupts The remote control signal receiver has remote control signal receiver 0 interrupt and remote control signal receiver 1 interrupt. The remote control signal receiver 0 interrupt and remote control signal receiver 1 interrupt are interrupts in PMC0 and PMC1, respectively. A remote control signal receiver i interrupt request signal is generated every time the conditions are met. If the interrupt enable bit in the PMCiCON2 or PMCiINT register is 1, the IR bit in the PMCiIC register becomes 1 (interrupt request) when the corresponding interrupt request signal is generated. Table 22.22 lists Interrupt Source of Remote Control Signal Receiver i Interrupt (i = 0, 1). Table 22.22 Interrupt Source of Remote Control Signal Receiver i Interrupt (i = 0, 1) | Mode | Interrupt | Interrupt Request Generating Condition | Interrupt Request Bit | | Interrupt Enable Bit | | |----------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------------|----------------------|---------| | Mode | Source | interrupt Nequest Generating Condition | Register | Bit | Register | Bit | | | Completion of data reception | Counter value is larger than values of registers PMCiHDPMAX, PMCiD0PMAX, and PMCiD1PMAX | PMCiSTS | DRFLG<br>(Changes<br>from 1 to 0) | PMCiINT | DRINT | | | Header match | The measured result is within the range set by registers PMCiHDPMIN and PMCiHDPMAX (when header is enabled) | PMCiSTS | PTHDFLG | PMCiINT | PTHDINT | | | Data 0/1<br>match | The measured result is within the range set by registers PMCiD0PMIN and PMCiD0PMAX or registers PMCiD1PMIN and PMCiD1PMAX | PMCiSTS<br>PMCiSTS | PTD0FLG<br>PTD1FLG | PMCiINT | PTDINT | | Pattern<br>match | Special data match | The measured result is within the range set by registers PMCiHDPMIN and PMCiHDPMAX (when special data is enabled) | PMC0STS | SDFLG | PMC0INT | SDINT | | mode | Receive error | Input signal width is not the header, data 0, data 1, or special data. Data 0 or data 1 is detected before detecting the header when the HDEN bit is 1 | PMCiSTS | REFLG | PMCiINT | REINT | | | Receive<br>buffer full | The value of the PMC0RBIT register is 48 | PMC0STS | BFULFLG | PMC0INT | BFULINT | | | Compare match | The values of registers PMC0CPD and PMC0DAT0 are matched (only bits selected by bits CPN2 to CPN0 in the PMC0CPC register are compared) | PMC0STS | CPFLG | PMC0INT | CPINT | | | Timer measurement | Measurement end edge of PMCi internal input signal | - | - | PMCiINT | TIMINT | | Input<br>capture -<br>mode | Timer measurement | Measurement end edge of PMCi internal input signal | - | - | PMCiINT | TIMINT | | | Counter overflow | Counter overflow (counter value exceeds FFFFh and becomes 0000h) | PMCiCON2 | CEFLG | PMCiCON2 | CEINT | Measured result: Content of the PMCiTIM register Figure 22.10 shows Remote Control Signal Receiver Interrupts. Figure 22.10 Remote Control Signal Receiver Interrupts Refer to 14.7 "Interrupt Control" for details on interrupt control. Table 22.23 lists Registers Associated with Remote Control Signal Receiver Interrupts. Table 22.23 Registers Associated with Remote Control Signal Receiver Interrupts | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------------------------------------------------------------------------------------|--------------------|-------------| | 0071h | UART7 Bus Collision Detection Interrupt Control<br>Register, Remote Control Signal Receiver 0 Interrupt<br>Control Register | U7BCNIC/<br>PMC0IC | XXXX X000b | | 0072h | UART7 Transmit Interrupt Control Register, Remote Control Signal Receiver 1 Interrupt Control Register | S7TIC/PMC1IC | XXXX X000b | | 0206h | Interrupt Source Select Register 2 | IFSR2A | 00h | The remote control signal receiver shares interrupt vectors or interrupt control registers with other peripheral functions. To use the remote control signal receiver 0 interrupt, set the IFSR24 bit in the IFSR2A register to 1 (remote control signal receiver 0). To use the remote control signal receiver 1 interrupt, set the IFSR25 bit in the IFSR2A register to 1 (remote control signal receiver 1). #### 22.5 Notes on Remote Control Signal Receiver #### 22.5.1 Starting/Stopping PMCi The EN bit in the PMCiCON0 register controls the start/stop of PMCi. The ENFLG bit in the PMCiCON2 register indicates that operation started/stopped. The PMCi circuit starts operating by setting the EN bit to 1 (operation enabled) and the ENFLG bit becomes 1 (operating). After setting the EN bit to 1, it takes up to two cycles of the count source before the ENFLG bit becomes 1. When the EN bit is set to 0 (operation disabled), the PMCi circuit stops operating and the ENFLG bit becomes 0 (operation stopped). After setting the EN bit to 0, it takes up to one cycle of the count source before the ENFLG bit becomes 0. Between setting the EN bit to 1 and the ENFLG bit becoming 1, and while the ENFLG bit is 1, do not access bits in the PMCi associated registers (registers listed in Table 22.4 and Table 22.5 "Registers") except for the ENFLG bit. #### 22.5.2 Reading the Register When the following registers are read while data changes, an undefined value may be read. Flags in registers PMCiCON2 and PMCiSTS Registers PMCiTIM, PMC0DAT0 to PMC0DAT5, and PMC0RBIT Follow the procedures below to avoid reading an undefined value. #### In pattern match mode Using an interrupt Set the DRINT bit in the PMCiINT register to 1 (data reception complete interrupt enabled) and read the registers within the PMCi interrupt routine. Monitoring by a program 1 Set the DRINT bit in the PMCiINT register to 1 (data reception complete interrupt enabled) and monitor the IR bit in the PMCiIC register by a program. Read the registers when the IR bit becomes 1 (interrupt request is generated). - Monitoring by a program 2 - (1) Monitor the DRFLG bit in the PMCiSTS register. - (2) When the DRFLG bit becomes 1, monitor the DRFLG bit until it becomes 0. - (3) Read the necessary content of the registers when the DRFLG bit becomes 0. #### In input capture mode Using an interrupt Set the TIMINT bit in the PMCiINT register to 1 (timer measure interrupt enabled) and read the registers within the PMCi interrupt routine. Monitoring by a program 1 Set the TIMINT bit in the PMCiINT register to 1 (timer measure interrupt enabled) and monitor the IR bit in the PMCiIC register by a program. Read the registers when the IR bit becomes 1 (interrupt request is generated). If the register data may change at the same time as the register is read even with above countermeasures, read the register more than once to determine whether the read value is correct. #### 22.5.3 Rewriting the Register Rewrite the registers and bits related to PMC excluding the EN bit in the PMCiCON0 register when both of the EN bit in the PMCiCON0 register and the ENFLG bit in the PMCiCON2 register are 0 (PMCi stops). # 22.5.4 Combined Operation When using combined operation, set same value to bits TYP1 to TYP0 in the PMC0CON1 register and bits TYP1 to TYP0 in the PMC1CON1 register. ## 23. Serial Interface UARTi (i = 0 to 2, 5 to 7) #### 23.1 Introduction Each UART has a dedicated timer to generate a transmit/receive clock, and operates independently of the others. Table 23.1 lists UARTi Specifications (i = 0 to 2, 5 to 7). Table 23.2 lists Specification Differences between UART0 to UART2 and UART5 to UART7. Figure 23.1 to Figure 23.3 show the block diagrams of UARTi. Figure 23.4 shows UARTi Transmit/Receive Unit Block Diagram. Table 23.1 UARTi Specifications (i = 0 to 2, 5 to 7) | Item | Specification | | | | | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Operational mode | <ul> <li>Clock synchronous serial I/O mode</li> <li>Clock asynchronous serial I/O mode (UART mode)</li> <li>Special mode 1 (I<sup>2</sup>C mode) The simplified I<sup>2</sup>C-bus interface is supported.</li> <li>Special mode 2 The transmit/receive clock polarity and phase are selectable.</li> <li>Special mode 3 (bus collision detection function, IE mode) A 1-byte wave of the UART mode approximates 1-bit of the IEBus.</li> <li>Special mode 4 (SIM mode) Can be used with UART2. The SIM interface is supported.</li> </ul> | | | | | | Table 23.2 Specification Differences between UART0 to UART2 and UART5 to UART7 | Mode | UARTO UART1 | UART2 | UART5 | UART6 UART7 | |------------------------------------------------|---------------|-------------|---------------|---------------| | Clock synchronous serial I/O mode | Available | Available | Available | Available | | Clock asynchronous serial I/O mode (UART mode) | Available | Available | Available | Available | | Special mode 1 (I <sup>2</sup> C mode) | Available | Available | Available | Available | | Special mode 2 | Available | Available | Available | Available | | Special mode 3 (IE mode) | Available | Available | Available | Available | | Special mode 4 (SIM mode) | Not available | Available | Not available | Not available | | Memory expansion mode or microprocessor mode | | Can be used | | Do not use. | Figure 23.1 UART0 Block Diagram Figure 23.2 UART1 Block Diagram Figure 23.3 Block Diagram of UART2 and UART5 to UART7 Figure 23.4 UARTi Transmit/Receive Unit Block Diagram ## 23.2 Registers Table 23.3 and Table 23.4 list registers associated with UART0 to UART2 and UART5 to UART7. Refer to 8.2.6 "Peripheral Clock Stop Register 1 (PCLKSTP1)" for the explanation of the PCLKSTP1 register. Set the OCOSEL0 or OCOSEL1 bit in the UCLKSEL0 register before setting other registers associated with UART0 to UART2 and UART5 to UART7. After changing the OCOSEL0 or OCOSEL1 bit, set other registers associated with UART0 to UART2 and UART5 to UART7 again. Refer to "Registers Used and Settings" in each mode for the settings of registers and bits. Table 23.3 Registers (1/2) | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------|----------|-------------| | 0012h | Peripheral Clock Select Register | PCLKR | 0000 0011b | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 0244h | UART0 Special Mode Register 4 | U0SMR4 | 00h | | 0245h | UART0 Special Mode Register 3 | U0SMR3 | 000X 0X0Xb | | 0246h | UART0 Special Mode Register 2 | U0SMR2 | X000 0000b | | 0247h | UART0 Special Mode Register | U0SMR | X000 0000b | | 0248h | UART0 Transmit/Receive Mode Register | U0MR | 00h | | 0249h | UART0 Bit Rate Register | U0BRG | XXh | | 024Ah | LIADTO Transmit Buffor Dogistor | U0TB | XXh | | 024Bh | UART0 Transmit Buffer Register | 0016 | XXh | | 024Ch | UART0 Transmit/Receive Control Register 0 | U0C0 | 0000 1000b | | 024Dh | UART0 Transmit/Receive Control Register 1 | U0C1 | 00XX 0010b | | 024Eh | LIADTO Bossiyo Buffor Bogistor | U0RB | XXh | | 024Fh | UART0 Receive Buffer Register | UURD | XXh | | 0250h | UART Transmit/Receive Control Register 2 | UCON | X000 0000b | | 0252h | UART Clock Select Register | UCLKSEL0 | X0h | | 0254h | UART1 Special Mode Register 4 | U1SMR4 | 00h | | 0255h | UART1 Special Mode Register 3 | U1SMR3 | 000X 0X0Xb | | 0256h | UART1 Special Mode Register 2 | U1SMR2 | X000 0000b | | 0257h | UART1 Special Mode Register | U1SMR | X000 0000b | | 0258h | UART1 Transmit/Receive Mode Register | U1MR | 00h | | 0259h | UART1 Bit Rate Register | U1BRG | XXh | | 025Ah | UART1 Transmit Buffer Register | U1TB | XXh | | 025Bh | OAKT Hansilii Builei Kegistei | UIIB | XXh | | 025Ch | UART1 Transmit/Receive Control Register 0 | U1C0 | 0000 1000b | | 025Dh | UART1 Transmit/Receive Control Register 1 | U1C1 | 00XX 0010b | | 025Eh | UART1 Receive Buffer Register | U1RB | XXh | | 025Fh | OAKT Receive Bullet Register | UIND | XXh | | 0264h | UART2 Special Mode Register 4 | U2SMR4 | 00h | | 0265h | UART2 Special Mode Register 3 | U2SMR3 | 000X 0X0Xb | | 0266h | UART2 Special Mode Register 2 | U2SMR2 | X000 0000b | | 0267h | UART2 Special Mode Register | U2SMR | X000 0000b | | 0268h | UART2 Transmit/Receive Mode Register | U2MR | 00h | | 0269h | UART2 Bit Rate Register | U2BRG | XXh | | 026Ah | LIADT2 Transmit Buffor Desister | LIOTE | XXh | | 026Bh | - UART2 Transmit Buffer Register | U2TB | XXh | | 026Ch | UART2 Transmit/Receive Control Register 0 | U2C0 | 0000 1000b | Table 23.4 Registers (2/2) | | • | + | <u> </u> | |----------|-------------------------------------------|--------|-------------| | Address | Register | Symbol | Reset Value | | 026Dh | UART2 Transmit/Receive Control Register 1 | U2C1 | 0000 0010b | | 026Eh | UART2 Receive Buffer Register | U2RB | XXh | | 026Fh | OARTZ Receive Bullet Register | OZNO | XXh | | 0284h | UART5 Special Mode Register 4 | U5SMR4 | 00h | | 0285h | UART5 Special Mode Register 3 | U5SMR3 | 000X 0X0Xb | | 0286h | UART5 Special Mode Register 2 | U5SMR2 | X000 0000b | | 0287h | UART5 Special Mode Register | U5SMR | X000 0000b | | 0288h | UART5 Transmit/Receive Mode Register | U5MR | 00h | | 0289h | UART5 Bit Rate Register | U5BRG | XXh | | 028Ah | LIADTE Teachers's Duffer Desirator | LICTO | XXh | | 028Bh | UART5 Transmit Buffer Register | U5TB | XXh | | 028Ch | UART5 Transmit/Receive Control Register 0 | U5C0 | 0000 1000b | | 028Dh | UART5 Transmit/Receive Control Register 1 | U5C1 | 0000 0010b | | 028Eh | HADTED : D " D : I | LIEDD | XXh | | 028Fh | UART5 Receive Buffer Register | U5RB | XXh | | 0294h | UART6 Special Mode Register 4 | U6SMR4 | 00h | | 0295h | UART6 Special Mode Register 3 | U6SMR3 | 000X 0X0Xb | | 0296h | UART6 Special Mode Register 2 | U6SMR2 | X000 0000b | | 0297h | UART6 Special Mode Register | U6SMR | X000 0000b | | 0298h | UART6 Transmit/Receive Mode Register | U6MR | 00h | | 0299h | UART6 Bit Rate Register | U6BRG | XXh | | 029Ah | · | | XXh | | 029Bh | UART6 Transmit Buffer Register | U6TB | XXh | | 029Ch | UART6 Transmit/Receive Control Register 0 | U6C0 | 0000 1000b | | 029Dh | UART6 Transmit/Receive Control Register 1 | U6C1 | 0000 0010b | | 029Eh | · · | | XXh | | 029Fh | UART6 Receive Buffer Register | U6RB | XXh | | 02A4h | UART7 Special Mode Register 4 | U7SMR4 | 00h | | 02A5h | UART7 Special Mode Register 3 | U7SMR3 | 000X 0X0Xb | | 02A6h | UART7 Special Mode Register 2 | U7SMR2 | X000 0000b | | 02A7h | UART7 Special Mode Register | U7SMR | X000 0000b | | 02A8h | UART7 Transmit/Receive Mode Register | U7MR | 00h | | 02A9h | UART7 Bit Rate Register | U7BRG | XXh | | 02AAh | | | XXh | | 02/J/III | UART7 Transmit Buffer Register | U7TB | XXh | | 02ACh | UART7 Transmit/Receive Control Register 0 | U7C0 | 0000 1000b | | 02ADh | UART7 Transmit/Receive Control Register 1 | U7C1 | 0000 1000b | | 02AEh | | | XXh | | 02AFh | UART7 Receive Buffer Register | U7RB | XXh | | 02/ALTI | | | 7//11 | ## 23.2.1 UART Clock Select Register (UCLKSEL0) OCOSEL0 (UART0 to UART2 clock prior to division select bit) (b2) OCOSEL1 (UART5 to UART7 clock prior to division select bit) (b3) Set bits OCOSEL0 and OCOSEL1 while transmission/reception of UART0 to UART2 and UART5 to UART7 stops. Set the OCOSEL0 or OCOSEL1 bit before setting other registers associated with UART0 to UART2 and UART5 to UART7. After changing the OCOSEL0 or OCOSEL1 bit, set other registers associated with UART0 to UART2 and UART5 to UART7 again. ## 23.2.2 Peripheral Clock Select Register (PCLKR) Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. ## 23.2.3 UARTi Transmit/Receive Mode Register (UiMR) (i = 0 to 2, 5 to 7) | UARTi Transmit/ | Receive | Mode Register (i = | = 0 to 2, 5 to 7) | | |-------------------------|------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-------------------------| | b7 b6 b5 b4 b3 b2 b1 b0 | U0MR, | Symbol<br>U1MR, U2MR<br>U6MR, U7MR | Address Re<br>0248h, 0258h, 0268h<br>0288h, 0298h, 02A8h | set Value<br>00h<br>00h | | | Bit Symbol | Bit Name | Function | RW | | <u></u> | SMD0 | | b2 b1 b0 0 0 0 : Serial interface disabled 0 0 1 : Clock synchronous serial I/O mod- | RW | | | SMD1 | Serial I/O mode select bit | 0 1 0: I <sup>2</sup> C mode<br>1 0 0: UART mode character bit length is 7 t<br>1 0 1: UART mode character bit length is 8 t | | | | SMD2 | | 1 1 0: UART mode character bit length is 9 to Only set the values listed above. | | | | CKDIR | Internal/external clock select bit | 0 : Internal clock<br>1 : External clock | RW | | | STPS | Stop bit length select bit | 0 : 1 stop bit<br>1 : 2 stop bit | RW | | | PRY | Odd/even parity select bit | Enabled when PRYE is 1<br>0 : Odd parity<br>1 : Even parity | RW | | | PRYE | Parity enable bit | 0 : Parity disabled<br>1 : Parity enabled | RW | | <u> </u> | IOPOL | TXD, RXD I/O polarity inverse bit | 0 : Not inverted<br>1 : Inverted | RW | ## SMD2 to SMD0 (Serial I/O mode select bit) (b2 to b0) When setting bits SMD2 to SMD0 to 000b (serial interface disabled), set the TE bit in the UiC1 register to 0 (transmission disabled) and the RE bit to 0 (reception disabled). When using $I^2C$ mode, set the IICM bit in the UiSMR register to 1 ( $I^2C$ mode), then set bits SMD2 to SMD0 to 010b ( $I^2C$ mode). ## 23.2.4 UARTi Bit Rate Register (UiBRG) (i = 0 to 2, 5 to 7) Write to the UiBRG register while the serial interface is neither transmitting nor receiving. Use the MOV instruction to write to the UiBRG register. Write to the UiBRG register after setting bits CLK1 to CLK0 in the UiC0 register. ## 23.2.5 UARTi Transmit Buffer Register (UiTB) (i = 0 to 2, 5 to 7) Use the MOV instruction to write to this register. When character length is 9 bits long or $I^2C$ mode, write to this register in 16-bit units, or in 8-bit units from upper byte to lower byte. ## 23.2.6 UARTi Transmit/Receive Control Register 0 (UiC0) (i = 0 to 2, 5 to 7) | UARTi Transmit/ | Receive | Control Register 0 ( | = 0 to 2, 5 to 7) | | |-------------------------|-------------------------------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | b7 b6 b5 b4 b3 b2 b1 b0 | Syı<br>U0C0, U10<br>U5C0, U60 | • | , 025Ch, 026Ch 0000 | et Value<br>1000b<br>1000b | | | Bit Symbol | Bit Name | Function | RW | | | CLK0 | UiBRG count source select | b1 b0<br>0 0: f1SIO or f2SIO selected | RW | | | CLK1 | bit | 0 1 : f8SIO selected<br>1 0 : f32SIO selected<br>1 1 : Do not set | RW | | | CRS | CTS/RTS function select bit | Enabled when CRD is 0 0 : CTS function selected 1 : RTS function selected | RW | | | TXEPT | | Data present in transmit register (transmission in progress) No data present in transmit register (transmission completed) | RO | | | CRD | CTS/RTS disable bit | 0 : CTS/RTS function enabled 1 : CTS/RTS function disabled | RW | | | NCH | Data output select bit | Pins TXDi/SDAi and SCLi are CMOS output Pins TXDi/SDAi and SCLi are N-cha open drain output | DW | | | CKPOL | CLK polarity select bit | Transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising ed Transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling ed | RW | | <u> </u> | UFORM | Bit order select bit | 0 : LSB first<br>1 : MSB first | RW | ## CLK1 to CLK0 (UiBRG count source select bit) (b1-b0) When bits CLK1 to CLK0 are 00b (f1SIO or f2SIO selected), select f1SIO or f2SIO by the PCLK1 bit in the PCLKR register. Set bits CLK1 to CLK0 after setting registers UCLKSEL0 and PCLKR. If bits CLK1 to CLK0 are changed, set the UiBRG register. ## CRS (CTS/RTS function select bit) (b2) CTS1/RTS1 can be used when the CLKMD1 bit in the UCON register is 0 (CLK output is only from CLK1) and the RCSP bit in the UCON register is 0 (CTS0/RTS0 not separated). ## CRD (CTS/RTS disable bit) (b4) When the CRD bit is 1 (CTS/RTS function disabled), the CTSi/RTSi pin can be used as an I/O port. ## NCH (Data output select bit) (b5) TXD2/SDA2 and SCL2 are N-channel open drain outputs. They cannot be set as CMOS outputs. Nothing is assigned to the NCH bit in the U2C0 register. If necessary, set this bit to 0. This function is used to set the P-channel transistor of the CMOS output buffer always off, but not to change pins TXDi/SDAi and SCLi to open drain output completely. Refer to the electrical characteristics for the input voltage range. ## UFORM (Bit order select bit) (b7) The UFORM bit is enabled when bits SMD2 to SMD0 in the UiMR register are 001b (clock synchronous serial I/O mode), or 101b (UART mode, 8-bit character data). Set the UFORM bit to 1 when bits SMD2 to SMD0 are 010b (I<sup>2</sup>C mode), and to 0 when bits SMD2 to SMD0 are 100b (UART mode, 7-bit character data) or 110b (UART mode, 9-bit character data). ## 23.2.7 UARTi Transmit/Receive Control Register 1 (UiC1) (i = 0 to 2, 5 to 7) Bits UiIRS and UiRRM of UART0 and UART1 are bits in the UCON register. #### UiLCH (Data logic select bit) (b6) The UiLCH bit is enabled when bits SMD2 to SMD0 in the UiMR register are 001b (clock synchronous serial I/O mode), 100b (UART mode, 7-bit character), or 101b (UART mode, 8-bit character). Set this bit to 0 when bits SMD2 to SMD0 are set to 010b (I<sup>2</sup>C mode) or 110b (UART mode, 9-bit character). ## 23.2.8 UARTi Receive Buffer Register (UiRB) (i = 0 to 2, 5 to 7) When bits SMD2 to SMD0 in the UiMR register are 100b, 101b, or 110b, read this register in 16-bit units, or in 8-bit units from upper byte to lower byte. Bits FER and PER in the upper byte become 0 when the lower byte of the UiRB register is read. If an overrun error occurs, the receive data of the UiRB register is undefined. ## ABT (Arbitration lost detect flag) (b11) The ABT bit is set to 0 by a program. (It remains unchanged even if 1 is written.) ## OER (Overrun error flag) (b12) Conditions to become 0: - Bits SMD2 to SMD0 in the UiMR register are 000b (serial interface disabled). - The RE bit in the UiC1 register is 0 (reception disabled). #### Condition to become 1: The RI bit in the UiC1 register is 1 (data present in UiRB register), and the last bit of the next data is received. ## FER (Framing error flag) (b13) The FER bit is disabled when bits SMD2 to SMD0 are set to 001b (clock synchronous serial I/O mode) or to 010b (I<sup>2</sup>C mode). The read value is undefined. #### Conditions to become 0: - Bits SMD2 to SMD0 in the UiMR register are 000b (serial interface disabled). - The RE bit in the UiC1 register is 0 (reception disabled). - The lower bytes of the UiRB register are read. #### Condition to become 1: The set number of stop bits is not detected. (detected when the received data is transferred from the UARTi receive register to the UiRB register.) ### PER (Parity error flag) (b14) The PER bit is disabled when bits SMD2 to SMD0 are set to 001b (clock synchronous serial I/O mode) or to 010b (I<sup>2</sup>C mode). The read value is undefined. #### Conditions to become 0: - Bits SMD2 to SMD0 in the UiMR register are 000b (serial interface disabled). - The RE bit in the UiC1 register is 0 (reception disabled). - The lower bytes of the UiRB register are read. #### Condition to become 1: • The number of 1's of the parity bit and character bits do not match the set value of the PRY bit in the UiMR register. (detected when the received data is transferred from the UARTi receive register to the UiRB register.) ## SUM (Error sum flag) (b15) The SUM bit is disabled when bits SMD2 to SMD0 are set to 001b (clock synchronous serial I/O mode) or to 010b (I<sup>2</sup>C mode). The read value is undefined. #### Conditions to become 0: - Bits SMD2 to SMD0 in the UiMR register are 000b (serial interface disabled). - The RE bit in the UiC1 register is 0 (reception disabled). - Bits PER, FER and OER are all 0 (no error). #### Condition to become 1: • At least two bits out of PER, FER, or OER are 1 (error found). ## 23.2.9 UART Transmit/Receive Control Register 2 (UCON) Bits UiIRS and UiRRM of UART2 and UART5 to UART7 are bits in the UiC1 register. ## CLKMD1 (UART1CLK, CLKS select bit 1) (b5) When using multiple transmit/receive clock output pins, make sure that the CKDIR bit in the U1MR register is 0 (internal clock). #### UARTi Special Mode Register 4 (i = 0 to 2, 5 to 7) Reset Value Symbol Address U0SMR4, U1SMR4, U2SMR4 0244h, 0254h, 0264h 00h U5SMR4, U6SMR4, U7SMR4 00h 0284h, 0294h, 02A4h Bit Symbol RW Bit Name **Function** 0: Clear **STAREQ** Start condition generate bit RW 1 : Start Restart condition generate 0: Clear **RSTAREQ** RW 1 : Start 0 : Clear 1 : Start **STPREQ** Stop condition generate bit RW 0 : Select serial I/O circuit **STSPSEL** RW SCL, SDA output select bit 1 : Select start condition/stop condition generate circuit 0: ACK **ACKD** ACK data bit RW 1: NACK 0 : Serial data output **ACKC** ACK data output enable bit RW 1 : ACK data output If stop condition is detected, **SCLHI** RW SCL output stop bit 0: Do not stop SCLi output 1 : Stop SCLi output 0 : No wait-state/wait-state cleared SWC9 SCL wait auto insert bit 3 RW 1 : Hold the SCLi pin low after the ninth bit ## 23.2.10 UARTi Special Mode Register 4 (UiSMR4) (i = 0 to 2, 5 to 7) ## STAREQ (Start condition generate bit) (b0) The STAREQ bit becomes 0 when a start condition is generated. This bit is used in master mode of $I^2C$ mode. To set this bit to 1, preset the IICM bit in the UiSMR register to 1 ( $I^2C$ mode). Do not set this bit to 1 when the IICM bit is 0. of the SCLi is received #### RSTAREQ (Restart condition generate bit) (b1) The RSTAREQ bit becomes 0 when a restart condition is generated. This bit is used in master mode of I<sup>2</sup>C mode. To set this bit to 1, preset the IICM bit in the UiSMR register to 1 (I<sup>2</sup>C mode). Do not set this bit to 1 when the IICM bit is 0. ## STPREQ (Stop condition generate bit) (b2) The STPREQ bit becomes 0 when a stop condition is generated. This bit is used in master mode of I<sup>2</sup>C mode. To set this bit to 1, preset the IICM bit in the UiSMR register to 1 (I<sup>2</sup>C mode). Do not set this bit to 1 when the IICM bit is 0. ## STSPSEL (SCL, SDA output select bit) (b3) This bit is used in master mode of I<sup>2</sup>C mode. To set this bit to 1, preset the IICM bit in the UiSMR register to 1 (I<sup>2</sup>C mode). Do not set this bit to 1 when the IICM bit is 0. Set the STSPSEL bit to 1 (select start condition/stop condition generate circuit) after setting the STARREQ, RSTAREQ, or STPREQ bit to 1 (start). ACKD (ACK data bit) (b4) ACKC (ACK data output enable bit) (b5) SWC9 (SCL wait auto insert bit 3) (b7) This bit is used in slave mode of $I^2C$ mode. To set this bit to 1, preset the IICM bit in the UiSMR register to 1 ( $I^2C$ mode). Do not set this bit to 1 when the IICM bit is 0. ## SCLHI (SCL output stop bit) (b6) This bit is used in master mode of $I^2C$ mode. To set this bit to 1, preset the IICM bit in the UiSMR register to 1 ( $I^2C$ mode). Do not set this bit to 1 when the IICM bit is 0. ## 23.2.11 UARTi Special Mode Register 3 (UiSMR3) (i = 0 to 2, 5 to 7) | UARTi Special I | Mode Re | gister 3 (i = 0 to 2 | , 5 to 7) | | |-------------------------|------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------| | b7 b6 b5 b4 b3 b2 b1 b0 | | Symbol<br>3, U1SMR3, U2SMR3<br>3, U6SMR3, U7SMR3 | 0245h, 0255h, 0265h 0000 | et Value<br>K 0X0Xb<br>K 0X0Xb | | | Bit Symbol | Bit Name | Function | RW | | | —<br>(b0) | No register bit. If necessar | ry, set to 0. Read as undefined value | | | | СКРН | Clock phase set bit | 0 : No clock delay<br>1 : With clock delay | RW | | | <br>(b2) | No register bit. If necessar | ry, set to 0. Read as undefined value | | | | NODC | Clock output select bit | 0 : CLKi is CMOS output<br>1 : CLKi is N-channel open drain output | RW | | | —<br>(b4) | No register bit. If necessar | ry, set to 0. Read as undefined value | | | | DL0 | | b7 b6 b5<br>0 0 0 : No delay<br>0 0 1 : 1 to 2 cycles of UiBRG count source | RW | | | DL1 | SDAi digital delay setup bit | 0 1 0:2 to 3 cycles of UiBRG count source<br>0 1 1:3 to 4 cycles of UiBRG count source<br>1 0 0:4 to 5 cycles of UiBRG count source | RW | | | DL2 | | 1 0 1:5 to 6 cycles of UiBRG count source<br>1 1 0:6 to 7 cycles of UiBRG count source<br>1 1 1:7 to 8 cycles of UiBRG count source | RW | ## NODC (Clock output select bit) (b3) This function is used to set P-channel transistor of the CMOS output buffer always off, but not to change the CLKi pin to open drain output completely. Refer to the electrical characteristics for the input voltage range. ## DL2-DL0 (SDAi digital delay setup bit) (b7-b5) Bits DL2 to DL0 are used to generate a digital delay in SDAi output in I<sup>2</sup>C mode. Except in I<sup>2</sup>C mode, set these bits to 000b (no delay). The delay length varies with the load on pins SCLi and SDAi. Also, when using an external clock, the delay length increases by about 100 ns. # 23.2.12 UARTi Special Mode Register 2 (UiSMR2) (i = 0 to 2, 5 to 7) | 7 b6 b5 b4 b3 b2 b1 b0 | | Symbol<br>, U1SMR2, U2SMR2<br>, U6SMR2, U7SMR2 | 0246h, 0256h, 0266h X000 | et Value<br>0 0000b<br>0 0000b | |------------------------|------------|------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------| | | Bit Symbol | Bit Name | Function | RW | | <u> </u> | IICM2 | I <sup>2</sup> C mode select bit 2 | 0 : Use NACK/ACK interrupt<br>1 : Use transmit/receive interrupt | RW | | | CSC | Clock synchronization bit | 0 : Clock synchronization disabled<br>1 : Clock synchronization enabled | RW | | | SWC | SCL wait auto insert bit | No wait-state/wait-state cleared Hold the SCLi pin low after the eighth be is received | oit RW | | | ALS | SDA output auto stop bit | When arbitration lost is detected, 0 : Do not stop the SDAi output 1 : Stop the SDAi output | RW | | | STAC | UARTi auto initialize bit | When the start condition is detected, 0 : Do not initialize the circuit 1 : Initialize the circuit | RW | | | SWC2 | SCL wait output bit 2 | O: Output the transmit/receive clock at the SCLi pin Hold the SCLi pin low | RW | | | SDHI | SDA output disable bit | 0: Output data 1: Stop the output (high-impedance) | RW | | <br> | <br>(b7) | No register bit. If necessary | set to 0. The read value is undefined. | _ | ## 23.2.13 UARTi Special Mode Register (UiSMR) (i = 0 to 2, 5 to 7) | b6 b5 b4 b3 b2 b1 b0 | | Symbol<br>U1SMR, U2SMR<br>U6SMR, U7SMR | 0247h, 0257h, 0267h X( | eset Value<br>000 0000b<br>000 0000b | |----------------------|------------|-------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------| | | Bit Symbol | Bit Name | Function | RW | | | IICM | I <sup>2</sup> C mode select bit | 0 : Other than I <sup>2</sup> C mode<br>1 : I <sup>2</sup> C mode | RW | | | ABC | Arbitration lost detect flag control bit | 0 : Update every bit<br>1 : Update every byte | RW | | | BBS | Bus busy flag | Stop-condition detected Start-condition detected (busy) | RW | | | <br>(b3) | Reserved bit | Set to 0 | RW | | 1 | ABSCS | Bus collision detect sampling clock select bit | 0 : Rising edge of transmit/receive clock<br>1 : Underflow signal of timer Aj | RW | | L | ACSE | Auto clear function select bit of transmit enable bit | 0 : No auto clear function<br>1 : Auto clear at bus collision | RW | | | SSS | Transmit start condition select bit | 0 : Not synchronized to RXDi<br>1 : Synchronized to RXDi | RW | | | —<br>(b7) | No register bit. If necessary, s | et to 0. The read value is undefined. | _ | ## BBS (Bus busy flag) (b2) The BBS bit is set to 0 by a program. (It remains unchanged even if 1 is written.) ## ABSCS (Bus collision detect sampling clock select bit) (b4) When the ABSCS bit is 1, the combinations of UARTi and timer Aj are as follows: UART0, UART6: Underflow signal of timer A3 UART1, UART7: Underflow signal of timer A4 UART2, UART5: Underflow signal of timer A0 ## SSS (Transmit start condition select bit) (b6) When a transmission starts, the SSS bit becomes 0 (not synchronized to RXDi). ## 23.3 Operations ## 23.3.1 Clock Synchronous Serial I/O Mode The clock synchronous serial I/O mode uses a transmit/receive clock to transmit/receive data. Table 23.5 lists the Clock Synchronous Serial I/O Mode Specifications. Table 23.5 Clock Synchronous Serial I/O Mode Specifications | Item | Specification | |-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Data format | Character length: 8 bits | | Transmit/receive clock | • CKDIR bit in the UiMR register = 0 (internal clock): fj = f1SIO, f2SIO, f8SIO, f32SIO n = setting value of UiBRG register (00h to FFh) • CKDIR bit = 1 (external clock): input from CLKi pin | | Transmit/receive control | Selectable from CTS, RTS, or CTS/RTS function disabled | | Transmission start conditions | To start transmission, satisfy the following requirements <sup>(1)</sup> • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data presents in UiTB register) • When $\overline{\text{CTS}}$ function is selected, input on the $\overline{\text{CTSi}}$ pin is low | | Reception start conditions | To start reception, satisfy the following requirements (1) • The RE bit in the UiC1 register is 1 (reception enabled) • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data presents in the UiTB register) | | Interrupt request generation timing | For transmission, one of the following conditions can be selected • The UiIRS bit in the UiC1 or UCON register is 0 (transmit buffer empty): When transferring data from the UiTB register to the UARTi transmit register (at start of transmission) • The UiIRS bit is 1 (transfer completed): When the serial interface completes sending data from the UARTi transmit register For reception • When transferring data from the UARTi receive register to the UiRB register (at completion of reception) | | Error detection | Overrun error (2) This error occurs if the serial interface starts receiving the next unit of data before reading the UiRB register and receiving the seventh bit of the next unit of data | | Selectable functions | <ul> <li>CLK polarity selection Data input/output can be selected to occur synchronously with the rising or falling edge of the transmit/receive clock</li> <li>LSB first, MSB first selection Whether to start transmitting/receiving the data from bit 0 or from bit 7 can be selected</li> <li>Continuous receive mode selection Reception is enabled immediately by reading the UiRB register</li> <li>Switching serial data logic This function inverts the logic value of the transmit/receive data</li> <li>Transmit/receive clock output from multiple pins selection (UART1) Two pins are set as UART1 transmit/receive clock pins. Output pin can be selected from them by a program.</li> <li>Separate CTS/RTS pins (UART0) CTS0 and RTS0 are input/output from separate pins.</li> </ul> | i = 0 to 2, 5 to 7 - 1. These requirements do not have to be set in any particular order. If transmission/reception is started while an external clock is selected and the TXEPT bit in the UiC0 register is 1 (no data present in transmit register), meet the last requirement at either of the following timings: - The CKPOL bit in the UiC0 register is 0 (transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising edge) and the external clock is high. - The CKPOL bit is 1 (transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling edge) and the external clock is low. - 2. If an overrun error occurs, the receive data of the UiRB register will be undefined. The IR bit in the SiRIC register remains unchanged. Table 23.6 lists Pin Functions in Clock Synchronous Serial I/O Mode (Multiple Transmit/Receive Clock Output Pin Function Not Selected). Table 23.7 lists P6\_4 Pin Functions in Clock Synchronous Serial I/O Mode. Note that for a period from when UARTi operating mode is selected to when transmission starts, the TXDi pin outputs a high-level signal. (If N-channel open drain output is selected, this pin is high-impedance.) Table 23.6 Pin Functions in Clock Synchronous Serial I/O Mode (Multiple Transmit/Receive Clock Output Pin Function Not Selected) | Pin Name | I/O | Function | Method of Selection | | | |-----------|--------|--------------------|--------------------------------------------------------------|--|--| | TXDi | Output | Serial data output | (Outputs dummy data only when receiving) | | | | | Input | Serial data input | Set the port direction bit sharing pin to 0. | | | | RXDi | Input | Input port | Set the port direction bit sharing pin to 0. (can be used as | | | | | Input | input port | an input port only when transmitting) | | | | | Output | Transmit/receive | The CKDIR bit in the UiMR register = 0 | | | | CLKi | Output | clock output | The Ordin bit in the olivin register = 0 | | | | CLN | Input | Transmit/receive | The CKDIR bit in the UiMR register = 1 | | | | | iriput | clock input | Set the port direction bit sharing pin to 0. | | | | | | | The CRD bit in the UiC0 register = 0 | | | | | Input | CTS input | The CRS bit in the UiC0 register = 0 | | | | CTSi/RTSi | | | Set the port direction bit sharing pin to 0. | | | | 013//013 | Output | RTS output | The CRD bit in the UiC0 register = 0 | | | | | Output | 1110 output | The CRS bit in the UiC0 register = 1 | | | | | I/O | I/O port | The CRD bit in the UiC0 register = 1 | | | i = 0 to 2, 5 to 7 Table 23.7 P6\_4 Pin Functions in Clock Synchronous Serial I/O Mode | | Bit Set Value | | | | | | | |--------------|---------------|-----------------------------|------|--------|--------|---------------------|--| | Pin Function | U1C0 ı | U1C0 register UCON register | | | | PD6 register | | | | CRD | CRS | RCSP | CLKMD1 | CLKMD0 | PD6_4 | | | P6_4 | 1 | - | 0 | 0 | - | Input: 0, Output: 1 | | | CTS1 | 0 | 0 | 0 | 0 | - | 0 | | | RTS1 | 0 | 1 | 0 | 0 | - | - | | | CTS0 (1) | 0 | 0 | 1 | 0 | - | 0 | | | CLKS1 | - | - | - | 1 (2) | 1 | - | | <sup>-</sup> indicates either 0 or 1 - 1. In addition to these settings, set the CRD bit in the U0C0 register to 0 (CTS0/RTS0 enabled) and the CRS bit in the U0C0 register to 1 (RTS0 selected). - 2. When the CLKMD1 bit is 1 and the CLKMD0 bit is 0, the following logic levels are output: - High if the CLKPOL bit in the U1C0 register is 0 - Low if the CLKPOL bit in the U1C0 register is 1 Table 23.8 Registers Used and Settings in Clock Synchronous Serial I/O Mode (1) | Register | Bits | Function | | | | |----------|-----------------------|----------------------------------------------------------------|--|--|--| | UCLKSEL0 | OCOSEL0 | Select clock prior to division for UART0 to UART2. | | | | | UCLKSELU | OCOSEL1 | Select clock prior to division for UART5 to UART7. | | | | | PCLKR | PCLK1 | Select the count source for the UiBRG register. | | | | | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | | LITE | 0 to 7 | Set transmission data. | | | | | UiTB | 8 | - (does not need to be set) If necessary, set to 0. | | | | | | 0 to 7 | Reception data can be read. | | | | | UiRB | 8, 11, 13 to 15 | When read, the read value is undefined. | | | | | | OER | Overrun error flag | | | | | UiBRG | 0 to 7 | Set bit rate. | | | | | | SMD2 to SMD0 | Set to 001b. | | | | | UiMR | CKDIR | Select internal clock or external clock. | | | | | Olivir | 4 to 6 | Set to 0. | | | | | | IOPOL | Set to 0. | | | | | | CLK1 to CLK0 | Select the count source for the UiBRG register. | | | | | | CRS | If CTS or RTS is used, select which function to use. | | | | | | TXEPT | Transmit register empty flag | | | | | UiC0 | CRD | Enable or disable the CTS or RTS function. | | | | | | NCH | Select TXDi pin output mode. (2) | | | | | | CKPOL | Select the transmit/receive clock polarity. | | | | | | UFORM | Select LSB first or MSB first. | | | | | | TE | Set to 1 to enable transmission/reception. | | | | | | TI | Transmit buffer empty flag | | | | | | RE | Set to 1 to enable reception. | | | | | UiC1 | RI | Reception complete flag | | | | | UIC I | UjIRS | Select source of UARTj transmit interrupt. | | | | | | UjRRM | Set to 1 to use continuous receive mode. | | | | | | UiLCH | Set to 1 to use inverted data logic. | | | | | | UiERE | Set to 0. | | | | | UiSMR | 0 to 7 | Set to 0. | | | | | UiSMR2 | 0 to 7 | Set to 0. | | | | | | 0 to 2 | Set to 0. | | | | | UiSMR3 | NODC | Select clock output mode. | | | | | | 4 to 7 | Set to 0. | | | | | UiSMR4 | 0 to 7 | Set to 0. | | | | | | U0IRS | Select source of UART0 transmit interrupt. | | | | | UCON | U1IRS | Select source of UART1 transmit interrupt. | | | | | | U0RRM | Set to 1 to use continuous receive mode. | | | | | | U1RRM | Set to 1 to use continuous receive mode. | | | | | | CLKMD0 | Select the transmit/receive clock output pin when CLKMD1 is 1. | | | | | | CLKMD1 | Set to 1 to output UART1 transmit/receive clock from two pins. | | | | | | RCSP | • | | | | | | | Set to 1 to separate the CTS0/RTS signal of UART0. | | | | | | 7<br>7: i = 2, 5 to 7 | Set to 0. | | | | i = 0 to 2, 5 to 7; j = 2, 5 to 7 - 1. This table does not describe a procedure. - 2. The TXD2 pin is N-channel open drain output. Nothing is assigned to the NCH bit in the U2C0 register. If necessary, set it to 0. Figure 23.5 Transmit and Receive Operation during Clock Synchronous Serial I/O Mode ## 23.3.1.1 CLK Polarity Select Function Use the CKPOL bit in the UiC0 register (i = 0 to 2, 5 to 7) to select the transmit/receive clock polarity. Figure 23.6 shows the Transmit/Receive Clock Polarity. Figure 23.6 Transmit/Receive Clock Polarity #### 23.3.1.2 LSB First/MSB First Select Function Use the UFORM bit in the UiC0 register (i = 0 to 2, 5 to 7) to select the bit order. Figure 23.7 shows the Bit Order. Figure 23.7 Bit Order ## 23.3.1.3 Continuous Receive Mode In continuous receive mode, the receive operation is enabled when the receive buffer register is read. Thus, a dummy write to the transmit buffer register to enable the receive operation is unnecessary in this mode. However, a dummy read of the receive buffer register is required when start receiving. When setting the UiRRM bit in the UiC1 or UCON register (i = 0 to 2, 5 to 7) to 1 (continuous receive mode), the TI bit in the UiC1 register is set to 0 (data present in the UiTB register) by reading the UiRB register. When the UiRRM bit is 1, do not write dummy data to the UiTB register by a program. When using an external clock, read the UiRB register between receiving the eighth bit of data and starting the next transmission. Figure 23.8 shows Operation Example in Continuous Receive Mode. Figure 23.8 Operation Example in Continuous Receive Mode ## 23.3.1.4 Serial Data Logic Switching Function When the UiLCH bit in the UiC1 register (i = 0 to 2, 5 to 7) is 1 (inverted), the data written to the UiTB register has its logic inverted before being transmitted. Similarly, the inverted data has its logic inverted when read from the UiRB register. Figure 23.9 shows Serial Data Logic. Figure 23.9 Serial Data Logic ## 23.3.1.5 Transmit/Receive Clock Output from Multiple Pins (UART1) Use bits CLKMD1 to CLKMD0 in the UCON register to select one of the two transmit/receive clock output pins (see Figure 23.10). This function can be used when the selected transmit/receive clock for UART1 is an internal clock. Figure 23.10 Transmit/Receive Clock Output from Multiple Pins ### 23.3.1.6 CTS/RTS Function The $\overline{\text{CTS}}$ function is used to start transmit/receive operation when a low signal is applied to the $\overline{\text{CTSi/RTSi}}$ (i = 0 to 2, 5 to 7) pin. Transmit/receive operation begins when input to the $\overline{\text{CTSi/RTSi}}$ pin becomes low. If the low signal is switched to high during a transmit or receive operation, the operation stops before the next data. For the RTS function, the CTSi/RTSi pin outputs a low signal when the MCU is ready to receive. The output level becomes high at the detection of the start bit. See Table 23.6 "Pin Functions in Clock Synchronous Serial I/O Mode (Multiple Transmit/Receive Clock Output Pin Function Not Selected)". ## 23.3.1.7 CTS/RTS Separate Function (UART0) This function separates $\overline{\text{CTS0}}/\overline{\text{RTS0}}$ , outputs $\overline{\text{RTS0}}$ from the P6\_0 pin, and inputs $\overline{\text{CTS0}}$ from the P6\_4 pin. To use this function, set the register bits as follows: - The CRD bit in the U0C0 register is 0 (enable CTS/RTS of UART0) - The CRS bit in the U0C0 register is 1 (output RTS of UART0) - The CRD bit in the U1C0 register is 0 (enable CTS/RTS of UART1) - The CRS bit in the U1C0 register is 0 (input CTS of UART1) - The RCSP bit in the UCON register is 1 (inputs CTSO from the P6\_4 pin) - The CLKMD1 bit in the UCON register is 0 (CLKS1 not used) Note that when using the CTS/RTS separate function, CTS/RTS of UART1 function cannot be used. Figure 23.11 CTS/RTS Separate Function ## 23.3.1.8 Processing When Terminating Communication or When an Error Occurs When communication is terminated in clock synchronous serial I/O mode, or when a communication error occurs, use the following procedure to reset communication: - (1) Set the TE bit in the UiC1 (i = 0 to 2, 5 to 7) register to 0 (transmission disabled) and the RE bit to 0 (reception disabled). - (2) Set bits SMD2 to SMD0 in the UiMR register to 000b (serial interface disabled). - (3) Set bits SMD2 to SMD0 in the UiMR register to 001b (clock synchronous serial I/O mode). - (4) Set the TE bit in the UiC1 register to 1 (transmission enabled) and the RE bit to 1 (reception enabled). ## 23.3.2 Clock Asynchronous Serial I/O (UART) Mode The UART mode allows data to be transmitted/received after setting the desired bit rate and bit order. Table 23.9 lists the UART Mode Specifications. Table 23.9 UART Mode Specifications | Item | Specification | |----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | | Character bit: selectable from 7, 8, or 9 bits | | Data farment | Start bit: 1 bit | | Data format | Parity bit: selectable from odd, even, or none | | | Stop bit: selectable from 1 bit or 2 bits | | | • The CKDIR bit in the UiMR register = 0 (internal clock): $\frac{fj}{16(n+1)}$ | | Transmit/receive clock | fj = f1SIO, f2SIO, f8SIO, f32SIO n: Setting value of UiBRG register 00h to FFh | | | ● CKDIR bit = 1 (external clock):<br>16(n+1) | | | fEXT: Input from CLKi pin n: Setting value of UiBRG register 00h to FFh | | Transmit/receive control | Selectable from CTS, RTS, or CTS/RTS function disabled | | | To start transmission, satisfy the following requirements: | | Transmission start | • The TE bit in the UiC1 register is 1 (transmission enabled) | | conditions | • The TI bit in the UiC1 register is 0 (data present in the UiTB register) | | | • If CTS function is selected, input on the CTSi pin = low | | Decention start | To start reception, satisfy the following requirements: | | Reception start conditions | • The RE bit in the UiC1 register is 1 (reception enabled) | | Conditions | Start bit detection | | | For transmission, one of the following conditions can be selected: | | | • The UiIRS bit in the UiC1 or UCON register is 0 (transmit buffer empty): | | | When transferring data from the UiTB register to the UARTi transmit register (at start of | | Interrupt request | transmission) | | generation timing | • The UiIRS bit is 1 (transmission completed): | | | When the serial interface completes sending data from the UARTi transmit register For reception: | | | When transferring data from the UARTi receive register to the UiRB register (at | | | completion of reception) | | | Overrun error (1) | | | This error occurs if the serial interface starts receiving the next unit of data before reading | | | the UiRB register and receives the bit before the last stop bit of the next unit of data. | | | Framing error | | Error detection | This error occurs when the number of stop bits set is not detected. | | Litter detection | Parity error | | | This error occurs when the number of 1's of the parity bit and character bit does not match | | | the set value of the PRY bit in the UiMR register. | | | • Error sum flag | | | This flag becomes 1 when any of the overrun, framing, or parity errors occur. | | | <ul> <li>LSB first, MSB first selection</li> <li>Whether to start transmitting/receiving the data from bit 0 or from bit 7 can be selected.</li> </ul> | | | Serial data logic switch | | | This function inverts the logic of the transmit/receive data. The start and stop bits are not | | | inverted. | | Selectable functions | TXD, RXD I/O polarity switch | | | This function inverts the polarities of the TXD pin output and RXD pin input. The logic | | | levels of all I/O data are inverted. | | | Separate CTS/RTS pins (UART0) | | | CTS0 and RTS0 are input/output from separate pins. | i = 0 to 2, 5 to 7 <sup>1.</sup> If an overrun error occurs, the receive data of the UiRB register will be undefined. The IR bit in the SiRIC register remains unchanged. Table 23.10 lists I/O Pin Functions in UART Mode. Table 23.11 lists the P6\_4 Pin Functions in UART Mode. Note that for a period from when the UARTi operating mode is selected to when transmission starts, the TXDi pin outputs a high-level signal. (If N-channel open drain output is selected, this pin becomes high-impedance.) Table 23.10 I/O Pin Functions in UART Mode | Pin Name | I/O | Function | Method of Selection | | | |-----------|--------|--------------------------------------------------------------------------------------------|----------------------------------------------|--|--| | TXDi | Output | Serial data output (High-level output only when receiving.) | | | | | RXDi | Input | Serial data input | Set the port direction bit sharing pin to 0. | | | | | Input | Set the port direction bit sharing pin to 0. (can b an input port only when transmitting.) | | | | | | I/O | Input/output port | The CKDIR bit in the UiMR register = 0 | | | | CLKi | Input | Transmit/receive | The CKDIR bit in the UiMR register = 1 | | | | | | clock input | Set the port direction bit sharing pin to 0. | | | | CTSi/RTSi | Input | | The CRD bit in the UiC0 register = 0 | | | | | | CTS input | The CRS bit in the UiC0 register = 0 | | | | | | | Set the port direction bit sharing pin to 0. | | | | | Output | RTS output | The CRD bit in the UiC0 register = 0 | | | | | | n 13 output | The CRS bit in the UiC0 register = 1 | | | | | I/O | I/O port | The CRD bit in the UiC0 register = 1 | | | i = 0 to 2, 5 to 7 Table 23.11 P6\_4 Pin Functions in UART Mode | | Bit Set Value | | | | | | |--------------|---------------|-----|---------------|--------|---------------------|--| | Pin Function | U1C0 register | | UCON register | | PD6 register | | | | CRD | CRS | RCSP | CLKMD1 | PD6_4 | | | P6_4 | 1 | - | 0 | 0 | Input: 0, Output: 1 | | | CTS1 | 0 | 0 | 0 | 0 | 0 | | | RTS1 | 0 | 1 | 0 | 0 | - | | | CTS0 (1) | 0 | 0 | 1 | 0 | 0 | | <sup>-</sup> indicates either 0 or 1. #### Note: 1. In addition to these settings, set the CRD bit in the U0C0 register to 0 (CTS0/RTS0 enabled) and the CRS bit in the U0C0 register to 1 (RTS0 selected). Table 23.12 Registers Used and Settings in UART Mode (1) | Register | Bits | Function | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--| | LICLIKETIO | OCOSEL0 | Select clock prior to division for UART0 to UART2. | | | | UCLKSEL0 | OCOSEL1 | Select clock prior to division for UART5 to UART7. | | | | PCLKR | PCLK1 | Select the count source for the UiBRG register. | | | | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | UiTB | 0 to 8 | Set transmission data. (2) | | | | | 0 to 8 | Reception data can be read. (2, 4) | | | | UiRB | OER, FER, PER, SUM | Error flag | | | | | 11 | When read, the read value is undefined. | | | | UiBRG | 0 to 7 | Set bit rate. | | | | | | Set to 100b when character bit length is 7 bits. | | | | | SMD2 to SMD0 | Set to 101b when character bit length is 8 bits. | | | | | | Set to 110b when character bit length is 9 bits. | | | | UiMR | CKDIR | Select the internal clock or external clock. | | | | | STPS | Select number of stop bits. | | | | | PRY, PRYE | Select whether parity is included and whether odd or even. | | | | | IOPOL | Select the TXD/RXD input/output polarity. | | | | | CLK0, CLK1 | Select the count source for the UiBRG register. | | | | | CRS | If CTS or RTS is used, select which function to use. | | | | | TXEPT | Transmit register empty flag | | | | UiC0 | CRD | Enable or disable the CTS or RTS function. | | | | OICO | NCH | Select TXDi pin output mode. (3) | | | | | CKPOL | Set to 0. | | | | | UFORM | LSB first or MSB first can be selected when character bit length is 8 bits. Set to 0 when character bit length is 7 or 9 bits. | | | | | TE | Set to 1 to enable transmission. | | | | | TI | Transmit buffer empty flag | | | | | RE | Set to 1 to enable reception. | | | | 11:04 | RI | Reception complete flag | | | | UiC1 | UjIRS | Select source of UARTj transmit interrupt. | | | | | UjRRM | Set to 0. | | | | | UiLCH | Set to 1 to use reversed data logic. | | | | | UiERE | Set to 0. | | | | UiSMR | 0 to 7 | Set to 0. | | | | UiSMR2 | 0 to 7 | Set to 0. | | | | UiSMR3 | 0 to 7 | Set to 0. | | | | UiSMR4 | 0 to 7 | Set to 0. | | | | | U0IRS | Select source of UART0 transmit interrupt. | | | | | U1IRS | Select source of UART1 transmit interrupt. | | | | UCON | U0RRM | Set to 0. | | | | | U1RRM | Set to 0. | | | | UCUN | CLKMD0 | Disabled because CLKMD1 is 0 | | | | | CLKMD1 | Set to 0. | | | | | RCSP | Set to 1 to input CTS0 signal of UART0 from the P6_4 pin. | | | | | 7 | Set to 0. | | | | i = 0 to 2.5 to 3.5 3. | 7· i = 2 5 to 7 | | | | i = 0 to 2, 5 to 7; j = 2, 5 to 7 - 1. This table does not describe a procedure. - 2. The bits used for transmit/receive data are as follows: Bits 0 to 6 when character bit length is 7 bits; bits 0 to 7 when character bit length is 8 bits; bits 0 to 8 when character bit length is 9 bits. - 3. The TXD2 pin is N-channel open drain output. Nothing is assigned to the NCH bit in the U2C0 register. If necessary, set it to 0. - 4. The values of bits 7 and 8 are undefined when character bit length is 7 bits. The values of bit 8 is undefined when character bit length is 8 bits. Figure 23.12 Transmit Timing in UART Mode Figure 23.13 Receive Timing in UART Mode ## 23.3.2.1 Bit Rate In UART mode, the frequency set by the UiBRG register (i = 0 to 2, 5 to 7) divided by 16 becomes a bit rate. The setting value (n) of the UiBRG register is calculated by the following formula: $$n = \frac{fj}{bitrate(bps) \times 16} - 1$$ fj = f1SIO, f2SIO, f8SIO, f32SIO n = 00h to FFh Table 23.13 lists Example Bit Rates and Settings. Table 23.13 Example of Bit Rates and Settings (1) | Bit Rate | Count Source | Peripheral Function Clock f1: 16 MHz | | Peripheral Function Clock f1: 24 MHz | | |----------|--------------|--------------------------------------|----------------|--------------------------------------|----------------| | (bps) | of UiBRG | Set Value of<br>UiBRG: n | Bit Rate (bps) | Set value of<br>UiBRG: n | Bit Rate (bps) | | 1200 | f8SIO | 103 (67h) | 1202 | 155 (9Bh) | 1202 | | 2400 | f8SIO | 51 (33h) | 2404 | 77 (4Dh) | 2404 | | 4800 | f8SIO | 25 (19h) | 4808 | 38 (26h) | 4808 | | 9600 | f1SIO | 103 (67h) | 9615 | 155 (9Bh) | 9615 | | 14400 | f1SIO | 68 (44h) | 14493 | 103 (67h) | 14423 | | 19200 | f1SIO | 51 (33h) | 19231 | 77 (4Dh) | 19231 | | 28800 | f1SIO | 34 (22h) | 28571 | 51 (33h) | 28846 | | 31250 | f1SIO | 31 (1Fh) | 31250 | 47 (2Fh) | 31250 | | 38400 | f1SIO | 25 (19h) | 38462 | 38 (26h) | 38462 | | 51200 | f1SIO | 19 (13h) | 50000 | 28 (1Ch) | 51724 | <sup>1.</sup> Assumed that either the OCOSEL0 bit or OCOSEL1 bit in the UCLKSEL0 register is 0 (f1). ## 23.3.2.2 LSB First/MSB First Select Function As shown in Figure 23.14, the bit order can be selected by setting the UFORM bit in the UiC0 register. This function is enabled when the character bit length is 8 bits. Figure 23.14 Bit Order # 23.3.2.3 Serial Data Logic Switching Function The logic of the data written to the UiTB register is inverted and then transmitted. Similarly, the inverted logic of the received data is read when the UiRB register is read. Figure 23.15 Serial Data Logic Switching ### 23.3.2.4 TXD and RXD I/O Polarity Reverse Function This function reverses the polarities of the TXDi pin output and RXDi pin input. The logic levels of all I/O data (including bits for start, stop, and parity) are inverted. Figure 23.16 TXD and RXD I/O Polarity Inversion ### 23.3.2.5 CTS/RTS Function The $\overline{\text{CTS}}$ function is used to start transmit operation when a low signal is applied to the $\overline{\text{CTSi}/\text{RTSi}}$ (i = 0 to 2, 5 to 7) pin. Transmit operation begins when input to the $\overline{\text{CTSi}/\text{RTSi}}$ pin becomes low. If the input level is switched from low to high during transmit operation, the operation stops after the ongoing transmit/receive operation is completed. When the RTS function is selected, the CTSi/RTSi pin outputs a low signal when the MCU is ready to receive. The output level becomes high when a start bit is detected. See Table 23.10 "I/O Pin Functions in UART Mode". # 23.3.2.6 CTS/RTS Separate Function (UART0) This function separates $\overline{\text{CTS0}}$ and $\overline{\text{RTS0}}$ , outputs $\overline{\text{RTS0}}$ from the P6\_0 pin, and inputs $\overline{\text{CTS0}}$ from the P6\_4 pin. To use this function, set the register bits as follows: - The CRD bit in the U0C0 register is 0 (enable CTS/RTS of UART0) - The CRS bit in the U0C0 register is 1 (output RTS of UART0) - The CRD bit in the U1C0 register is 0 (enable CTS/RTS of UART1) - The CRS bit in the U1C0 register is 0 (input CTS of UART1) - The RCSP bit in the UCON register is 1 (inputs CTS0 from the P6\_4 pin) - The CLKMD1 bit in the UCON register is 0 (CLKS1 not used) Note that when using the CTS/RTS separate function, CTS/RTS function of UART1 cannot be used. Figure 23.17 CTS/RTS Separate Function ## 23.3.2.7 Processing When Terminating Communication or When an Error Occurs If communication is terminated in UART mode, or a communication error occurs, use following procedure reset communication: - (1) Set the TE bit in the UiC1 (i = 0 to 2, 5 to 7) register to 0 (transmission disabled) and the RE bit to 0 (reception disabled). - (2) Set bits SMD2 to SMD0 in the UiMR register to 000b (serial interface disabled). - (3) Set bits SMD2 to SMD0 in the UiMR register to 100b (UART mode character bit length is 7 bits), 101b (UART mode character bit length is 8 bits), and 110b (UART mode character bit length is 9 bits). - (4) Set the TE bit in the UiC1 register to 1 (transmission enabled) and the RE bit to 1 (reception enabled). # 23.3.3 Special Mode 1 (I<sup>2</sup>C Mode) $I^2C$ mode is compatible with the simplified $I^2C$ interface. Table 23.14 lists the $I^2C$ Mode Specifications. Table 23.16 and Table 23.17 list the Registers Used and Settings in $I^2C$ Mode. Table 23.18 lists the $I^2C$ Mode Functions. Figure 23.18 shows the $I^2C$ Mode Block Diagram. As shown in Table 23.18, the MCU is placed in I<sup>2</sup>C mode by setting the IICM bit in the UiSMR register to 1 and bits SMD2 to SMD0 in the UiMR register to 010b. Because SDAi transmit output has a delay circuit attached, SDAi output does not change state until SCLi goes low and remains stably low. Table 23.14 I<sup>2</sup>C Mode Specifications | Item | Specification | |----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Data format | Character bit length: 8 bits | | Transfer clock | <ul> <li>Master mode The CKDIR bit in the UiMR register is 0 (internal clock): fj / (2(n+1)) fj = f1SIO, f2SIO, f8SIO, f32SIO n = setting value of the UiBRG register (03h to FFh) </li> <li>Slave mode The CKDIR bit is 1 (external clock): input from the SCLi pin </li> </ul> | | Transmit/receive clock | To start transmission, satisfy the following requirements (1) • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data present in UiTB register) | | Reception start conditions | To start reception, satisfy the following requirements (1) • The RE bit in the UiC1 register is 1 (reception enabled) • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data present in the UiTB register) | | Interrupt request | When a start condition, stop condition, ACK (acknowledge), or NACK (not- | | generation timing | acknowledge) is detected. | | Error detection | Overrun error <sup>(2)</sup> This error occurs if the serial interface starts receiving the next unit of data before reading the UiRB register and receives the eighth bit of the unit of next data. | | Selectable functions | <ul> <li>Arbitration lost Timing at which the ABT bit in the UiRB register is updated can be selected. </li> <li>SDAi digital delay No digital delay or a delay of 2 to 8 UiBRG count source clock cycles can be selected. </li> <li>Clock phase setting With or without clock delay can be selected. </li> </ul> | i = 0 to 2, 5 to 7 - These requirements do not have to be set in any particular order. When transmission/reception is started as a slave and the TXEPT bit in the UiC0 register is 1 (no data present in transmit register), meet the last requirement when the external clock is high. - 2. If an overrun error occurs, the received data of the UiRB register will be undefined. Figure 23.18 I<sup>2</sup>C Mode Block Diagram Figure 23.19 Internal Clock Configuration Table 23.15 I/O Pin Functions in I<sup>2</sup>C Mode | Pin Name | I/O | Function | |-------------|-----|-----------------------| | SCLi (1, 2) | I/O | Clock input or output | | SDAi (1, 2) | I/O | Data input or output | - 1. Set the port direction bit sharing pin to 0. - 2. Pins CLKi and CTSi/RTSi are not used (they can be used as I/O ports). Table 23.16 Registers Used and Settings in I<sup>2</sup>C Mode (1/2) <sup>(1)</sup> | Master Slave | Register Bits | | Function | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | UCLKSELO | rregister I | Dita | Master | Slave | | | OCOSEL1 Select clock prior to division for UART5 to UART7. | | OCOSEL0 | | The state of s | | | PCLKR PCLK1 register. register. register. | | OCOSEL1 | | <u> </u> | | | UiTB | PCLKR | PCLK1 | | | | | UITB | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | When transmitting, set to 1. When receiving, set the value in the ACK bit. Vicinity Computer | LIiTR | 0 to 7 | data. When receiving, set FFh. | data. When receiving, set FFh. | | | UIRB ABT Arbitration lost detection flag Disabled OER Overrun error flag Overrun error flag I 3 to 15 When read, the read value is undefined. When read, the read value is undefined. UIBRG 0 to 7 Set a bit rate. SMD2 to SMD0 Set to 010b. UIMR CKDIR Set to 0. IOPOL Set to 0. IOPOL Set to 0. Select the count source for the UIBRG register. CRS Disabled because CRD is 1 Disabled because CRD is 1 TXEPT Transmit register empty flag Transmit register empty flag CRD Set to 1. NCH Set to 1. Set to 1. Set to 1. Set to 1. VICO UICOROM Set to 0. Set to 1. 3. Set to 1. Set to 1. Set to 3. Set to 1. Set to 1. Set to 1. Set to 3. Set to 1. Set to 1. Set t | OND | | receiving, set the value in the ACK bit. | set the value in the ACK bit. | | | UIRB | | 0 to 7 | - | | | | OER Overrun error flag 13 to 15 When read, the read value is undefined. When read, the read value is undefined. UiBRG O to 7 Set a bit rate. Disabled SMD2 to SMD2 to SMD0 CKDIR Set to 0.0 Set to 1. 4 to 6 Set to 0. IOPOL Set to 0. Set to 0. CLK1, CLK0 CRS Disabled because CRD is 1 Disabled because CRD is 1 TXEPT Transmit register empty flag Transmit register empty flag CRD (3) Set to 1. NCH Set to 1. NCH Set to 1. VIFORM Set to 1. TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UISMR UISMR UISMR BBS Bus busy flag Bus busy flag Bus busy flag Disabled When read, the read value is undefined. When read, the read, the read value is undefined. When Disabled Set to 1. 0. Set to 0. Set to 0. Set to 0. Set to 0. Set to 1. Set to 1. Set to 1. Set to 1. Set to 1. Set to 1. | | 8 | ACK or NACK is set in this bit. | ACK or NACK is set in this bit. | | | UiBRG 0 to 7 Set a bit rate. Disabled SMD2 to SMD0 Set to 010b. Set to 010b. Set to 010b. Set to 010b. Set to 010b. Set to 0. UiMR EXPRESS SET SET SET SET SET TRANSITION SET TO 1. UICO SET SET SET TO 1. UICO SET SET SET SET TO 1. UICO SET | UiRB | ABT | Arbitration lost detection flag | | | | UiBRG 0 to 7 Set a bit rate. Disabled UIMR SMD0 sMD0 Set to 010b. Set to 010b. Set to 010b. Set to 010b. UICO CKDIR Set to 0. Set to 0. Set to 0. Set to 0. UICO Set to 0. Set to 0. Set to 0. Set to 0. UICO CLK1, CLK0 Select the count source for the UiBRG register. Disabled CRS Disabled because CRD is 1 Disabled because CRD is 1 TXEPT Transmit register empty flag Transmit register empty flag CRD (3) Set to 1. Set to 1. NCH Set to 1. Set to 1. NCH Set to 1. Set to 1. Set to 1. Set to 1. Set to 1. UFORM Set to 1. Set to 1. UICO Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. Set to 1 to enable reception. RE Set to 1. Set to 1. UjRRM, UiLCH, UiERE Set to 0. Set to 1. UISMR <td></td> <td>_</td> <td>5</td> <td>9</td> | | _ | 5 | 9 | | | SMD2 to SMD0 | | 13 to 15 | · | When read, the read value is undefined. | | | UiMR | UiBRG | 0 to 7 | Set a bit rate. | Disabled | | | 4 to 6 Set to 0. IOPOL Set to 0. Set to 0. Set to 0. Set to 0. CLK1, CLK0 Select the count source for the UiBRG register. CRS Disabled because CRD is 1 Disabled because CRD is 1 TXEPT Transmit register empty flag Transmit register empty flag CRD (3) Set to 1. NCH Set to 1. (2) Set to 1. NCH Set to 0. UFORM Set to 1. TE Set to 1 to enable transmission. Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. Set to 1. UjRRM, UiLCH, UIERE IICM Set to 1. Set to 1. Set to 1. Set to 1. Set to 0. Set to 0. Set to 0. Set to 0. Set to 1. Disabled BBS Bus busy flag Bus busy flag | | | Set to 010b. | Set to 010b. | | | IOPOL Set to 0. CLK1, CLK0 Select the count source for the UiBRG register. CRS Disabled because CRD is 1 Disabled because CRD is 1 TXEPT Transmit register empty flag Transmit register empty flag CRD (3) Set to 1. Set to 1. NCH Set to 1. (2) Set to 0. UFORM Set to 1. Set to 1. TE Set to 1 to enable transmission. Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. UiCH, UiERE IICM Set to 1. Disabled BBS Bus busy flag Bus busy flag | UiMR | CKDIR | Set to 0. | Set to 1. | | | UICO CLK1, CLK0 Select the count source for the UiBRG register. CRS Disabled because CRD is 1 Disabled because CRD is 1 TXEPT Transmit register empty flag Transmit register empty flag CRD (3) Set to 1. NCH Set to 1. (2) Set to 1. NCH Set to 0. UFORM Set to 1. Set to 1. Set to 1. TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reseption complete flag UjIRS Set to 1. Set to 1. Set to 1. Set to 1. Set to 1 to enable reception. Bet to 1. Set to 1. Set to 0. UjiRM, UiLCH, UiERE IICM Set to 1. Set to 1. Set to 0. Disabled Bus busy flag | | 4 to 6 | Set to 0. | Set to 0. | | | UiC0 CRS Disabled because CRD is 1 Disabled because CRD is 1 TXEPT Transmit register empty flag Transmit register empty flag CRD (3) Set to 1. Set to 1. NCH Set to 1. (2) Set to 0. UFORM Set to 1. Set to 1. TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. UjRRM, UjICH, UjERE UISMR BBS Bus busy flag Bus busy flag Disabled because CRD is 1 Disabled because CRD is 1 Disabled because CRD is 1 Disabled because CRD is 1 Disabled Disabled Disabled Disabled Disabled | | IOPOL | Set to 0. | Set to 0. | | | UiC0 TXEPT Transmit register empty flag Transmit register empty flag CRD (3) Set to 1. NCH Set to 1. (2) Set to 1. CKPOL Set to 0. UFORM Set to 1. TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. UjRRM, UiLCH, UiERE IICM Set to 1. Set to 1. Set to 0. Set to 0. Set to 1. 0. Set to 0. Set to 0. Set to 0. Set to 0. Set to 0. BBS Bus busy flag Bus busy flag | | CLK1, CLK0 | | Disabled | | | UiC0 CRD (3) Set to 1. NCH Set to 1. (2) Set to 1. CKPOL Set to 0. UFORM Set to 1. TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. UjRRM, UiLCH, UiERE UISMR ABC Set to 1. Belse Bus busy flag Bus busy flag Bus busy flag | | CRS | Disabled because CRD is 1 | Disabled because CRD is 1 | | | UiSMR NCH Set to 1. (2) Set to 0. Set to 1. (2) Set to 0. UFORM Set to 1. TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. UiCH, UiLCH, UiERE UISMR UISMR BBS Bus busy flag Set to 1. Set to 1. Set to 1. Set to 0. | | TXEPT | Transmit register empty flag | Transmit register empty flag | | | CKPOL Set to 0. UFORM Set to 1. Set to 1. Set to 1. TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. Set to 1. Set to 1. UjRRM, UiLCH, UiERE IICM Set to 0. Set to 0. Set to 1. Set to 0. Set to 1. Set to 0. Set to 0. Set to 0. Set to 0. Set to 1. Set to 0. Set to 1. Set to 0. Set to 1. Set to 1. Bess Bus busy flag Bus busy flag | UiCo | CRD (3) | Set to 1. | Set to 1. | | | UFORM Set to 1. TE Set to 1 to enable transmission. Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. Set to 1. UjRRM, UiLCH, UiERE IICM Set to 0. Set to 0. Set to 1. Set to 0. UiSMR ABC Select the timing that arbitration lost is detected. BBS Bus busy flag Bus busy flag Set to 1. | | NCH | Set to 1. (2) | Set to 1. (2) | | | UiC1 TE Set to 1 to enable transmission. TI Transmit buffer empty flag Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. Set to 1. UjRRM, UiLCH, UiERE IICM Set to 0. Set to 0. Set to 1. Set to 0. Bess Bus busy flag Bus busy flag | | CKPOL | Set to 0. | Set to 0. | | | UiC1 Transmit buffer empty flag RE Set to 1 to enable reception. RI Reception complete flag UjIRS Set to 1. UjRRM, UiLCH, UiERE IICM Set to 1. Set to 0. Set to 1. Set to 0. Set to 1. Set to 1. Set to 1. Set to 1. Set to 0. | | UFORM | Set to 1. | Set to 1. | | | UiC1 RE Set to 1 to enable reception. RI Reception complete flag Reception complete flag UjIRS Set to 1. UjRRM, UiLCH, UiERE IICM Set to 1. Set to 0. Set to 0. Set to 0. Set to 1. Set to 1. Set to 0. Set to 0. Disabled Disabled BBS Bus busy flag Bus busy flag | | TE | Set to 1 to enable transmission. | Set to 1 to enable transmission. | | | UiC1 RI Reception complete flag UjIRS Set to 1. Set to 1. UjRRM, UiLCH, UiERE Set to 0. Set to 0. Set to 1. Set to 0. Set to 1. Set to 0. Disabled BBS Bus busy flag Reception complete flag Reception complete flag Set to 1. Set to 1. Disabled Bus busy flag | | TI | Transmit buffer empty flag | Transmit buffer empty flag | | | UjIRS Set to 1. UjRRM, UiLCH, UiERE IICM Set to 1. Set to 0. Set to 0. Set to 1. Set to 1. Set to 0. Set to 0. Disabled BBS Bus busy flag Bus busy flag | | RE | | | | | UjIRS Set to 1. UjRRM, UiLCH, UiERE IICM Set to 1. Set to 0. Set to 0. Set to 1. Set to 1. Set to 0. Set to 0. Disabled BBS Bus busy flag Bus busy flag | LliC1 | RI | Reception complete flag | Reception complete flag | | | UjRRM, UiLCH, UiERE Set to 0. Set to 0. Set to 1. Set to 1. ABC Select the timing that arbitration lost is detected. BBS Bus busy flag Bus busy flag Bus busy flag | UIC1 . | UjIRS | | | | | UiSMR ABC Select the timing that arbitration lost is detected. BBS Bus busy flag Bus busy flag Bus busy flag | | UiLCH, | Set to 0. | Set to 0. | | | UiSMR detected. BBS Bus busy flag Bus busy flag Bus busy flag | | IICM | Set to 1. | Set to 1. | | | | UiSMR | ABC | _ | Disabled | | | 3 to 7 Set to 0. Set to 0. | | | | | | | | | 3 to 7 | Set to 0. | Set to 0. | | i = 0 to 2, 5 to 7; j = 2, 5 to 7 - 1. This table does not describe a procedure. - 2. The TXD2 pin is N-channel open drain output. Nothing is assigned to the NCH bit in the U2C0 register. If necessary, set it to 0. - 3. When using UART1 in I<sup>2</sup>C mode, to enable the $\overline{\text{CTS}/\text{RTS}}$ separate function of UART0, set the CRD bit in the U1C0 register to 0 ( $\overline{\text{CTS}/\text{RTS}}$ enabled) and the CRS bit to 0 ( $\overline{\text{CTS}}$ input). Table 23.17 Registers Used and Settings in I<sup>2</sup>C Mode (2/2) (1) | Dogistor | Bits | Fu | nction | |-----------------|-----------------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------| | Register | DIIS | Master | Slave | | | IICM2 | See Table 23.18 "I <sup>2</sup> C Mode Functions". | See Table 23.18 "I <sup>2</sup> C Mode Functions". | | | CSC | Set to 1 to enable clock synchronization. | Set to 0. | | | SWC | Set to 1 to fix SCLi output to low after receiving the eighth bit of the clock. | Set to 1 to fix SCLi output to low after receiving the eighth bit of the clock. | | UiSMR2 | ALS | Set to 1 to stop SDAi output when arbitration lost is detected. | Set to 0. | | | STAC | Set to 0. | Set to 1 to initialize UARTi at start condition detection. | | | SWC2 | Set to 1 to forcibly pull SCLi output low. | Set to 1 to forcibly pull SCLi output low. | | | SDHI | Set to 1 to disable SDAi output. | Set to 1 to disable SDAi output. | | | 7 | Set to 0. | Set to 0. | | LUCATO | 0, 2, 4<br>NODC | Set to 0. | Set to 0. | | UiSMR3 | CKPH | Set to 1. | Set to 1. | | | DL2 to DL0 | Set the amount of SDAi digital delay. | Set the amount of SDAi digital delay. | | | STAREQ | Set to 1 to generate start condition. | Set to 0. | | | RSTAREQ | Set to 1 to generate restart condition. | Set to 0. | | | STPREQ | Set to 1 to generate stop condition. | Set to 0. | | | STSPSEL | Set to 1 to output each condition. | Set to 0. | | UiSMR4 | ACKD | Select ACK or NACK. | Select ACK or NACK. | | O.O.W.C. | ACKC | Set to 1 to output ACK data. | Set to 1 to output ACK data. | | | SCLHI | Set to 1 to stop SCLi output when stop condition is detected. | Set to 0. | | | SWC9 | Set to 0. | Set to 1 to set SCLi to remain low at the falling edge of the ninth bit of clock. | | | U0IRS | Set to 1. | Set to 1. | | UCON | U1IRS | Set to 1. | Set to 1. | | | U0RRM | Set to 0. | Set to 0. | | | U1RRM | Set to 0. | Set to 0. | | UCON | CLKMD0 | Set to 0. | Set to 0. | | | CLKMD1 | Set to 0. | Set to 0. | | | RCSP | Set to 0. | Set to 0. | | | 7 | Set to 0. | Set to 0. | | i = 0 to 2 5 to | . 7 | | • | i = 0 to 2, 5 to 7 #### Note: 1. This table does not describe a procedure. In I<sup>2</sup>C mode, functions and timings vary depending on the IICM2 bit setting in the UiSMR2 register. Figure 23.20 shows Transfer to UiRB Register and Interrupt Timing. See Figure 23.20 for the timing of transferring data to the UiRB register, the bit position of the data stored in the UiRB register, types of interrupts, interrupt requests, and DMA request generation timing. Table 23.18 lists a comparison of other functions in clock synchronous serial I/O mode with I<sup>2</sup>C mode. Table 23.18 I<sup>2</sup>C Mode Functions | | Clask Cynobronous Coriol | I <sup>2</sup> C Mode (SMD2 to SI | MD0 = 010b, IICM = 1) | |----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------| | Function | Clock Synchronous Serial<br>I/O Mode (SMD2 to SMD0<br>= 001b, IICM = 0) | IICM2 = 0<br>(NACK/ACK interrupt) | IICM2 = 1<br>(UART transmit/receive interrupt) | | | = 00 lb, licivi = 0) | CKPH = 1 (Clock delay) | CKPH = 1 (Clock delay) | | Start and stop<br>condition detect<br>interrupts <sup>(3)</sup> | - | Start condition or stop condition de (See Figure 23.22 "STSPSEL Bit F | | | Transmission, NACK interrupt (2, 3) | UARTi transmission<br>Transmission started or<br>completed (selected by<br>UilRS) | No acknowledgment<br>detection (NACK)<br>Rising edge of the 9th bit of SCLi | UARTi transmission<br>Falling edge of the 9th bit of SCLi | | Reception, ACK interrupt (2, 3) | UARTi reception When 8th bit received CKPOL = 0 (rising edge) CKPOL = 1 (falling edge) | Acknowledgment detection (ACK)<br>Rising edge of the 9th bit of SCLi | UARTi reception<br>Falling edge of the 9th bit of SCLi | | Timing for transferring data from UART reception shift register to UiRB register | CKPOL = 0 (rising edge)<br>CKPOL = 1 (falling edge) | Rising edge of the 9th bit of SCLi | Falling edges of the 8th bit of SCLi and rising edges of the 9th bit of SCLi | | UARTi transmission output delay | Not delayed | Delayed | Delayed | | Read RXDi and SCLi<br>pin levels | Possible when the corresponding port direction bit = 0 | Always possible no matter how the corresponding port direction bit is set | Always possible no matter how the corresponding port direction bit is set | | Initial value of TXDi and SDAi outputs | CKPOL = 0 (high)<br>CKPOL = 1 (low) | The value set in the port register before setting I <sup>2</sup> C mode <sup>(1)</sup> | The value set in the port register before setting I <sup>2</sup> C mode <sup>(1)</sup> | | Initial and end values of SCLi | - | Low | Low | | DMA1, DMA3 factor | UARTi reception | Acknowledgment detection (ACK) | UARTi reception Falling edge of the 9th bit of SCLi | | Read received data | 1st to 8th bits of the received data are stored in bits 0 to 7 in the UiRB register. | 1st to 8th bits of the received data are stored in bits 7 to 0 in the UiRB register. | Refer to Figure 23.20 "Transfer to UiRB Register and Interrupt Timing". | i = 0 to 2, 5 to 7 SMD2 to SMD0: Bits in the UiMR register CKPOL: Bit in the UiC0 register IICM: Bit in the UiSMR register IICM2: Bit in the UiSMR2 register CKPH: Bit in the UiSMR3 register UiIRS: Bit in the UCON or UiC1 register - Set the initial value of SDAi output while bits SMD2 to SMD0 in the UiMR register are 000b (serial interface 1. - See Figure 23.20 "Transfer to UiRB Register and Interrupt Timing". - The procedure to change interrupt sources is as follows: - (1) Disable the interrupt to be changed the source. - (2) Change the source of interrupt. - (3) Set the IR bit in the interrupt control register of that interrupt to 0 (no interrupt requested). - (4) Set bits ILVL2 to ILVL0 in the interrupt control register of that interrupt. Figure 23.20 Transfer to UiRB Register and Interrupt Timing # 23.3.3.1 Detecting Start and Stop Conditions Start and stop conditions are detected by their respective detectors. Whether a start or a stop condition has been detected is determined. A start condition detect interrupt request is generated when the SDAi pin changes state from high to low while the SCLi pin is in the high state. A stop condition detect interrupt request is generated when the SDAi pin changes state from low to high while the SCLi pin is in the high state. Because the start and stop condition detect interrupts share the interrupt control register and vector, check the BBS bit in the UiSMR register to determine which interrupt source is requesting the interrupt. To detect a start or stop condition, both the set-up and hold times require at least six cycles of the BRGi count source as shown in Figure 23.21. To meet the condition for the Fast-mode specification, the BRGi count source must be at least 10 MHz. Figure 23.21 Detecting Start and Stop Conditions #### 23.3.3.2 Generating Start and Stop Conditions A start condition is generated by setting the STAREQ bit in the UiSMR4 register (i = 0 to 2, 5 to 7) to 1 (start). A restart condition is generated by setting the RSTAREQ bit in the UiSMR4 register to 1 (start). A stop condition is generated by setting the STPREQ bit in the UiSMR4 register to 1 (start). The output procedure is described below. - (1) Set the STAREQ bit, RSTAREQ bit or STPREQ bit to 1 (start). - (2) Set the STSPSEL bit in the UiSMR4 register to 1 (output). The functions of the STSPSEL bit are shown in Table 23.19 and Figure 23.22. Table 23.19 STSPSEL Bit Functions | Function | STSPSEL = 0 | STSPSEL = 1 | |--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | Output of pins SCLi and SDAi | Output of transmit/receive clock and data Output of start/stop condition is accomplished by a program using ports (not automatically generated in hardware) | Output of a start/stop condition according to bits STAREQ, RSTAREQ, and STPREQ | | Start/stop condition Interrupt request Detection of start/stop condition generation timing | | Completion of generating start/stop condition | Figure 23.22 STSPSEL Bit Functions Figure 23.23 Register Setting Procedures for Condition Generation #### 23.3.3.3 Arbitration The MCU determines whether the transmit data matches data input to the SDAi pin on the rising edge of SCLi. If it does not match the input data, arbitration takes place at the SDAi pin by stopping data output. The ABC bit in the UiSMR register (i = 0 to 2, 5 to 7) determines the update timing for the ABT bit in the UiRB register. When the ABC bit is 0 (update per bit), the ABT bit becomes 1 as soon as a data discrepancy is detected. If not detected, the ABT bit becomes 0. When the ABC bit is 1 (update per byte), the ABT bit becomes 1 on the falling edge of the eighth bit of SCLi if any discrepancy is detected. In this ABC bit setting, the ABT bit should be set to 0 after ACK detection of 1-byte is completed to start the next 1-byte transmission/reception. When the ALS bit in the UiSMR2 register is set to 1 (SDA output stop enabled), an arbitration lost occurs. As soon as the ABT bit becomes 1, the SDAi pin becomes high-impedance. # 23.3.3.4 SCL Control and Clock Synchronization Data transmission/reception in I<sup>2</sup>C mode uses the transmit/receive clock as shown in Figure 23.20 "Transfer to UiRB Register and Interrupt Timing". The clock speed increase makes it difficult to secure the required time for ACK generation and data transmit procedure. The I<sup>2</sup>C mode supports a function of wait-state insertion to secure this required time and a function of clock synchronization with a wait-state inserted by other devices. The SWC bit in the UiSMR2 register (i = 0 to 2, 5 to 7) is used to insert a wait-state for ACK generation. When the SWC bit is set to 1 (the SCLi pin is held low after the eighth bit of SCLi is received), the SCLi pin is held low on the falling edge of the eighth bit of SCLi. When the SWC bit is set to 0 (no wait-state/wait-state cleared), the SCLi line is released. When the SWC2 bit in the UiSMR2 register is set to 1 (the SCLi pin is held low), the SCLi pin is forced low even during transmission or reception. When the SWC2 bit is set to 0 (transmit/receive clock is output at the SCLi pin), the SCLi line is released to output the transmit/receive clock. The SWC9 bit in the UiSMR4 register is used to insert a wait-state for checking received acknowledge bits. While the CKPH bit in the UiSMR3 register is 1 (clock delayed), when the SWC9 bit is set to 1 (the SCLi pin is held low after the ninth bit of the SCLi is received), the SCLi pin is held low on the falling edge of the ninth bit of SCLi. When the SWC9 bit is set to 0 (no wait-state/wait-state cleared), the SCLi line is released. Figure 23.24 Inserting Wait-States Using Bits SWC and SWC9 The CSC bit in the UiSMR2 register synchronizes an internally generated clock with the clock applied to the SCLi pin. For example, if a wait-state is inserted from other devices, the two clocks are not synchronized. While the CSC bit is 1 (clock synchronization enabled) and the internal clock is held high, when a high at the SCLi pin changes to low, the internal clock becomes low in order to reload the UiBRG register value and resume counting. While the SCLi pin is held low, when the internal clock changes from low to high, the count is stopped until the SCLi pin becomes high. That is, the UARTi transmit/receive clock is the logical AND of the internal clock and SCLi. The synchronized period starts from one clock prior to an internally generated clock and ends when the ninth clock is completed. The CSC bit can be set to 1 only when the CKDIR bit in the UiMR register is set to 0 (internal clock selected). The SCLHI bit in the UiSMR4 register is used to leave the SCLi pin open when another master generates a stop condition while the master is performing a transmit/receive operation. While the SCLHI bit is set to 1 (output stopped), the SCLi pin is open (the pin is high-impedance) when a stop condition is detected and the clock output is stopped. Figure 23.25 Clock Synchronization # 23.3.3.5 SCL Clock Frequency The SCL clock duty generated in I²C mode is 50%. The low-level width of the SCL clock is 1.25 $\mu$ s when the I²C-bus setting is Fast-mode maximum SCL clock (400 kbps). This value does not satisfy the Fast-mode I²C-bus specification ( $f_{LOW}$ = minimum 1.3 $\mu$ s). Set the SCL clock to 384.6 kbps or less to satisfy the SCL clock low-level width of 1.3 $\mu$ s or more. When the clock synchronous function (Figure 23.25 "Clock Synchronization") is enabled, there is a sampling delay of the noise filter plus 1 to 1.5 cycles of UiBRG count source. There is also a delay of the SCL clock when high is determined and the SCL clock high width is extended. Therefore, the actual SCL clock becomes slower than SCL clock bit rate setting. To calculate the effective value of SCL clock, take the SCL clock rise time (t<sub>R</sub>) into consideration. The following is an example of an SCL clock calculation. Example of an effective value of SCL clock calculation at 384.6 kbps - UiBRG count source: f1 = 20 MHz - UiBRG register setting value: n = 26 1 - SCL clock rise time: t<sub>R</sub> = 100 ns - SCL clock fall time: t<sub>F</sub> = 0 ns - Noise filter width: t<sub>NF</sub> = 100 ns <sup>(1)</sup> - Sampling delay: t<sub>SD</sub> = 1 cycle ``` \begin{split} f_{SCL} & \text{(theoretical value)} = \text{f1 / (2(n + 1))} = 20 \text{ MHz / (2(25 + 1))} = 384.6 \text{ kbps} \\ t_{LOW} &= 1 / (2 f_{SCL} \text{(theoretical value)}) = 1 / (2 \times 384.6 \text{ kbps}) = 1.3 \text{ μs} \\ t_{HIGH} &= 1 / (2 f_{SCL} \text{(theoretical value)}) + t_{NF} + (t_{SD} \times 1 / \text{f1}) \\ &= 1 / (2 \times 384.6 \text{ kbps}) + 100 \text{ ns} + (1 \times 1 / 20 \text{ MHz}) \\ &= 1.45 \text{ μs} \\ f_{SCL} & \text{(actual value)} = 1 / (t_F + t_{LOW} + t_R + t_{HIGH}) = 1 / (0 \text{ ns} + 1.3 \text{ μs} + 100 \text{ ns} + 1.45 \text{ μs}) \approx 350.8 \text{ kbps} \end{split} ``` Note: 1. Maximum 200 ns. Figure 23.26 SCL Clock ## 23.3.3.6 SDA Output Control When transmitting byte data, the SDAi pin outputs transmit data for the first to eighth bits, and it is released to receive an acknowledgment for the ninth bit. In I<sup>2</sup>C mode, set 9-bit data to the UiTB register. In 9-bit data, set the transmit data to bits b7 to b0 and set b8 to 1. By setting the UFORM bit in the UiC0 register to 1 (MSB first) and 9-bit data to the UiTB register, transmit data is output from the SDAi pin in the following order: b7, b6, b5, b4, b3, b2, b1, b0 and b8. As b8 is 1, the SDAi pin becomes high-impedance at the ninth bit and an acknowledgment can be received. Figure 23.27 UiTB Register Setting (SDA Output) Figure 23.28 Byte Data Transmission Set bits DL2 to DL0 in the UiSMR3 register to add no delays or a delay of one to eight UiBRG count source clock cycles to SDAi output. Setting the SDHI bit in the UiSMR2 register to 1 (SDA output disabled) forcibly places the SDAi pin in a high-impedance state. Do not write to the SDHI bit at the rising edge of the UARTi transmit/receive clock as the ABT bit in the UiRB register may inadvertently become 1 (detected). ### 23.3.3.7 SDA Digital Delay When transferring data with the I<sup>2</sup>C-bus, change the data while the SCL clock is low. When SDA is changed while the SCL clock is a high, the change is recognized as one of the corresponding conditions (see 23.5.3.4 "Setup and Hold Times When Generating a Start/Stop Condition"). This function delays output from the SDAi pin. By delaying the change of the SDA, the data can be changed while the SCL clock is low. This function is enabled by setting bits DL2 to DL0 in the UiSMR3 register to 001b to 111b, and disabled by setting them to 000b. Figure 23.29 SDA Output Selection by Setting Bits DL2 to DL0 ### 23.3.3.8 SDA Input When the IICM2 bit in the UiSMR2 register (i = 0 to 2, 5 to 7) is set to 0, the first 8 bits of received data (D7 to D0) are stored in bits 7 to 0 in the UiRB register and the ninth bit (ACK/NACK) is stored in bit 8. When the IICM2 bit is 1, the first to seventh bits (D7 to D1) of the received data are stored in bits 6 to 0 in the UiRB register and the eighth bit (D0) is stored in bit 8 in the UiRB register. Even when the IICM2 bit is 1, if the CKPH bit in the UiSMR3 register is 1, the same data as when the IICM2 bit is 0 can be read. To read the data, read the UiRB register after the rising edge of ninth bit of the corresponding clock pulse. When receiving byte data, the SDAi pin is released for the first to eighth bits to receive data, and an acknowledgment is generated for the ninth bit. NACK is generated when the last byte data is received in master mode, or when the slave address does not match in slave mode. In all other cases, ACK is generated. In I<sup>2</sup>C mode, set 9-bit data to the UiTB register. In 9-bit data, set FFh to b7 to b0 to release the SDAi pin and set b8 to 0 to generate ACK or 1 to generate NACK. By setting 00FFh or 01FFh as 9-bit data to the UiTB register, the SDAi pin becomes high-impedance for the first to eighth bits, and data can be received. ACK or NACK is generated at the ninth bit. Read the received data from the UiRB register. When the clock delay function is used, data transfer to the UiRB register occurs twice and each UiRB register value is different. Refer to Figure 23.20 "Transfer to UiRB Register and Interrupt Timing" for details. Figure 23.30 UiTB Register Setting (SDA Input) Figure 23.31 Byte Data Reception #### 23.3.3.9 ACK and NACK When data is to be received, ACK is output after 8 bits are received by setting the UiTB register to 00FFh as dummy data. When the STSPSEL bit in the UiSMR4 register (i = 0 to 2, 5 to 7) is set to 0 (serial I/O circuit selected) and the ACKC bit is set to 1 (ACK data output), the value of the ACKD bit is output at the SDAi pin. If the IICM2 bit is 0, a NACK interrupt request is generated when the SDAi pin is held high at the rising edge of the ninth bit of SCLi. An ACK interrupt request is generated when the SDAi pin is held low. If the DMA request source is "UARTi receive interrupt request or ACK interrupt request", the DMA transfer is activated when ACK is detected. ### 23.3.3.10 Initialization of Transmission/Reception Select the external clock as the transmit/receive clock when using this function. If a start condition is detected while the STAC bit in the UiSMR2 register is 1 (initialize the circuit if the start condition is detected), the serial interface operates as follows: - The transmit shift register is initialized, and the UiTB register value is transferred to the transmit shift register. Doing so starts the data transmission when the next clock pulse is applied. However, the UARTi output value does not change until the first bit of data is output synchronously with the input clock. It remains the same as when a start condition was detected. - The receive shift register is initialized, and the serial interface starts receiving data when the next clock pulse is applied. - The SWC bit becomes 1 (hold the SCLi pin low after the eighth bit of SCLi is received). Consequently, the SCLi pin is pulled low at the falling edge of the ninth clock pulse. When UARTi transmission/reception is started using this function, the TI bit does not change. When the UARTi initializing function is used in slave mode, UARTi is initialized automatically when a start condition is detected. Therefore, an interrupt is unnecessary for detecting a start condition. # 23.3.4 Special Mode 2 In special mode 2, the serial interface module allows serial communication between one master and multiple slaves. The transmit/receive clock polarity and phase are selectable. Table 23.20 lists Special Mode 2 Specifications. Table 23.20 Special Mode 2 Specifications | Item | Specification | |-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Data format | Character data length: 8 bits | | Transmit/receive clock | Master mode The CKDIR bit in the UiMR register = 0 (internal clock): fj = f1SIO, f2SIO, f8SIO, f32SIO n: Setting value of UiBRG register 00h to FFh | | Transmit/receive control | Controlled by I/O ports | | Transmission start conditions | To start transmission, satisfy the following requirements: • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data present in UiTB register) | | Reception start conditions | To start reception, satisfy the following requirements: • The RE bit in the UiC1 register is 1 (reception enabled) • The TE bit is 1 (transmission enabled) • The TI bit is 0 (data present in the UiTB register) | | Interrupt request generation timing | <ul> <li>For transmit interrupt, one of the following conditions can be selected</li> <li>The UilRS bit in the UiC1 or UCON register is 0 (transmit buffer empty): When transferring data from the UiTB register to the UARTi transmit register (at start of transmission)</li> <li>The UilRS bit is 1 (transfer completed): When the serial interface completed sending data from the UARTi transmit register For receive interrupt</li> <li>When transferring data from the UARTi receive register to the UiRB register (at completion of reception)</li> </ul> | | Error detection | Overrun error <sup>(1)</sup> This error occurs if the serial interface starts receiving the next data before reading the UiRB register and receives the 7th bit of the next data | | Selectable functions | <ul> <li>CLK polarity selection Whether transfer data is output/input at the rising or falling edge of the transfer clock can be selected.</li> <li>LBS first, MSB first selection Whether to start sending/receiving data beginning with bit 0 or beginning with bit 7.</li> <li>Continuous receive mode selection Reception is enabled by reading the UiRB register</li> <li>Serial data logic switching Function to invert the logic value of the transmit/receive data.</li> <li>Clock phase setting Selectable from four combinations of transmit/receive clock polarities and phases.</li> </ul> | i = 0 to 2, 5 to 7 Note: 1. If an overrun error occurs, the received data of the UiRB register will be undefined. The IR bit in the SiRIC register does not change. Figure 23.32 Serial Bus Communication Control Example in Special Mode 2 (UART2) Table 23.21 I/O Pin Functions in Special Mode 2 | Pin Name | I/O | Function | Method of Selection | |----------|--------|--------------------|------------------------------------------------------------------------------------------------------| | CLKi | Output | Clock output | The CKDIR bit in the UiMR register = 0 | | TXDi | Output | Serial data output | (Dummy data is output when performing reception only.) | | | Input | Serial data input | Set the port direction bits sharing pins to 0. | | RXDi | Input | Input port | Set the port direction bits sharing pins to 0. (can be used as an input port only when transmitting) | i = 0 to 2, 5 to 7 Pins CTSi/RTSi are not used. (They can be used as I/O ports.) Table 23.22 Registers Used and Settings in Special Mode 2 (1) | Register | Bits | Function | |-----------------|-------------------|------------------------------------------------------------------| | UCLKSEL0 | OCOSEL0 | Select clock prior to division for UART0 to UART2. | | UCLKSELU | OCOSEL1 | Select clock prior to division for UART5 to UART7. | | PCLKR | PCLK1 | Select the count source for the UiBRG register. | | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | UiTB | 0 to 7 | Set transmission data. | | OHE | 8 | - (does not need to be set) If necessary, set to 0. | | | 0 to 7 | Reception data can be read. | | UiRB | OER | Overrun error flag | | | 8, 11, 13 to 15 | When read, the read value is undefined. | | UiBRG | 0 to 7 | Set bit rate. | | | SMD2 to SMD0 | Set to 001b. | | UiMR | CKDIR | Set to 0. | | Oliviix | 4 to 6 | Set to 0. | | | IOPOL | Set to 0. | | | CLK0, CLK1 | Select the count source for the UiBRG register. | | | CRS | Disabled because CRD is 1 | | | TXEPT | Transmit register empty flag | | UiC0 | CRD | Set to 1. | | UICU | NCH | Select TXDi pin output format. (2) | | | CKPOL | Clock phases can be set in combination with the CKPH bit in the | | | CKPOL | UiSMR3 register. | | | UFORM | Select the LSB first or MSB first. | | | TE | Set to 1 to enable transmission/reception. | | | TI | Transmit buffer empty flag | | | RE | Set to 1 to enable reception. | | UiC1 | RI | Reception complete flag | | OIC I | UjIRS | Select UARTj transmit interrupt source. | | | UjRRM | Set to 1 to use continuous receive mode. | | | UiLCH | Set to 1 to use inverted data logic. | | | UiERE | Set to 0. | | UiSMR | 0 to 7 | Set to 0. | | UiSMR2 | 0 to 7 | Set to 0. | | | СКРН | Clock phases can be set in combination with the CKPOL bit in the | | UiSMR3 | CKPH | UiC0 register. | | | NODC | Set to 0. | | | 0, 2, 4 to 7 | Set to 0. | | UiSMR4 | 0 to 7 | Set to 0. | | UCON - | U0IRS | Select UART0 transmit interrupt source. | | | U1IRS | Select UART1 transmit interrupt source. | | | U0RRM | Set to 1 to use continuous receive mode. | | | U1RRM | Set to 1 to use continuous receive mode. | | | CLKMD0 | Disabled because CLKMD1 is 0 | | | CLKMD1, RCSP, 7 | Set to 0. | | i = 0 to 2 5 to | 7: $i = 2.5$ to 7 | · | i = 0 to 2, 5 to 7; j = 2, 5 to 7 - 1. This table does not describe a procedure. - 2. The TXD2 pin is N-channel open drain output. Nothing is assigned to the NCH bit in the U2C0 register. Only write 0 to this bit. # 23.3.4.1 Clock Phase Setting Function One of four combinations of transmit/receive clock phases and polarities can be selected using the CKPH bit in the UiSMR3 register and the CKPOL bit in the UiC0 register. Make sure the transmit/receive clock polarity and phase are the same for the master and slaves to be used for communication. Figure 23.33 shows the Transmit and Receive Timing in Master Mode (Internal Clock). Figure 23.33 Transmit and Receive Timing in Master Mode (Internal Clock) # 23.3.5 Special Mode 3 (IE Mode) In this mode, 1 bit of IEBus is approximated by 1 byte of UART mode waveform. Table 23.23 lists the Registers Used and Settings in IE Mode. Figure 23.34 shows the Bus Collision Detect Function-Related Bits. If the TXDi pin (i = 0 to 2, 5 to 7) output level and RXDi pin input level do not match, a UARTi bus collision detect interrupt request is generated. Use bits IFSR26 and IFSR27 in the IFSR2A register to enable the UART0/UART1 bus collision detect function. Table 23.23 Registers Used and Settings in IE Mode (1) | Register | Bits | Function | |----------|-------------------------|---------------------------------------------------------------------| | UiTB | 0 to 8 | Set transmission data. | | UiRB (4) | 0 to 8 | Reception data can be read. | | UIRD (+) | OER, FER, PER, SUM | Error flag | | UiBRG | 0 to 7 | Set bit rate. | | | SMD2 to SMD0 | Set to 110b. | | | CKDIR | Select internal clock or external clock. | | UiMR | STPS | Set to 0. | | Oliviix | PRY | Disabled because PRYE is 0 | | | PRYE | Set to 0. | | | IOPOL | Select the TXD and RXD input/output polarity. | | | CLK1, CLK0 | Select the count source for the UiBRG register. | | | CRS | Disabled because CRD is 1 | | | TXEPT | Transmit register empty flag | | UiC0 | CRD | Set to 1. | | | NCH | Select TXDi pin output format. (3) | | <br> | CKPOL | Set to 0. | | <br> | UFORM | Set to 0. | | | TE | Set to 1 to enable transmission. | | | TI | Transmit buffer empty flag | | UiC1 | RE | Set to 1 to enable reception. | | UIC1 | RI | Reception complete flag | | | UjIRS <sup>(2)</sup> | Select the source of UARTj transmit interrupt. | | <br> | UjRRM (2), UiLCH, UiERE | Set to 0. | | | 0 to 3, 7 | Set to 0. | | UiSMR - | ABSCS | Select the sampling timing to detect a bus collision. | | UISIVIK | ACSE | Set to 1 to use the auto clear function of the transmit enable bit. | | | SSS | Select the transmit start condition. | | UiSMR2 | 0 to 7 | Set to 0. | | UiSMR3 | 0 to 7 | Set to 0. | | UiSMR4 | 0 to 7 | Set to 0. | | | U0IRS, U1IRS | Select the source of UART0/UART1 transmit interrupt. | | UCON | U0RRM, U1RRM | Set to 0. | | UCON | CLKMD0 | Disabled because CLKMD1 is 0 | | | CLKMD1, RCSP, 7 | Set to 0. | i = 0 to 2, 5 to 7; j = 2, 5 to 7 - 1. This table does not describe a procedure. - 2. Set bits 4 and 5 in registers UOC1 and U1C1 to 0. Bits U0IRS, U1IRS, U0RRM, and U1RRM are in the UCON register. - 3. The TXD2 pin is N-channel open drain output. Nothing is assigned to the NCH bit in the U2C0 register. If necessary, set it to 0. - 4. Set the bits not listed above to 0 when writing to registers in IE mode. Figure 23.34 Bus Collision Detect Function-Related Bits # 23.3.6 Special Mode 4 (SIM Mode) (UART2) In this mode, the serial interface module allows SIM interface devices to communicate in UART mode. Both direct and inverted formats are available. The TXD2 pin outputs a low-level signal when a parity error is detected. Table 23.24 lists the specifications of SIM mode. Table 23.25 lists the related registers and their settings. Table 23.24 SIM Mode Specifications | Item | Specification | |------------------------|-----------------------------------------------------------------------------------------------------| | Data formats | Direct format | | Data formats | • Inverted format | | | • The CKDIR bit in the U2MR register is 0 (internal clock): fi/(16(n + 1)) | | | fi = f1SIO, f2SIO, f8SIO, f32SIO | | Transmit/receive clock | n = setting value of the U2BRG register 00h to FFh | | Transmittederve Gock | •The CKDIR bit is 1 (external clock): fEXT/(16(n + 1)) | | | fEXT = input from the CLK2 pin | | | n = setting value of the U2BRG register 00h to FFh | | Transmission start | To start transmission, satisfy the following requirements: | | conditions | • The TE bit in the U2C1 register is 1 (transmission enabled) | | CONTRICTION | • The TI bit in the U2C1 register is 0 (data present in the U2TB register) | | Reception start | To start reception, satisfy the following requirements: | | conditions | • The RE bit in the U2C1 register is 1 (reception enabled) | | CONTRICTION | Start bit detection | | | While transmitting | | | When the serial interface completes transmitting data from the UART2 | | Interrupt request | transmit register (the U2IRS bit is 1) | | generation timing (2) | While receiving | | | When transferring data from the UART2 receive register to the U2RB register | | | (at completion of reception) | | | • Overrun error <sup>(1)</sup> | | | This error occurs if the serial interface starts receiving the next data before | | | reading the U2RB register and receives the bit before the last stop bit of the next data. | | | • Framing error (3) | | | This error occurs when the number of stop bits set is not detected. | | Error detection | Parity error (3) | | | During reception, if a parity error is detected, a parity error signal is output from the TXD2 pin. | | | During transmission, a parity error is detected by the level of input to the RXD2 | | | pin when a transmission interrupt occurs. | | | • Error sum flag | | | This flag becomes 1 when an overrun, framing, or parity errors occurs. | - 1. If an overrun error occurs, the received data of the U2RB register will be undefined. The IR bit in the S2RIC register does not change. - 2. After reset, a transmit interrupt request is generated by setting bits U2IRS and U2ERE in the U2C1 register to 1 (transmission completed, error signal output), then setting the TE bit to 1 (transmission enabled) and the transmission data to the U2TB register. Therefore, when using SIM mode, make sure to set the IR bit to 0 (interrupt not requested) after setting these bits. - 3. The timing at which the framing error flag and the parity error flag are set is detected when data is transferred from the UART2 receive register to the U2RB register. Table 23.25 Registers Used and Settings in SIM Mode (1) | Register | Bit | Function | |-----------|--------------------|----------------------------------------------------| | U2TB (2) | 0 to 7 | Set transmit data. | | 11000 (3) | 0 to 7 | Received data can be read. | | U2RB (2) | OER, FER, PER, SUM | Error flag | | U2BRG | 0 to 7 | Set a bit rate. | | | SMD2 to SMD0 | Set to 101b. | | | CKDIR | Select the internal clock or external clock. | | U2MR | STPS | Set to 0. | | UZIVIK | PRY | Set to 1 in direct format or 0 in inverted format. | | | PRYE | Set to 1. | | | IOPOL | Set to 0. | | | CLK0, CLK1 | Select the count source for the U2BRG register. | | | CRS | Disabled because CRD is 1. | | | TXEPT | Transmit register empty flag | | U2C0 | CRD | Set to 1. | | | NCH | Set to 0. | | | CKPOL | Set to 0. | | | UFORM | Set to 0 in direct format or 1 in inverted format. | | | TE | Set to 1 to enable transmission. | | | TI | Transmit buffer empty flag | | | RE | Set to 1 to enable reception. | | U2C1 | RI | Reception complete flag | | 0201 | U2IRS | Set to 1. | | | U2RRM | Set to 0. | | | U2LCH | Set to 0 in direct format or 1 in inverted format. | | | U2ERE | Set to 1. | | U2SMR (2) | 0 to 3 | Set to 0. | | U2SMR2 | 0 to 7 | Set to 0. | | U2SMR3 | 0 to 7 | Set to 0. | | U2SMR4 | 0 to 7 | Set to 0. | - 1. This table does not describe a procedure. - 2. Set bits not listed above to 0 when writing to the registers in SIM mode. Figure 23.35 Transmit/Receive Timing in SIM Mode Figure 23.36 shows the Example of SIM Interface Connection. Connect pins TXD2 and RXD2, and then place a pull-up resistance. Figure 23.36 Example of SIM Interface Connection # 23.3.6.1 Parity Error Signal Output The parity error signal is enabled by setting the U2ERE bit in the U2C1 register to 1 (error signal output). The parity error signal is output when a parity error is detected while receiving data. A low-level signal is output from the TXD2 pin in the timing shown in Figure 23.37. If the U2RB register is read while outputting a parity error signal, the PER bit is cleared to 0 (no parity error) and at the same time the TXD2 output again goes high. When transmitting, a transmission complete interrupt request is generated at the falling edge of the transmit/receive clock pulse that immediately follows the stop bit. Therefore, whether a parity error signal has been returned can be determined by reading the port that shares the RXD2 pin in a transmission complete interrupt routine. Figure 23.37 Parity Error Signal Output Timing #### 23.3.6.2 Formats Two formats are available: direct format and inverse format. For direct format, set the PRYE bit in the U2MR register to 1 (parity enabled), the PRY bit to 1 (even parity), the UFORM bit in the U2C0 register to 0 (LSB first), and the U2LCH bit in the U2C1 register to 0 (not inverted). When data is transmitted, data set in the U2TB register are transmitted with the even-numbered parity, starting from D0. When data is received, the received data is stored in the U2RB register, starting from D0. The even-numbered parity is used to determine whether a parity error occurs. For inverted format, set the PRYE bit to 1, the PRY bit to 0 (odd parity), the UFORM bit to 1 (MSB first), and the U2LCH bit to 1 (inverted). When data is transmitted, values set in the U2TB register are logically inverted and are transmitted with the odd-numbered parity, starting from D7. When data is received, the received data is logically inverted to be stored in the U2RB register, starting from D7. The odd-numbered parity is used to determine whether a parity error occurs. Figure 23.38 shows the SIM Interface Format. Figure 23.38 SIM Interface Format # 23.4 Interrupts UARTO to UART2, UART5 to UART7 include interrupts by transmission, reception, ACK, NACK, start/stop condition detection, and bus collision detection. # 23.4.1 Interrupt Related Registers Refer to operation examples in each mode for interrupt sources and interrupt request generation timing. For details of interrupt control, refer to 14.7 "Interrupt Control". Table 23.26 lists UART0 to UART2, UART5 to UART7 Interrupt Related Registers. Table 23.26 UART0 to UART2, UART5 to UART7 Interrupt Related Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------------------------------|---------|-------------| | 0046h | UART1 Bus Collision Detection Interrupt Control Register U1BCNIC | | XXXX X000b | | 0047h | UART0 Bus Collision Detection Interrupt Control Register U0BC | | XXXX X000b | | 004Ah | UART2 Bus Collision Detection Interrupt<br>Control Register | BCNIC | XXXX X000b | | 004Fh | UART2 Transmit Interrupt Control Register | S2TIC | XXXX X000b | | 0050h | UART2 Receive Interrupt Control Register | S2RIC | XXXX X000b | | 0051h | UART0 Transmit Interrupt Control Register | S0TIC | XXXX X000b | | 0052h | UART0 Receive Interrupt Control Register | SORIC | XXXX X000b | | 0053h | UART1 Transmit Interrupt Control Register | S1TIC | XXXX X000b | | 0054h | UART1 Receive Interrupt Control Register | S1RIC | XXXX X000b | | 006Bh | UART5 Bus Collision Detection Interrupt<br>Control Register | U5BCNIC | XXXX X000b | | 006Ch | UART5 Transmit Interrupt Control Register | S5TIC | XXXX X000b | | 006Dh | UART5 Receive Interrupt Control Register | S5RIC | XXXX X000b | | 006Eh | UART6 Bus Collision Detection Interrupt<br>Control Register | U6BCNIC | XXXX X000b | | 006Fh | UART6 Transmit Interrupt Control Register | S6TIC | XXXX X000b | | 0070h | UART6 Receive Interrupt Control Register | S6RIC | XXXX X000b | | 0071h | UART7 Bus Collision Detection Interrupt<br>Control Register | U7BCNIC | XXXX X000b | | 0072h | UART7 Transmit Interrupt Control Register | S7TIC | XXXX X000b | | 0073h | UART7 Receive Interrupt Control Register | S7RIC | XXXX X000b | | 0205h | Interrupt Source Select Register 3 | IFSR3A | 00h | | 0206h | Interrupt Source Select Register 2 | IFSR2A | 00h | Some interrupts of UART0 to UART2 and UART5 to UART7 share interrupt vectors and interrupt control registers with other peripheral functions. When using these interrupts, select them by interrupt source select registers. Table 23.27 lists Interrupt Selection in UART0 to UART2 and UART5 to UART7. Table 23.27 Interrupt Selection in UART0 to UART2 and UART5 to UART7 | Interrupt Source | Interrupt Source Select Register Settings | | | |---------------------------------------------------------------|-------------------------------------------|--------|---------------| | interrupt Source | Register | Bit | Setting Value | | UART0 start/stop condition detection, bus collision detection | IFSR2A | IFSR26 | 1 | | UART1 start/stop condition detection, bus collision detection | IFSR2A | IFSR27 | 1 | | UART5 start/stop condition detection, bus collision detection | IFSR3A | IFSR33 | 0 | | UART5 transmission, NACK | IFSR3A | IFSR34 | 0 | | UART6 start/stop condition detection, bus collision detection | IFSR3A | IFSR35 | 0 | | UART6 transmission, NACK | IFSR3A | IFSR36 | 0 | | UART7 start/stop condition detection, bus collision detection | IFSR2A | IFSR24 | 0 | | UART7 transmission, NACK | IFSR2A | IFSR25 | 0 | In the following modes, an interrupt request can be generated by rewriting bit values. • Special mode 1 (I<sup>2</sup>C mode) Set the IR bit in the interrupt control register of UARTi to 0 (interrupt not requested), when the following bits are changed: Bits SMD2 to SMD0 in the UiMR register, the IICM bit in the UiSMR register, the IICM2 bit in the UiSMR2 register, the CKPH bit in the UiSMR3 register Special mode 4 (SIM mode) After reset, a transmit interrupt request is generated by setting bits U2IRS and U2ERE in the U2C1 register to 1 (transmission completed, error signal output), then setting the TE bit to 1 (transmission enabled) and the transmission data to the U2TB register. Therefore, when using SIM mode, make sure to set the IR bit to 0 (interrupt not requested) after setting these bits. # 23.4.2 Reception Interrupt The case that bits SMD2 to SMD0 in the UiMR register are not set to 010b (I<sup>2</sup>C mode) When the RI bit in the UiC1 register is changed from 0 (no data in the UiRB register) to 1 (data present in the UiRB register), the IR bit in the SiRIC register is automatically set to 1 (interrupt requested). If an overrun error occurs (when the RI bit is 1, the next data is received), the RI bit remains 1, and therefore, the IR bit in the SiRIC register remains unchanged. The case that bits SMD2 to SMD0 in the UiMR register are set to 010b (I<sup>2</sup>C mode) When the RI bit in the UiC1 register is changed from 0 (no data in the UiRB register) to 1 (data present in the UiRB register), the IR bit in the SiRIC register is automatically set to 1 (interrupt requested). When an overrun error occurs, the IR bit in the SiRIC register also becomes 1. # 23.5 Notes on Serial Interface UARTi (i = 0 to 2, 5 to 7) ### 23.5.1 Common Notes on Multiple Modes #### 23.5.1.1 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/CTS2/RTS2/TA1IN/V, P7\_4/TA2OUT/W, P7\_5/TA2IN/W, P8\_0/TA4OUT/RXD5/SCL5/U, P8\_1/TA4IN/CTS5/RTS5/U #### 23.5.1.2 Register Setting Set the OCOSEL0 or OCOSEL1 bit in the UCLKSEL0 register before setting other registers associated with UART0 to UART2 or UART5 to UART7. After changing the OCOSEL0 or OCOSEL1 bit, set other registers associated with UART0 to UART2 or UART5 to UART7 again. ## 23.5.1.3 CLKi Output (Technical update number: TN-16C-A178A/E) When using the N-channel open drain output as an output mode of the CLKi pin, use following procedure to change the pin function: When changing the pin function from the port to CLKi. - (1) Set bits SMD2 to SMD0 in the UiMR register to a value other than 000b to select serial interface mode. - (2) Set the NODC bit in the UiSMR3 register to 1. When changing the pin function from CLKi to the port. - (1) Set the NODC bit to 0. - (2) Set bits SMD2 to SMD0 to 000b to disable the serial interface. ## 23.5.2 Clock Synchronous Serial I/O Mode ### 23.5.2.1 Transmission/Reception When the $\overline{\text{RTS}}$ function is used with an external clock, the $\overline{\text{RTSi}}$ pin (i = 0 to 2, 5 to 7) outputs a low-level signal, which informs the transmitting side that the MCU is ready for a receive operation. The $\overline{\text{RTSi}}$ pin outputs a high-level signal when a receive operation starts. Therefore, transmit timing and receive timing can be synchronized by connecting the $\overline{\text{RTSi}}$ pin to the $\overline{\text{CTSi}}$ pin on the transmitting side. The $\overline{\text{RTS}}$ function is disabled when an internal clock is selected. #### 23.5.2.2 Transmission If the transmission is started while an external clock is selected and the TXEPT bit in the UiC0 register (i = 0 to 2, 5 to 7) is 1 (no data present in transmit register), meet the last requirement at either of the following timings: External clock level: - The CKPOL bit in the UiC0 register is 0 (transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising edge) and the external clock is high. - The CKPOL bit is 1 (transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling edge) and the external clock is low. Requirements to start transmission (in no particular order): - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). - When the CTS function is selected, input on the CTSi pin is low. #### 23.5.2.3 **Reception** In clock synchronous serial I/O mode, a shift clock is generated by activating a transmitter. Set the UARTi-associated registers for a transmit operation even if the MCU is used for a receive operations only. Dummy data is output from the TXDi pin (i = 0 to 2, 5 to 7) while receiving. When an internal clock is selected, a shift clock is generated by setting the TE bit in the UiC1 register to 1 (transmission enabled) and placing dummy data in the UiTB register. When an external clock is selected, set the TE bit to 1 (transmission enabled), set dummy data in the UiTB register, and input an external clock to the CLKi pin to generate a shift clock. If data is received consecutively, an overrun error occurs when the RI bit in the UiC1 register is 1 (data present in the UiRB register) and the next receive data is received in the UARTi receive register. Then, the OER bit in the UiRB register becomes 1 (overrun error occurred). At this time, the UiRB register is undefined. When an overrun error occurs, program the transmitting and receiving sides to retransmit the previous data. If an overrun error occurs again, the IR bit in the SiRIC register remains unchanged. To receive data consecutively, set dummy data in the low-order byte in the UiTB register for each receive operation. If the reception is started while an external clock is selected and the TXEPT bit in the UiC0 register is 1 (no data present in transmit register), meet the last requirement at either of the timings below. #### External clock level: - The CKPOL bit in the UiC0 register is 0 (transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising edge) and the external clock is high. - The CKPOL bit is 1 (transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling edge) and the external clock is low. Requirements to start reception (in no particular order): - The RE bit in the UiC1 register is 1 (reception enabled). - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). ### 23.5.3 Special Mode 1 (I<sup>2</sup>C Mode) ### 23.5.3.1 Generating Start and Stop Conditions (Technical update number: TN-16C-130A/EA) When generating start, stop, and restart conditions, set the STSPSEL bit in the UiSMR4 register (i = 0 to 2, 5 to 7) to 0 and wait for more than a half cycle of the transmit/receive clock. Then set each condition generation bit (STAREQ, RSTAREQ, and STPREQ) from 0 to 1. #### 23.5.3.2 IR Bit Set the following bits first, and then set the IR bit in each UARTi interrupt control register to 0 (interrupt not requested). Bits SMD2 to SMD0 in the UiMR register, the IICM bit in the UiSMR register, the IICM2 bit in the UiSMR2 register, the CKPH bit in the UiSMR3 register # 23.5.3.3 Low/High-level Input Voltage and Low-level Output Voltage The low-level input voltage, high-level input voltage, and low-level output voltage differ from the I<sup>2</sup>C-bus specification. Refer to the recommended operating conditions for I/O ports which share the pins with SCL and SDA. I<sup>2</sup>C-bus specification High level input voltage ( $V_{IH}$ ) = min. 0.7 $V_{CC}$ Low level input voltage $(V_{IL})$ = max. 0.3 $V_{CC}$ ### 23.5.3.4 Setup and Hold Times When Generating a Start/Stop Condition When generating a start condition, the hold time ( $t_{HD}$ :STA) is a half cycle of the SCL clock. When generating a stop condition, the setup time ( $t_{SU}$ :STO) is a half cycle of the SCL clock. When the SDA digital delay function is enabled, take delay time into consideration (see 23.3.3.7 "SDA Digital Delay"). The following shows a calculation example of hold and setup times when generating a start/stop condition. Calculation example when setting 100 kbps - UiBRG count source: f1 = 20 MHz - UiBRG register setting value: n = 100 1 - SDA digital delay setting value: DL2 to DL0 are 101b (5 or 6 cycles of UiBRG count source) $f_{SCL}$ (theoretical value) = f1 / (2(n+1)) = 20 MHz / (2 × (99 + 1)) = 100 kbps $t_{DL}$ = delay cycle count / f1 = 6 / 20 MHz = 0.3 $\mu$ s $t_{HD:STA}$ (theoretical value) = 1 / (2 $f_{SCL}$ (theoretical value)) = 1 / (2 × 100 kbps) = 5 $\mu s$ $t_{SU:STO}$ (theoretical value) = 1 / (2 $f_{SCL}$ (theoretical value)) = 1 / (2 × 100 kbps) = 5 $\mu s$ $f_{HD:STA}$ (actual value) = $t_{HD:STA}$ (theoretical value) - $t_{DL}$ = 5 $\mu$ s - 0.3 $\mu$ s = 4.7 $\mu$ s $f_{SU:STO}$ (actual value) = $t_{SU:STO}$ (theoretical value) + $t_{DL}$ = 5 $\mu$ s + 0.3 $\mu$ s = 5.3 $\mu$ s Figure 23.39 Setup and Hold Times When Generating Start and Stop Conditions ### 23.5.3.5 Restrictions on the Bit Rate When Using the UiBRG Count Source In I<sup>2</sup>C mode, set the UiBRG register to a value of 03h or greater. A maximum of three UiBRG count source cycles are necessary until the internal circuit acknowledges the SCL clock level. The connectable I<sup>2</sup>C-bus bit rate is one-third or less than the UiBRG count source speed. If a value between 00h to 02h is set to the UiBRG register, bit slippage may occur. #### 23.5.3.6 Restart Condition in Slave Mode When a restart condition is detected in slave mode, the successive processes may not be executed correctly. In slave mode, do not use a restart condition. #### 23.5.3.7 Requirements to Start Transmission/Reception in Slave Mode When transmission/reception is started in slave mode and the TXEPT bit in the UiC0 register is 1 (no data present in transmit register), meet the last requirement when the external clock is high. Requirements to start transmission (in no particular order): - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). Requirements to start reception (in no particular order): - The RE bit in the UiC1 register is 1 (reception enabled). - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). ### 23.5.4 Special Mode 4 (SIM Mode) (Technical update number: TN-M16C-101-0309) After reset, a transmit interrupt request is generated by setting bits U2IRS and U2ERE in the U2C1 register to 1 (transmission completed, error signal output), then setting the TE bit to 1 (transmission enabled) and the transmission data to the U2TB register. Therefore, when using SIM mode, make sure to set the IR bit to 0 (interrupt not requested) after setting these bits. # 24. Serial Interface SI/O3 and SI/O4 #### 24.1 Introduction SI/O3 and SI/O4 are dedicated clock-synchronous serial I/O ports. Table 24.1 lists SI/O3 and SI/O4 Specifications. Figure 24.1 shows SI/O3 and SI/O4 Block Diagram, and Table 24.2 lists the I/O Ports. Table 24.1 SI/O3 and SI/O4 Specifications | Item | Specification | | | |-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Data format | Character length: 8 bits | | | | Transmit/receive clocks | The SMi6 bit in the SiC register = 1 (internal clock): fj 2(n+1) fj = f1SIO, f2SIO, f8SIO, f32SIO n = setting value of the SiBRG register 00h to FFh | | | | | The SMi6 bit = 0 (external clock): Input from the CLKi pin (1) | | | | Transmission/reception start condition Before transmission/reception starts, write transmit data to the register. (2) | | | | | Interrupt request generation timing | | | | | Selectable functions | <ul> <li>CLK polarity selection Whether data is input/output at the rising or falling edge of the transmit/receive clock can be selected.</li> <li>LSB first or MSB first selection Whether to start transmitting/receiving data from bit 0 or from bit 7 can be selected.</li> <li>SOUTi initial value setting function When the SMi6 bit in the SiC register = 0 (external clock), the SOUTi pin output level while not transmitting can be selected.</li> <li>SOUTi state selection after transmission Whether to set to high-impedance or retain the last bit level can be selected when the SMi6 bit in the SiC register is 1 (internal clock).</li> </ul> | | | # i = 3, 4 Notes: - 1. The data is shifted every time the external clock is input. When completing data transmission/reception of the eighth bit, read or write to the SiTRR register before inputting the clock for the next data transmission/reception. - 2. When the SMi6 bit in the SiC register is 0 (external clock), follow the steps below. - When the SMi4 bit in the SiC register is 0, write transmit data to the SiTRR register while input to the CLKi pin is high. - When the SMi4 bit is 1, write transmit data to the SiTRR register while input to the CLKi pin is low. Figure 24.1 SI/O3 and SI/O4 Block Diagram Table 24.2 I/O Ports | Pin Name | I/O | Function | Selecting Method | | |----------|--------|-------------------------------|-----------------------------------------------|--| | CLKi | Output | Transmit/receive clock output | SMi3 bit in the SiC register = 1 | | | | | | SMi6 bit in the SiC register = 1 | | | | Input | Transmit/receive clock input | SMi3 bit in the SiC register = 1 | | | | | | SMi6 bit in the SiC register = 0 | | | | | | Port direction bits sharing pins = 0 | | | SOUTi | Output | Serial data output | SMi3 bit in the SiC register = 1 | | | | | | SMi2 bit in the SiC register = 0 | | | SINi | Input | Serial data input | SMi3 bit in the SiC register = 1 | | | | | | Port direction bits sharing pins = 0 | | | | | | (Dummy data is input only when transmitting.) | | # 24.2 Registers Table 24.3 lists registers associated with SI/O3 and SI/O4. Refer to 8.2.6 "Peripheral Clock Stop Register 1 (PCLKSTP1)" for the explanation of the PCLKSTP1 register. Set the SM22 bit in the S34C2 register before setting other registers associated with SI/O3 and SI/O4. After changing the SM22 bit, set other registers associated with SI/O3 and SI/O4 again. Table 24.3 Registers | Address | Register | Symbol | Reset Value | |---------|----------------------------------|----------|-------------| | 0012h | Peripheral Clock Select Register | PCLKR | 0000 0011b | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 0270h | SI/O3 Transmit/Receive Register | S3TRR | XXh | | 0272h | SI/O3 Control Register | S3C | 0100 0000b | | 0273h | SI/O3 Bit Rate Register | S3BRG | XXh | | 0274h | SI/O4 Transmit/Receive Register | S4TRR | XXh | | 0276h | SI/O4 Control Register | S4C | 0100 0000b | | 0277h | SI/O4 Bit Rate Register | S4BRG | XXh | | 0278h | SI/O3, 4 Control Register 2 | S34C2 | 00XX X0X0b | # 24.2.1 Peripheral Clock Select Register (PCLKR) Rewrite the PCLKR register after setting the PRC0 bit in the PRCR register to 1 (write enabled). # 24.2.2 SI/Oi Transmit/Receive Register (SiTRR) (i = 3, 4) Write to the SiTRR register while the serial interface is neither transmitting nor receiving. Write a value to the SiTRR register each time 1-byte data is received, even when data is only received. #### SI/Oi Control Register (i = 3, 4) Address Reset Value S3C S4C 0100 0000b 0272h 0276h 0100 0000b Bit symbol Bit Name **Function** RW b1 b0 SMi0 0: f1SIO or f2SIO selected Internal synchronous RW 1: f8SIO selected 0 clock select bit 0: f32SIO selected SMi1 1: Do not set this value. 0: SOUTi output enabled SMi2 SOUTi output disable bit RW 1: SOUTi output disabled (high-impedance) 0 : I/O port serial interface disabled SMi3 SI/Oi port select bit RW 1 : SOUTi output, CLKi function serial interface enabled 0: Transmit data is output at falling edge of transmit/receive clock and receive data is input at rising edge SMi4 CLK polarity select bit RW 1 : Transmit data is output at rising edge of transmit/receive clock and receive data is input at falling edge 0: LSB first SMi5 Bit order select bit RW 1: MSB first Synchronous clock 0: External clock SMi6 RW 1 : Internal clock select bit ## 24.2.3 SI/Oi Control Register (SiC) (i = 3, 4) After setting the PRC2 bit in the PRCR register to 1 (write enabled), use the next instruction to write to this register. Enabled when SMi6 is 0 0: Low output 1: High output # SMi1-SMi0 (Internal synchronous clock select bit) (b1-b0) SOUTi initial output set Select f1SIO or f2SIO by the PCLK1 bit in the PCLKR register. Set the SiBRG register when changing bits SMi1 to SMi0. bit ### SMi2 (SOUTi output disable bit) (b2) SM<sub>i</sub>7 When the SMi2 bit is set to 1 (SOUTi output disabled), the target pin becomes high-impedance regardless of which function of the pin is being used. ### SMi7 (SOUTi initial value set bit) (b7) Set the SMi7 bit when the SMi3 bit is 0 (I/O port, serial interface disabled). The level selected by the SMi7 bit is output from the SOUTi pin by setting the SMi3 bit to 1 and the SMi2 bit to 0 (SOUTi output). RW # 24.2.4 SI/Oi Bit Rate Register (SiBRG) (i = 3, 4) Use the MOV instruction to write to the SiBRG register. Write to the SiBRG register after setting bits SMi1 to SMi0 in the SiC register, and while the serial interface is neither transmitting nor receiving. # 24.2.5 SI/O3, 4 Control Register 2 (S34C2) ### SM22 (SI/O3, SI/O4 pre-division clock select bit) (b2) Set the SM22 bit while transmission/reception of SI/O3 and SI/O4 is stopped. Set the SM22 bit before setting other registers associated with SI/O3 and SI/O4. After changing the SM22 bit, set other registers associated with SI/O3 and SI/O4 again. SM26 (SOUT3 output control bit) (b6) SM27 (SOUT4 output control bit) (b7) Bits SM26 and SM27 are enabled when the SMi6 bit in the SiC register is 1 (internal clock). Set the SMi3 bit in the SiC register to 1 (serial interface enabled) after setting bits SM26 and SM27. ### 24.3 Operations ### 24.3.1 Basic Operations SI/Oi transmits and receives data simultaneously. The SiTRR register is not divided into a register for transmission/reception and buffer. Write transmit data to the SiTRR register while transmission/reception is stopped. Read receive data from the SiTRR register while transmission/reception is stopped. # 24.3.2 CLK Polarity Selection Use the SMi4 bit in the SiC register to select the transmit/receive clock polarity. Figure 24.2 shows Polarity of Transmit/Receive Clock. Figure 24.2 Polarity of Transmit/Receive Clock ### 24.3.3 LSB First or MSB First Selection Bit order is selected by setting the SMi5 bit in the SiC register (i = 3, 4). Figure 24.3 shows Bit Order. Figure 24.3 Bit Order #### 24.3.4 Internal Clock When the SMi6 bit in the SiC register is 1, data is transmitted/received using the internal clock. The internal clock is selected by setting the SM22 bit in the S34C2 register, the PCLK1 bit in the PCLKR register, and bits SMi1 to SMi0 in the SiC register. When using f1 as the clock source of the internal clock, set the PCKSTP1A bit in the PCLKSTP1 register to 0 (f1 provide enabled). When the internal clock is used as the transmit/receive clock, the SOUTi pin becomes high-impedance from when the SMi3 bit in the SiC register is set to 1 (SI/Oi enabled) and the SMi2 bit is set to 0 (SOUTi output enabled) to when the first data is output. When writing transmit data to the SiTRR register, data transmission/reception starts by outputting the transmit/receive clock from the CLKi pin after waiting between 0.5 to 1.0 cycles of the transmit/receive clock. After 8 bits of data have been transmitted/received, the transmit/receive clock from the CLKi pin stops. Figure 24.4 shows SI/Oi Operation Timing (Internal Clock). Figure 24.4 SI/Oi Operation Timing (Internal Clock) # 24.3.5 Function for Selecting SOUTi State after Transmission The SOUTi pin state after transmission can be selected when the SMi6 bit in the SiC register is set to 1 (internal clock). If bits SM26 and SM27 in the S34C2 register are both set to 1 (last bit level retained), output from the SOUTi pin retains the last bit level after transmission. Figure 24.5 shows SOUT3 Pin Level after Transmission. Figure 24.5 SOUT3 Pin Level after Transmission #### 24.3.6 External Clock When the SMi6 bit in the SiC register is 0, data is transmitted/received using the external clock. The external clock is used as a transmit/receive clock, the SOUTi output level from when the SMi3 bit in the SiC register is set to 1 (SI/Oi enabled) and SMi2 bit is set to 0 (SOUTi output enabled) to when the first data is output can be selected by the SMi7 bit in the SiC register. Refer to 24.3.8 "Function for Setting SOUTi Initial Value". Transmission/reception starts with the external clock after writing the transmit data to the SiTRR register. Data written to the SiTRR register shifts each time the external clock is input. When completing data transmission/reception of the eighth bit, read or write to the SiTRR register before inputting the clock for the next data transmission/reception. Figure 24.6 shows SI/Oi Operation Timing (External Clock). Figure 24.6 SI/Oi Operation Timing (External Clock) When the SMi6 bit in the SiC register is 0 (external clock), write to the SiTRR register and SMi7 bit in the SiC register under the following conditions: - When the SMi4 bit in the SiC register is 0 (transmit data is output at falling edge of transmit/receive clock and receive data is input at rising edge): CLKi input is high. - When the SMi4 bit is 1 (transmit data is output at rising edge of transmit/receive clock and receive data is input at falling edge): CLKi input is low. ### 24.3.7 **SOUTI Pin** The SOUTi pin state can be selected by setting bits SMi2 and SMi3 in the SiC register. Table 24.4 lists SOUTi Pin State. Table 24.4 SOUTi Pin State | Bit Setting | | | |--------------|------|---------------------------------------| | SiC register | | SOUTi Pin State | | SMi2 | SMi3 | | | 0 | 0 | I/O port or other peripheral function | | | 1 | SOUTi output | | 1 0/1 | | High-impedance | ## 24.3.8 Function for Setting SOUTi Initial Value When the SMi6 bit in the SiC register is 0 (external clock), the SOUTi pin output can be fixed high or low when not transmitting/receiving data. High or low can be selected by setting the SMi7 bit in the SiC register. However, the last bit value of the previous unit of data is retained between adjacent units of data when using the external clock. Figure 24.7 shows Timing Chart for Setting SOUTi Initial Value and How to Set It. Figure 24.7 Timing Chart for Setting SOUTi Initial Value and How to Set It ### 24.4 Interrupt Refer to the operation example for interrupt source or interrupt request generation timing. Refer to 14.7 "Interrupt Control" for interrupt control. Table 24.5 lists Registers Associated with SI/O3 and SI/O4. Table 24.5 Registers Associated with SI/O3 and SI/O4 | Address | Register | Symbol | Reset Value | |---------|----------------------------------|--------|-------------| | 0048h | SI/O4 Interrupt Control Register | S4IC | XX00 X000b | | 0049h | SI/O3 Interrupt Control Register | S3IC | XX00 X000b | | 0207h | Interrupt Source Select Register | IFSR | 00h | The interrupts below share the interrupt vector and interrupt control register with other peripheral functions. To use the following interrupts, set the bits as follows: - SI/O3: Set the IFSR6 bit in the IFSR register to 0 (SI/O3). - SI/O4: Set the IFSR7 bit in the IFSR register to 0 (SI/O4). Set the POL bit in the SilC register to 0 (falling edge). #### 24.5 Notes on Serial Interface SI/O3 and SI/O4 ### 24.5.1 SOUTI Pin Level When SOUTI Output Is Disabled When the SMi2 bit in the SiC register is set to 1 (SOUTi output disabled), the target pin becomes high-impedance regardless of which pin function being used. #### 24.5.2 External Clock Control The data written to the SiTRR register shifts each time the external clock is input. When completing data transmission/reception of the eighth bit, read or write to the SiTRR register before inputting the clock for the next data transmission/reception. # 24.5.3 Register Access Set the SM22 bit in the S34C2 register before setting other registers associated with SI/O3 and SI/O4. After changing the SM22 bit, set other registers associated with SI/O3 and SI/O4 again. ### 24.5.4 Register Access When Using the External Clock When the SMi6 bit in the SiC register is 0 (external clock), write to the SMi7 bit in the SiC register and SiTRR register under the following conditions: - When the SMi4 bit in the SiC register is 0 (transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising edge): CLKi input is high. - When the SMi4 bit in the SiC register is 1 (transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling edge): CLKi input is low. ### 24.5.5 SiTRR Register Access Write transmit data to the SiTRR register while transmission/reception is stopped. Read receive data from the SiTRR register while transmission/reception is stopped. The IR bit in the SiIC register becomes 1 (interrupt requested) during output of the eighth bit. When the SM26 bit (SOUT3) or SM27 bit (SOUT4) in the S34C2 register is 0 (high-impedance after transmission), the SOUTi pin becomes high-impedance when the transmit data is written to the SiTRR register immediately after an interrupt request is generated, and the hold time of the transmit data becomes shorter. ### 24.5.6 Pin Function Switch When Using the Internal Clock (Technical update number: TN-16C-121A/EA) If the SMi3 bit in the SiC register (i = 3, 4) changes from 0 (I/O port) to 1 (SOUTi output, CLKi function) when setting the SMi2 bit to 0 (SOUTi output) and the SMi6 bit to 1 (internal clock), the SOUTi initial value set to the SOUTi pin by the SMi7 bit may be output for about 10 ns. Then, the SOUTi pin becomes high-impedance. If the output level from the SOUTi pin when the SMi3 bit changes from 0 to 1 becomes a problem, set the SOUTi initial value by the SMi7 bit. ### 24.5.7 Operation after Reset When Selecting the External Clock When the SMi6 bit in the SiC register is 0 (external clock) after reset, the IR bit in the SiIC register becomes 1 (interrupt requested) by inputting an external clock for 8 bits to the CLKi pin. This will also occur even when the SMi3 bit in the SiC register is 0 (serial interface disabled) or before a value is written to the SiTRR register. # 25. Multi-master I<sup>2</sup>C-bus Interface #### 25.1 Introduction The multi-master I<sup>2</sup>C-bus interface (I<sup>2</sup>C interface) is a serial communication circuit based on the I<sup>2</sup>C-bus data transmit/receive format, and is equipped with arbitration lost detect and clock synchronous functions. Table 25.1 lists the Multi-master I<sup>2</sup>C-bus Interface Specifications, Table 25.2 lists the I<sup>2</sup>C Interface Detection Function, Figure 25.1 shows the Multi-master I<sup>2</sup>C-bus Interface Block Diagram, and Table 25.3 lists the I/O Ports. Table 25.1 Multi-master I<sup>2</sup>C-bus Interface Specifications | Item | Function | | | | | | |------------------------------|-----------------------------------------------------------------------------------|--|--|--|--|--| | | Based on I <sup>2</sup> C-bus standard: | | | | | | | Formats | 7-bit addressing format | | | | | | | Formats | Fast-mode | | | | | | | | Standard clock mode | | | | | | | | Based on I <sup>2</sup> C-bus standard: | | | | | | | | Master transmission | | | | | | | Communication modes | Master reception | | | | | | | | Slave transmission | | | | | | | | Slave reception | | | | | | | Bit rate | 16.1 kbps to 400 kbps (fVIIC = 4 MHz) | | | | | | | I/O pins | Serial data line SDAMM (SDA) | | | | | | | i/O piris | Serial clock line SCLMM (SCL) | | | | | | | | • I <sup>2</sup> C-bus interrupt | | | | | | | | Completion of transmission | | | | | | | | Completion of reception | | | | | | | Interrupt request generating | Slave address match detection | | | | | | | sources | General call detection | | | | | | | Sources | Stop condition detection | | | | | | | | Timeout detection | | | | | | | | SDA/SCL interrupt | | | | | | | | Rising or falling edge of the signal of the SDAMM or SCLMM pin | | | | | | | | I <sup>2</sup> C-bus interface pin input level select | | | | | | | | Selectable input level with I <sup>2</sup> C-bus input level or SMBus input level | | | | | | | | SDA/port, SCL/port selection | | | | | | | | A function to change the SDAMM and SCLMM pins to output ports. | | | | | | | Selectable functions | Timeout detection | | | | | | | Selectable functions | A function that detects when the SCLMM pin is driven high over a certain | | | | | | | | period of time when the bus is busy. | | | | | | | | Free data format select | | | | | | | | A function that generates an interrupt request when receiving the first byte | | | | | | | | of data, regardless of the slave address value. | | | | | | fVIIC: I<sup>2</sup>C-bus system clock Table 25.2 I<sup>2</sup>C Interface Detection Function | Item | Function | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Slave address match detection | A function to detect a slave address match when in slave transmission/reception. If slave address match is detected, an ACK is returned. If the slave address match is not detected, a NACK is returned, and no further data is transmitted/received. Up to three slave addresses can be set. | | General call detection | A function to detect a general call in slave reception. | | Arbitration lost detection | A function to detect arbitration lost and stop the output from pins SDAMM and SCLMM. | | Bus busy detection | A function to detect a bus busy state and set/reset the BB bit. | Figure 25.1 Multi-master I<sup>2</sup>C-bus Interface Block Diagram Table 25.3 I/O Ports | Pin Name | I/O | Function | |----------|-----|-----------------------------------------------| | SDAMM | I/O | I/O pin for SDA (N-channel open drain output) | | SCLMM | I/O | I/O pin for SCL (N-channel open drain output) | # 25.2 Registers Descriptions Table 25.4 lists registers associated with multi-master I<sup>2</sup>C-bus interface. Refer to 8.2.6 "Peripheral Clock Stop Register 1 (PCLKSTP1)" for the explanation of the PCLKSTP1 register. When the CM07 bit in the CM0 register is set to 1 (sub clock is CPU clock), registers listed in Table 25.4 should not be accessed. Set them after the CM07 bit is set to 0 (main clock, PLL clock, or on-chip oscillator clock). Table 25.4 Registers | Address | Register | Symbol | Reset Value | |---------|--------------------------------------------|----------|-------------| | 0012h | Peripheral Clock Select Register | PCLKR | 0000 0011b | | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 02B0h | I2C0 Data Shift Register | S00 | XXh | | 02B2h | I2C0 Address Register 0 | S0D0 | 0000 000Xb | | 02B3h | I2C0 Control Register 0 | S1D0 | 00h | | 02B4h | I2C0 Clock Control Register | S20 | 00h | | 02B5h | I2C0 Start/Stop Condition Control Register | S2D0 | 0001 1010b | | 02B6h | I2C0 Control Register 1 | S3D0 | 0011 0000b | | 02B7h | I2C0 Control Register 2 | S4D0 | 00h | | 02B8h | I2C0 Status Register 0 | S10 | 0001 000Xb | | 02B9h | I2C0 Status Register 1 | S11 | XXXX X000b | | 02BAh | I2C0 Address Register 1 | S0D1 | 0000 000Xb | | 02BBh | I2C0 Address Register 2 | S0D2 | 0000 000Xb | # 25.2.1 Peripheral Clock Select Register (PCLKR) Write to the PCLKR register after setting the PRC0 bit in the PRCR register to 1 (write enabled). ## 25.2.2 I2C0 Data Shift Register (S00) When the I<sup>2</sup>C interface is a transmitter, write transmit data to the S00 register. When the I<sup>2</sup>C interface is a receiver, received data can be read from the S00 register. In master mode, this register is also used to generate a start condition or stop condition on a bus. (Refer to 25.3.2 "Generating a Start Condition" and 25.3.3 "Generating a Stop Condition".) Write to the S00 register when the ES0 bit in the S1D0 register is 1 (I<sup>2</sup>C interface enabled). Do not write to the S00 register when transmitting/receiving data. When the $I^2C$ interface is a transmitter, the data in the S00 register is transmitted to other devices. The MSB (bit 7) is transmitted first, synchronizing with the SCLMM clock. Every time 1-bit data is output, the S00 register value is shifted 1 bit to the left. When the I<sup>2</sup>C interface is a receiver, data is transferred to the S00 register from other devices. The LSB (bit 0) is input first, synchronizing with the SCLMM clock. Every time 1-bit data is output, the S00 register value is shifted 1 bit to the left. Figure 25.2 shows Timing to Store Received Data to the S00 Register. Figure 25.2 Timing to Store Received Data to the S00 Register # 25.2.3 I2C0 Address Register i (S0Di) (i = 0 to 2) ### SAD6 to SAD0 (Slave address) (b7-b1) Bits SAD6 to SAD0 indicate a slave address to be compared for a slave address match detection in slave mode. Up to three slave addresses can be set. Set the S0Di register to 00h when not setting the slave address. However, when the MSLAD bit in the S4D0 register is 0, registers S0D1 and S0D2 are disabled. Only the slave address set to the S0D0 register is compared with address the data received. # 25.2.4 I2C0 Control Register 0 (S1D0) ### BC2 to BC0 (Bit counter) (b2-b0) Bits BC2 to BC0 become 000b (8 bits) when a start condition is detected. When the ACKCLK bit in the S20 register is 0 (no ACK clock), and data for the number of bits selected by bits BC2 to BC0 is transmitted or received, bits BC2 to BC0 become 000b again. When the ACKCLK bit in the S20 register is 1 (ACK clock), and data for the number of bits selected and an ACK is transmitted or received, bits BC2 to BC0 become 000b again. ### ES0 (I<sup>2</sup>C-bus interface enable bit) (b3) The ES0 bit enables the I<sup>2</sup>C interface. When the ES0 bit is set to 0, the I2C interface becomes as follows: - Pins SDAMM and SCLMM: I/O ports or other peripheral pins - The S00 register is write disabled. - The I<sup>2</sup>C-bus system clock (hereinafter called fVIIC) stops. - S10 register ADR0 bit: 0 (general call not detected) AAS bit: 0 (slave address not matched) AL bit: 0 (arbitration lost not detected) PIN bit: 1 (no I<sup>2</sup>C-bus interrupt request) BB bit: 0 (bus free) TRX bit: 0 (receive mode) MST bit: 0 (slave mode) - Bits AAS2 to AAS0 in the S11 register: 0 (slave address not matches) - The TOF bit in the S4D0 register: 0 (timeout not detected) ### ALS (Data format select bit) (b4) The ALS bit is enabled in slave mode. When the ALS bit is 0 (addressing format), the slave address match detection is performed. When a slave address stored to bits SAD6 to SAD0 in the S0Di register (i = 0 to 2) is compared and matched with the calling address by a master, or when a general call address is received, the IR bit in the IICIC register becomes 1 (interrupt requested). When the ALS bit is 1 (free data format), the slave address match detection is not performed. Therefore, the IR bit in the IICIC register becomes 1 (interrupt requested), regardless of the calling address by a master. ## IHR (I<sup>2</sup>C-bus interface reset bit) (b6) The IHR bit resets the I<sup>2</sup>C interface if there is an anomaly during transmission/reception. When the ES0 bit in the S1D0 register is 1 (I<sup>2</sup>C interface enabled) and then the IHR bit is set to 1 (reset), the I<sup>2</sup>C interface becomes as follows: • S10 register ADR0 bit: 0 (general call not detected) AAS bit: 0 (slave address not matched) AL bit: 0 (arbitration lost not detected) PIN bit: 1 (No I<sup>2</sup>C-bus interrupt request) BB bit: 0 (bus free) TRX bit: 0 (receive mode) MST bit: 0 (slave mode) - Bits AAS2 to AAS0 in the S11 register: 0 (slave address not matches) - TOF bit in the S4D0 register: 0 (timeout not detected) When the IHR bit is set to 1, the I<sup>2</sup>C interface is reset and the IHR bit becomes 0 automatically. It takes a maximum of 2.5 fVIIC cycles to complete the reset sequence. Figure 25.3 shows the I<sup>2</sup>C Interface Reset Timing. Figure 25.3 I<sup>2</sup>C Interface Reset Timing TISS (I<sup>2</sup>C-bus interface pin input level select bit) (b7) Set the TISS bit to select the input level of the SCLMM pin and SDAMM pin for the I<sup>2</sup>C interface. # 25.2.5 I2C0 Clock Control Register (S20) ### CCR4 to CCR0 (Bit rate control bit) (b4-b0) Assuming the CCR value (3 to 31) is the value set to bits CCR4 to CCR0, the bit rate can be calculated using the following equation: Refer to 25.3.1.2 "Bit Rate and Duty Cycle" for more details. In standard-speed clock mode, Bit rate = $$\frac{\text{fVIIC}}{8 \times \text{CCR value}} \le 100 \text{ kbps}$$ When the CCR value is other than 5 in fast-mode, Bit rate = $$\frac{\text{fVIIC}}{4 \times \text{CCR value}} \le 400 \text{ kbps}$$ When the CCR value is 5 in fast-mode, the bit rate is assumed to reach 400 kbps, the maximum bit rate in fast-mode. Bit rate = $$\frac{\text{fVIIC}}{2 \times \text{CCR value}} = \frac{\text{fVIIC}}{10} \le 400 \text{ kbps}$$ Do not set the CCR value from 0 to 2 regardless of the fVIIC frequency. Rewrite bits CCR4 to CCR0 when the ES0 bit in the S1D0 register is 0 (disabled). # FASTMODE (SCL mode select bit) (b5) When using the fast-mode I<sup>2</sup>C-bus standard (maximum 400 kbps), set the FASTMODE bit to 1 (fast-mode) and set fVIIC to 4 MHz or more. Rewrite the FASTMODE bit when the ES0 bit in the S1D0 register is 0 (disabled). ### ACKBIT (ACK bit) (b6) The ACK bit is enabled in master reception, slave reception, or slave address reception. When receiving a slave address, the SDAMM pin level during the ACK clock pulse is determined by a combination of bits ALS and ACKBIT in the S1D0 register and the received slave address. When receiving data, the SDAMM pin level during the ACK clock pulse is determined by the ACKBIT bit. Table 25.5 lists the SDAMM Pin Level during the ACK Clock Pulse. Table 25.5 SDAMM Pin Level during the ACK Clock Pulse | Received<br>Content | ALS Bit in the S1D0 Register | ACKBIT Bit in the S20 Register | Slave Address Content | SDAMM Pin Level at<br>ACK Clock | |---------------------|------------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------| | Slave<br>Address | | 0 | When the MSLAD bit in the S4D0 register is 0: Matched with bits SAD6 to SAD0 in the S0D0 register. When the MSLAD bit is 1: Matched with bits SAD6 to SAD0 in any of registers S0D0 to S0D2. | Low (ACK) | | | | | Others | High (NACK) | | | | 1 | _ | High (NACK) | | | | 0 | _ | Low (ACK) | | | | 1 | _ | High (NACK) | | Data | | 0 | _ | Low (ACK) | | Dala | _ | 1 | _ | High (NACK) | ### ACKCLK (ACK clock bit) (b7) When the ACKCLK bit is 1 (ACK clock present), an ACK clock is generated immediately after 1-byte data is transmitted or received (8 clocks). When the ACKCLK bit is 0 (no ACK clock), no ACK clock is generated after 1-byte data is transmitted or received (8 clocks). At the falling edge of data transmission/reception (the falling edge of the eighth clock), the IR bit in the IICIC register becomes 1 (interrupt requested). Do not write to this bit when transmitting/receiving data. # 25.2.6 I2C0 Start/Stop Condition Control Register (S2D0) | b7 b6 b5 b4 b3 b2 b1 b0 | Symbol<br>S2D0 | Addre<br>02B5h | | t Value<br>1010b | |-----------------------------------------|----------------|--------------------------------------------|--------------------------------------------------------------------------------------------|------------------| | | Bit Symbol | Bit Name | Function | RW | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | SSC0 | | | RW | | | SSC1 | | | RW | | | SSC2 | Start/stop condition setting bit | Refer to SSC4 to SSC0 (Start/Stop<br>Condition Setting Bit) (b4 to b0) in the<br>same page | RW | | | SSC3 | | | RW | | | SSC4 | | | RW | | | SIP | SCL/SDA interrupt pin polarity select bit | 0: Falling edge<br>1: Rising edge | RW | | <u> </u> | SIS | SCL/SDA interrupt pin select bit | 0: SDAMM<br>1: SCLMM | RW | | | STSPSEL | Start/stop condition generation select bit | 0: Short setup/hold time mode 1: Long setup/hold time mode | RW | ### SSC4 to SSC0 (Start/stop condition setting bit) (b4-b0) Set bits SSC4 to SSC0 to select the start/stop condition detect parameter (SCL open time, setup time, hold time) in standard-speed clock mode. Refer to 25.3.7 "Detecting Start/Stop Conditions". Do not set an odd value or 00000b to these bits. SIP (SCL/SDA interrupt pin polarity select bit) (b5) SIS (SCL/SDA interrupt pin select bit) (b6) The IR bit in the SCLDAIC register becomes 1 (interrupt requested) when the I<sup>2</sup>C interface detects the edge selected by the SIP bit for the pin signal selected by the SIS bit. Refer to 25.4 "Interrupts". ### STSPSEL (Start/stop condition generation select bit) (b7) See Table 25.13 "Setup/Hold Time for Generating a Start/Stop Condition". If the fVIIC frequency is more than 4 MHz, set the STSPSEL bit to 1 (long mode). # 25.2.7 I2C0 Control Register 1 (S3D0) Do not use the bit managing instruction (read-modify-write instruction) to access the S3D0 register. Use the MOV instruction to write to the S3D0 register. ### SIM (Stop condition detect interrupt enable bit) (b0) When the SIM bit is 1 (I<sup>2</sup>C-bus interrupt by stop condition detection enabled) and a stop condition is detected, the SCPIN bit in the S4D0 register becomes 1 (stop condition detect interrupt requested) and the IR bit in the IICIC register becomes 1 (interrupt requested). ### WIT (Data receive interrupt enable bit) (b1) The WIT bit is enabled in master reception or slave reception. The WIT bit has two functions: - Selects the I<sup>2</sup>C-bus interrupt timing when data is received. (write) - Monitors the state of the internal WAIT flag. (read) The WIT bit can select whether to generate an I<sup>2</sup>C-bus interrupt request at eighth clock (before ACK clock) during the data reception. When the ACKCLK bit in the S20 register is 1 (ACK clock presents) and the WIT bit is set to 1 (enable I<sup>2</sup>C-bus interrupt at 8th clock), an I<sup>2</sup>C-bus interrupt request is generated at the eighth clock (before the ACK clock). Then, the PIN bit in the S10 register becomes 0 (interrupt requested). When the ACKCLK bit in the S20 register is 0 (no ACK clock presents), write 0 to the WIT bit to disable the I<sup>2</sup>C-bus interrupt by data reception. When transmitting data and receiving a slave address, no interrupt requests are generated at the eighth clock (before the ACK clock) regardless of the value written to the WIT bit. Reading the WIT bit returns the internal WAIT flag status. An I<sup>2</sup>C-bus interrupt request is generated at the falling edge of the ninth clock (ACK clock) regardless of the value written to the WIT bit. Then, the PIN bit in the S10 register becomes 0 (interrupt requested). Therefore, read the internal WAIT flag status to determine whether the I<sup>2</sup>C-bus interrupt request is generated at the eighth clock (before the ACK clock) or at the falling edge of the ACK clock. When the WIT bit is set to 1 (I<sup>2</sup>C-bus interrupt enabled by receiving data), the internal WAIT flag changes under the following conditions: Condition to become 0: • The S20 register (ACKBIT bit) is written. Condition to become 1: • The S00 register is written during data reception. When transmitting data and receiving a slave address, the internal WAIT flag is 0 and the I<sup>2</sup>C-bus interrupt request will be generated only at the falling edge of the ninth clock (ACK clock), regardless of the value written to the WIT bit. Table 25.6 lists interrupt request generation timing and the conditions to restart transmission/reception when receiving data. Figure 25.4 shows Interrupt Request Generation Timing in Receive Mode. Table 25.6 Generating an Interrupt Request and Restarting Transmission/Reception When Receiving Data | I <sup>2</sup> C-bus Interrupt Request Generation Timing | Internal WAIT<br>Flag Status | Conditions to Restart Transmission/Reception | |--------------------------------------------------------------------|------------------------------|------------------------------------------------------------| | At the falling edge of the eighth clock (before the ACK clock) (1) | 1 | Write to the ACKBIT bit in the S20 register <sup>(3)</sup> | | At the falling edge of the ninth clock (ACK clock) (2) | 0 | Write to the S00 register | ### Notes: - 1. See the timing of (1) on the IR bit in the IICIC register in Figure 25.4. - 2. See the timing of (2) on the IR bit in the IICIC register in Figure 25.4. - 3. When setting the ACKBIT bit, do not rewrite any other bits and do not set the S00 register. Figure 25.4 Interrupt Request Generation Timing in Receive Mode PED (SDAMM/port function switch bit) (b2) PEC (SCLMM/port function switch bit) (b3) Bits PEC and PED are enabled when the ES0 bit in the S1D0 register is 1 (I<sup>2</sup>C interface enabled). When the PEC bit is set to 1 (output port), the P7\_1 bit value is output from the SCLMM pin regardless of the internal SCL output signal and PD7\_1 bit value. When the PED bit is set to 1 (output port), the P7\_0 bit value is output from the SDAMM pin regardless of the internal SDA output signal and PD7\_0 bit value. The signal level on the bus is input to the internal SDA and internal SCL. When bits P7\_1 to P7\_0 in the P7 register are read after setting bits PD7\_1 and PD7\_0 in the PD7 register to 0 (input mode), the level on the bus can be read regardless of the values set to bits PED and PEC. Table 25.7 lists SCLMM and SDAMM Pin Functions. Table 25.7 SCLMM and SDAMM Pin Functions | Pin | S1D0 Register | S3D0 Register | | Pin Function | | |------------|---------------|---------------|---------|-------------------------------------|--| | | ES0 bit | PED bit | PEC bit | - I in Function | | | | 0 | - | - | I/O port or other peripheral pins | | | P7_1/SCLMM | 1 | - | 0 | SCLMM (SCL input/output) | | | | | - | 1 | Output port (output P7_1 bit value) | | | | 0 | - | - | I/O port or other peripheral pins | | | P7_0/SDAMM | 1 | 0 | - | SDAMM (SDA input/output) | | | | • | 1 | - | Output port (output P7_0 bit value) | | <sup>-: 0</sup> or 1 SDAM (Internal SDA output monitor bit) (b4) SCLM (Internal SCL output monitor bit) (b5) The internal SDA and SCL output signal levels are the same as the output level of the I<sup>2</sup>C interface before it has any effect from the external device output. Bits SDAM and SCLM are read only bits. If necessary, set these bits to 0. ## ICK1 and ICK0 (I<sup>2</sup>C-bus system clock select bit) (b7-b6) Rewrite these bits when the ES0 bit in the S1D0 register is 0 (I<sup>2</sup>C interface disabled). fVIIC is selected by setting all the bits ICK1 to ICK0, bits ICK4 to ICK2 in the S4D0 register, and the PCLK0 bit in the PCLKR register. Refer to 25.3.1.2 "Bit Rate and Duty Cycle". Table 25.8 I<sup>2</sup>C-bus System Clock Select Bits | S4D0 Register | | S3D0 Register | | fVIIC | | |---------------|----------|---------------|----------|----------|---------------------| | ICK4 Bit | ICK3 Bit | ICK2 Bit | ICK1 Bit | ICK0 Bit | TVIIC | | 0 | 0 | 0 | 0 | 0 | fIIC divided-by-2 | | 0 | 0 | 0 | 0 | 1 | fIIC divided-by-4 | | 0 | 0 | 0 | 1 | 0 | fIIC divided-by-8 | | 0 | 0 | 1 | _ | _ | fIIC divided-by-2.5 | | 0 | 1 | 0 | _ | _ | fIIC divided-by-3 | | 0 | 1 | 1 | _ | _ | fIIC divided-by-5 | | 1 | 0 | 0 | _ | _ | fIIC divided-by-6 | -: 0 or 1 Only set the values listed above. # 25.2.8 I2C0 Control Register 2 (S4D0) ### TOE (Timeout detect function enable bit) (b0) The TOE bit enables the timeout detect function. Refer to 25.3.9 "Timeout Detection" for details. ### TOF (Timeout detect flag) (b1) The TOF bit is enabled when the TOE bit is set to 1. When the TOF bit becomes 1 (detected), the IR bit in the IICIC register becomes 1 (interrupt requested) at the same time. ### Conditions to become 0: - The ES0 bit in the S1D0 register is set to 0 (I2C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I2C interface reset). #### Condition to become 1: • The BB bit in the S10 register is set to 1 (bus busy) and the SCLMM high period is greater than the timeout detect period. ### TOSEL (Timeout detect time select bit) (b2) Set the TOSEL bit to select a timeout detection period. The TOSEL bit is enabled when the TOE bit is 1 (timeout detect function enabled). When long time is selected, the internal counter increments fVIIC as a 16-bit counter. When short time is selected, the internal counter increments fVIIC as a 14-bit counter. Therefore, the timeout detect time is as follows: When the TOSEL bit is set to 0 (long time) $$65536 \times \frac{1}{\text{fVIIC}}$$ When the TOSEL bit is set to 1 (short time) $$16384 \times \frac{1}{\text{fVIIC}}$$ Table 25.9 lists Timeout Detect Time. Table 25.9 Timeout Detect Time | fVIIC | Timeout Detect | | | | | | |-------|--------------------------|---------------------------|--|--|--|--| | 17110 | TOSEL bit: 0 (Long time) | TOSEL bit: 1 (Short time) | | | | | | 4 MHz | 16.4 ms | 4.1 ms | | | | | | 2 MHz | 32.8 ms | 8.2 ms | | | | | | 1 MHz | 65.6 ms | 16.4 ms | | | | | Rewrite this bit when the TOE bit is 0. # ICK4-ICK2 (I<sup>2</sup>C-bus system clock select bit) (b5-b3) Rewrite bits ICK4 to ICK2 when the ES0 bit in the S1D0 register is 0 (I<sup>2</sup>C interface disabled). fVIIC is selected by setting all the bits ICK4 to ICK2, bits ICK1 to ICK0 in the S3D0 register, and the PCLK0 bit in the PCLKR register. Refer to Table 25.8 "I<sup>2</sup>C-bus System Clock Select Bits" and 25.3.1.2 "Bit Rate and Duty Cycle". #### MSLAD (Slave address control bit) (b6) The MSLAD bit is enabled when the ALS bit in the S1D0 register is set to 0 (addressing format). The MSLAD bit is used to select the S0Di register (i = 0 to 2) used for slave address match detection. ### SCPIN (Stop condition detect interrupt request bit) (b7) The SCPIN bit is enabled when the SIM bit in the S3D0 register is set to 1 (enable I<sup>2</sup>C-bus interrupt by stop condition detection). Condition to become 0: Writing 0 by a program. Condition to become 1: Stop condition is detected (This bit cannot be set to 1 by a program.) # 25.2.9 I2C0 Status Register 0 (S10) Do not use the bit managing instruction (read-modify-write instruction) to access the S10 register. Use the MOV instruction to write to the S10 register. Bit 5 to bit 0 in the S10 register (6 lower bits) monitor the state of the I<sup>2</sup>C interface. The bit values cannot be changed by a program. However, writing to the S10 register, including the 6 lower bits, generates a start/stop condition. Bits MST and TRX are read and write bits. To change bits MST or TRX without generating a start/stop condition, set 1111b to the 4 lower bits in the S10 register. Table 25.10 lists Functions Enabled by Writing to the S10 Register. Only set the values listed in Table 25.10. If the values listed in Table 25.10 are written to the S10 register, the 6 lower bits in the S10 register will not be changed. Table 25.10 Functions Enabled by Writing to the S10 Register | Bit Setting of the S10 Register | | | | | | | | Function | |---------------------------------|-----|----|-----|----|-----|------|-----|------------------------------------------------------------------------------------------------------| | MST | TRX | BB | PIN | AL | AAS | ADR0 | LRB | i unction | | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | Sets the I <sup>2</sup> C interface to start condition standby state in master transmit/receive mode | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Sets the I <sup>2</sup> C interface to stop condition standby state in master transmit/receive mode | | 0 | 0 | - | 0 | 1 | 1 | 1 | 1 | Slave receive mode | | 0 | 1 | - | 0 | 1 | 1 | 1 | 1 | Slave transmit mode | | 1 | 0 | _ | 0 | 1 | 1 | 1 | 1 | Master receive mode | | 1 | 1 | ı | 0 | 1 | 1 | 1 | 1 | Master transmit mode | -: 0 or 1 Refer to 25.3.2 "Generating a Start Condition" and 25.3.3 "Generating a Stop Condition" for start/stop conditions. ### LRB (Last receive bit) (b0) When read, the LRB bit functions as described below. See Table 25.10 "Functions Enabled by Writing to the S10 Register" for the bit function in write access. The LRB bit stores the value of the last bit of the received data. It is used to check if ACK is received. The bit becomes 0 after writing to the S00 register. ### ADR0 (General call detect flag) (b1) The ADR0 bit function in read access is described below. See Table 25.10 "Functions Enabled by Writing to the S10 Register" for the bit function in write access. ### Conditions to become 0: - Stop condition is detected. - Start condition is detected. - The ES0 bit in the S1D0 register is set to 0 (I<sup>2</sup>C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I<sup>2</sup>C interface reset). #### Condition to become 1: • The ALS bit in the S1D0 register is set to 0 (addressing format) and the received slave address is 0000000b (general call) in slave mode. ### AAS (Slave address compare flag) (b2) The AAS bit function in read access is described below. See Table 25.10 "Functions Enabled by Writing to the S10 Register" for the bit function in write access. Conditions to become 0: - The S00 register is written. - The ES0 bit in the S1D0 register is set to 0 (I2C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I2C interface reset). #### Conditions to become 1: - In slave receive mode, the MSLAD bit in the S4D0 register is 1 (registers S0D0 to S0D2), the ALS bit in the S1D0 register is 0 (addressing format), and the received slave address is matched with bits SAD6 to SAD0 in any registers from S0D0 to S0D2. - In slave receive mode, the MSLAD bit is 0, the ALS bit in the S1D0 register is 0 (addressing format), and the received slave address is matched with bits SAD6 to SAD0 in the S0D0 register. - In slave receive mode, the ALS bit in the S1D0 register is 0 (addressing format) and the received slave address is 0000000b (general call). ### AL (Arbitration lost detect flag) (b3) The AL bit function in read access is described below. See Table 25.10 "Functions Enabled by Writing to the S10 Register" for the bit function in write access. Conditions to become 0: - The S00 register is written. - The ES0 bit in the S1D0 register is set to 0 (I2C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I<sup>2</sup>C interface reset). #### Conditions to become 1: - In master transmit mode or master receive mode, the SDAMM pin level changes to low by an external device, not by the ACK clock, when slave address is transmitted. - The SDAMM pin level changes to low by an external device for other than the ACK clock when data is transmitted in master transmit mode. - In master transmit mode or master receive mode, the SDAMM pin level changes to low by an external device when start condition is transmitted. - In master transmit mode or master receive mode, the SDAMM pin level changes to low by an external device when stop condition is transmitted. - The function to prevent start condition overlaps is activated. ## PIN (I<sup>2</sup>C-bus interface interrupt request bit) (b4) The PIN bit function in read access is described below. See Table 25.10 "Functions Enabled by Writing to the S10 Register" for the bit function in write access. #### Conditions to become 0: - Slave address transmission is completed in master mode (including a case of detecting arbitration lost). - 1-byte data transmission is completed (including a case of detecting arbitration lost). - 1-byte data reception is completed (the falling edge of eighth clock is detected when the ACKCLK bit in the S20 register is 0, or the falling edge of ACK clock when the ACKCLK bit is 1). - The WIT bit in the S3D0 register is 1 (I<sup>2</sup>C-bus interrupt enabled at 8th clock) and 1-byte data reception is completed (before ACK clock). - In slave receive mode, the MSLAD bit in the S4D0 register is 1, the ALS bit in the S1D0 register is 0 (addressing format), and any of the slave address stored in bits SAD6 to SAD0 in the S0Di register (i = 0 to 2) is matched with the received slave address (slave address match). - In slave receive mode, the MSLAD bit is 0, the ALS bit is 0 (addressing format), and the slave address stored in bits SAD6 to SAD0 in the S0D0 register is matched with the received slave address (slave address match). - In slave receive mode, the ALS bit in the S1D0 register is 0 (addressing format) and the received slaved address is 0000000b (general call). - In slave receive mode, the ALS bit in the S1D0 register is 1 (free data format) and the slave address reception is completed. #### Conditions to become 1: - The S00 register is written. - The S20 register is written (when the WIT bit is 1 and the internal WAIT flag is 1). - The ES0 bit in the S1D0 register is set to 0 (I<sup>2</sup>C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I2C interface reset). The IR bit in the IICIC register becomes 1 (interrupt requested) as soon as the PIN bit becomes 0 (I<sup>2</sup>C-bus interrupt requested). When the PIN bit is 0, the SCLMM pin output level is low. However, when all of the following conditions are met, the SCLMM pin does not output a low level signal: - In master mode, arbitration lost is detected by a slave address or data - The ALS bit in the S1D0 register is 0 (addressing format) - The slave address is not 0000000b (general call) and does not match any of the bits from SAD6 to SAD0 in registers S0D0 to S0D2. ### BB (Bus busy flag) (b5) The BB bit function in read access is described below. See Table 25.10 "Functions Enabled by Writing to the S10 Register" for the bit function in write access. The BB bit indicates the state of the bus system, whether the bus is free or not. The BB bit changes depending on the SCLMM and SDAMM input signals, regardless of master mode or slave mode. Conditions to become 0: - Stop condition is detected. - The ES0 bit in the S1D0 register is set to 0 (I2C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I2C interface reset). #### Condition to become 1: Start condition is detected. ### TRX (Communication mode select bit 0) (b6) Set the TRX bit to select transmit mode or receive mode. #### Conditions to become 0: - The TRX bit is set to 0 by a program. - Arbitration lost is detected. - Stop condition is detected. - Start condition overlap protect function is enabled. - Start condition is detected when the MST bit in the S10 register is 0 (slave mode). - No ACK is detected from a receiver when the MST bit in the S10 register is 0 (slave mode). - The ES0 bit in the S1D0 register is set to 0 (I2C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I2C interface reset). #### Conditions to become 1: - The TRX bit is set to 1 by a program. - In slave mode, the ALS bit in the S1D0 register is 0 (addressing format), the AAS bit in the S10 register becomes 1 (address matched) after receiving the slave address, and the received R/W bit is 1. # MST (Communication mode select bit 1) (b7) Set the MST bit to select master mode or slave mode. #### Conditions to become 0: - The MST bit is set to 0 by a program. - The 1-byte data that lost arbitration is completed transmitting/receiving when arbitration lost is detected. - Stop condition is detected. - Start condition overlap protect function is enabled. - The ES0 bit in the S1D0 register is 0 (I<sup>2</sup>C interface disabled). - The IHR bit in the S1D0 register is 1 (I2C interface reset). ### Conditions to become 1: • The MST bit is set to 1 by a program. # 25.2.10 I2C0 Status Register 1 (S11) AAS0 (Slave address 0 compare flag) (b0) AAS1 (Slave address 1 compare flag) (b1) AAS2 (Slave address 2 compare flag) (b2) When the ALS bit in the S1D0 register is 0 (addressing format), any slave address stored in bits SAD6 to SAD0 in the S0Di register (i = 0 to 2) is compared with the received slave address. The compare result is shown in the AASi bit. The AASi bit becomes 1 when there is an address match or when a general call address is received. The AAS0 bit is enabled when the MSLAD bit in the S4D0 register is 0 (S0D0 register only). Bits AAS2 to AAS0 are enabled when the MSLAD bit is 1 (registers S0D0 to S0D2). Conditions to become 0: - The ES0 bit in the S1D0 register is set to 0 (I2C interface disabled). - The IHR bit in the S1D0 register is set to 1 (I2C interface reset). - The S00 register is written. # 25.3 Operations #### 25.3.1 Clock Set the PCKSTP1A bit in the PCLKSTP1 register to 0 (f1 provide enabled). Figure 25.5 shows the I<sup>2</sup>C-bus Interface Clock. Figure 25.5 I<sup>2</sup>C-bus Interface Clock #### 25.3.1.1 fVIIC fVIIC is determined by setting a combination of the following: - The frequency of peripheral clock f1 - The PCLK0 bit in the PCLKR register - Bits ICK1 to ICK0 in the S3D0 register - Bits ICK4 to ICK2 in the S4D0 register fVIIC stops when the ES0 bit in the S1D0 register is 0 (I2C interface disabled). See Table 25.8 "I<sup>2</sup>C-bus System Clock Select Bits" for details. # 25.3.1.2 Bit Rate and Duty Cycle Bit rate is determined by a combination of fVIIC, the FASTMODE bit in the S20 register, and bits CCR4 to CCR0 in the S20 register. Table 25.11 lists the Bit Rate of Internal SCL Output and Duty Cycle. When the change in the internal SCL output high level is a negative value, although the low period increases the amount that the high periods decreases, the bit rate does not increase. The values described is the following table are the values of the internal SCL output before being effected by the SCL output of an external device. Table 25.11 Bit Rate of Internal SCL Output and Duty Cycle | Item | Standard Clock Mode<br>(FASTMODE = 0) | Fast-mode<br>(FASTMODE = 1)<br>(CCR value = other than 5) | Fast-mode<br>(FASTMODE = 1)<br>(CCR value = 5) | |----------------|------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------| | Bit rate (bps) | fVIIC<br>8 × CCR value | fVIIC<br>4 × CCR value | $\frac{\text{fVIIC}}{2 \times \text{CCRvalue}} = \frac{\text{fVIIC}}{10}$ | | Duty cycle | 50% Fluctuation of high level: -4 to +2 fVIIC cycles | 50% Fluctuation of high level: -2 to +2 fVIIC cycles | 35 to 45% | CCR value: Value set to bits CCR4 to CCR0 When the CCR value (setting value of bits CCR4 to CCR0) is 5 (00101b) in fast-mode, the bit rate is assumed to reach 400 kbps, the maximum bit rate in fast-mode. The bit rate and duty cycle are as follows. • Bit rate: $$\frac{\text{fVIIC}}{2 \times \text{CCR value}} = \frac{\text{fVIIC}}{10}$$ When fVIIC is 4 MHz, the bit rate is 400 kbps. Duty cycle is 35 to 45% Even if the bit rate is 400 kbps, the 1.3 $\mu$ s minimum low period of the SCLMM clock (I<sup>2</sup>C-bus standard) is allocated. Table 25.12 lists the Bit Setting for Bits CCR4 to CCR0 and Bit Rate (fVIIC = 4 MHz). Table 25.12 Bit Setting for Bits CCR4 to CCR0 and Bit Rate (fVIIC = 4 MHz) | Bits CCR4 to CCR0 in the S20 Register | | | ne S20 R | Register | Bit Rate (kbps) | | |---------------------------------------|------|------|----------|----------|---------------------|----------------| | CCR4 | CCR3 | CCR2 | CCR1 | CCR0 | Standard Clock Mode | Fast-mode | | 0 | 0 | 0 | 0 | 0 | Do not set (1) | Do not set (1) | | 0 | 0 | 0 | 0 | 1 | Do not set (1) | Do not set (1) | | 0 | 0 | 0 | 1 | 0 | Do not set (1) | Do not set (1) | | 0 | 0 | 0 | 1 | 1 | Do not set (2) | 333 | | 0 | 0 | 1 | 0 | 0 | Do not set (2) | 250 | | 0 | 0 | 1 | 0 | 1 | 100 | 400 | | 0 | 0 | 1 | 1 | 0 | 83.3 | 166 | | : | : | : | : | : | : | : | | 1 | 1 | 1 | 0 | 1 | 17.2 | 34.5 | | 1 | 1 | 1 | 1 | 0 | 16.6 | 33.3 | | 1 | 1 | 1 | 1 | 1 | 16.1 | 32.3 | Notes: - 1. Do not set bits CCR4 to CCR0 to 0 to 2 regardless of the fVIIC frequency. - Do not exceed the maximum bit rates of 100 kbps in standard clock mode and 400 kbps in fastmode. # 25.3.1.3 Receiving a Slave Address in Wait Mode and Stop Mode When the CM02 bit in the CM0 register is set to 0 (peripheral clock f1 does not stop in wait mode) and transition is made to wait mode, the I<sup>2</sup>C interface can receive the slave address even in wait mode. When the CM02 bit in the CM0 register is set to 1 (peripheral clock f1 stops in wait mode) and transition is made to wait mode, the I<sup>2</sup>C interface stops operating because fVIIC supply is stopped in stop mode and low-power consumption mode. The SCL/SDA interrupt can be used in either wait mode or stop mode. # 25.3.2 Generating a Start Condition Follow the procedure below when the ES0 bit in the S1D0 register is 1 (I<sup>2</sup>C interface enabled) and the BB bit in the S10 register is set to 0 (bus free). Figure 25.6 shows the Procedure to Generate a Start Condition. - (1) Write E0h to the S10 register. - The I<sup>2</sup>C interface enters the start condition standby state and the SDAMM pin is released. - (2) Write a slave address to the S00 register. A start condition is generated. Then, the bit counter becomes 000b, the SCL clock signal is output for 1 byte, and the slave address is transmitted. After a stop condition is generated and the BB bit becomes 0 (bus free), a write to the S10 register is disabled for 1.5 fVIIC cycles. Therefore, even if the S00 register is subsequently written to, a start condition is not generated. When generating a start condition shortly after changing the BB bit from 1 to 0, confirm that both bits TRX and MST are 1 after executing step (1), then execute step (2). Figure 25.6 Procedure to Generate a Start Condition The start condition generation timing depends on the modes - standard clock mode or fast-mode. Figure 25.7 shows the Start Condition Generation Timing. Table 25.13 lists the Setup/Hold Time for Generating a Start/Stop Condition. Figure 25.7 Start Condition Generation Timing Table 25.13 Setup/Hold Time for Generating a Start/Stop Condition | Item | STSPSEL Bit | Standard Clock Mode | | Fast-mode | | |-----------------------------|----------------|--------------------------|-------------------------|--------------|---------------| | пеш | | fVIIC cycles | fVIIC = 4 MHz | fVIIC cycles | fVIIC = 4 MHz | | Setup time | 0 (short mode) | 20 | 5.0 μs | 10 | 2.5 μs | | Setup time | 1 (long mode) | 52 | 13.0 μs | 26 | 6.5 μs | | Hold time | 0 (short mode) | 20 | 5.0 μs | 10 | 2.5 μs | | | 1 (long mode) | 52 | 13.0 μs | 26 | 6.5 μs | | BB bit<br>set/reset<br>time | - | <u>SSC value – 1</u> + 2 | 3.375 μs <sup>(1)</sup> | 3.5 | 0.875 μs | <sup>-: 0</sup> or 1 STSPSEL: Bit in the S2D0 register SSC value: Value of bits SSC4 to SSC0 in the S2D0 register Note: 1. Example value when bits SSC4 to SSC0 are 11000b. # 25.3.3 Generating a Stop Condition Use the following procedure when the ES0 bit in the S1D0 register is 1 (I<sup>2</sup>C interface enabled). (1) Write C0h to the S10 register. The I<sup>2</sup>C interface enters the stop condition standby state and the SDAMM pin is driven low. (2) Write dummy data to the S00 register. A stop condition is generated. The stop condition generation timing depends on the modes - standard clock mode or fast-mode. Figure 25.8 shows the Stop Condition Generation Timing. See Table 25.13 "Setup/Hold Time for Generating a Start/Stop Condition" for setup/hold time. Figure 25.8 Stop Condition Generation Timing Do not write to the S10 register or S00 register until the BB bit in the S10 register becomes 0 (bus free) after the instructions to generate a stop condition (refer to above (2)) are executed. If the SCLMM pin input signal becomes low until the BB bit in the S10 register becomes 0 (bus free) from the instruction to generate a stop condition is executed and the SCLMM pin becomes high-level, the internal SCL output becomes low. In this case, perform one of the steps below to stop the low signal output from the SCLMM pin (release the SCLMM pin). - Generate a stop condition (perform steps (1) and (2) above). - Set the ES0 bit in the S1D0 register to 0 (I2C interface disabled). - Write 1 to the IHR bit (I2C interface reset). # 25.3.4 Generating a Restart Condition Use the following procedure to generate a restart condition when 1-byte data is transmitted/received. - (1) Write E0h to the S10 register. (Start condition standby state. The SDAMM pin released.) - (2) Wait until the SDAMM pin level becomes high. - (3) Write a slave address to the S00 register (a start condition trigger is generated) Figure 25.9 shows the Restart Condition Generation Timing. Figure 25.9 Restart Condition Generation Timing # 25.3.5 Start Condition Overlap Protect The I<sup>2</sup>C interface generates a start condition by setting registers S10 and S00 by a program. The bus system must be free before setting these registers. Check whether the bus is free with the BB bit in the S10 register by a program before setting the registers. However, even after confirming that the bus is free, other master devices may generate a start condition before setting registers S10 and S00. In this case, when the I<sup>2</sup>C interface detects a start condition, the BB bit becomes 1 (bus busy) and the start condition overlap protect function is activated. The start condition overlap protect function operates as follows: - The multi-master I<sup>2</sup>C-bus interface does not enter start condition standby state even if the S10 register is set to E0h. - If the I<sup>2</sup>C interface is in a start condition standby state, exit the state. - A start condition trigger is not generated even if a data is written to the S00 register by program. - Bits MST and TRX in the S10 register become 0 (slave receive mode). - The AL bit in the S10 register becomes 1 (arbitration lost detected). Figure 25.10 shows the Start Condition Overlap Protect Operation. Figure 25.10 Start Condition Overlap Protect Operation The start condition overlap protect is enabled from the falling edge of SDAMM (start condition) to the completion of the slave address receive. If data is written to registers S10 and S00 during that period, the above operation is performed. Figure 25.11 shows the Start Condition Overlap Protect Function Enable Period. Figure 25.11 Start Condition Overlap Protect Function Enable Period #### 25.3.6 Arbitration Lost When all of the conditions below are met, the SDAMM pin signal level becomes low by an external device and the I<sup>2</sup>C interface determines that it has lost arbitration. - (a) Transmit/receive (one of the following) - Slave address transmit (not an ACK clock) in master transmit mode or master receive mode - Data transmit (not an ACK clock) in master transmit mode - Start condition generated in master transmit mode or master receive mode - Stop condition generated in master transmit mode or master receive mode - (b) Internal SDA output: High - (c) SDAMM pin level: Low (sampling at the rising edge of the clock of SCLMM pin.) Figure 25.12 shows Operation Example When Arbitration Lost is Detected. Figure 25.12 Operation Example When Arbitration Lost is Detected When arbitration lost is detected: - The AL bit in the S10 register becomes 1 (arbitration lost detected) - Internal SDA output becomes high. (SDAMM released) - The I2C interface enters the slave receive mode The TRX bit in the S10 register is 0 (receive mode). The MST bit in the S10 register is 0 (slave mode). In order to set the AL bit to 0 again after arbitration lost is detected, set a value to the S00 register. When arbitration lost is detected during slave address transmission, the I<sup>2</sup>C interface automatically enters slave receive mode and receives the slave address sent from another master. When the ALS bit in the S1D0 register is 0 (addressing format), the slave address comparison result is determined by reading bits ADR0 and AAS in the S10 register. When arbitration lost is detected during data transmission, the I<sup>2</sup>C interface automatically enters slave receive mode. Also, when arbitration lost is detected, the TRX bit becomes 0 (receive mode) even when the bit after the slave address is 1 (read). Therefore, read the S00 register after arbitration lost is detected. When bit 0 in the S00 register is 1, write 4Fh (slave transmit mode) to the S10 register and execute slave transmission. # 25.3.7 Detecting Start/Stop Conditions Figure 25.13 shows Start Condition Detection, Figure 25.14 shows Stop Condition Detection, and Table 25.14 lists Conditions to Detect Start/Stop Condition. A start/stop condition can be detected only when the start/stop condition detect parameters are selected by setting bits SSC4 to SSC0 in the S2D0 register, and the signals input to pins SCLMM and SDAMM meet all three conditions (SCLMM release time, setup time, and hold time) listed in Table 25.14. The BB bit in the S10 register becomes 1 when a start condition is detected, and becomes 0 when a stop condition is detected. The set timing and reset timing of the BB bit depends on whether the mode is standard mode or fast-mode. Refer to the BB bit set/reset times in Table 25.15. Table 25.15 lists the Recommended Values of Bits SSC4 to SSC0 in Standard Clock Mode. Figure 25.13 Start Condition Detection Figure 25.14 Stop Condition Detection Table 25.14 Conditions to Detect Start/Stop Condition | | Standard Clock Mode | Fast-Mode | |-------------------------------------|--------------------------------------|------------| | SCLMM open time | SSC value + 1 cycle | 4 cycles | | Setup time | SSC value + 1 cycle | 2 cycles | | Hold time | SSC value cycles | 2 cycles | | BB bit<br>setting/resetting<br>time | $\frac{SSC\;value-1}{2} + 2\;cycles$ | 3.5 cycles | Unit: Number of fVIIC cycles SSC value: Value of bits SSC4 to SSC0 in the S2D0 register Table 25.15 Recommended Values of Bits SSC4 to SSC0 in Standard Clock Mode | | SSC Value | Start/Sto | BB Bit | | | |---------------------|-----------|-----------------|--------------|--------------|---------------------------| | fVIIC (recommended) | | SCLMM open time | Setup time | Hold time | Setting/Resetting<br>Time | | 5 MHz | 11110b | 6.2 μs (31) | 3.2 μs (16) | 3.0 μs (15) | 3.3 μs (16.5) | | 4 MHz | 11010b | 6.75 μs (27) | 3.5 μs (14) | 3.25 µs (13) | 3.625 μs (14.5) | | 4 1011 12 | 11000b | 6.25 μs (25) | 3.25 μs (13) | 3.0 μs (12) | 3.375 μs (13.5) | | 2 MHz | 01100b | 6.5 μs (13) | 3.5 μs (7) | 3.0 μs (6) | 3.75 μs (7.5) | | 2 1011 12 | 01010b | 5.5 μs (11) | 3.0 μs (6) | 2.5 μs (5) | 3.25 μs (6.5) | | 1 MHz | 00100b | 5.0 μs (5) | 3.0 μs (3) | 2.0 μs (2) | 3.5 µs (3.5) | SSC value: Value of bits SSC4 to SSC0 in the S2D0 register <sup>():</sup> Number of fVIIC cycles # 25.3.8 Operation after Transmitting/Receiving a Slave Address or Data After a slave address or 1-byte data has been transmitted/received, the PIN bit in the S10 register becomes 0 (interrupt requested) at the falling edge of the ACK clock. The IR bit in the IICIC register becomes 1 (interrupt requested) at the same time. The value in the S10 register or other register changes depending on the state of the transmit/receive data, and the level of pins SCLMM and SDAMM. Figure 25.15 shows Operation When Transmitted/Received a Slave Address or Data. Figure 25.15 Operation When Transmitted/Received a Slave Address or Data #### 25.3.9 Timeout Detection When the SCL clock is stopped during transmission/reception, each device stops operating, keeping the communication state. To avoid this, the I<sup>2</sup>C interface incorporates a function to detect timeouts and generate an I<sup>2</sup>C-bus interrupt request when the SCLMM pin is driven high for more than the selected timeout detection period during transmission/reception. Figure 25.16 shows the Timeout Detection Timing. Refer to "TOSEL (Timeout Detection Period Select Bit) (b2)" in 25.2.8 "I2C0 Control Register 2 (S4D0)" for the timeout detection period. Figure 25.16 Timeout Detection Timing A timeout is detected when all of the following conditions are met: - The TOE bit in the S4D0 register is 1 (timeout detection enabled) - The BB bit in the S10 register is 1 (bus busy) - The SCLMM pin is driven high for more than the timeout detect period When a timeout is detected: - The TOF bit in the S4D0 register becomes 1 (timeout detected) - The IR bit in the IICIC register becomes 1 (I<sup>2</sup>C-bus interrupt requested) When the timeout is detected, perform one of the following: - Set the ES0 bit in the S1D0 register to 0 (disabled). - Set the IHR bit in the S1D0 register to 1 (I2C interface reset). # 25.3.10 Data Transmit/Receive Examples The data transmit/receive examples are described in this section. The conditions for the examples are as follows: - Slave address: 7 bits - Data: 8 bits - ACK clock - Standard clock mode, bit rate: 100 kbps (fIIC: 20 MHz; fVIIC: 4 MHz) 20 MHz (fIIC) divided-by-5 = 4 MHz (fVIIC), - 4 MHz (fVIIC) divided-by-8 and further divided-by-5 = 100 kbps (bit rate) - In receive mode, an ACK is returned for received data other than the last data. NACK is returned after the last data is received. - When receiving data, I<sup>2</sup>C-bus interrupt at the eighth clock (just before ACK clock): disabled - Stop condition interrupt: enabled - Timeout detect interrupt: disabled - Set an own slave address to the S0D0 register (registers S0D1 or S0D2 should not be used) When enabling an I<sup>2</sup>C-bus interrupt at the eighth clock (just before ACK clock) during data reception, a receiver can determine whether to generate ACK or NACK after checking the received data each byte. #### 25.3.10.1 Initial Settings Follow the initial setting procedures below for 25.3.10.2 to 25.3.10.5. - (1) Write an own slave address to bits SAD6 to SAD0 in the S0D0 register. - (2) Write 85h to the S20 register (CCR value: 5, standard clock mode, ACK clock presents). - (3) Write 18h to the S4D0 register (fVIIC: fIIC divided-by-5, timeout interrupt disabled). - (4) Write 01h to the S3D0 register (stop condition detect interrupt enabled and I<sup>2</sup>C-bus interrupt at eighth clock is disabled when receiving data). - (5) Write 0Fh to the S10 register (slave receive mode). - (6) Write 98h to the S2D0 register (SSC value: 18h; start/stop condition generation timing: long mode). - (7) Write 08h to the S1D0 register (bit counter: 8, I<sup>2</sup>C interface enabled, addressing format, input level: I<sup>2</sup>C-bus input). If the MCU uses a single-master system and it is a master, start the initial setting procedures from step (2). #### 25.3.10.2 Master Transmission Master transmission is described in this section. The initial settings described in 25.3.10.1 "Initial Settings" are assumed to be completed. Figure 21.17 shows master transmission operation. The following programs (A) to (C) are executed at (A) to (C) in Figure 25.17, respectively. Figure 25.17 Example of Master Transmission - (A) Slave address transmission - (1) The BB bit in the S10 register must be 0 (bus free). - (2) Write E0h to the S10 register (start condition standby). - (3) Write a slave address to the upper 7 bits and set the least significant bit (LSB) to 0 (start condition generated, then slave address transmitted). - (B) Data transmission - (in I<sup>2</sup>C-bus interrupt routine) - (1) Write transmit data to the S00 register (data transmission). - (C) Completion of Master transmission - (in I<sup>2</sup>C-bus interrupt routine) - (1) Write C0h to the S10 register (stop condition standby state) - (2) Write dummy data to the S00 register (stop condition generated). When transmission is completed or ACK is not returned from a slave device (NACK returned), master transmission should be completed as shown in the example above. #### 25.3.10.3 Master Reception Master reception is described in this section. The initial settings described in 25.3.10.1 "Initial Settings" are assumed to be completed. Figure 25.18 shows the operation example of master reception. The following programs (A) to (D) are executed at (A) to (D) in Figure 25.18, respectively. Figure 25.18 Example of Master Reception - (A) Slave address transmission - (1) The BB bit in the S10 register must be 0 (bus free). - (2) Write E0h to the S10 register (start condition standby). - (3) Write a slave address to the upper 7 bits and a set the least significant bit (LSB) to 1. (Start condition generated, then slave address transmitted) - (B) Data reception 1 (after slave address transmission) - (In I<sup>2</sup>C-bus interrupt routine) - (1) Write AFh to the S10 register (master receive mode). - (2) Set the ACKBIT bit in the S20 register to 0 (ACK presents) because the data is not the last one. - (3) Write dummy data to the S00 register - (C) Data reception 2 (data reception) - (In I<sup>2</sup>C-bus interrupt routine) - (1) Read the received data from the S00 register. - (2) Set the ACKBIT bit in the S20 register to 1 (no ACK) because the data is the last one. - (3) Write dummy data to the S00 register. - (D) Completion of master reception - (In I2C-bus interrupt routine) - (1) Read the received data from the S00 register. - (2) Write C0h to the S10 register (stop condition standby state). - (3) Write dummy data to the S00 register (stop condition generated). #### 25.3.10.4 Slave Reception The slave reception is described in this section. The initial settings described in 225.3.10.1 "Initial Settings" are assumed to be completed. Figure 25.19 shows the example of slave reception. The following programs (A) to (C) are executed at (A) to (C) in Figure 25.19, respectively. Figure 25.19 Example of Slave Reception - (A) Slave receive is started. - (In I<sup>2</sup>C-bus interrupt routine) - (1) Check the value of the S10 register. When the TRX bit is 0, the I<sup>2</sup>C interface is in slave receive mode. - (2) Write dummy data to the S00 register. - (B) Data reception 1 - (In I<sup>2</sup>C-bus interrupt routine) - (1) Read the received data from the S00 register. - (2) Set the ACKBIT bit in the S20 register to 0 (ACK presents) because the data is not the last one. - (3) Write dummy data to the S00 register. - (C) Data reception 2 - (In I<sup>2</sup>C-bus interrupt routine) - (1) Read the received data from the S00 register. - (2) Set the ACKBIT bit in the S20 register to 1 (no ACK presents) because the data is the last one. - (3) Write dummy data to the S00 register. #### 25.3.10.5 Slave Transmission Slave transmission is described in this section. The initial settings described in 25.3.10.1 "Initial Settings" are assumed to be completed. Figure 25.20 shows the example of slave transmission. The following programs (A) to (B) are executed at (A) and (B) in Figure 25.20, respectively. When arbitration lost is detected, the TRX bit becomes 0 (receive mode) even when the bit after the slave address is 1 (read). Therefore, after arbitration lost is detected, read the S00 register. When the bit 0 in the S00 register is 1, write 4Fh (slave transmit mode) to the S10 register and execute slave transmission. Figure 25.20 Example of Slave Transmission - (A) Start of slave transmission - (In I<sup>2</sup>C-bus interrupt routine) - (1) Check the value of the S10 register. When the TRX bit is 1, the I<sup>2</sup>C interface is in slave transmit mode. - (2) Write transmit data to the S00 register. - (B) Data transmission - (In I<sup>2</sup>C-bus interrupt routine) - (1) Write transmit data to the S00 register. Write dummy data to the S00 register even if an interrupt occurs at an ACK clock of the last transmit data. After writing to the S00 register, the SCLMM pin is released. # 25.4 Interrupts The I<sup>2</sup>C interface generates interrupt requests. Figure 25.21 shows I<sup>2</sup>C Interface Interrupts, and Table 25.16 lists I<sup>2</sup>C-bus Interrupts. Figure 25.21 I<sup>2</sup>C Interface Interrupts Table 25.16 I<sup>2</sup>C-bus Interrupts | | | Associated E | Bits (Register) | Interrupt | | |--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------|-----------|--| | Interrupt | Interrupt Source | Interrupt | Interrupt | Control | | | | | enabled | request | Register | | | | Completion of data transmit/receive When the ACKCLK bit in the S20 register is 0: Detection of the falling edge of the last clock of transmit/receive data through the SCLMM pin When the ACKCLK bit is 1: Detection of the falling edge of ACK clock through the SCLMM pin | l | | | | | rbt | Data reception (before ACK clock) Detection of the falling edge of the last clock of transmit/receive data through the SCLMM pin | WIT (S3D0) | | IICIC | | | I <sup>2</sup> C-bus Interrupt | Detection of slave address match Received slave address matches bits SAD6 to SAD0 in registers S0D0 to S0D2 in slave receive mode with addressing format (AAS bit in the S10 register = 1) | | PIN (S10) | | | | | Detection of general call General call in slave receive mode with addressing format (ADR0 bit in the S10 register = 1) | _ | | | | | | Completion of receiving slave address in slave receive mode with free data format | | | | | | | Stop condition detected | SIM (S3D0) | SCPIN (S4D0) | | | | | Timeout detected | TOE (S4D0) | TOF (S4D0) | | | | SCL/SDA interrupt | Detection of the falling edge or rising edge of input/output signal for the SCLMM or SDAMM pin | _ | _ | SCLDAIC | | Refer to 14.7 "Interrupt Control". Table 25.17 lists Registers Associated with I<sup>2</sup>C Interface Interrupts. Table 25.17 Registers Associated with I<sup>2</sup>C Interface Interrupts | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------------|---------|-------------| | 007Bh | I2C-bus Interface Interrupt Control<br>Register | IICIC | XXXX X000b | | 007Ch | SCL/SDA Interrupt Control Register | SCLDAIC | XXXX X000b | | 0206h | Interrupt Source Select Register 2 | IFSR2A | 00h | When using the $I^2C$ -bus interface interrupt, set the IFSR22 bit in the IFSR2A register to 1 ( $I^2C$ -bus interrupt). When using the SCL/SDA interrupt, set the IFSR23 bit in the IFSR2A register to 1 (SCL/SDA interrupt). The SCL/SDA interrupt is enabled even in wait mode and stop mode. The IR bit in the SCLDAIC register may become 1 (interrupt requested) when the ES0 bit in the S1D0 register, the SIP bit in the S2D0 register, or the SIS bit in the S2D0 register is changed. Therefore, follow the procedure below to change these bits. Refer to 14.13 "Notes on Interrupts". - (1) Set bits ILVL2 to ILVL0 in the SCLDAIC register to 000b (interrupt disabled). - (2) Set the ES0 bit in the S1D0 register and bits SIP and SIS in the S2D0 register. - (3) Set the IR bit in the SCLDAIC register to 0 (no interrupt request). #### 25.5 Notes on Multi-master I<sup>2</sup>C-bus Interface #### 25.5.1 Limitation on CPU Clock When the CM07 bit in the CM0 register is 1 (CPU clock is a sub clock), do not access the registers listed in Table 25.4 "Registers". Set the CM07 bit to 0 (main clock, PLL clock, or on-chip oscillator clock) to access these registers. #### 25.5.2 Register Access Refer to the notes below when accessing the I<sup>2</sup>C interface control registers. The period from the rising edge of the first clock of the slave address or 1-byte data transmission/reception to the falling edge of an ACK clock is considered to be the transmission/reception period. When the ACKCLK bit is 0 (no ACK clock), the transmission/reception period is from the rising edge of the first clock of the slave address or 1-byte data transmission/reception to the falling edge of the eighth clock. #### 25.5.2.1 S00 Register Do not write to the S00 register during transmission/reception. #### 25.5.2.2 S1D0 Register Do not change bits other than the IHR bit in the S1D0 register during transmission/reception. #### 25.5.2.3 S20 Register Do not change bits other than the ACKBIT bit in the S20 register during transmission/reception. # 25.5.2.4 S3D0 Register - Do not use the bit managing instruction (read-modify-write instruction) to access the S3D0 register. Use the MOV instruction to write to this register. - Rewrite bits ICK1 and ICK0 when the ES0 bit in the S1D0 register is 0 (I<sup>2</sup>C interface disabled). #### 25.5.2.5 S4D0 Register Rewrite bits ICK4 to ICK2 when the ES0 bit in the S1D0 register is 0 (I<sup>2</sup>C interface disabled). #### 25.5.2.6 S10 Register - Do not use the bit managing instruction (read-modify-write instruction) to access the S10 register. Use the MOV instruction to write to this register. - Do not write to the S10 register when bits MST and TRX change their values. Refer to operation examples in 25.3 "Operations" for bits MST and TRX change. #### 25.5.3 Low/High-level Input Voltage and Low-level Output Voltage The low-level input voltage, high-level input voltage, and low-level output voltage differ from the I<sup>2</sup>C-bus specification. Refer to the recommended operating conditions for I/O ports which share the pins with SCL and SDA. I<sup>2</sup>C-bus specification High level input voltage ( $V_{IH}$ ) = min. 0.7 $V_{CC}$ Low level input voltage ( $V_{II}$ ) = max. 0.3 $V_{CC}$ # 26. Consumer Electronics Control (CEC) Function #### 26.1 Introduction The CEC function indicates circuitry which supports the transmission and reception of CEC signals standardized by the High-Definition Multimedia Interface (HDMI). Table 26.1 and Table 26.2 list the CEC Function Specifications, Figure 26.1 shows the CEC Function Block Diagram and Table 26.3 lists the I/O Pin. Table 26.1 CEC Function Specifications (1/2) | Item | Specification | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count sources | fC, timer A0 underflow In either case, set the frequency to 32.768 kHz and the oscillation allowable error to within ±1%. | | Data formats | Start bit: 1 bit Data bit: 8 bits EOM bit: 1 bit ACK bit: 1 bit | | Transmission start condition | Before transmission starts, satisfy the following requirement: • The CTXDEN bit in the CECC3 register = 1 (transmission enabled) | | Reception start condition | Before reception starts, satisfy the following requirements: • The CRXDEN bit in the CECC3 register = 1 (reception enabled) • Start bit detected | | Interrupt request generation timing | A transmit interrupt is generated when: • 8 bits of data have been transmitted. • 10 bits of data have been transmitted. A transmit error interrupt is generated when: • Transmit arbitration lost occurs. • NACK is received during transmission (ACK received during broadcast transmission). A receive interrupt is generated when: • 8 bits of data have been received. • 10 bits of data have been received. • The above receive interrupts can be confined to when matching Destination address or during broadcast. • The start bit has been received. A receive error interrupt is generated when: • A signal outside the tolerated range is received. | | Error detection | Arbitration lost If one of the following conditions occurs during transmission, arbitration lost is detected: • The CEC pin level is low while the pin outputs Hi-Z. • When changing the CEC pin from low output to Hi-Z, the pin level remains low even though it is outside the tolerated range. Transmission error The value of the CCTBA bit in the CCTB2 register matches the value of the CTNACK bit in the CECC2 register. Acceptable range error Low or high period of the data bit is outside the tolerated range. | Table 26.2 CEC Function Specifications (2/2) | Item | Specification | |----------------------|----------------------------------------------------------------------------------------------------| | | Digital filter enabled/disabled | | | Transmission stop selected | | | Transmission stop by receiving ACK or NACK can be selected. | | | Arbitration lost detection conditions | | | One of the following conditions can be selected: | | | When transmitting the start bit and the data bit of Initiator address | | | When transmitting the start bit and all data bits | | | Transmit rising timing selected | | | • Selected from 8 levels, standard value -180 μs to standard value +30 μs | | | Transmit falling timing selected | | | • Start bit: standard value -160 μs to standard value | | | <ul> <li>Data bit: selectable from 4 levels, standard value -310 μs to standard value</li> </ul> | | | Receive edge detection selected | | | One of the following conditions can be selected. | | | Only a falling edge is detected | | | Both falling and rising edges are detected | | SUC | ACK output in receiving process | | ctic | One of the following conditions can be selected. | | Selectable functions | • Inserted by program | | <u>e</u> | Set by the CCRBAO bit of CCRB2 register. | | )tak | Inserted by hardware | | ) <u>e</u> | ACK is output when matching Destination address. | | S | NACK is output when not matching or in Broadcast. | | | Start bit acceptable range | | | • Select ±200μs or ±300μs | | | Data bit acceptable range | | | One of the following conditions can be selected: | | | <ul> <li>Period between a falling edge and a rising edge ±200 μs,</li> </ul> | | | Period between a falling edge and a falling edge ±350 μs | | | • Period between a falling edge and a rising edge ±300 μs, | | | Period between a falling edge and a falling edge ±500 μs | | | Low pulse output when receive error occurs | | | • Whether error low pulse is output or not can be selected when the receive error occurs. | | | Low pulse output wait control when receive error occurs. | | | One of the following conditions can be selected: | | | • Error low pulse is output in synchronization with the rising edge of the CEC input signal if the | | | CEC input signal is low level when the receive error occurs. | | | Error low pulse is output immediately after the error occurs regardless of the CEC input signal | | | state. | Figure 26.1 CEC Function Block Diagram Table 26.3 I/O Pin | Pin Name | I/O | Description | |----------|--------------|----------------------------------------------------| | CEC | Input/Output | CEC input and output (N-channel open drain output) | Note: 1. Set the direction bit of the ports sharing a pin to 0 (input mode). # 26.2 Registers The CEC function's bits and registers are synchronized with the count source. Register values change immediately after being rewritten by a program, while the internal circuit starts operating from the next count source timing. Table 26.4 Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------------------------|---------|-------------| | 0350h | CEC Function Control Register 1 | CECC1 | XXXX X000b | | 0351h | CEC Function Control Register 2 | CECC2 | 00h | | 0352h | CEC Function Control Register 3 | CECC3 | XXXX 0000b | | 0353h | CEC Function Control Register 4 | CECC4 | 00h | | 0354h | CEC Flag Register | CECFLG | 00h | | 0355h | CEC Interrupt Source Select Register | CISEL | 00h | | 0356h | CEC Transmit Buffer Register 1 | CCTB1 | 00h | | 0357h | CEC Transmit Buffer Register 2 | CCTB2 | XXXX XX00b | | 0358h | CEC Receive Buffer Register 1 | CCRB1 | 00h | | 0359h | CEC Receive Buffer Register 2 | CCRB2 | XXXX X000b | | 035Ah | CEC Receive Follower Address Set Register 1 | CRADRI1 | 00h | | 035Bh | CEC Receive Follower Address Set Register 2 | CRADRI2 | 00h | | 0366h | Port Control Register | PCR | 0000 0XX0b | # 26.2.1 CEC Function Control Register 1 (CECC1) # CECEN (CEC enable bit) (b0) Set the CECEN bit to 1 (enabled) when the count source is selected by using bits CCLK1 to CCLK0 and the count source is stable. When the CECEN bit is set to 0 (disabled), the circuit of the CEC function is reset. # CCLK1 to CCLK0 (Clock source select bit) (b2-b1) Change the clock source when the CECEN bit is set 0 (CEC disabled). #### CEC Function Control Register 2 b7 b6 b5 b4 b3 b2 b1 b0 Symbol Address Reset Value CECC2 0351h 00h Bit Symbol RW Bit Name Function 0: Detects falling edge acceptable Receive edge detection CRRNG RW 1: Detects both edges acceptable select bit range Transmit NACK (ACK) end 0: End with ACK **CTNACK** RW 1: End with NACK Transmit NACK (ACK) end 0: Continue transmitting **CTACKEN** RW 1: End with NACK/ACK control bit 0: Inserted by program CRACK RW ACK output control bit 1: Inserted by hardware 0: When transmitting start bit and Arbitration lost detect Initiator address **CTABTS** RW condition select bit 1: When transmitting start bit and all data bits 0: Filter disabled **CFIL** RW Digital filter enable bit 1: Filter enabled 0: ±200 µs Start bit acceptable range **CSTRRNG** RW select bit 1: ±300 µs 0: Period between falling edge and rising edge ± 200 µs Period between falling edge and Data bit acceptable range falling edge ± 350 µs **CDATRNG** RW 1: Period between falling edge and select bit rising edge ± 300 µs Period between falling edge and falling edge ± 500 µs #### 26.2.2 CEC Function Control Register 2 (CECC2) Do not write to the CECC2 register while transmitting/receiving. # CTNACK (Transmit NACK (ACK) end select bit) (b1) This bit is enabled when the CTACKEN bit is set to 1 (end with NACK/ACK). #### CTACKEN (Transmit NACK (ACK) end control bit) (b2) Select the end condition by using the CTNACK bit when the CTACKEN bit is 1 (end with NACK/ACK). #### CRACK (ACK output control bit) (b3) When the CRACK bit is set 0 (inserted by program), the value of the CCRBAO bit in the CCRB2 register is output as ACK data. When the CRACK bit is set to 1 (inserted by hardware), ACK is output if the received Destination address matches the address selected by the CRADRI1 or CRADRI2 register. Table 26.5 lists ACK Output When Inserted by Hardware. Table 26.5 ACK Output When Inserted by Hardware | Destination Address | | | |------------------------------|-------------------------------------------------------------------|------------| | Received Destination address | Address selected by the CRADRI1 or CRADRI2 register (own address) | ACK Output | | Direct | Matches the received Destination address | ACK | | (0000b to 1110b) | Does not match the received Destination address | NACK | | Proodoost (1111h) | 1111b (matches the received Destination address) | ACK | | Broadcast (1111b) | 0000b to 1110b | NACK | CTABTS (Arbitration lost detect condition select bit) (b4) Refer to 26.3.6.2 "Arbitration Lost Detection". #### CEC Function Control Register 3 b7 b6 b5 b4 b3 b2 b1 b0 Address Reset Value Symbol CECC3 XXXX 0000b 0352h Bit Symbol **Function** RW Bit Name 0: Disabled **CTXDEN** RW Transmit enable bit 1: Enabled 0: Disabled **CRXDEN** RW Receive enable bit 1: Enabled The CREGFLG bit in the CECC4 Receive edge detect flag **CREGCLR** RW register becomes 0 by setting 1 to clear bit this bit 0: EOM enabled CEOMI EOM disable bit RW 1: EOM disabled (EOM ignored) No register bits. If necessary, set to 0. Read as undefined value (b7-b4) # 26.2.3 CEC Function Control Register 3 (CECC3) # CTXDEN (Transmit enable bit) (b0) CRXDEN (Receive enable bit) (b1) When changing the values of these bits, transmission/reception is enabled or disabled after one or more cycles of the clock source elapses. When setting the CTXDEN bit to 0 while transmitting/receiving, transmitting is disabled after ACK completion. In the same way, when setting the CRXDEN bit to 0 while transmitting/receiving, reception is disabled after ACK completion. #### CREGCLR (Receive edge detect flag clear bit) (b2) The CREGFLG bit in the CECC4 register becomes 0 by setting the CREGCLR bit to 1 when CEC input is Hi-Z. The CREGCLR bit retains the value written to it. In order set the CREGFLG bit to 0 again by setting the CREGCLR bit to 1, first set the CREGCLR bit to 0, then set it to 1. When setting the CREGCLR bit to 1 while CEC input is low, the CREGFLG bit becomes 0. If the CREGCLR bit is set to 0 after that, the CREGFLG bit becomes 1. Figure 26.2 shows the Operation of Bits CREGFLG and CREGCLR. Figure 26.2 Operation of Bits CREGFLG and CREGCLR # CEOMI (EOM disable bit) (b3) Set the CEOMI bit to select whether to continue or stop the operation when the EOM bit is 1. Table 26.6 lists Operation When the EOM Bit is 1. Do not write to the CEOMI bit while transmitting/receiving. When the CEOMI bit is 1 (EOM disabled), data transmission continues even after the EOM bit is set to 1 and transmitted. To stop transmitting, set the CTXDEN bit in the CECC3 register to 0 (transmission disabled). Table 26.6 Operation When the EOM Bit is 1 | CEOMI Bit | Reception | Transmission | |-----------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------| | 0 | When the EOM bit is 1 and is received, subsequent data reception is ignored. (wait for start bit) | When the EOM bit is 1 and is transmitted, subsequent data is not transmitted. | | 1 | When the EOM bit is 1 and is received, ACK/NACK is returned for subsequent data reception. | When the EOM bit is 1 and is transmitted, data transmission continues. | #### **CEC Function Control Register 4** b7 b6 b5 b4 b3 b2 b1 b0 Symbol Address Reset Value CECC4 0353h 00h Bit Symbol Bit Name Function RW b2 b1 b0 CRISE0 0 0 0: Standard value RW 1: Standard value - 30 μs 1 0: Standard value - 60 μs 0 Rising timing select bit CRISE1 0 1 1: Standard value - 90 μs RW 0 0: Standard value - 120 μs 1 1 0 1: Standard value - 150 μs CRISE2 0: Standard value - 180 μs RW 1 1 1 1: Standard value + 30 µs 1 Error low pulse output 0: Disabled CABTEN RW enabled bit 1: Enabled CFALL0 RW Falling timing select bit Refer to the following. CFALL1 RW 0: Not detected **CREGFLG** RO Receive edge detect flag 1: Detected 0: Low pulse output regardless of Error low pulse output wait CEC signal state **CABTWEN** RW 1: Low pulse output at the rising edge control bit of the CEC signal #### 26.2.4 CEC Function Control Register 4 (CECC4) #### CRISE2-CRISE0 (Rising timing select bit) (b2-b0) The rising timing of the signal in transmission is selected. The rising timing is common to the start bit and data bit. Do not write to bits CRISE2 to CRISE0 while transmitting/receiving. #### CABTEN (Error low pulse output enable bit) (b3) When the CRXDEN bit is 0 (receive disabled), if the CABTEN bit is set to 1 (low pulse output enabled in receive error) and then the CRXDEN bit is set to 1 (receive enabled), a 3.6 ms low-level pulse is output if the data bit during reception exceeds the tolerated range. Output timing is selected by setting the CABTWEN bit. After setting the CRXDEN bit to 1 (receive enabled) and then setting the CABTEN bit to 1 while not receiving, a low pulse is output when writing to the CABTEN bit. After setting the CRXDEN bit to 1 (receive enabled) and then setting the CABTEN bit to 1 if the receiving data bit exceeds the tolerated range, a low pulse is output. # CFALL1-CFALL0 (Falling timing select bit) (b5-b4) The falling timing of the signal in transmission is specified. Do not write to bits CFALL1 to CFALL0 while transmitting/receiving. Table 26.7 Falling Timing of Signal in Transmission | Bits CFALL1 to CFALL0 | Falling Timing | | |-----------------------|-------------------------|-------------------------| | BIS CFALLT IO CFALLO | Start bit | Data bit | | 00b | Standard value | Standard value | | 01b | Standard value - 40 μs | Standard value - 190 μs | | 10b | Standard value - 100 μs | Standard value - 250 μs | | 11b | Standard value - 160 μs | Standard value - 310 μs | ## CREGFLG (Receive edge detect flag) (b6) See Figure 26.2 "Operation of Bits CREGFLG and CREGCLR". Condition to become 0: • Set the CREGCLR bit in the CECC3 register to 1. Condition to become 1: • Detect a low level input to CEC while the CREGCLR bit is 0. #### CABTWEN (Error low pulse output wait control bit) (b7) This bit is enabled when the CABTEN bit is 1 (low pulse output enabled in reception error). If a receive error occurs when the CABTWEN bit is set to 1 (low pulse output at rising edge of the CEC signal) and the CEC input is low, a 3.6 ms low-level pulse is output from the rising edge of the CEC signal after the error. If there is no rising edge of the CEC signal within 3.6 ms from the reception error, a low-level pulse is not output because it is assumed that another device output an error low-level pulse. Do not write to the CABTWEN bit while transmitting/receiving. # 26.2.5 CEC Flag Register (CECFLG) | CEC Flag Register | | | | | |-------------------------|------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------|----| | b7 b6 b5 b4 b3 b2 b1 b0 | Symbol<br>CECFLG | Address<br>0354h | Reset Value<br>00h | | | | Bit Symbol | Bit Name | Function | RW | | | CRFLG | Receive status flag | 0: Waiting<br>1: Receiving | RO | | | CTFLG | Transmit status flag | 0: Waiting<br>1: Receiving | RO | | | CRERRFLG | Receive error detect flag | O: Not detected 1: Error detected (out of the determinable range) | RO | | | CTABTFLG | Arbitration lost detect flag | 0: Not detected<br>1: Detected | RO | | | CTNACKFLG | Transmit NACK detect flag | 0: Not detected 1: NACK detected (when transmitting a directly addressed message) ACK detected (when broadcasting) | RO | | | CRD8FLG | 8th bit of data receive flag | 0: 8th bit not received or<br>10th bit received<br>1: 8th bit received | RO | | | CTD8FLG | 8th bit of data transmit flag | 0: 8th bit not transmitted or 10th bit transmitted 1: The 8th bit transmitted | RO | | | CRSTFLG | Start bit detection | Start bit not detected or 8th bit received. Start bit detected | RO | # CRFLG (Receive status flag) (b0) Condition to become 0. Waiting Condition to become 1. - Receiving - Error low pulse is being output when the CABTEN bit in the CECC4 register is set to 1 (error low pulse output enabled). # CRERRFLG (Receive error detect flag) (b2) Condition to become 0. • Set the CRXDEN bit in the CECC3 to 0 (receive disabled). Condition to become 1. • Low or high period of the data bit is out of the acceptable range #### CTABTFLG (Arbitration lost detect flag) (b3) Condition to become 0. • Set the CTXDEN bit in the CECC3 register to 0 (transmit disabled). # CTNACKFLG (Transmit NACK detect flag) (b4) Condition to become 0. • Set the CTXDEN bit in the CECC3 register to 0 (transmit disabled). # 26.2.6 CEC Interrupt Source Select Register (CISEL) ## 26.2.7 CEC Transmit Buffer Register 1 (CCTB1) Rewrite the CCTB1 register when the CTXDEN bit in the CECC3 register is 0 (transmit disabled), or the CTXDEN bit is 1 and the CTD8FLG in the CECFLG register is 1 (while bits EOM and ACK are being transmitted after the eighth bit has been transmitted). Do not rewrite the CCTB1 register when the CTXDEN bit is 1 and the CTD8FLG bit is 0 (while the first bit to eighth bit are being transmitted). ## 26.2.8 CEC Transmit Buffer Register 2 (CCTB2) ## CCTBE (Transmit data EOM bit) (b0) Rewrite the CCTBE bit when the CTXDEN bit in the CECC3 register is 0 (transmit disabled), or the CTXDEN bit is 1 and the CTD8FLG in the CECFLG register is 1 (while bits EOM and ACK are being transmitted after the eighth bit has been transmitted). The information written to this bit is output after the next data transmission. Do not rewrite the CCTBE bit when the CTXDEN bit is 1 and the CTD8FLG bit is 0 (while the first bit to eighth bit are being transmitted). ## CCTBA (Transmit data ACK input bit) (b1) Read the CCTBA bit after transmitting the tenth bit (ACK bit) (the CTD8FLG bit in the CECFLG register changes from 1 to 0). ## 26.2.9 CEC Receive Buffer Register 1 (CCRB1) Read the CCRB1 register after receiving the eighth bit (the CRD8FLG bit in the CECFLG register changes from 0 to 1). ## 26.2.10 CEC Receive Buffer Register 2 (CCRB2) ## CCRBE (Receive data EOM bit) (b0) Read the CCRBE bit after receiving the tenth bit (ACK bit) (the CRD8FLG bit in the CECFL register changes from 1 to 0). ## CCRBAO (Receive data ACK output bit) (b1) The CCRBAO bit is enabled when the CRACK bit in the CECC2 register is 0 (inserted by program). Rewrite the CCRBAO bit when the CRXDEN bit in the CECC3 register is 0 (receive disabled), or the CRXDEN bit is 1 and the start bit to EOM bit are being received. Do not rewrite the CCRBAO bit when the ACK bit is being transmitted. ## CCRBAI (Receive data ACK input bit) (b2) Read the CCRBAI bit after the tenth bit (ACK bit) is received (the CRD8FLG bit in the CECFL register changes from 1 to 0). # 26.2.11 CEC Receive Follower Address Set Register 1 (CRADRI1), CEC Receive Follower Address Set Register 2 (CRADRI2) Select the receive follower address (own address). ACK is returned by setting the CRADRI27 bit to 1 (selects 1111b) when the Follower address is 1111b (Broadcast) and the CRACK bit in the CECC2 register is 1 (ACK output in reception is inserted by hardware). When the received Destination address matches the address selected by the CRADRI1 or CRADRI2 register, it may be described as Destination address match in this chapter. # 26.2.12 Port Control Register (PCR) PCR4 (CEC output enable bit) (b4) To use the CEC function, set the PCR4 bit to 1 (CEC output enabled). ## 26.3 Operations ## 26.3.1 Standard Value and I/O Timing CEC transmission/reception is based on the count source cycle. When outputting, an output waveform is based on the count source cycle which is closest to the CEC standard value. When inputting, an input waveform is sampled in the count source cycle. Also, the input/output is practically performed based on the count source cycle closest to the acceptable range or output timing. ## 26.3.2 Count Source Select fC or timer A0 underflow by bits CCLK1 to CCLK0 in the CECC1 register. In either case, the clock frequency should be 32.768 kHz and oscillation allowable error should be within ±1%. Set the CECEN bit in the CECC1 register to 1 (CEC enabled), after the count source is selected by bits CCLK1 and CCLK0 and when the count source is stable. To use fC, set the PM25 bit in the PM2 register to 1 (peripheral clock fC provided). Refer to 8. "Clock Generator" for details. When the timer A0 underflow is used as the count source, each time timer A0 underflows the internal signal of the timer A0 is inverted. Since this internal signal is the count source, two cycles of timer A0 underflows are one cycle of the count source. Figure 26.3 shows the Count Source When Timer A0 Underflow Selected. Use timer A0 without timer mode and gate function. Refer to 17. "Timer A" for details. Figure 26.3 Count Source When Timer A0 Underflow Selected ## 26.3.3 CEC Input/Output The CEC input and output share pins with the I/O port and NMI input. To use CEC input and output, set bits as follows: - Set the PM24 bit in the PM2 register to 0 (NMI interrupt disabled) - Set the PCR4 bit in the PCR register to 1 (CEC output enabled) - Set the PD8\_5 bit in the PD8 register to 0 (input mode) Also, the CEC input has a digital filter. (refer to 26.3.4 "Digital Filter"). # 26.3.4 Digital Filter Input to the CEC pin goes into the internal circuit in synchronization with the count source. If the same level signal is input to the CEC pin twice in a row that level is transferred to the internal circuit, when the CFIL bit in the CECC2 register is 1 (digital filter enable). Figure 26.4 shows Digital Filter. Figure 26.4 Digital Filter ## 26.3.5 Reception ## 26.3.5.1 Start Bit Detection The detect timing of the start bit and data bit is selected by setting the CRRNG bit in the CEC2 register. Select the start bit acceptable range by setting the CSTRRNG bit in the CECC2 register. Figure 26.5 shows Start Bit Acceptable Range. When the start bit within the acceptable range is detected, the CRSTFLG bit in the CECFLG register becomes 1 (start bit detected). Figure 26.5 Start Bit Acceptable Range #### 26.3.5.2 Data Bit Detection The detect timing of the start bit and data bit (other than the start bit) is selected by setting the CRRNG bit in the CECC2 register. Select the data bit acceptable range by setting the CDATRNG bit in the CECC2 register. Figure 26.6 shows Data Bit Acceptable Range (CRRNG Bit = 0). When the CRRNG bit is 0 (detects falling edge acceptable range), the input data is determined as data 1 if the rising edge is detected before 1.05 ms and the input data is determined as data 0 if the rising edge is detected after 1.05 ms. Figure 26.6 Data Bit Acceptable Range (CRRNG Bit = 0) Figure 26.7 Data Bit Acceptable Range (CRRNG Bit = 1) ## 26.3.5.3 Error Determination If the data bit is out of the acceptable range, a receive error occurs. The operations when the receive error occurs are as follows: - The CRERRFLG bit in the CECFLG register becomes 1 (receive error) - A 3.6 ms low-level pulse is output when the CABTEN bit in the CECC4 register is 1 (low pulse output enabled in receive error). However, this pulse is not output if an error occurs in the start bit. Low pulse output timing can be selected by setting the CABTWEN bit in the CECC4 register when the CABTEN bit is 1 (low pulse output enabled in receive error). Figure 26.8 Low Pulse Output in Receive Error Figure 26.9 Low Pulse Output Timing in Receive Error ## **26.3.5.4** ACK Bit Output The output value of the tenth bit (ACK bit) can be selected. When the CRACK bit in the CECC2 register is 0 (inserted by program), the value of the CCRBAO bit in the CCRB2 register is output as ACK data. When the CRACK bit is 1 (inserted by hardware), ACK is output when the received Destination address matches the address selected by the CRADRI1 or CRADRI2 register (own address). Table 26.8 lists ACK Output. Table 26.8 ACK Output | CRACK | CCRBAO | Destination Address | | | | |-------|--------|----------------------|----------------------------------------------|----------------------------------------|------| | Bit | Bit | Received destination | Address selected by the CRADRI1 or | ACK<br>Output | | | Dit | ы | address | CRADRI2 register (own address) | Output | | | 0 | 0 - | | - | ACK | | | U | | | - | NACK | | | | | Direct | Matches received Destination address | ACK | | | 1 | - | | (0000b to 1110b) | Not match received Destination address | NACK | | ı | | Broadcast | 1111b (matches received Destination address) | ACK | | | | | (1111b) | 0000b to 1110b | NACK | | ## 26.3.5.5 Reception Examples Figure 26.10 shows a Reception Example and Figure 26.11 shows a Reception Example (Change from Error Low Pulse Output Disabled to Enabled When an Error Occurs). When a receive error occurs, the CRERRFLG bit in the CECFLG register becomes 1 (receive error). If a reception ends due to the error during reception, set the CRXDEN bit in the CECC3 register to 0 (receive disabled). When the CRXDEN bit is set to 0, the CRERRFLG bit becomes 0. To restart reception, set the CRXDEN bit to 0 (reception disabled), and then set the CRXDEN bit to 1 (reception enabled) after waiting for one or more cycles of the count source. Figure 26.10 Reception Example Figure 26.11 Reception Example (Change from Error Low Pulse Output Disabled to Enabled When an Error Occurs) #### 26.3.6 Transmission ## 26.3.6.1 Transmit Signal Timing Select Rising or falling timing of the transmit signal can be selected. The rising timing of the transmit signal is selected by bits CRISE2 to CRISE0 in the CECC4 register. Figure 26.12 shows Rising Timing of Transmit Signal. Figure 26.12 Rising Timing of Transmit Signal The falling timing of the transmit signal is selected by bits CFALL1 to CFALL0 in the CECC4 register. Figure 26.13 shows Falling Timing of Transmit Signal. Figure 26.13 Falling Timing of Transmit Signal #### 26.3.6.2 Arbitration Lost Detection When data is transmitted, an arbitration lost is detected in the following cases: - The CEC output changes from Hi-Z to low by the external source. - When changing the CEC pin from low output to Hi-Z, the pin level remains low even though it is outside the tolerated range. A range for detecting the arbitration lost is selected by the CTABTS bit in the CECC2 register. Figure 26.14 shows Arbitration Lost Detectable Range. When the arbitration lost is detected, the CTABTFLG bit in the CECFLG register becomes 1 (arbitration lost detected). Figure 26.14 Arbitration Lost Detectable Range ## 26.3.6.3 Transmission Example Figure 26.15 shows a Transmission Example, Figure 26.16 shows a Transmission Example (When NACK Received) and Figure 26.17 shows a Transmission Example (When an Arbitration Lost Detected). Set the CTXDEN bit in the CECC3 register to 0 (transmit disabled) after the transmission. To continue the transmission, set the CTXDEN bit to 0 (transmit disabled) after sending one frame (one header block and one or more data blocks), and wait for one or more cycles of the count source before setting the CTXDEN bit to 1 (transmit enabled). Figure 26.15 Transmission Example Figure 26.16 Transmission Example (When NACK Received) Figure 26.17 Transmission Example (When an Arbitration Lost Detected) ## 26.4 Interrupts The CEC function has CEC1 interrupt and CEC2 interrupt. Table 26.9 and Table 26.10 list CEC Interrupt Sources. These sources generate a CEC1 interrupt or CEC2 interrupt request. When the CRISELM bit in the CISEL register is 1, the eighth/tenth bit receive interrupt request is generated if the received Destination address is either one of the following case: - Matches the address selected by the CRADRI1 or CRADRI2 register. - Broadcast (1111b) Figure 26.18 shows CEC Function Interrupt. Table 26.9 CEC1 Interrupt Sources | Туре | Source | Interrupt Request Timing | Interrupt Enable<br>Bit | |----------------|-------------------------------------------------|--------------------------------------------|-------------------------| | Transmit | Eighth bit transmitted | When the CTD8FLG bit changes from 0 to 1 | CTISEL0 | | interrupt | Tenth bit transmitted | When the CTD8FLG bit changes from 1 to 0 | CTISEL1 | | Transmit error | Arbitration lost | When the CTABTFLG bit changes from 0 to 1 | CTISEL2 | | interrupt | NACK received (Direct) ACK received (Broadcast) | When the CTNACKFLG bit changes from 0 to 1 | CHISELZ | CTD8FLG, CTABTFLG, CTNACKFLG: Bits in the CECFLG register CTISEL0, CTISEL1, CTISEL2: Bits in the CISEL register Table 26.10 CEC2 Interrupt Sources | Туре | Source | Interrupt Request Timing | Interrupt Enable<br>Bit | |-------------------------|-----------------------------|----------------------------------------------|-------------------------| | | Eighth bit received | When the CRD8FLG bit changes from 0 to 1 (1) | CRISEL0 | | Receive interrupt | Tenth hit received | When the CRD8FLG bit changes from 1 to 0 (1) | CRISEL1 | | | Start bit detected | When the CRSTFLG bit changes from 0 to 1 | CRISELS | | Receive error interrupt | Nonstandard signal received | When the CRERRFLG bit changes from 0 to 1 | CRISEL2 | CRD8FLG, CRSTFLG, CRERRFLG: Bits in the CECFLG register CRISEL0, CRISEL1, CRISELS, CRISEL2: Bits in the CISEL register Note: 1. The CRISELM bit in the CISEL register affects the interrupt. Figure 26.18 CEC Function Interrupt For the interrupt request timing, refer to the operation examples. For interrupt control, refer to 14.7 "Interrupt Control". Table 26.11 lists the CEC Function Interrupt-Associated Registers. Table 26.11 CEC Function Interrupt-Associated Registers | Address | Register | Symbol | Reset Value | |---------|------------------------------------|--------|-------------| | 006Bh | CEC1 Interrupt Control Register | CEC1IC | XXXX X000b | | 006Ch | CEC2 Interrupt Control Register | CEC2IC | XXXX X000b | | 0205h | Interrupt Source Select Register 3 | IFSR3A | 00h | The CEC function shares the interrupt vectors and the interrupt control registers with other peripheral functions. To use CEC1 interrupt, set the IFSR33 bit in the IFSR3A register to 1 (CEC1). To use CEC2 interrupt, set the IFSR34 bit in the IFSR3A register to 1 (CEC2). #### 26.5 Notes on CEC ## 26.5.1 Registers and Bit Operation The registers and bits of the CEC function are synchronized with the count source. Therefore, the internal circuit starts to operate from the next count source timing, while the values of the register are changed immediately after rewriting the register. When rewriting the same bit successively or reading the bit changed under the influence of another bit, wait for one or more cycles of the count source. Example: when rewriting the same bit successively - (1) Change the bit to 0. - (2) Wait for one or more cycles of the count source. - (3) Change the same bit to 1. Example: when reading the bit rewritten under the influence of another bit (after reception is disabled, to ensure that the CRERRFLG bit in the CECFLG register becomes 0 (no reception error detected)). - (1) Set the CRXDEN bit in the CECC3 register to 0 (reception disabled) - (2) Wait for one or more cycles of the count source. - (3) Read the CRERRFLG bit in the CECFLG register. ## 26.5.2 VIH of the CEC pin VIH of the CEC pin does not meet the CEC standard value. Apply VIH to the CEC pin or use the CEC external circuit shown in Figure 26.19 "CEC External Circuit" to change the CEC pin input voltage to VIH of the CEC pin or above. Figure 26.19 CEC External Circuit # 27. A/D Converter ## 27.1 Introduction The A/D converter consists of one 10-bit successive approximation A/D converter. Table 27.1 lists the A/D Converter Specifications and Figure 27.1 shows an A/D Converter Block Diagram. Table 27.1 A/D Converter Specifications | Item | Specification | | | | |---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | A/D conversion method | Successive approximation | | | | | Analog input voltage | 0 V to AVCC (VCC1) | | | | | Operating clock φAD | f1, f1 divided by 2, f1 divided by 3, f1 divided by 4, f1 divided by 6, f1 divided by 12 fOCO40M divided by 2, fOCO40M divided by 3, fOCO40M divided by 4, fOCO40M divided by 6, or fOCO40M divided by 12 | | | | | Resolution | 10 bits | | | | | Integral nonlinearity<br>error | AVCC = VREF = 5 V AN0 to AN7, AN0_0 to AN0_7, or AN2_0 to AN2_7 input: ±3 LSB ANEX0 or ANEX1 input: ±3 LSB AVCC = VREF = 3.0 V AN0 to AN7, AN0_0 to AN0_7, or AN2_0 to AN2_7 input: ±3 LSB ANEX0 or ANEX1 input: ±3 LSB | | | | | Operation modes | One-shot mode, repeat mode, single sweep mode, repeat sweep mode 0, repeat sweep mode 1 | | | | | Analog input pins | 8 pins (AN0 to AN7) + 2 pins (ANEX0 and ANEX1) + 8 pins (AN0_0 to AN0_7) + 8 pins (AN2_0 to AN2_7) | | | | | A/D conversion start conditions | Software trigger The ADST bit in the ADCON0 register is set to 1 (A/D conversion start). External trigger (retrigger is enabled) Input to the ADTRG pin changes from high to low after the ADST bit is set to 1 (A/D conversion start). | | | | | Conversion rate per pin | Minimum 43 ¢AD cycles | | | | Figure 27.1 A/D Converter Block Diagram Table 27.2 I/O Ports | Pin Name | I/O | Function | |----------------|-------|---------------| | AN0 to AN7 | Input | Analog input | | ANEX0, ANEX1 | Input | Analog input | | AN0_0 to AN0_7 | Input | Analog input | | AN2_0 to AN2_7 | Input | Analog input | | ADTRG | Input | Trigger input | Note: 1. Set the direction bit of the ports sharing a port to 0 (input mode). ## 27.2 Registers Table 27.3 lists registers associated with A/D converter. Refer to 8.2.6 "Peripheral Clock Stop Register 1 (PCLKSTP1)" for the explanation of the PCLKSTP1 register. Set the CKS3 bit in the ADCON2 register before setting other registers associated with A/D converter excluding the PCR register. However, bits in the ADCON2 register and the CKS3 bit can be set simultaneously. After changing the CKS3 bit, set the registers in the same way again. The PCR register can be set before setting the CKS3 bit. After changing the CKS3 bit, the PCR register does not need to be set again. Table 27.3 Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------------|-------------|-------------| | 0016h | Peripheral Clock Stop Register 1 | PCLKSTP1 | 0XXX XX00b | | 0366h | Port Control Register | PCR | 0000 0XX0b | | 03A2h | Open-Circuit Detection Assist Function Register | AINRST | XX00 XXXXb | | 03C0h | A/D Register 0 | AD0 | XXXX XXXXb | | 03C1h | A/D Register 0 | ADO | 0000 00XXb | | 03C2h | A/D Register 1 | AD1 | XXXX XXXXb | | 03C3h | A/D Register 1 | ADI | 0000 00XXb | | 03C4h | A/D Pagistor 2 | AD2 | XXXX XXXXb | | 03C5h | A/D Register 2 | AD2 | 0000 00XXb | | 03C6h | A/D Register 3 | AD3 | XXXX XXXXb | | 03C7h | A/D Register 5 | | 0000 00XXb | | 03C8h | A/D Register 4 | AD4 | XXXX XXXXb | | 03C9h | A/D Register 4 | | 0000 00XXb | | 03CAh | A/D Register 5 | AD5 | XXXX XXXXb | | 03CBh | No Register 5 | ADS | 0000 00XXb | | 03CCh | A/D Register 6 | AD6 | XXXX XXXXb | | 03CDh | A/D Register 6 | ADO | 0000 00XXb | | 03CEh | A/D Register 7 | AD7 | XXXX XXXXb | | 03CFh | TAD Itegister / | AD <i>I</i> | 0000 00XXb | | 03D4h | A/D Control Register 2 | ADCON2 | 0000 X00Xb | | 03D6h | A/D Control Register 0 | ADCON0 | 0000 0XXXb | | 03D7h | A/D Control Register 1 | ADCON1 | 0000 X000b | # 27.2.1 Port Control Register (PCR) # PCR5 (INT6 input enable bit) (b5) Set the PCR5 bit to 1 (INT6 input disabled) when using the AN2\_4 pin for analog input. ## PCR6 (INT7 input enable bit) (b6) Set the PCR6 bit to 1 (INT7 input disabled) when using AN2\_5 pin for analog input. ## PCR7 (Key input enable bit) (b7) Set the PCR7 bit to 1 (key input disabled) when using pins AN4 to AN7 for analog input. # 27.2.2 Open-Circuit Detection Assist Function Register (AINRST) AINRST1-AINRST0 (Open-circuit detection assist function enable bit) (b5-b4) To enable the A/D open-circuit detection assist function, set the AINRST0 bit or AINRST1 bit to 1, and then set the ADST bit in the ADCON0 register to 1 (A/D conversion) after waiting for one cycle of $\phi$ AD. # 27.2.3 A/D Register i (ADi) (i = 0 to 7) The A/D conversion result is stored in the ADi register corresponding to pins ANi, ANEXi, AN0\_i, and AN2\_i. Read the ADi register in 16-bit units. Table 27.4 lists Analog Pin and A/D Conversion Result Storing Register. Table 27.4 Analog Pin and A/D Conversion Result Storing Register | | Analo | A/D Conversion Result Storing<br>Register | | | |-----|-------|-------------------------------------------|-------|--------------| | AN0 | ANEX0 | AN0_0 | AN2_0 | AD0 register | | AN1 | ANEX1 | AN0_1 | AN2_1 | AD1 register | | AN2 | - | AN0_2 | AN2_2 | AD2 register | | AN3 | - | AN0_3 | AN2_3 | AD3 register | | AN4 | - | AN0_4 | AN2_4 | AD4 register | | AN5 | - | AN0_5 | AN2_5 | AD5 register | | AN6 | _ | AN0_6 | AN2_6 | AD6 register | | AN7 | _ | AN0_7 | AN2_7 | AD7 register | # 27.2.4 A/D Control Register 2 (ADCON2) If the ADCON2 register is rewritten during A/D conversion, the conversion result is undefined. ## ADGSEL1-ADGSEL0 (A/D input group select bit) (b2-b1) Pins AN0\_0 to AN0\_7 are used as analog input pins even if bits PM01 to PM00 in the PM0 register are set to 01b (memory expansion mode) and bits PM05 to PM04 are 11b (multiplexed bus is allocated to the entire $\overline{\text{CS}}$ space). ## CKS3 (fAD select bit) (b7) Set the CKS3 bit while A/D conversion is stopped. Set the CKS3 bit, and then set other A/D converter related registers. Also, after changing the CKS3 bit, set the A/D converter related registers again. Note that bits in the ADCON2 register and the CKS3 bit can be set simultaneously. ## 27.2.5 A/D Control Register 0 (ADCON0) If the ADCON0 register is rewritten during A/D conversion, the conversion result is undefined. ## CH2-CH0 (Analog input pin select bit) (b2-b0) In one-shot and repeat modes, pins AN0\_0 to AN0\_7 and AN2\_0 to AN2\_7 can be used in the same way as pins AN0 to AN7. Use bits ADGSEL1 to ADGSEL0 in the ADCON2 register to select the desired group. These bits are disabled in single sweep mode, repeat sweep mode 0, and repeat sweep mode 1. ## MD1-MD0 (A/D operation mode select bit 0) (b4-b3) A/D operation mode is selected by a combination of bits MD1 to MD0 and the MD2 bit in the ADCON1 register. Table 27.5 lists A/D Operation Mode. Table 27.5 A/D Operation Mode | В | it Setting | | | |-----------------|-----------------|-----|---------------------| | ADCON1 register | ADCON0 register | | A/D Operation Mode | | MD2 | MD1 | MD0 | | | 0 | 0 | 0 | One-shot mode | | 0 | 0 | 1 | Repeat mode | | 0 | 1 | 0 | Single sweep mode | | 0 | 1 | 1 | Repeat sweep mode 0 | | 1 | 1 | 1 | Repeat sweep mode 1 | Only set the combinations listed above. # CKS0 (Frequency select bit 0) (b7) $\phi$ AD frequency is selected by a combination of the CKS0 bit in the ADCON0 register, the CKS1 bit in the ADCON1 register, and bits CKS3 and CKS2 in the ADCON2 register. Select bits CKS2 to CKS0 after setting the CKS3 bit in the ADCON2 register. Note that bits CKS3 and CKS2 can be set simultaneously. Table 27.6 lists $\phi$ AD Frequency. | CKS3 | CKS2 | CKS1 | CKS0 | φAD | | |------|------|------|------|-----------------------------|--| | | 0 | 0 | 0 | fAD(f1) divided by 4 | | | | 0 | 0 | 1 | fAD(f1) divided by 2 | | | | 0 | 1 | 0 | fAD(f1) | | | 0 | 0 | 1 | 1 | | | | 0 | 1 | 0 | 0 | fAD(f1) divided by 12 | | | | 1 | 0 | 1 | fAD(f1) divided by 6 | | | | 1 | 1 | 0 | fAD(f1) divided by 3 | | | | 1 | 1 | 1 | TAD(IT) divided by 3 | | | | 0 | 0 | 0 | fAD(fOCO40M) divided by 4 | | | | 0 | 0 | 1 | fAD(fOCO40M) divided by 2 | | | 1 | 1 | 0 | 0 | fAD(fOCO40M) divided by 12 | | | 1 | 1 | 0 | 1 | fAD(fOCO40M) divided by 6 | | | | 1 | 1 | 0 | fAD(fOCO40M) divided by 3 | | | | 1 | 1 | 1 | TAD(100040IVI) divided by 3 | | Only set the values listed above. ## 27.2.6 A/D Control Register 1 (ADCON1) If the ADCON1 register is rewritten during A/D conversion, the conversion result is undefined. ## SCAN1-SCAN0 (A/D sweep pin select bit) (b1-b0) These bits are disabled in one-shot and repeat modes. In single sweep mode, repeat sweep mode 0, and repeat sweep mode 1, pins AN0\_0 to AN0\_7 and AN2\_0 to AN2\_7 can be used in the same way as pins AN0 to AN7. Use bits ADGSEL1 to ADGSEL0 in the ADCON2 register to select the desired group. ## MD2 (A/D operation mode select bit 1) (b2) A/D operation mode is selected by a combination of bits MD1 to MD0 in the ADCON0 register and the MD2 bit. See Table 27.5 "A/D Operation Mode". #### ADSTBY (A/D standby bit) (b5) If the ADSTBY bit is changed from 0 (A/D operation stopped) to 1 (A/D operation enabled), wait for one $\phi$ AD cycle or more before starting A/D conversion. When the A/D converter is not used, no current flows in the A/D converter by setting the ADSTBY bit to 0 (A/D operation stopped: standby). This helps reduce power consumption. ## 27.3 Operations # 27.3.1 A/D Conversion Cycle A/D conversion cycle is based on fAD and $\phi$ AD. Divide fAD so $\phi$ AD conforms the standard frequency. Figure 27.2 shows fAD and $\phi$ AD. Set the PCKSTP1A bit in the PCLKSTP1 register to 0 (f1 provide enabled) when using f1 as the clock source of fAD. Figure 27.2 fAD and $\phi$ AD Figure 27.3 shows A/D Conversion Timing. Figure 27.3 A/D Conversion Timing Table 27.7 lists Cycles of A/D Conversion Item. A/D conversion time is described below. Start processing time depends on which $\phi AD$ is selected. A/D conversion starts after the start processing time elapses by setting the ADST bit in the ADCON0 register to 1 (A/D conversion start). When reading the ADST bit before starting A/D conversion, 0 (A/D conversion stop) is read. When selecting multiple pins, or in a mode which performs A/D conversion multiple times, inter-execution processing time is inserted between A/D conversions. In one-shot mode and single sweep mode, the ADST bit becomes 0 at the end processing time and the last A/D conversion result is stored in the ADi register. #### One-shot mode: Start processing time + A/D conversion execution time + end processing time Two pins are selected in single sweep mode: Start processing time + (A/D conversion execution time + inter-execution processing time + A/D conversion execution time) + end processing time Table 27.7 Cycles of A/D Conversion Item | A/D ( | Conversion Item | Number of Cycles | |-------------------------------|---------------------------------|----------------------| | | φAD = fAD | 1 to 2 cycles of fAD | | | φAD = fAD divided by 2 | 2 to 3 cycles of fAD | | Start processing time | φAD = fAD divided by 3 | 3 to 4 cycles of fAD | | Start processing time | φAD = fAD divided by 4 | 3 to 4 cycles of fAD | | | φAD = fAD divided by 6 | 4 to 5 cycles of fAD | | | φAD = fAD divided by 12 | 7 to 8 cycles of fAD | | A/D conversion execution | Open-circuit detection disabled | 40 cycles of φAD | | time | Open-circuit detection enabled | 42 cycles of φAD | | Inter-execution processing ti | me | 1 cycle of φAD | | End processing time | | 2 to 3 cycles of fAD | #### 27.3.2 A/D Conversion Start Conditions An A/D conversion start trigger has a software trigger and an external trigger. Figure 27.4 shows A/D Conversion Start Trigger. Figure 27.4 A/D Conversion Start Trigger #### 27.3.2.1 Software Trigger The software trigger is enabled when the TRG bit in the ADCON0 register is 0 (software trigger). A/D conversion starts by setting the ADST bit in the ADCON0 register to 1 (A/D conversion start). ## 27.3.2.2 External Trigger The external trigger is enabled when the TRG bit in the ADCON0 register is 1 (ADTRG trigger). To use this trigger, set the following: - The direction bit of the port which shares a pin with ADTRG is 0 (input mode). - The TRG bit in the ADCON0 register is 1 (ADTRG trigger). - The ADST bit in the ADCON0 register is 1 (A/D conversion start). Under the above conditions, when input to the $\overline{ADTRG}$ pin is changed from high to low, A/D conversion starts. Set the high- and low-level durations of the pulse input to the ADTRG pin to two or more cycles of fAD. Figure 27.5 A/D Conversion Start Timing When External Trigger Input #### 27.3.3 A/D Conversion Result When reading the ADi register before A/D conversion is completed, the undefined value is read. Read the ADi register after completing A/D conversion. Use the following procedure to detect the completion of A/D conversion. • In one-shot mode and single sweep mode: The IR bit in the ADIC register becomes 1 (interrupt requested) at a completion of A/D conversion. Ensure that the IR bit becomes 1 to read the ADI register. When not using an A/D interrupt, set the IR bit to 0 (interrupt not requested) by a program after reading the ADi register. • In repeat mode, repeat sweep mode 0, and repeat sweep mode 1: The IR bit remains unchanged (no interrupt request is generated). At first, read the ADi register after one A/D conversion time elapses (refer to 27.3.1 "A/D Conversion Cycle"). After that, whenever the ADi register is read, the conversion result which has been obtained before reading is read. The ADi register is overwritten after every A/D conversion. Read the value before the ADi register is overwritten. ## 27.3.4 Extended Analog Input Pins In one-shot mode and repeat modes, pins ANEX0 and ANEX1 can be used as analog input pins by setting bits ADEX1 to ADEX0 in the ADCON1 register. The A/D conversion result of pins ANEX0 and ANEX1 are stored in registers AD0 and AD1, respectively. ## 27.3.5 Current Consumption Reduce Function When the A/D converter is not in use, power consumption can be reduced by setting the ADSTBY bit in the ADCON1 register to 0 (A/D operation stopped: standby) to shut off any analog circuit current flow. To use the A/D converter, set the ADSTBY bit to 1 (A/D operation enabled) and wait for one $\phi$ AD cycle or more before setting the ADST bit in the ADCON0 register to 1 (A/D conversion start). Do not set bits ADST and ADSTBY to 1 at the same time. Also, do not set the ADSTBY bit to 0 (A/D operation stopped: standby) during A/D conversion. ## 27.3.6 Open-Circuit Detection Assist Function The A/D converter has a function to set the charge of the sampling capacitor to a predefined state (AVCC or AVSS) before A/D conversion starts. This helps prevent the influence of analog input voltage from the previous conversion and more reliably detect an open-circuit of a trace connected to an analog input pin. Figure 27.6 shows A/D Open-Circuit Detection Example on AVCC (Preconversion Charge) and Figure 27.8 shows A/D Open-Circuit Detection Example on AVSS (Preconversion discharge). The conversion result in open-circuit depends on the external circuit. Use this function only after careful evaluation of the system. Figure 27.6 A/D Open-Circuit Detection Example on AVCC (Preconversion Charge) Figure 27.7 A/D Open-Circuit Detection (Charge) Characteristics (Standard Characteristics) Figure 27.8 A/D Open-Circuit Detection Example on AVSS (Preconversion discharge) Figure 27.9 A/D Open-Circuit Detection (Discharge) Characteristics (Standard Characteristics) # 27.4 Operational Modes #### 27.4.1 One-Shot Mode In one-shot mode, the analog voltage applied to a selected pin is converted to a digital code once. Table 27.8 lists One-Shot Mode Specifications. Table 27.8 One-Shot Mode Specifications | Item | Specification | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Function Bits CH2 to CH0 in the ADCON0 register and bits ADGSEL1 to in the ADCON2 register, or bits ADEX1 to ADEX0 in the ADCON are used to select a pin. The analog voltage applied to the pin is to a digital code once. | | | | A/D conversion start conditions | <ul> <li>When the TRG bit in the ADCON0 register is 0 (software trigger) the ADST bit in the ADCON0 register is set to 1 (A/D conversion starts)</li> <li>When the TRG bit is 1 (ADTRG trigger) the input level at the ADTRG pin changes from high to low after the ADS bit is set to 1 (A/D conversion start).</li> </ul> | | | A/D conversion stop conditions | <ul> <li>Completion of A/D conversion (if a software trigger is selected, the ADST bit becomes 0 (A/D conversion stop)).</li> <li>Set the ADST bit to 0.</li> </ul> | | | Interrupt request generation timing | Completion of A/D conversion. | | | Analog input pin | Select one pin from AN0 to AN7, AN0_0 to AN0_7, AN2_0 to AN2_7, ANEX0, or ANEX1. | | | Reading of A/D conversion result | Read the register among AD0 to AD7 that corresponds to the selected pin. | | Table 27.9 Registers and Settings in One-Shot Mode (1) | Register | Bit | Setting | | |------------------|------------------|----------------------------------------------------------------------------|--| | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | PCR5 | Set to 1 (INT6 input disabled) when using the AN2_4 pin for analog input. | | | PCR | PCR6 | Set to 1 (INT7 input disabled) when using the AN2_5 pin for analog input. | | | | PCR7 | Set to 1 (key input disabled) when using pins AN4 to AN7 for analog input. | | | AINRST | AINRST1, AINRST0 | Select whether open-circuit detection assist function is used or not. | | | AD0 to AD7 | b9 to b0 | A/D conversion result can be read. | | | ADGSEL1, ADGSEL0 | | Select analog input pin group. | | | ADCON2 | CKS2 | Select φAD frequency. | | | | CKS3 | Select fAD. | | | | CH2 to CH0 | Select analog input pin. | | | | MD1 to MD0 | Set to 00b. | | | ADCON0 | TRG | Select a trigger. | | | | ADST | Set to 1 to start A/D conversion and set to 0 to stop it. | | | | CKS0 | Select φAD frequency. | | | | SCAN1, SCAN0 | Disabled | | | | MD2 | Set to 0. | | | ADCON1 | CKS1 | Select φAD frequency. | | | | ADSTBY | Set to 1 when performing A/D conversion. | | | | ADEX1, ADEX0 | Select whether ANEX0 and ANEX1 are used or not | | #### Note: 1. This table does not describe a procedure. Figure 27.10 Operation Example in One-Shot Mode # 27.4.2 Repeat Mode In repeat mode, the analog voltage applied to a selected pin is repeatedly converted to a digital code. Table 27.10 lists Repeat Mode Specifications. Table 27.10 Repeat Mode Specifications | Item | Specification | | | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | Bits CH2 to CH0 in the ADCON0 register and bits ADGSEL1 to ADGSEL in the ADCON2 register, or bits ADEX1 to ADEX0 in the ADCON1 register are used to select a pin. The analog voltage applied to the pin is repeated converted to a digital code. | | | | A/D conversion start conditions | <ul> <li>When the TRG bit in the ADCON0 register is 0 (software trigger) the ADST bit in the ADCON0 register is set to 1 (A/D conversion start).</li> <li>When the TRG bit is 1 (ADTRG trigger) the input level at the ADTRG pin changes from high to low after the ADST bit is set to 1 (A/D conversion start).</li> </ul> | | | | A/D conversion stop condition | Set the ADST bit to 0 (A/D conversion stop). | | | | Interrupt request generation timing | No interrupt requests generated | | | | Analog input pin | Select one pin from among AN0 to AN7, AN0_0 to AN0_7, AN2_0 to AN2_7, ANEX0, or ANEX1. | | | | Reading of A/D conversion result | Read the register among AD0 to AD7 that corresponds to the selected pin. | | | Table 27.11 Registers and Settings in Repeat Mode (1) | Register | Bit | Setting | | |------------|---------------------|----------------------------------------------------------------------------|--| | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | PCR5 | Set to 1 (INT6 input disabled) when using the AN2_4 pin for analog input. | | | PCR | PCR6 | Set to 1 (INT7 input disabled) when using the AN2_5 pin for analog input. | | | | PCR7 | Set to 1 (key input disabled) when using pins AN4 to AN7 for analog input. | | | AINRST | AINRST1,<br>AINRST0 | Select whether open-circuit detection assist function is used or not. | | | AD0 to AD7 | b9 to b0 | A/D conversion result can be read. | | | ADOONO | ADGSEL1,<br>ADGSEL0 | Select analog input pin group. | | | ADCON2 | CKS2 | Select | | | | CKS3 | Select fAD. | | | | CH2 to CH0 | Select analog input pin. | | | | MD1 to MD0 | Set to 01b. | | | ADCON0 | TRG | Select a trigger. | | | | ADST | Set to 1 to start A/D conversion and set to 0 to stop it. | | | | CKS0 | Select | | | | SCAN1, SCAN0 | Disabled | | | | MD2 | Set to 0. | | | ADCON1 | CKS1 | Select $\phi$ AD frequency. | | | | ADSTBY | Set to 1 when performing A/D conversion. | | | | ADEX1, ADEX0 | Select whether ANEX0 and ANEX1 are used or not | | #### Note: 1. This table does not describe a procedure. Figure 27.11 Operation Example in Repeat Mode # 27.4.3 Single Sweep Mode In single sweep mode, the analog voltage applied to selected pins is converted one-by-one to a digital code. Table 27.12 lists the Single Sweep Mode Specifications. Table 27.12 Single Sweep Mode Specifications | Item | Specification | | | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | Bits SCAN1 to SCAN0 in the ADCON1 register and bits ADGSEL1 to ADGSEL0 in the ADCON2 register are used to select pins. The analog voltage applied to the pins is converted one-by-one to a digital code. | | | | A/D conversion start conditions | <ul> <li>When the TRG bit in the ADCON0 register is 0 (software trigger) the ADST bit in the ADCON0 register is set to 1 (A/D conversion start).</li> <li>When the TRG bit is 1 (ADTRG trigger) the input level at the ADTRG pin changes from high to low after the ADST bit is set to 1 (A/D conversion start).</li> </ul> | | | | A/D conversion stop conditions | <ul> <li>Completion of A/D conversion (if a software trigger is selected, the ADST bit is set to 0 (A/D conversion stop)).</li> <li>Set the ADST bit to 0.</li> </ul> | | | | Interrupt request generation timing | Completion of A/D conversion | | | | Analog input pin | Select one of the following groupings from AN0 to AN7: 2 pins: AN0 and AN1 4 pins: AN0 to AN3 6 pins: AN0 to AN5 8 pins: AN0 to AN7 AN0_0 to AN0_7 and AN2_0 to AN2_7 can also be selected in the same way. | | | | Reading of A/D conversion result | Read the registers among AD0 to AD7 that corresponds to the selected pin. | | | Table 27.13 Registers and Settings in Single Sweep Mode (1) | Register | Bit | Setting | | |------------|---------------------|----------------------------------------------------------------------------|--| | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | PCR5 | Set to 1 (INT6 input disabled) when using the AN2_4 pin for analog input. | | | PCR | PCR6 | Set to 1 (INT7 input disabled) when using the AN2_5 pin for analog input. | | | | PCR7 | Set to 1 (key input disabled) when using pins AN4 to AN7 for analog input. | | | AINRST | AINRST1,<br>AINRST0 | Select whether open-circuit detection assist function is used or not. | | | AD0 to AD7 | b9 to b0 | A/D conversion result can be read. | | | | ADGSEL1,<br>ADGSEL0 | Select analog input pin group. | | | ADCON2 | CKS2 | Select | | | | CKS3 | Select fAD. | | | | CH2 to CH0 | Disabled | | | | MD1 to MD0 | Set to 10b. | | | ADCON0 | TRG | Select a trigger. | | | | ADST | Set to 1 to start A/D conversion and set to 0 to stop it. | | | | CKS0 | Select | | | | SCAN1, SCAN0 | Select analog input pin. | | | | MD2 | Set to 0. | | | ADCON1 | CKS1 | Select $\phi$ AD frequency. | | | | ADSTBY | Set to 1 when performing A/D conversion. | | | | ADEX1, ADEX0 | Set to 00b. | | #### Note: 1. This table does not describe a procedure. Figure 27.12 Operation Example in Single Sweep Mode # 27.4.4 Repeat Sweep Mode 0 In repeat sweep mode 0, the analog voltage applied to selected pins is repeatedly converted to a digital code. Table 27.14 lists the Repeat Sweep Mode 0 Specifications. Table 27.14 Repeat Sweep Mode 0 Specifications | Item | Specification | | | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | Bits SCAN1 to SCAN0 in the ADCON1 register and bits ADGSEL1 to ADGSEL0 in the ADCON2 register are used to select pins. Analog voltage applied to the pins is repeatedly converted to a digital code. | | | | A/D conversion start conditions | <ul> <li>When the TRG bit in the ADCON0 register is 0 (software trigger) the ADST bit in the ADCON0 register is set to 1 (A/D conversion start).</li> <li>When the TRG bit is 1 (ADTRG trigger) the input level at the ADTRG pin changes from high to low after the ADST bit is set to 1 (A/D conversion start).</li> </ul> | | | | A/D conversion stop condition | Set the ADST bit to 0 (A/D conversion stop). | | | | Interrupt request generation timing | No interrupt requests generated | | | | Analog input pin | Select one of the following groupings from AN0 to AN7: 2 pins: AN0 and AN1 4 pins: AN0 to AN3 6 pins: AN0 to AN5 8 pins: AN0 to AN7 AN0_0 to AN0_7 and AN2_0 to AN2_7 can also be selected in the same way. | | | | Reading of A/D conversion result | Read the registers among AD0 to AD7 that correspond to the selected pins. | | | Table 27.15 Registers and Settings in Repeat Sweep Mode 0 (1) | Register | Bit | Setting | | |------------|--------------|------------------------------------------------------------------|--| | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | PCR5 | Set to 1 (INT6 input disabled) when using the AN2_4 pin for | | | | 1 010 | analog input. | | | PCR | PCR6 | Set to 1 (INT7 input disabled) when using the AN2_5 pin for | | | 1 5.1 | 1 0110 | analog input. | | | | PCR7 | Set to 1 (key input disabled) when using pins AN4 to AN7 for | | | | - | analog input. | | | AINRST | AINRST1, | Select whether open-circuit detection assist function is used or | | | | AINRST0 | not. | | | AD0 to AD7 | b9 to b0 | A/D conversion result can be read. | | | | ADGSEL1, | Select analog input pin group. | | | ADCON2 | ADGSEL0 | | | | ADCONZ | CKS2 | Select φAD frequency. | | | | CKS3 | Select fAD. | | | | CH2 to CH0 | Disabled | | | | MD1 to MD0 | Set to 11b. | | | ADCON0 | TRG | Select a trigger. | | | | ADST | Set to 1 to start A/D conversion and set to 0 to stop it. | | | | CKS0 | Select | | | | SCAN1, SCAN0 | Select analog input pin. | | | | MD2 | Set to 0. | | | ADCON1 | CKS1 | Select φAD frequency. | | | | ADSTBY | Set to 1 when performing A/D conversion. | | | | ADEX1, ADEX0 | Set to 00b. | | #### Note: 1. This table does not describe a procedure. Figure 27.13 Operation Example in Repeat Sweep Mode 0 # 27.4.5 Repeat Sweep Mode 1 In repeat sweep mode 1, the analog voltage applied to eight selected pins, including some prioritized pins, is repeatedly converted to a digital code. Table 27.16 lists the Repeat Sweep Mode 1 Specifications. Table 27.16 Repeat Sweep Mode 1 Specifications | Item | Specification | | | |-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | The input voltage of all eight pins selected by setting bits ADGSEL1 to ADGSEL0 in the ADCON2 register is repeatedly converted to a digital code. One to four pins selected by SCAN1 to SCAN0 in the ADCON1 register is/are converted by priority. Example: If AN0 is prioritized, input voltage is converted to a digital code in the following order: AN0→AN1→AN0→AN2→AN0→AN3 ••• | | | | A/D conversion start conditions | <ul> <li>When the TRG bit in the ADCON0 register is 0 (software trigger), the ADST bit in the ADCON0 register is set to 1 (A/D conversion start).</li> <li>When the TRG bit is 1 (ADTRG trigger), the input level at the ADTRG pin changes from high to low after the ADST bit is set to 1 (A/D conversion start).</li> </ul> | | | | A/D conversion stop condition | Set the ADST bit to 0 (A/D conversion stop). | | | | Interrupt request generation timing | No interrupt requests generated | | | | Analog input pins to be given priority when A/D converted | Select one of the following groupings from AN0 to AN3: 1 pin: AN0 2 pins: AN0 and AN1 3 pins: AN0 to AN2 4 pins: AN0 to AN3 AN0_0 to AN0_3 and AN2_0 to AN2_3 can be selected in the same way. | | | | Reading of A/D conversion result | Read the registers among AD0 to AD7 that correspond to the selected pins. | | | Table 27.17 Registers and Settings in Repeat Sweep Mode 1 (1) | Register | Bit | Setting | | |------------|--------------|------------------------------------------------------------------|--| | PCLKSTP1 | PCKSTP1A | Set to 0 when using f1. | | | | PCR5 | Set to 1 (INT6 input disabled) when using the AN2_4 pin for | | | | 1 010 | analog input. | | | PCR | PCR6 | Set to 1 (INT7 input disabled) when using the AN2_5 pin for | | | | | analog input. | | | | PCR7 | Set to 1 (key input disabled) when using pins AN4 to AN7 for | | | | | analog input. | | | AINRST | AINRST1, | Select whether open-circuit detection assist function is used or | | | 7 | AINRST0 | not. | | | AD0 to AD7 | b9 to b0 | A/D conversion result can be read. | | | | ADGSEL1, | Select analog input pin group. | | | ADCON2 | ADGSEL0 | Octobe arialog input pin group. | | | ADCONZ | CKS2 | Select $\phi$ AD frequency. | | | | CKS3 | Select fAD. | | | | CH2 to CH0 | Disabled | | | | MD1 to MD0 | Set to 11b. | | | ADCON0 | TRG | Select a trigger. | | | | ADST | Set to 1 to start A/D conversion and set to 0 to stop it. | | | | CKS0 | Select | | | | SCAN1, SCAN0 | Select a pin to be given priority when A/D converted | | | | MD2 | Set to 1. | | | ADCON1 | CKS1 | Select | | | | ADSTBY | Set to 1 when performing A/D conversion. | | | | ADEX1, ADEX0 | Set to 00b. | | #### Note: 1. This table does not describe a procedure. Figure 27.14 Operation Example in Repeat Sweep Mode 1 Figure 27.15 Transition Diagram of Pins Used during A/D Conversion in Repeat Sweep Mode 1 #### 27.5 External Sensor To perform A/D conversion accurately, charging the internal capacitor C shown in Figure 27.16 must be completed within a specified period of time. T: Specified period of time (sampling time) R0: Output impedance of sensor equivalent circuit R: Internal resistance of the MCU X: Precision (error) of the A/D converter Y: Resolution of the A/D converter be Y (Y is 1024) Generally, $$VC = VIN \left\{ 1 - e^{-\frac{1}{C(R0 + R)}t} \right\}$$ When $t = T$ , $VC = VIN - \frac{X}{Y}VIN = VIN \left(1 - \frac{X}{Y}\right)$ $$e^{-\frac{1}{C(R0 + R)}T} = \frac{X}{Y}$$ $$-\frac{1}{C(R0 + R)}T = \ln \frac{X}{Y}$$ Therefore, $R0 = -\frac{T}{C \bullet \ln \frac{X}{Y}}$ Figure 27.16 shows Analog Input Pin and External Sensor Equivalent Circuit. Impedance R0 by which voltage VC between pins of the capacitor C changes from 0 to VIN - (0.1/1024)VIN in time T when the difference between VIN and VC is 0.1LSB is obtained. (0.1/1024) means that A/D precision drop due to insufficient capacitor charge is kept to 0.1LSB in A/D conversion. However, the actual error is the value of absolute accuracy added to 0.1LSB. When $\phi AD$ is 20 MHz, T is 0.75 $\mu s$ . Output impedance R0 for charging capacitor C sufficiently within time T is obtained as follows. $$R0 = -\frac{0.75 \times 10^{-6}}{6.0 \times 10^{-12} \bullet \ln \frac{0.1}{1024}} - 10 \times 10^{3} \approx 3.5 \times 10^{3}$$ Thus, the output impedance R0 of the sensor equivalent circuit, making the A/D converter precision (error) 0.1LSB or less, is up to 3.5 k $\Omega$ . Figure 27.16 Analog Input Pin and External Sensor Equivalent Circuit ## 27.6 Interrupt Refer to the operation examples for timing of generating interrupt requests. Also, refer to 14.7 "Interrupt Control" for details. Table 27.18 lists Registers Associated with A/D Converter Interrupt. Table 27.18 Registers Associated with A/D Converter Interrupt | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------|--------|-------------| | 004Eh | A/D Conversion Interrupt Control Register | ADIC | XXXX X000b | #### 27.7 Notes on A/D Converter ### 27.7.1 Analog Input Voltage Set the analog input voltage as follows: analog input voltage (AN\_0 to AN\_7, ANEX0, and ANEX1) $\leq$ VCC1 analog input voltage (AN0\_0 to AN0\_7 and AN2\_7 to AN2\_7) $\leq$ VCC2 ### 27.7.2 Analog Input Pin Do not use any pin from AN4 to AN7 as analog input pin if any pin from $\overline{\text{KI0}}$ to $\overline{\text{KI3}}$ is used as a key input interrupt. ### 27.7.3 Pin Configuration To prevent operation errors due to noise or latchup, and to reduce conversion errors, place capacitors between the AVSS pin and the AVCC pin, the VREF pin, and analog inputs (ANi (i = 0 to 7), ANEXi, ANO\_i, and AN2\_i). Also, place a capacitor between the VCC1 pin and VSS pin. Figure 27.17 Example of Pin Configuration #### 27.7.4 Register Access Set registers associated with A/D converter after setting the CKS3 bit in the ADCON2 register. However the other bits in the ADCON2 register and the CKS3 bit can be set at the same time. After changing the CKS3 bit, set the others in the same way. Write registers ADCON0 (excluding the ADST bit), ADCON1, and ADCON2 when A/D conversion stops (before a trigger is generated). After A/D conversion stops, set the ADSTBY bit in the ADCON1 register from 1 to 0. #### 27.7.5 A/D Conversion Start When rewriting the ADSTBY bit in the ADCON1 register from 0 (A/D operation stopped) to 1 (A/D operation enabled), wait for one $\phi$ AD cycle or more before starting A/D conversion. ### 27.7.6 A/D Operation Mode Change When the A/D operation mode has been changed, reselect analog input pins by using bits CH2 to CH0 in the ADCON0 register or bits SCAN1 to SCAN0 in the ADCON1 register. ### 27.7.7 State When Forcibly Terminated If A/D conversion in progress is halted by setting the ADST bit in the ADCON0 register to 0 (A/D conversion stopped), the conversion result is undefined. In addition, the unconverted ADi register (i = 0 to 7) may also become undefined. Do not use any value in ADi registers when setting the ADST bit to 0 by a program during A/D conversion. ### 27.7.8 A/D Open-Circuit Detection Assist Function The conversion result in open-circuit depends on the external circuit. Use this function only after careful evaluation of the system. Do not use this function when VCC1 > VCC2. When A/D conversion starts after changing the AINRST register, follow these steps: - (1) Change bits AINRST1 to AINRST0 in the AINRST register. - (2) Wait for one cycle of φAD. - (3) Set the ADST bit in the ADCON0 register to 1 (A/D conversion started). ## 27.7.9 Detecting Completion of A/D Conversion In one-shot mode and single sweep mode, use the IR bit in the ADIC register to detect completion of A/D conversion. When not using an interrupt, set the IR bit to 0 by a program after detection. When 1 is written to the ADST bit in the ADCON0 register, the ADST bit becomes 1 (A/D conversion start) after start processing time elapses (see Table 27.7 "Cycles of A/D Conversion Item"). Therefore when reading the ADST bit immediately after writing 1, 0 (A/D conversion stop) may be read. Figure 27.18 ADST Bit Operation #### 27.7.10 **\$\phiAD**\$ Divide fAD so $\phi$ AD conforms to the standard frequency. In particular, consider the maximum and minimum values of fOCO40M when the CKS3 bit in the ADCON2 register is 1 (fOCO40M is fAD). ### 28. D/A Converter #### 28.1 Introduction The D/A converter is an 8-bit, R-2R type converter. There are two independent D/A converters. Table 28.1 lists the D/A Converter Specifications and Figure 28.1 shows the D/A Converter Block Diagram. Table 28.1 D/A Converter Specifications | Item | Specification | |-----------------------|---------------| | D/A conversion method | R-2R | | Resolution | 8 bits | Figure 28.1 D/A Converter Block Diagram Table 28.2 I/O Ports | Pin Name | I/O | Function | | |----------|------------|-----------------------|--| | DA0 | Output (1) | D/A comparator output | | | DA1 | Output (1) | DIA comparator output | | Note: 1. Set the direction bit of the ports sharing a pin to 0 (input mode). When the DAiE bit (i = 0, 1) in the DACON register is set to 1 (output enabled), the corresponding port cannot be pulled up. ## 28.2 Registers Table 28.3 Registers | Address | Register | Symbol | Reset Value | |---------|----------------------|--------|-------------| | 03D8h | D/A0 Register | DA0 | 00h | | 03DAh | D/A1 Register | DA1 | 00h | | 03DCh | D/A Control Register | DACON | 00h | # 28.2.1 D/Ai Register (DAi) (i = 0, 1) ## 28.2.2 D/A Control Register (DACON) ### 28.3 Operations D/A conversion is performed by writing a value to the DAi register (i = 0, 1). Output analog voltage (V) is determined by the value n (n = decimal) set in the DAi register. $$V = VREF \times \frac{n}{256}$$ (n = 0 to 255) VREF: Reference voltage Figure 28.2 shows the D/A Converter Equivalent Circuit. Figure 28.2 D/A Converter Equivalent Circuit ### 28.4 Notes on D/A Converter ## 28.4.1 When Not Using the D/A Converter When not using the D/A converter, set the DAiE bit (i = 0, 1) in the DACON register to 0 (output disabled) and the DAi register to 00h in order to minimize unnecessary current consumption and prevent current flow to the R-2R resistor. ### 29. CRC Calculator #### 29.1 Introduction The cyclic redundancy check (CRC) calculator detects errors in data blocks. This CRC calculator is enhanced by an additional feature, the CRC snoop, in order to monitor reads from and writes to a certain SFR address, and perform CRC calculations automatically on the data read from and data written to the aforementioned SFR address. Table 29.1 CRC Calculator Specifications | Item | Specification | | |--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--| | Generator polynomial | CRC-CCITT (X <sup>16</sup> + X <sup>12</sup> + X <sup>5</sup> + 1) or CRC-16 (X <sup>16</sup> + X <sup>15</sup> + X <sup>2</sup> + 1) | | | Selectable functions • MSB/LSB selectable • CRC snoop | | | Figure 29.1 CRC Calculator Block Diagram ## 29.2 Registers Table 29.2 Registers | Address | Register | Symbol | Reset Value | |---------|-------------------------------|--------|-------------| | 03B4h | SFR Snoop Address Register | CRCSAR | XXXX XXXXb | | 03B5h | 31 IX 31100p Address Register | | 00XX XXXXb | | 03B6h | CRC Mode Register | CRCMR | 0XXX XXX0b | | 03BCh | CRC Data Register | CRCD | XXh | | 03BDh | ONO Data Negistei | | XXh | | 03BEh | CRC Input Register | CRCIN | XXh | ## 29.2.1 SFR Snoop Address Register (CRCSAR) CRCSR (Snoop-on-read enable bit) (b14) CRCSW (Snoop-on-write enable bit) (b15) Do not set bits CRCSR and CRCSW to 1 at the same time. Set the CRCSR bit to 0 when the CRCSW bit is 1. Set the CRCSW bit to 0 when the CRCSR bit is 1. ### 29.2.2 CRC Mode Register (CRCMR) ### 29.2.3 CRC Data Register (CRCD) Write 0000h to the CRCD register and then write the first data to the CRCIN register. Execute this operation every time CRC calculation is performed. Refer to the setting procedures described in Figure 29.2 "CRC Calculation When Using CRC-CCITT" and Figure 29.3 "CRC Calculation When Using CRC-16". ### 29.2.4 CRC Input Register (CRCIN) #### 29.3 Operations ### 29.3.1 Basic Operation The CRC (Cyclic Redundancy Check) calculator detects errors in data blocks. The MCU uses two generator polynomials to generate CRC: CRC-CCITT ( $X^{16} + X^{12} + X^5 + 1$ ) and CRC-16 ( $X^{16} + X^{15} + X^2 + 1$ ). The CRC code is 16-bit code generated for a given length of a data block in 8-bit units. After setting the default value in the CRCD register, the CRC code is stored in the CRCD register every time 1-byte of data is written to the CRCIN register. CRC code generation for 1-byte data is completed in two CPU clock cycles. ### 29.3.2 CRC Snoop The CRC snoop monitors reads from and writes to a certain SFR address and performs CRC calculation on the data read from and written to the aforementioned SFR address automatically. Because the CRC snoop recognizes writes to and reads from a certain SFR address as a trigger to automatically perform CRC calculation, there is no need to write data to the CRCIN register. All SFR addresses from 0020h to 03FFh are subject to the CRC snoop. The CRC snoop is useful in monitoring writes to the UART transmit buffer, and reads from the UART receive buffer. To use this function, write a target SFR address to bits CRCSAR9 to CRCSAR0 in the CRCSAR register. Then, set the CRCSW bit in the CRCSAR register to 1 to enable snooping on writes to the target, or set the CRCSR bit in the CRCSAR register to 1 to enable snooping on reads from the target. When setting the CRCSW bit to 1 and writing data to a target SFR address by CPU or DMA, the CRC calculator stores the data in the CRCIN register and performs CRC calculation. Similarly, when setting the CRCSR bit to 1 and reading data in a target SFR address by CPU or DMA, the CRC calculator stores the data in the CRCIN register and performs CRC calculation. CRC calculation is performed 1-byte at a time. When the target SFR address is accessed in words (16 bits), CRC code is generated on the lower byte (1 byte) of data. Figure 29.2 CRC Calculation When Using CRC-CCITT Figure 29.3 CRC Calculation When Using CRC-16 # 30. Flash Memory Note - There are no P11 to P14 in the 100-pin package. For the 100-pin package, do not use these pins for the entry of user boot function. #### 30.1 Introduction This product uses flash memory as ROM. In this chapter, flash memory refers to the flash memory inside the MCU. In this product, the flash memory can perform in three rewrite modes: CPU rewrite mode, standard serial I/O mode, and parallel I/O mode. Table 30.1 lists Flash Memory Specifications (see Table 1.1 to Table 1.4 "Specifications" for the items not listed in Table 30.1). **Table 30.1** Flash Memory Specifications | Item | | Specification | | | |---------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Flash memory rewrite modes | | 3 modes (CPU rewrite, standard serial I/O, and parallel I/O) | | | | | Program ROM 1 | See Figure 30.1 "Flash Memory Block Diagram". | | | | Erase block | Program ROM 2 | 1 block (16 KB) | | | | | Data flash | 2 blocks (4 KB each) | | | | Program method | | In 2-word (4-byte) units | | | | Erase method | | Block erase | | | | Program and erase control method | | Program and erase controlled by software commands | | | | Suspend function | | Program suspend and erase suspend | | | | Protect method | | A lock bit protects each block. | | | | Number of command | ds | 8 | | | | Program and erase | Program ROM 1 and program ROM 2 | 1,000 times <sup>(1)</sup> | | | | cycles | Data flash | 10,000 times <sup>(1)</sup> | | | | Data retention | | 20 years | | | | Flash memory rewrite disable function | | Parallel I/O mode ROM code protect function Standard serial I/O mode ID code check function, forced erase function, and standard serial I/O mode disable function | | | | User boot function | | User boot mode | | | | NI-1- | | l. | | | #### Note: 1. Definition of program and erase cycles: The program and erase cycles is the number of erase operations performed on a per-block basis. For example, assume that a 4 KB block is programmed in 1,024 operations, writing 2 words at a time, and erased thereafter. In this case, the block is considered to have been programmed and erased once. If the program and erase cycles are 1,000 times, each block can be erased up to 1,000 times. Table 30.2 Flash Memory Rewrite Modes Overview | Flash Memory<br>Rewrite Mode | CPU Rewrite Mode | Standard Serial I/O Mode | Parallel I/O Mode | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | Function | The flash memory is rewritten when the CPU executes software commands. EW0 mode: Rewritable in areas other than the flash memory EW1 mode: Rewritable in the flash memory | The flash memory is rewritten using a dedicated serial programmer. Standard serial I/O mode 1: Clock synchronous serial I/O Standard serial I/O mode 2: 2-wire clock asynchronous serial I/O | The flash memory is rewritten using a dedicated parallel programmer. | | Areas which can be rewritten | Program ROM 1, program ROM 2, and data flash | Program ROM 1, program ROM 2, and data flash | Program ROM 1,<br>program ROM 2, and<br>data flash | | CPU operating mode | Single-chip mode<br>Memory expansion mode (EW0<br>mode) | Boot mode | Parallel I/O mode | | ROM programmer | None | Serial programmer | Parallel programmer | | On-board rewrite | Available | Available | Unavailable | ### 30.2 Memory Map The flash memory is used as ROM in this product. The flash memory is comprised of program ROM 1, program ROM 2, and data flash. Figure 30.1 shows the Flash Memory Block Diagram. The flash memory is divided into several blocks, each of which can be protected (locked) from being programmed or erased. The flash memory can be rewritten in CPU rewrite, standard serial I/O, and parallel I/O modes. Program ROM 2 can be used when the PRG2C0 bit in the PRG2C register is 0 (program ROM 2 enabled). Data flash can be used when the PM10 bit in the PM1 register is set to 1 (0E000h to 0FFFFh: data flash). Data flash is divided into block A and block B. Table 30.3 lists the differences among program ROM 1, program ROM 2, and data flash. In single-chip mode or memory expansion mode, program can be allocated in either program ROM 1, program ROM 2, or data flash. Table 30.3 Program ROM 1, Program ROM 2, and Data Flash | Item | Flash Memory | | | | |------------------------------|-----------------|---------------|-----------------|--| | nem | Program ROM 1 | Program ROM 2 | Data flash | | | Program and erase cycles | 1,000 times | | 10,000 times | | | Forced erase function | Enabled | | Disabled | | | Frequency limit when reading | No | | Yes | | | User boot program | Do not allocate | Allocatable | Do not allocate | | Figure 30.1 Flash Memory Block Diagram ### 30.3 Registers Table 30.4 Registers | Address | Register | Symbol | Reset Value | |---------|---------------------------------|--------|-----------------------------------------------------------------------| | 0220h | Flash Memory Control Register 0 | FMR0 | 0000 0001b (Other than user boot mode)<br>0010 0001b (User boot mode) | | 0221h | Flash Memory Control Register 1 | FMR1 | 00X0 XX0Xb | | 0222h | Flash Memory Control Register 2 | FMR2 | XXXX 0000b | | 0223h | Flash Memory Control Register 3 | FMR3 | XXXX 0000b | | 0230h | Flash Memory Control Register 6 | FMR6 | XX0X XX00b | ### 30.3.1 Flash Memory Control Register 0 (FMR0) # FMR00 (RY/BY status flag) (b0) This bit indicates the flash memory operating state. Conditions to become 0: - When executing the following commands: Program, block erase, lock bit program, read lock bit status, and block blank check - When the flash memory stops (the FMSTP bit is 1) - During the wake up operation when the FMSTP bit is changed from 1 to 0 Condition to become 1: Other than those above. #### FMR01 (CPU rewrite mode select bit) (b1) Commands can be accepted by setting the FMR01 bit to 1 (CPU rewrite mode enabled). To set the FMR01 bit to 1, write 0 and then 1 in succession. Do not generate any interrupts or DMA transfers between setting 0 and 1. Change the FMR01 bit when the PM24 bit in the PM2 register is 0 ( $\overline{\text{NMI}}$ interrupt disabled) or high is input to the $\overline{\text{NMI}}$ pin. While in EW0 mode, write to this bit from a program in an area other than flash memory. Enter read array mode, and then set this bit to 0. ### FMR02 (Lock bit disable select bit) (b2) The lock bit is disabled by setting the FMR02 bit to 1 (lock bit disabled) (Refer to 30.8.4 "Data Protect Function"). The FMR02 bit does not change the lock bit data, but disables the lock bit function. If an erase command is executed when the FMR02 bit is set to 1, the lock bit data status changes from 0 (locked) to 1 (unlocked) after command execution is completed. To set the FMR02 bit to 1, write 0 and then 1 to the FMR02 bit in succession when the FMR01 bit is 1. Make sure no interrupts or DMA transfers will occur before writing 1 after writing 0. Do not change the FMR02 bit while programming, erasing or suspending. ### FMSTP (Flash memory stop bit) (b3) The FMSTP bit resets the flash memory control circuits and minimizes current consumption in the flash memory. Access to the internal flash memory is disabled when the FMSTP bit is set to 1 (flash memory operation stopped). Set the FMSTP bit by a program located in an area other than the flash memory. Set the FMSTP bit to 1 under the following condition: • A flash memory access error occurs while erasing or programming in EW0 mode (the FMR00 bit does not revert to 1 (ready)). After the FMSTP bit is set to 0 (Flash memory operation enabled), wait until the flash memory circuit stabilizes (tps), then perform the next operation. Also when the FMSTP bit is set to 0 immediately after this bit is set to 1, wait for tps after the bit is set to 1. The procedure for this case is described below. - (1) Set the FMSTP bit to 1. - (2) Wait until the flash memory circuit stabilizes (tps). - (3) Set the FMSTP bit to 0. - (4) Wait for tps. The FMSTP bit is enabled when the FMR01 bit is 1 (CPU rewrite mode). When the FMR01 bit is 0, although the FMSTP bit can be set to 1 by writing 1, the flash memory is neither placed in low-power mode nor initialized. When the FMR22 bit is 1 (slow read mode enabled) or the FMR23 bit is 1 (low-current consumption read mode enabled), do not set the FMSTP bit in the FMR0 register to 1 (flash memory operation stopped). Also, when the FMSTP bit is 1, do not set the FMR22 or FMR23 bit to 1. ### FMR06 (Program status flag) (b6) This bit indicates the auto-program operation state. Condition to become 0: • Execute the clear status command. Condition to become 1: • Refer to 30.8.7.1 "Full Status Check". Do not execute the following commands when the FMR06 bit is 1: Program, block erase, lock bit program, and block blank check. ## FMR07 (Erase status flag) (b7) This bit indicates the auto-erase operation state. Condition to become 0: • Execute the clear status command Condition to become 1: • Refer to 30.8.7.1 "Full Status Check". Do not execute the following commands when the FMR07 bit is 1: Program, block erase, lock bit program, and block blank check. ## 30.3.2 Flash Memory Control Register 1 (FMR1) ### FMR11 (Write to FMR6 register enable bit) (b1) Change FMR11 bit when the PM24 bit in the PM2 register is 0 ( $\overline{\text{NMI}}$ interrupt disabled) or high is input to the $\overline{\text{NMI}}$ pin. #### FMR16 (Lock bit status flag) (b6) This bit indicates the execution result of the read lock bit status command. #### FMR17 (Data flash wait bit) (b7) This bit is used to select the number of waits for data flash. When setting this bit to 0, one wait is inserted to the read cycle of the data flash. The write cycle is not affected. ## 30.3.3 Flash Memory Control Register 2 (FMR2) FMR22 (Slow read mode enable bit) (b2) FMR23 (Low-current consumption read mode enable bit) (b3) Refer to 9.4 "Power Control in Flash Memory". ## 30.3.4 Flash Memory Control Register 3 (FMR3) ## FMR30 (Suspend function enable bit) (b0) To set the FMR30 bit to 1, write 0 and then 1 in succession. Make sure no interrupts or DMA transfers will occur before writing 1 after writing 0. # 30.3.5 Flash Memory Control Register 6 (FMR6) When accessing the FMR6 register, select a CPU clock frequency of 10 MHz or less by setting the CM06 bit in the CM0 register and bits CM17 and CM16 in the CM1 register. Also, set the PM17 bit in the PM1 register to 1 (wait state). ## FMR60 (EW1 mode select bit) (b0) To set the FMR60 bit to 1, write 1 when both FMR01 bit in the FMR0 register and FMR11 bit in the FMR1 register are 1. Change the FMR60 bit when the PM24 bit in the PM2 register is 0 (NMI interrupt disabled) or high is input to the NMI pin. Also, change this bit when the FMR00 bit in the FMR0 register is 1 (ready). ## FMR61 (b1) Set the FMR61 bit to 1 when using CPU rewrite mode. # 30.4 Optional Function Select Area In an option function select area, the MCU state after reset and the function to prevent rewrite in parallel I/O mode are selected. The option function select area is not an SFR, and therefore cannot be rewritten by a program. Set an appropriate value when writing a program to the flash memory. The entire option function select area becomes FFh when the block including the option function select area is erased. In blank products, the OFS1 address value is FFh when shipped. After a value is written by the user, this address takes on the written value. In programmed products, the OFS1 address is the value set in the user program prior to shipping. Selection using the optional function select area can be used in single-chip mode or memory expansion mode. The option function select area cannot be used in microprocessor mode. When using the MCU in microprocessor mode, clear the internal ROM. Figure 30.2 Option Function Select Area # 30.4.1 Optional Function Select Address 1 (OFS1) ROMCR (ROM code protect disable bit) (b2) ROMCP1 (ROM code protect bit) (b3) These bits are used to disable the flash memory from being read or rewritten in parallel I/O mode. Table 30.5 ROM Code Protect | Bit S | etting | ROM Code Protect | | | |-----------|------------|------------------|--|--| | ROMCR bit | ROMCP1 bit | NOW Code Protect | | | | 0 | 0 | Disabled | | | | 0 | 1 | Disabled | | | | 1 | 0 | Enabled | | | | 1 | 1 | Disabled | | | ## 30.5 Flash Memory Rewrite Disable Function This function disables the flash memory from being read, written, and erased. The following are details for each mode: Parallel I/O mode ROM code protect function Standard serial I/O mode ID code check function, forced erase function, and standard serial I/O mode disable function ### 30.6 Boot Mode A hardware reset occurs while a low-level signal is applied to the P5\_5 pin and a high-level signal is applied to pins CNVSS and P5\_0. After reset, the MCU enters boot mode. In boot mode, user boot mode or standard serial I/O mode is selected in accordance with the content of the user boot code area. Refer to 30.9 "Standard Serial I/O Mode" for details. The MCU does not enter boot mode in power-on reset and voltage monitor 0 reset. #### 30.7 User Boot Mode This mode is used for starting the flash memory rewrite program programmed by a user. Allocate the flash memory rewrite program to program ROM 2. In user boot mode, the program is executed from address 10000h (starting address of program ROM 2). After starting the program, the flash memory is rewritten according to the program in EW0 or EW1 mode. #### 30.7.1 User Boot Function User boot mode can be selected by the status of a port when the MCU starts in boot mode. Table 30.6 lists the User Boot Function Specifications. Table 30.6 User Boot Function Specifications | ltem | Specification | |-------------------------|----------------------------------------------| | Entry pin | None or select a port from P0 to P14 | | User boot start level | Select high or low | | User boot start address | Address 10000h (program ROM 2 start address) | Set "UserBoot" in ASCII code to addresses 13FF0h to 13FF7h in the user boot code area, select a port for entry from addresses 13FF8h to 13FF9h and 13FFAh, and select the start level with address 13FF8h. After starting boot mode, user boot mode or standard serial I/O mode is selected in accordance with the input level of the selected port. In addition, if addresses 13FF0h to 13FF7h are set to "UserBoot" in ASCII code and addresses 13FF8h to 13FF8h are set to 00h, user boot mode is selected. In user boot mode, the program of address 10000h (program ROM 2 start address) is executed. Figure 30.3 shows the User Boot Code Area, Table 30.7 lists Start Mode (When Port Pi\_j is Selected for Entry), Table 30.8 lists "UserBoot" in ASCII Code, and Table 30.9 lists Addresses of Selectable Ports for Entry. Figure 30.3 User Boot Code Area Table 30.7 Start Mode (When Port Pi\_j is Selected for Entry) (1) | Boot Code | Port Ir | nformation for | · Entry | | | | |-------------------------------------------|-------------------------------|----------------|-----------------------------------|-----------------------|--------------------------|--| | (13FF0h to<br>13FF7h) | (13FF8h to (13FFAh) selection | | Start level<br>select<br>(13FFBh) | Port Pi_j Input Level | Start Mode | | | | 0000h | 00h | 00h | _ | User boot mode | | | "UserBoot" in ASCII code (2) | Pi register | | 00h | High | Standard serial I/O mode | | | | address (3) (v | | | Low | User boot mode | | | Acon code ( ) | Pi register 00h to 07h | | 01h | High | User boot mode | | | | address (3) | (value of j) | OIII | Low | Standard serial I/O mode | | | Other than<br>"UserBoot" in<br>ASCII code | - | _ | - | _ | Standard serial I/O mode | | i = 0 to 14; j = 0 to 7 (when i = 14; j = 0, 1) ### Notes: - 1. Only use the values listed in Table 30.7. - 2. See Table 30.8 "UserBoot" in ASCII Code. - 3. See Table 30.9 "Addresses of Selectable Ports for Entry". Table 30.8 "UserBoot" in ASCII Code | Address | ASCII Code | |---------|--------------------| | 13FF0h | 55h (upper-case U) | | 13FF1h | 73h (lower-case s) | | 13FF2h | 65h (lower-case e) | | 13FF3h | 72h (lower-case r) | | 13FF4h | 42h (upper-case B) | | 13FF5h | 6Fh (lower-case o) | | 13FF6h | 6Fh (lower-case o) | | 13FF7h | 74h (lower-case t) | Table 30.9 Addresses of Selectable Ports for Entry | Port | Add | ress | Port | Address | | Port | Address | | |------|--------|--------|------|---------------|-----|------|---------|--------| | Foit | 13FF9h | 13FF8h | Foit | 13FF9h 13FF8h | | Foit | 13FF9h | 13FF8h | | P0 | 03h | E0h | P6 | 03h | ECh | P12 | 03h | F8h | | P1 | 03h | E1h | P7 | 03h | EDh | P13 | 03h | F9h | | P2 | 03h | E4h | P8 | 03h | F0h | P14 | 03h | FCh | | P3 | 03h | E5h | P9 | 03h | F1h | | | | | P4 | 03h | E8h | P10 | 03h | F4h | _ | | | | P5 | 03h | E9h | P11 | 03h | F5h | | | | Table 30.10 Example Settings of User Boot Code Area When starting up in user boot mode while input level of the port P1\_5 is low: | Address | Setting Value | Meaning | |---------|---------------|--------------| | 13FF0h | 55h | Upper-case U | | 13FF1h | 73h | Lower-case s | | 13FF2h | 65h | Lower-case e | | 13FF3h | 72h | Lower-case r | | 13FF4h | 42h | Upper-case B | | 13FF5h | 6Fh | Lower-case o | | 13FF6h | 6Fh | Lower-case o | | 13FF7h | 74h | Lower-case t | | 13FF8h | E1h | | | 13FF9h | 03h | Port P1_5 | | 13FFAh | 05h | | | 13FFBh | 00h | Low level | Figure 30.4 Program Starting Address in User Boot Mode ## 30.8 CPU Rewrite Mode In CPU rewrite mode, the flash memory can be rewritten when the CPU executes software commands. Program ROM 1, program ROM 2, and data flash can be rewritten with the MCU mounted on the board and without using a ROM programmer. The program and block erase commands are executed only in individual block areas of program ROM 1, program ROM 2, and data flash. The flash memory has a suspend function to temporarily suspend operation when erasing or programming in CPU rewrite mode. Refer to 30.8.5 "Suspend Function" for details of the suspend function. EW0 mode and EW1 mode are available in CPU rewrite mode. Table 30.11 lists the differences between EW0 mode and EW1 mode. Refer to 30.8.1 "EW0 Mode" and 30.8.2 "EW1 Mode" for details. Table 30.11 EW0 Mode and EW1 Mode | Item | EW0 Mode | EW1 Mode | |-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Operating mode | Single-chip mode Memory expansion mode | Single-chip mode | | Rewrite control program allocatable area | <ul><li>Program ROM 1</li><li>Program ROM 2</li><li>External area</li></ul> | Program ROM 1 Program ROM 2 | | Rewrite control program executable area | The rewrite control program must be transferred to an area other than the flash memory (e.g., RAM) before being executed. | The rewrite control program can be executed in program ROM 1 and program ROM 2. | | Rewritable area | <ul><li>Program ROM 1</li><li>Program ROM 2</li><li>Data flash</li></ul> | <ul> <li>Program ROM 1</li> <li>Program ROM 2</li> <li>Data flash</li> <li>Excluding blocks with the rewrite control program</li> </ul> | | Software command restriction | None | <ul> <li>Do not execute program and block<br/>erase commands in a block with the<br/>rewrite control program.</li> <li>Read status register command<br/>Do not execute.</li> </ul> | | Mode after program/erase, or during program/erase suspend | Read status register mode | Read array mode | | State during auto write and auto erase | Bus is not in a hold state. | Bus is in a hold state. (1) | | Flash memory status detection | <ul> <li>Read bits FMR00, FMR06, and FMR07 in the FMR0 register, and bits FMR32 and FMR33 in the FMR3 register by a program.</li> <li>Execute the read status register command, and then read bits SR7, SR5 and SR4 in the status register.</li> </ul> | Read bits FMR00, FMR06, and FMR07 in the FMR0 register, and bits FMR32 and FMR33 in the FMR3 register by a program. | Note: 1. Refer to 11.3.1.2 "Bus Hold" for detail about the bus hold. #### 30.8.1 EW0 Mode The MCU enters CPU rewrite mode when the FMR01 bit in the FMR0 register is set to 1 (CPU rewrite mode enabled) and is ready to accept commands. EW0 mode is selected by setting the FMR60 bit in the FMR6 register to 0. Figure 30.5 shows Setting and Resetting of EW0 Mode Figure 30.5 Setting and Resetting of EW0 Mode Do not execute the following instructions in EW0 mode: UND instruction, INTO instruction, JMPS instruction, JSRS instruction, and BRK instruction. The following are interrupts which can be used in EW0 mode and operations when the interrupts occur during auto-erase operation or auto-program operation: - Maskable interrupt (suspend disabled) To use the interrupt, allocate a variable vector table in an area other than the flash memory. - Maskable interrupt (suspend enabled) To use the interrupt, allocate a variable vector table in an areas other than the flash memory. When the FMR00 bit in the FMR0 register is checked in the interrupt routine and the result is 0 (being written or erased), auto-erase operation or auto-program operation suspends after td(SR-SUS) elapses by setting the FMR31 bit in the FMR3 register to 1 (suspend request). Auto-erase operation or auto-program operation restarts by setting the FMR31 bit to 0 (command restart) at the completion of the interrupt. - NMI, watchdog timer, oscillator stop/restart detect, voltage detect 1, and voltage detect 2 interrupts Auto-erase operation or auto-program operation is forcibly stopped as soon as the interrupt occurs, and then the interrupt process starts. After the flash memory restart, execute auto-erase operation again and confirm that it is completed as expected in order to read the correct value. The watchdog timer operates even in auto erasing or auto programming operation. Refresh the watchdog timer regularly. Table 30.12 Modes after Executing Commands (in EW0 Mode) | Command | Mode after Executing Command | |-----------------------|-------------------------------| | Read array | Read array mode | | Clear status register | Read array mode | | Program | | | Block erase | Read status register mode (1) | | Lock bit program | | | Read lock bit status | Read lock bit status mode (1) | | Block blank check | Read status register mode (1) | ## Note: 1. Flash memory can be read only in read array mode. # 30.8.1.1 Suspend Function (EW0 Mode) When using suspend function in EW0 mode, check the status of the flash memory in the interrupt routine and enter suspend mode. Program suspend or erase suspend is not accepted until td(SR-SUS) elapses after the FMR31 bit is set to 1. Access to the flash memory after confirming the acceptance of program suspend or erase suspend by the FMR33 or FMR32 bit. Set the FMR31 bit to 0 (command restart) to restart auto-program and auto-erase operations at the completion of the access to the flash memory. Figure 30.6 to Figure 30.8 show a flowchart in EW0 mode when the suspend function is enabled, and Figure 30.9 shows Suspend Operation Example in EW0 Mode. Figure 30.6 Program Flowchart in EW0 Mode (Suspend Function Enabled) Figure 30.7 Block Erase Flowchart in EW0 Mode (Suspend Function Enabled) Figure 30.8 Lock Bit Program Flowchart in EW0 Mode (Suspend Function Enabled) Figure 30.9 Suspend Operation Example in EW0 Mode #### 30.8.2 EW1 Mode EW1 mode is selected by setting the FMR60 bit in the FMR6 register to 1 after setting the FMR01 bit in the FMR0 register to 1. Figure 30.10 shows Setting and Resetting of EW1 Mode. When a program or erase operation is initiated, the CPU halts all program execution until the operation is completed. Figure 30.10 Setting and Resetting of EW1 Mode The following are interrupts which can be used in EW1 mode and operations when the interrupts occur during auto-erase operation or auto-program operation: - Maskable interrupt (suspend function enabled) Auto-erase operation or auto-program operation suspends after td(SR-SUS) elapses and the interrupt process is executed. Auto-erase operation or auto-program operation restarts by setting the FMR31 bit in the FMR3 register to 0 (command restart) after the interrupt process is completed. - Maskable interrupt (suspend function disabled) Auto-erase operation or auto-program operation has a higher priority level and the interrupt request has to wait. The interrupt process is executed after auto-erase operation or auto-program operation is completed. - NMI, watchdog timer, oscillator stop/restart detect, voltage detect 1, and voltage detect 2 interrupts Auto-erase operation or auto-program operation forcibly stops as soon as the interrupt occurs, and then the interrupt process starts. - After the flash memory restart, execute auto-erase operation again and confirm that it is completed as expected in order to read the correct value. The watchdog timer stops its counting during auto-erase or auto-programming. Do not use EW1 mode while the CSPRO bit in the CSPR register is 1 (count source protection mode enabled). Use EW0 mode. However, counts does not stop during erase suspend or program suspend. As the interrupt request may be generated, initialize the watchdog timer regularly using the suspend function. Table 30.13 Modes after Executing Commands (in EW1 Mode) | Command | Mode after Executing Command | |-----------------------|------------------------------| | Read array | | | Clear status register | | | Program | | | Block erase | Read array mode | | Lock bit program | | | Read lock bit status | | | Block blank check | | # 30.8.2.1 Suspend Function (EW1 Mode) When using suspend function in EW1 mode, an interrupt request is not accepted until td(SR-SUS) elapses after the interrupt request is generated. When the interrupt request is accepted, the flash memory enters erase suspend or program suspend. Set the FMR31 bit to 0 (command restart) to restart automatic program and erase operations at the completion of the interrupt. Figure 30.11 to Figure 30.13 show a flowchart in EW1 mode when the suspend function is enabled, and Figure 30.14 shows Suspend Operation Example in EW1 Mode. Figure 30.11 Program Flowchart in EW1 Mode (Suspend Function Enabled) Figure 30.12 Block Erase Flowchart in EW1 Mode (Suspend Function Enabled) Figure 30.13 Lock Bit Program Flowchart in EW1 Mode (Suspend Function Enabled) Figure 30.14 Suspend Operation Example in EW1 Mode ## 30.8.3 Operating Speed Select a CPU clock frequency of 10 MHz or less by setting the CM06 bit in the CM0 register and bits CM17 and CM16 in the CM1 register before entering CPU rewrite mode (EW0 or EW1 mode). Also, set the PM17 bit in the PM1 register to 1 (wait state). ## 30.8.4 Data Protect Function Each block in the flash memory has a nonvolatile lock bit. The lock bit is enabled by setting the FMR02 bit to 0 (lock bit enabled). The lock bit allows blocks to be individually protected (locked) against being programmed and erased. This prevents data from being inadvertently written to or erased from the flash memory. Table 30.14 lists Lock Bit and Block State. Table 30.14 Lock Bit and Block State | FMR02 Bit in the FMR0 Register | Lock Bit | Block State | | |--------------------------------|--------------|-----------------------------------------------|--| | 0 (enabled) | 0 (locked) | Protected against being programmed and erased | | | (eriableu) | 1 (unlocked) | Can be programmed or erased | | | 1 (disabled) | 0 (locked) | Can be programmed or erased | | | i (disabled) | 1 (unlocked) | Can be programmed or erased | | Condition to become 0: • Execute the lock bit program command Condition to become 1: • Execute the block erase command while the FMR02 bit in the FMR0 register is set to 1 (lock bit disabled). If the block erase command is executed while the FMR02 bit is set to 1, the target block is erased regardless of lock bit status. The lock bit data can be read by the read lock bit status command. Refer to 30.8.6 "Software Commands", for details on each command. ## 30.8.5 Suspend Function The suspend function suspends automatic programming and erasure. It can be used for an interrupt operation because program ROM 1, program ROM 2, and data flash can be read while automatic programming or erasure is suspended. Enable the interrupts used to enter suspend mode beforehand. The program command, erase command, and lock bit program command are subjects for suspend. Suspend operation is the same for the program command and lock bit program command, so both commands are described together as program suspend. Do not suspend again in suspend mode. Table 30.15 lists Operation after Command is Issued during Suspend. Table 30.15 Operation after Command is Issued during Suspend | | | Oper | ation | | | | |-----------------------------------------|-----------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Suspend | Command | Blocks erased or programmed before suspend | Other blocks | | | | | Erase suspend | Block erase | The command is not executed. A command sequence error occurs. | | | | | | (Suspend while executing erase command) | Program | The command is not executed. A command sequence error occurs. | The command can be executed. Program suspend does not start or an error does not occur even when setting the FMR31 bit to 1 (suspend request). | | | | | | Lock bit program | The command is not executed. A command sequence error occurs. | The command can be executed. | | | | | | Read array | | | | | | | | Read status register | The command can be executed. | | | | | | | Clear status register | | | | | | | | Read lock bit status | The command is not executed. A command sequence error occurs. | The command can be executed. | | | | | | Block blank check | Do not execute the command. | | | | | | Program suspend | Block erase | | | | | | | (Suspend while | Program | The command is not executed. A co | mmand sequence error occurs. (1) | | | | | executing program or lock bit program | Lock bit program | | | | | | | command) | Read array | The command can be executed. | | | | | | | Read status register | The command can be executed. | | | | | | | Clear status register | Do not execute the command. (1) | | | | | | | Read lock bit status | Do not execute the command. | | | | | | | Block blank check | Do not execute the command. | | | | | #### Note: 1. If the command sequence error occurs after executing block erase, program, or lock bit program commands mistakenly during program suspend. Execute the clear status register command, then restart suspend. Figure 30.15 Suspend Request #### 30.8.6 Software Commands Table 30.16 list Software Commands. Read or write commands and data in 16-bit units. When command code is written, the upper 8 bits (D15 to D8) are ignored. Table 30.16 Software Commands | | First Bus Cycle | | Second Bus Cycle | | | Third Bus Cycle | | | | |-----------------------|-----------------|---------|---------------------|-------|---------|---------------------|-------|---------|---------------------| | Command | Mode | Address | Data<br>(D15 to D0) | Mode | Address | Data<br>(D15 to D0) | Mode | Address | Data<br>(D15 to D0) | | Read array | Write | Х | xxFFh | _ | _ | _ | _ | _ | - | | Read status register | Write | Х | xx70h | Read | Х | SRD | _ | _ | - | | Clear status register | Write | Х | xx50h | - | - | _ | _ | _ | _ | | Program | Write | WA | xx41h | Write | WA | WD0 | Write | WA | WD1 | | Block erase | Write | Х | xx20h | Write | BA | xxD0h | _ | _ | - | | Lock bit program | Write | BA | xx77h | Write | BA | xxD0h | _ | _ | - | | Read lock bit status | Write | х | xx71h | Write | BA | xxD0h | - | _ | - | | Block blank check (1) | Write | Х | xx25h | Write | BA | xxD0h | _ | _ | _ | SRD : Data in the status register (D7 to D0) WA : Write address (set the end of the address to 0h, 4h, 8h, or Ch) WD0 : Write data lower word (16 bits)WD1 : Write data upper word (16 bits)BA : Highest block address (even address) x : Any even address in program ROM 1, program ROM 2, or data flash xx : 8 upper bits of command code (ignored) Note: 1. Block blank check command is designed for programmer manufacturer. Not for customers in general. Software commands are described below. For symbols shown in the flowcharts, refer to those in Table 30.16. Refer to 30.8.5 "Suspend Function" for program, block erase, and lock bit program commands when using suspend function. ### 30.8.6.1 Read Array Command The read array command is used to read the flash memory. By writing the command code xxFFh in the first bus cycle, the flash memory enters read array mode. The value of the specified address can be read in 16-bit units by entering the address to be read after the next bus cycle. The flash memory remains in read array mode until another command is written. Therefore, the values of multiple addresses can be read consecutively. Figure 30.16 Read Array Command # 30.8.6.2 Read Status Register Command The read status register command is used to read the status register. By writing the command code xx70h in the first bus cycle, the status register can be read in the second bus cycle. (Refer to 30.8.7 "Status Register"). To read the status register, read an even address in program ROM 1, program ROM 2, or the data flash. Do not execute this command in EW1 mode. Figure 30.17 Read Status Register Command ## 30.8.6.3 Clear Status Register Command The clear status register command is used to clear the status register. By writing the command code xx50h, bits FMR07 and FMR06 in the FMR0 register (SR5 and SR4 in the status register) become 00b. Figure 30.18 Clear Status Register Command # 30.8.6.4 Program Command The program command is used to write 2 words (4 bytes) of data to the flash memory. By writing xx41h in the first bus cycle and data to the write address in the second and third bus cycles, an auto-program operation (data program and verify) is started. Set the end of the write address to 0h, 4h, 8h, or Ch. The FMR00 bit in the FMR0 register indicates whether the auto-program operation has been completed. The FMR00 bit is 0 (busy) during the auto-program operation, and becomes 1 (ready) after the auto-program operation is completed. Do not execute other commands while the FMR00 bit is 0 After the auto-program operation is completed, the FMR06 bit in the FMR0 register indicates whether or not the auto-program operation has been completed as expected. (Refer to 30.8.7.1 "Full Status Check"). Do not rewrite the addresses already programmed. Figure 30.19 shows a flowchart of the Program Command (Suspend Function Disabled). The lock bit protects individual blocks from being programmed inadvertently. (Refer to 30.8.4 "Data Protect Function".) In EW1 mode, do not execute this command on a block to which the rewrite control program is allocated. Figure 30.19 Program Command (Suspend Function Disabled) ### 30.8.6.5 Block Erase Command By writing xx20h in the first bus cycle and xxD0h to the highest even address of a block in the second bus cycle, an auto-erase operation (erase and verify) is started on the specified block. The FMR00 bit in the FMR0 register indicates whether the auto-erase operation has been completed. The FMR00 bit is 0 (busy) during the auto-erase operation, and becomes 1 (ready) when the auto-erase operation is completed. Do not execute other commands while the FMR00 bit is 0. After the auto erase operation is completed, the FMR07 bit in the FMR0 register indicates whether or not the auto erase operation has been completed as expected. (Refer to 30.8.7.1 "Full Status Check"). Figure 30.20 shows a flowchart of the Block Erase Command (Suspend Function Disabled). The lock bit protects individual blocks from being erased inadvertently. (Refer to 30.8.4 "Data Protect Function") In EW1 mode, do not execute this command on the block to which the rewrite control program is allocated. Figure 30.20 Block Erase Command (Suspend Function Disabled) # 30.8.6.6 Lock Bit Program Command The lock bit program command is used to set the lock bit for a specified block to 0 (locked). By writing xx77h in the first bus cycle and xxD0h to the highest even address of a block in the second bus cycle, the lock bit for the specified block is set to 0. The address value specified in the first bus cycle must be the same highest address of a block specified in the second bus cycle. Figure 30.21 shows a flowchart of the Lock Bit Program Command (Suspend Function Disabled). Execute the read lock bit status command to read the lock bit state (lock bit data). The FMR00 bit in the FMR0 register indicates whether a lock bit program operation has been completed. Do not execute other commands while the FMR00 bit is 0. Refer to 30.8.4 "Data Protect Function", for details on lock bit functions and how to set it to 1 (unlocked). Figure 30.21 Lock Bit Program Command (Suspend Function Disabled) ## 30.8.6.7 Read Lock Bit Status The read lock bit status command is used to read the lock bit state of a specified block. By writing xx71h in the first bus cycle and xxD0h to the highest even address of a block in the second bus cycle, the FMR16 bit in the FMR1 register stores information on the lock bit status of a specified block. Read the FMR16 bit after the FMR00 bit in the FMR0 register becomes 1 (ready). Do not execute other commands while the FMR00 bit is 0. Figure 30.22 shows a flowchart of the Read Lock Bit Status Command. Figure 30.22 Read Lock Bit Status Command #### 30.8.6.8 Block Blank Check Command The block blank check command is used to check whether or not a specified block is blank (state after erase). By writing xx25h in the first bus cycle and xxD0h in the second bus cycle to the highest even address of a block, the check result is stored in the FMR07 bit in the FMR0 register. Read the FMR07 bit after the FMR00 bit in the FMR0 register is set to 1 (ready). Do not execute other commands while the FMR00 bit is 0. The block blank check command is valid for unlocked blocks. If the block blank check command is executed on a block whose lock bit is 0 (locked), the FMR07 bit (SR5) is set to 1 (not blank) regardless of the FMR02 bit state. Figure 30.23 shows a flowchart of the Block Blank Check Command. Figure 30.23 Block Blank Check Command As a result of block blank check, when the block is not blank, execute the clear status register command before executing other software commands. The block blank check command is designated for use with a programmer. Use this command where instantaneous power failures do not occur. When an instantaneous power failure occurs while the block erase command is executed, execute the block erase command again. The block blank check command cannot be used to check whether the erase operation is successfully completed or not. Do not execute the block blank check command during suspend. # 30.8.7 Status Register The status register indicates flash memory operating state and whether or not an erase or program operation has been completed as expected. Bits FMR00, FMR06, and FMR07 in the FMR0 register indicate status register states. Refer to 30.3.1 "Flash Memory Control Register 0 (FMR0)" for a description of each bit. Table 30.17 Difference in Reading of Status Register | Item | FMR0 register | Command | |-----------|-------------------------|-------------------------------------------------------------| | Condition | No limit | | | Reading | Read bits FMR00, FMR06, | Read any even address in program ROM 1, program | | procedure | and FMR07 in the FMR0 | ROM 2, or data flash after writing the read status register | | | register | command. | | | | Read any even address in program ROM 1, program | | | | ROM 2, or data flash after executing the program | | | | command, block erase command, lock bit program | | | | command, or block blank check command before | | | | executing the read array command. | ### Table 30.18 Status Register | Bits in Status | Bit in FMR0 | Status | Status | | Reset Value | |----------------|-------------|------------------|-----------------------|--------------------|--------------| | Register | Register | | 0 | 1 | 110001 10100 | | SR0 (D0) | - | Reserved | - | - | - | | SR1 (D1) | - | Reserved | - | - | - | | SR2 (D2) | - | Reserved | - | - | - | | SR3 (D3) | - | Reserved | - | - | - | | SR4 (D4) | FMR06 | Program status | Completed as expected | Completed in error | 0 | | SR5 (D5) | FMR07 | Erase status | Completed as expected | Completed in error | 0 | | SR6 (D6) | - | Reserved | - | - | - | | SR7 (D7) | FMR00 | Sequencer status | Busy | Ready | 1 | D0 to D7: The data buses read when the read status register command is executed. ## 30.8.7.1 Full Status Check If an error occurs, bits FMR06 and FMR07 in the FMR0 register become 1, indicating the occurrence of an error. Therefore, the execution results can be confirmed by checking these status bits (full status check). Table 30.19 Errors and FMR0 Register States | FMR00 Register | | Error | Error Occurrence Conditions | | |----------------|-----------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | FMR07 bit | FMR06 bit | Ellol | End Occurrence Conditions | | | | 1 | | Command is written incorrectly. | | | 1 | | Command | Data other than xxD0h and xxFFh is written in the second | | | | | sequence error | bus cycle of the lock bit program, block erase, block | | | | | | blank check, or read lock bit status command. (1) | | | 1 | 0 | Erase error | • The block erase command is executed on a locked block. (2) | | | | | | <ul> <li>The block erase command is executed on an unlocked block, but the auto-erase operation is not completed as expected.</li> <li>The block blank check command is executed, and the check result is not blank.</li> </ul> | | | 0 | 1 | Program error | <ul> <li>The program command is executed on a locked block. (2)</li> <li>The program command is executed on an unlocked block, but the auto-program operation is not completed as expected.</li> <li>The lock bit program command is executed, but the lock bit is not written as expected.</li> </ul> | | ### Notes: - 1. When writing xxFFh in the second bus cycle of the command, the flash memory becomes the state before executing the command, and the command code written in the first bus cycle is cancelled. - 2. When the FMR02 bit is 1 (lock bit disabled), no error occurs even under the conditions above. Figure 30.24 Full Status Check # 30.8.7.2 Handling Procedure for Errors When errors occur, follow the procedures below. Do not execute the program, block erase, lock bit program, and block blank check commands when either FMR06 or FMR07 bit is 1 (completed in error). Execute each command after executing the clear status register command. #### Command sequence error - (1) Execute the clear status register command and set bits FMR06 and FMR07 to 0 (completed as expected). - (2) Check if the command is written correctly and execute the correct command. #### Erase error - (1) Execute the clear status register command and set the FMR07 bit to 0 (completed as expected). - (2) Execute the read lock bit status command. If the lock bit in the block where the error occurred is set to 0 (locked), set the FMR02 bit in the FMR register to 1 (lock bit disabled). - (3) Execute the block erase command again. - (4) Repeat (1) to (3) until an erase error is not generated. If an error still occurs even after repeating three times, do not use that block. When handling an erase error of the block blank check command and erasing is not necessary, execute (1) only. ### Program error [When a program operation is executed] - (1) Execute the clear status register command and set the FMR06 bit to 0 (completed as expected). - (2) Execute the read lock bit status command. If the lock bit in the block where the error occurred is set to 0, set the FMR02 bit in the FMR0 register to 1. - (3) Execute the program command again. If the lock bit is set to 1 (unlocked), do not use the address in which error has occurred as it is. Execute the block erase command to erase the block, in which the error has occurred, before executing the program command to write to the same address again. If an error still occurs, do not use that block. [When a lock bit program operation is executed] - (1) Execute the clear status register command and set the FMR06 bit to 0. - (2) Set the FMR02 bit in the FMR0 register to 1. - (3) Execute the block erase command to erase the block where the error occurred. - (4) Execute the lock bit program command again after writing the data as needed. If an error still occurs, do not use that block. ## 30.9 Standard Serial I/O Mode In standard serial I/O mode, a serial programmer supporting the M16C/65C Group can be used to rewrite program ROM 1, program ROM 2, and data flash while the MCU is mounted on a board. Standard serial I/O mode has following modes: - Standard serial I/O mode 1: The MCU is connected to the serial programmer by using clock synchronous serial I/O - Standard serial I/O mode 2: The MCU is connected to the serial programmer by using 2-wire clock asynchronous serial I/O For more information about the serial programmer, contact the serial programmer manufacturer. Refer to the user's manual included with your serial programmer for instructions. ### 30.9.1 ID Code Check Function Use the ID code check function in standard serial I/O mode. This function determines whether the ID codes sent from the serial programmer match those written in the flash memory. If the ID codes do not match, commands sent from the serial programmer are not accepted. However, if the 4 bytes of the reset vector are FFFFFFFh, ID codes are not compared, allowing all commands to be accepted. The ID codes are 7-byte data stored consecutively, starting with the first byte, at addresses 0FFFDFh, 0FFFE3h, 0FFFE8h, 0FFFE9h, 0FFFF7h, and 0FFFBh. The flash memory must have a program with the ID codes set in these addresses. Figure 30.25 shows ID Code Storage Addresses. The ID code of "ALERASE" in ASCII code is used for forced erase function. The ID code "Protect" in ASCII code is used for standard serial I/O mode disable function. Table 30.20 lists Reserved Word of ID Code. All ID code storage addresses and data must match the combinations listed in Table 30.20. When the forced erase function or standard serial I/O mode disable function is not used, use another combination of ID codes. Table 30.20 Reserved Word of ID Code | ID Code Storage Address | | Reserved Word of ID Code (ASCII) | | | |-------------------------|-----|----------------------------------|--------------------|--| | | | ALeRASE | Protect | | | FFFDFh | ID1 | 41h (upper-case A) | 50h (upper-case P) | | | FFFE3h | ID2 | 4Ch (upper-case L) | 72h (lower-case r) | | | FFFEBh | ID3 | 65h (lower-case e) | 6Fh (lower-case o) | | | FFFEFh | ID4 | 52h (upper-case R) | 74h (lower-case t) | | | FFFF3h | ID5 | 41h (upper-case A) | 65h (lower-case e) | | | FFFF7h | ID6 | 53h (upper-case S) | 63h (lower-case c) | | | FFFFBh | ID7 | 45h (upper-case E) | 74h (lower-case t) | | All ID code storage addresses and data must match the combinations listed in Table 30.20. Figure 30.25 ID Code Storage Addresses #### 30.9.2 Forced Erase Function Use the forced erase function in standard serial I/O mode. When the reserved word, "ALeRASE" in ASCII code, is sent from the serial programmer as an ID code, the contents of program ROM 1 and program ROM 2 will all be erased. However, if the ID codes stored in the ID code storage addresses are set to a reserved word other than "ALERASE" (other than the combination table listed in Table 30.20), the ROMCR bit in the OFS1 address is 1 (ROMCP1 bit enabled), and the ROMCP1 bit in the OFS1 address is 0 (ROM code protect enabled), the forced erase function is ignored and ID code check is executed by the ID code check function. Table 30.21 lists conditions and functions for forced erase function. When both the ID codes sent from the serial programmer and the ID codes stored in the ID code storage addresses correspond to the reserved word "ALERASE", program ROM 1 and program ROM 2 will be erased. However, when the serial programmer sends other than "ALERASE", even if the ID codes stored in the ID code storage addresses are "ALERASE", there is no ID match and no command is accepted. The flash memory cannot be operated. Table 30.21 Forced Erase Function | | Condition | | | | |-----------------------|--------------------------------------|-------------------------------|-------------------------------------------------------------------|--| | ID code from serial | Code in ID code | ROMCP1 bit in the | Function | | | programmer | storage address | OFS1 address | | | | ALeRASE | ALeRASE | _ | Program ROM 1 and program ROM 2 all erase (forced erase function) | | | | Other than<br>ALeRASE (1) | 1 (ROM code protect disabled) | | | | | | 0 (ROM code protect enabled) | ID code check (ID code check function) | | | Other than<br>ALeRASE | ALeRASE | _ | ID code check (ID code check function. No ID match) | | | | Other than<br>ALeRASE <sup>(1)</sup> | - | ID code check (ID code check function) | | Note: ### 30.9.3 Standard Serial I/O Mode Disable Function Use the standard serial I/O mode disable function in standard serial I/O mode. When the ID codes in the ID code stored addresses are set to "Protect" in ASCII code (see Table 30.20 "Reserved Word of ID Code"), the MCU does not communicate with the serial programmer. Therefore, the flash memory cannot be read, written or erased by the serial programmer. User boot mode can be selected even when the ID codes are set to "Protect". When the ID codes are set to "Protect", the ROMCR bit in the OFS1 address is 1 (ROMCP1 bit enabled), and the ROMCP1 bit in the OFS1 address is set to 0 (ROM code protect enabled), ROM code protection cannot be disabled by the serial programmer. Therefore, the flash memory cannot be read, written, or erased by the serial or parallel programmer. <sup>1.</sup> When the combination of the stored addresses is "Protect", refer to 30.9.3 "Standard Serial I/O Mode Disable Function". # 30.9.4 Standard Serial I/O Mode 1 In standard serial I/O mode 1, a serial programmer is connected to the MCU using clock synchronous serial I/O. Table 30.22 Pin Functions (Flash Memory Standard Serial I/O Mode 1) | Pin | Name | I/O | Power<br>Supply | Description | |-----------------------------|---------------------------|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VCC1, VCC2,<br>VSS | Power input | | - | Apply the flash memory program and erase voltage to the VCC1 pin, and VCC2 to the VCC2 pin. The VCC application condition is that VCC2 ≤ VCC1. Apply 0 V to the VSS pin. | | CNVSS | CNVSS | I | VCC1 | Connect to the VCC1 pin. | | RESET | Reset input | I | VCC1 | Reset input pin. | | XIN | Clock input | I | | Input a high-level signal to the XIN pin and open the XOUT pin | | XOUT | Clock output | 0 | VCC1 | when the main clock is not used. Connect a ceramic resonator or crystal between pins XIN and XOUT when the main clock is used. To input an externally generated clock, input it to the XIN pin and open the XOUT pin. | | BYTE | BYTE input | I | VCC1 | Connect this pin to VSS or VCC1. | | AVCC, AVSS | Analog power supply input | | | Connect the AVCC pin to VCC1 and the AVSS pin to VSS, respectively. | | VREF | Reference voltage input | I | | Reference voltage input pin for A/D converter. When using standard serial I/O mode 1, and power supply to VREF is not supplied, connect with VSS. | | P0_0 to P0_7 | Input port P0 | I | VCC2 | Input a high- or low-level signal or leave open. | | P1_0 to P1_7 | Input port P1 | I | VCC2 | Input a high- or low-level signal or leave open. | | P2_0 to P2_7 | Input port P2 | I | VCC2 | Input a high- or low-level signal or leave open. | | P3_0 to P3_7 | Input port P3 | I | VCC2 | Input a high- or low-level signal or leave open. | | P4_0 to P4_7 | Input port P4 | I | VCC2 | Input a high- or low-level signal or leave open. | | P5_1 to P5_4,<br>P5_6, P5_7 | Input port P5 | I | VCC2 | Input a high- or low-level signal or leave open. | | P5_0 | CE input | I | VCC2 | Input a high-level signal. | | P5_5 | EPM input | I | VCC2 | Input a low-level signal. | | P6_0 to P6_3 | Input port P6 | I | VCC1 | Input a high- or low-level signal or leave open. | | P6_4 / RTS1 | BUSY output | 0 | VCC1 | BUSY signal output pin | | P6_5/CLK1 | SCLK input | I | VCC1 | Serial clock input pin | | P6_6 / RXD1 | RXD input | I | VCC1 | Serial data input pin. | | P6_7 / TXD1 | TXD output | 0 | VCC1 | Serial data output pin. | | P7_0 to P7_7 | Input port P7 | 1 | VCC1 | Input a high- or low-level signal or leave open. | | P8_0 to P8_7 | Input port P8 | I | VCC1 | Input a high- or low-level signal or leave open. | | P9_0 to P9_7 | Input port P9 | I | VCC1 | Input a high- or low-level signal or leave open. | | P10_0 to P10_7 | Input port P10 | I | VCC1 | Input a high- or low-level signal or leave open. | | P11_0 to P11_7 | Input port P11 | I | VCC1 | Input a high- or low-level signal or leave open. | | P12_0 to P12_7 | Input port P12 | I | VCC2 | Input a high- or low-level signal or leave open. | | P13_0 to P13_7 | Input port P13 | I | VCC2 | Input a high- or low-level signal or leave open. | | P14_0 to P14_1 | Input port P14 | ı | VCC1 | Input a high- or low-level signal or leave open. | Table 30.23 Setting of Standard Serial I/O Mode 1 | Signal | Input Level | |--------|-------------| | CNVSS | VCC1 | | EPM | VSS | | RESET | VSS → VCC1 | | CE | VCC2 | | SCLK | VCC1 | Figure 30.26 Circuit Application in Standard Serial I/O Mode 1 # 30.9.5 Standard Serial I/O Mode 2 In standard serial I/O mode 2, a serial programmer is connected to the MCU by using 2-wire clock asynchronous serial I/O. The main clock is used. Table 30.24 Pin Functions (Flash Memory Standard Serial I/O Mode 2) | Pin | Name | I/O | Power<br>Supply | Description | |-----------------------------|---------------------------|-----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VCC1, VCC2,<br>VSS | Power input | | - | Apply the flash memory program and erase voltage to the VCC1 pin, and VCC2 to the VCC2 pin. The VCC application condition is that VCC2 ≤ VCC1. Apply 0 V to the VSS pin. | | CNVSS | CNVSS | I | VCC1 | Connect to the VCC1 pin. | | RESET | Reset input | ı | VCC1 | Reset input pin. | | XIN | Clock input | ı | VCC1 | Connect a ceramic resonator or crystal between pins XIN and | | XOUT | Clock output | 0 | VCC1 | XOUT. To input an externally generated clock, input it to the XIN pin and open the XOUT pin. | | BYTE | BYTE input | | VCC1 | Connect this pin to VSS or VCC1. | | AVCC, AVSS | Analog power supply input | | | Connect the AVCC pin to VCC1 and the AVSS pin to VSS. | | VREF | Reference voltage input | 1 | | Reference voltage input pin for A/D converter. When using standard serial I/O mode 2, and power supply to VREF is not supplied, connect with VSS. | | P0_0 to P0_7 | Input port P0 | I | VCC2 | Input a high- or low-level signal or leave open. | | P1_0 to P1_7 | Input port P1 | ı | VCC2 | Input a high- or low-level signal or leave open. | | P2_0 to P2_7 | Input port P2 | ı | VCC2 | Input a high- or low-level signal or leave open. | | P3_0 to P3_7 | Input port P3 | ı | VCC2 | Input a high- or low-level signal or leave open. | | P4_0 to P4_7 | Input port P4 | I | VCC2 | Input a high- or low-level signal or leave open. | | P5_1 to P5_4,<br>P5_6, P5_7 | Input port P5 | I | VCC2 | Input a high- or low-level signal or leave open. | | P5_0 | CE input | ı | VCC2 | Input a high-level signal. | | P5_5 | EPM input | ı | VCC2 | Input a low-level signal. | | P6_0 to P6_3 | Input port P6 | ı | VCC1 | Input a high- or low-level signal or leave open. | | P6_4 / RTS1 | BUSY output | 0 | VCC1 | Monitor signal output pin for checking the boot program operation. | | P6_5/CLK1 | SCLK input | ı | VCC1 | Input a low-level signal | | P6_6 / RXD1 | RXD input | ı | VCC1 | Serial data input pin. | | P6_7 / TXD1 | TXD output | 0 | VCC1 | Serial data output pin. | | P7_0 to P7_7 | Input port P7 | I | VCC1 | Input a high- or low-level signal or leave open. | | P8_0 to P8_7 | Input port P8 | I | VCC1 | Input a high- or low-level signal or leave open. | | P9_0 to P9_7 | Input port P9 | I | VCC1 | Input a high- or low-level signal or leave open. | | P10_0 to P10_7 | Input port P10 | I | VCC1 | Input a high- or low-level signal or leave open. | | P11_0 to P11_7 | Input port P11 | I | VCC1 | Input a high- or low-level signal or leave open. | | P12_0 to P12_7 | Input port P12 | I | VCC2 | Input a high- or low-level signal or leave open. | | P13_0 to P13_7 | Input port P13 | - 1 | VCC2 | Input a high- or low-level signal or leave open. | | P14_0 to P14_1 | Input port P14 | I | VCC1 | Input a high- or low-level signal or leave open. | Table 30.25 Setting of Standard Serial I/O Mode 2 | Signal | Input Level | |-----------|-------------| | CNVSS | VCC1 | | EPM | VSS | | RESET | VSS → VCC1 | | CE | VCC2 | | P6_5/CLK1 | VSS | Figure 30.27 Circuit Application in Standard Serial I/O Mode 2 #### 30.10 Parallel I/O Mode In parallel I/O mode, program ROM 1, program ROM 2, and data flash can be rewritten using a parallel programmer supporting the M16C/65C Group. Contact the parallel programmer manufacturer for more information. Refer to the user's manual included with your parallel programmer for instructions. #### 30.10.1 ROM Code Protect Function The ROM code protect function disables the flash memory from being read or rewritten during parallel I/O mode. Refer to 30.4.1 "Optional Function Select Address 1 (OFS1)". The OFS1 address is located in block 0 of program ROM 1. When the ROMCR bit in the OFS1 address is 1 (ROMCP1 bit enabled) and the ROMCP1 bit is set to 0, the ROM code protect function is enabled. To cancel ROM code protect, erase block 0 including the OFS1 address using standard serial I/O mode or CPU rewrite mode. # 30.11 Notes on Flash Memory #### 30.11.1 OFS1 Address and ID Code Storage Address The OFS1 address and ID code storage address are part of flash memory. When writing a program to flash memory, write an appropriate value to those addresses simultaneously. In the OFS1 address, the MCU state after reset and the function to prevent rewrite in parallel I/O mode are selected. The OFS1 address is 0FFFFFh. This is the most significant address of block 0 in program ROM 1 and upper address of reset vector. Also, the ID code storage address is in block 0 and upper address of the interrupt vector. The ID code check function cannot be disabled. Even if the protect using the ID code check function is unnecessary, input the appropriate ID code when using a serial programmer or debugger. Without the appropriate ID code, the serial programmer or debugger cannot be used. ex) Set FEh to the OFS1 address When using an address control instruction and logical addition: .org 0FFFFCh RESET: .lword start | 0FE000000h When using an address control instruction: .org 0FFFFCh RESET: .addr start .byte 0FEh (Program format varies depending on the compiler. Refer to the compiler manual.) #### 30.11.2 Reading Data Flash When $2.7 \text{ V} \le \text{VCC1} \le 3.0 \text{ V}$ and $f(\text{BCLK}) \ge 16 \text{ MHz}$ , or $3.0 \text{ V} < \text{VCC1} \le 5.5 \text{ V}$ and $f(\text{BCLK}) \ge 20 \text{ MHz}$ , one wait must be inserted to execute the program on the data flash and read the data. Set the PM17 in the PM1 register or FMR17 bit in the FMR1 register to insert one wait. #### 30.11.3 CPU Rewrite Mode # 30.11.3.1 Operating Speed Select a CPU clock frequency of 10 MHz or less by setting the CM06 bit in the CM0 register and bits CM17 and CM16 in the CM1 register before entering CPU rewrite mode (EW0 or EW1 mode). Also, set the PM17 bit in the PM1 register to 1 (wait state). #### 30.11.3.2 CPU Rewrite Mode Select Change FMR01 bit in the FMR0 register, FMR11 bit in the FMR1 register, and FMR60 bit in the FMR6 register while in the following state: - The PM24 bit in the PM2 register is 0 (NMI interrupt disabled). - High is input to the NMI pin. Change the FMR60 bit while the FMR00 bit in the FMR0 register is 1 (ready). #### 30.11.3.3 Prohibited Instructions Do not use the following instructions in EW0 mode: UND instruction, INTO instruction, JMPS instruction, JSRS instruction, and BRK instruction. ### 30.11.3.4 Interrupts (EW0 Mode and EW1 Mode) - Do not use an address match interrupt during command execution because the address match interrupt vector is located in ROM. - Do not use a non-maskable interrupt during block 0 erase because fixed vector is located in block 0. ### 30.11.3.5 Rewrite (EW0 Mode) If the power supply voltage drops while rewriting the block where the rewrite control program is stored, the rewrite control program is not correctly rewritten. This may prevent the flash memory from being rewritten. If this error occurs, use standard serial I/O mode or parallel I/O mode for rewriting. #### 30.11.3.6 Rewrite (EW1 Mode) Do not rewrite any blocks in which the rewrite control program is stored. #### 30.11.3.7 DMA transfer In EW0 mode, do not use flash memory as a source of the DMA transfer. In EW1 mode, do not generate a DMA transfer while the FMR00 bit in the FMR0 register is 0 (auto programming or auto erasing). #### 30.11.3.8 Wait Mode To enter wait mode, set the FMR01 bit in the FMR0 register to 0 (CPU rewrite mode disabled) before executing the WAIT instruction. #### 30.11.3.9 Stop Mode To enter stop mode, set the FMR01 bit to 0 (CPU rewrite mode disabled), and then disable DMA transfer before setting the CM10 bit in the CM 1 register to 1 (stop mode). #### 30.11.3.10 Software Command Observe the notes below when using the following commands. - Program - Block erase - Lock bit program - Read lock bit status - Block blank check - (a) The FMR00 bit in the FMR0 register indicates the status while executing these commands. Do not execute other commands while the FMR00 bit is 0 (busy). - (b) Use these commands in 40 MHz on-chip oscillator mode, high-speed mode, medium-speed mode, and PLL operating mode. Do not change clock modes while the FMR00 bit in the FMR0 register is 0 (busy). - (c) After executing the program, block erase, or lock bit program command, perform a full status check per command (Do not execute multiple commands or same command more than once before performing a full status check). - (d) Do not execute the program, block erase, lock bit program, or block blank check command when either or both bits FMR06 and FMR07 in the FMR0 register are 1 (error). - (e) Do not use these commands in slow read mode (when the FMR22 bit is 1) or low current consumption read mode (when both bits FMR22 and FMR23 are 1). #### 30.11.3.11 PM13 Bit The PM13 bit in the PM1 register becomes 1 while the FMR01 bit in the FMR0 register is 1 (CPU rewrite mode enabled). The PM13 bit returns to the former value by setting the FMR01 bit to 0 (CPU rewrite mode disabled). When the PM13 bit is changed during CPU rewrite mode, the value of the PM13 bit after being changed is not reflected until the FMR01 bit is set to 0. #### 30.11.3.12 Area Where the Rewrite Control Program is Executed Bits PM10 and PM13 in the PM1 register become 1 in CPU rewrite mode. Execute the rewrite program in internal RAM or an external area which can be used when both bits PM10 and PM13 are 1. Do not use the area (40000h to BFFFFh) where accessible space is expanded when the PM13 bit is 0 and 4-MB mode is set. #### 30.11.3.13 Program and Erase Cycles and Execution Time Execution time of the program, block erase, and lock bit program commands becomes longer as the number of programming and erasing increases. #### 30.11.3.14 Suspending the Auto-Erase and Auto-Program Operations When the program, block erase, and lock bit program commands are suspended, the blocks for those commands must be erased. Execute the program and lock bit program commands again after erasing. Those commands are suspended by the following reset or interrupts: - Hardware, power-on, voltage monitor 0, voltage monitor 1, voltage monitor 2, oscillator stop detect, watchdog timer, software resets. - NMI, watchdog timer, oscillator stop/restart detect, voltage monitor 1, and voltage monitor 2 interrupts. #### 30.11.4 User Boot #### 30.11.4.1 User Boot Mode Program Note the following when using user boot mode: - When using user boot mode, make sure to allocate the program to be executed to program ROM 2. - Bits VDSEL1 and LVDAS in the OFS1 address are disabled in boot mode. - When restarting the MCU in user boot mode after starting it in user boot mode, RAM becomes undefined. - If addresses 13FF8h to 13FF8h are all 00h, the MCU does not enter standard serial I/O mode. Therefore, the programmer or on-chip debugger cannot be connected. - As the reset sequence differs, the time necessary for starting the program is longer than in singlechip mode. - Functions in user boot mode cannot be debugged by the on-chip debugging emulator or full spec emulator. - While using user boot mode, do not change the input level of the pin used for user boot entry. However, if there is a possibility that the input level may change, perform the necessary processes in user boot mode, then restart the MCU in single-chip mode before the input level changes. - To use user boot mode after standard serial I/O mode, turn off the power when exiting standard serial I/O mode, and then turn on the power again (cold start). The MCU enters user boot mode under the right conditions. # 31. Electrical Characteristics # 31.1 Electrical Characteristics (Common to 3 V and 5 V) # 31.1.1 Absolute Maximum Rating Table 31.1 Absolute Maximum Ratings | Symbol | | Parameter | Condition | Rated Value | Unit | |------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------------------------------------|------| | V <sub>CC1</sub> | Supply voltage | | $V_{CC1} = AV_{CC}$ | -0.3 to 6.5 | V | | $V_{CC2}$ | Supply voltage | | $V_{CC1} = AV_{CC}$ | $-0.3$ to $V_{\rm CC1}$ + 0.1 $^{(1)}$ | V | | AV <sub>CC</sub> | Analog supply | voltage | $V_{CC1} = AV_{CC}$ | -0.3 to 6.5 | V | | $V_{REF}$ | Analog referen | ce voltage | $V_{CC1} = AV_{CC}$ | $-0.3$ to $V_{\rm CC1}$ + 0.1 <sup>(1)</sup> | V | | Vı | Input voltage | RESET, CNVSS, BYTE, P6_0 to P6_7, P7_2 to P7_7, P8_0 to P8_4, P8_6, P8_7, P9_0 to P9_7, P10_0 to P10_7, P11_0 to P11_7, P14_0, P14_1 XIN | | -0.3 to V <sub>CC1</sub> + 0.3 <sup>(1)</sup> | V | | | | P0_0 to P0_7, P1_0 to P1_7,<br>P2_0 to P2_7, P3_0 to P3_7,<br>P4_0 to P4_7, P5_0 to P5_7,<br>P12_0 to P12_7, P13_0 to P13_7 | | $-0.3$ to $V_{CC2}$ + $0.3$ <sup>(1)</sup> | V | | | | P7_0, P7_1, P8_5 | | -0.3 to 6.5 | V | | Vo | Output voltage | P6_0 to P6_7, P7_2 to P7_7,<br>P8_0 to P8_4, P8_6, P8_7,<br>P9_0 to P9_7, P10_0 to P10_7,<br>P11_0 to P11_7, P14_0, P14_1<br>XOUT | | $-0.3$ to $V_{CC1}$ + $0.3$ <sup>(1)</sup> | > | | | | P0_0 to P0_7, P1_0 to P1_7,<br>P2_0 to P2_7, P3_0 to P3_7,<br>P4_0 to P4_7, P5_0 to P5_7,<br>P12_0 to P12_7, P13_0 to P13_7 | | $-0.3$ to $V_{CC2}$ + $0.3$ <sup>(1)</sup> | V | | | | P7_0, P7_1, P8_5 | | -0.3 to 6.5 | V | | $P_d$ | Power consum | ption | -40°C < T <sub>opr</sub> ≤ 85°C | 300 | mW | | T <sub>opr</sub> | Operating temperature | When the MCU is operating Flash program erase | Program area Data area | -20 to 85/-40 to 85<br>0 to 60<br>-20 to 85/-40 to 85 | °C | | T <sub>stg</sub> | Storage tempe | I<br>rature | _ 3.0 0.00 | -65 to 150 | °C | Note: 1. Maximum value is 6.5 V. 31. Electrical Characteristics # 31.1.2 Recommended Operating Conditions Table 31.2 Recommended Operating Conditions (1/3) $V_{CC1} = V_{CC2} = 2.7$ to 5.5 V at $T_{opr} = -20$ °C to 85°C/-40°C to 85°C unless otherwise specified. | Symbol | Parameter | | , | Standard | d | Unit | | |----------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|---------------------|----------------------|----------------------|-------| | Symbol | | | | | Тур. | Max. | Offic | | $V_{CC1}$ , | Supply volta | age (V <sub>CC1</sub> ≥ V <sub>CC2</sub> ) | CEC function is not used | 2.7 | 5.0 | 5.5 | V | | $V_{CC2}$ | | | CEC function is used | 2.7 | | 3.63 | V | | AV <sub>CC</sub> | Analog sup | ply voltage | | | V <sub>CC1</sub> | | V | | V <sub>SS</sub> | Supply volta | age | | | 0 | | V | | AV <sub>SS</sub> | Analog sup | ply voltage | | 0 | | V | | | V <sub>IH</sub> | High input voltage | P3_1 to P3_7, P4_0 to P4_7, P5_0<br>P12_0 to P12_7, P13_0 to P13_7 | to P5_7, | 0.8V <sub>CC2</sub> | | V <sub>CC2</sub> | V | | | | P0_0 to P0_7, P1_0 to P1_7, P2_0 (in single-chip mode) | to P2_7, P3_0 | 0.8V <sub>CC2</sub> | | V <sub>CC2</sub> | V | | | | P0_0 to P0_7, P1_0 to P1_7, P2_0 (data input in memory expansion armodes) | * | 0.5V <sub>CC2</sub> | | V <sub>CC2</sub> | V | | | | P6_0 to P6_7, P7_2 to P7_7, P8_0<br>P9_0 to P9_7, P10_0 to P10_7, P1<br>P14_1<br>XIN, RESET, CNVSS, BYTE | | 0.8V <sub>CC1</sub> | | V <sub>CC1</sub> | V | | | | P7_0, P7_1, P8_5 | 0.8V <sub>CC1</sub> | | 6.5 | V | | | | | CEC | | 0.7V <sub>CC1</sub> | | | V | | V <sub>IL</sub> | Low input voltage | P3_1 to P3_7, P4_0 to P4_7, P5_0 to P5_7, P12_0 to P12_7, P13_0 to P13_7 | | 0 | | 0.2V <sub>CC2</sub> | V | | | | P0_0 to P0_7, P1_0 to P1_7, P2_0 (in single-chip mode) | 0 | | 0.2V <sub>CC2</sub> | V | | | | | P0_0 to P0_7, P1_0 to P1_7, P2_0 (data input in memory expansion ar | 0 | | 0.16V <sub>CC2</sub> | V | | | | | P6_0 to P6_7, P7_0 to P7_7, P8_0<br>P10_0 to P10_7,P11_0 to P11_7, F<br>XIN, RESET, CNVSS, BYTE | | 0 | | 0.2V <sub>CC1</sub> | V | | | | CEC | | | | 0.26V <sub>CC1</sub> | V | | I <sub>OH(sum)</sub> | High peak output | Sum of I <sub>OH(peak)</sub> at P0_0 to P0_7, I<br>P2_0 to P2_7 | P1_0 to P1_7, | | | -40.0 | mA | | | current | Sum of I <sub>OH(peak)</sub> at P3_0 to P3_7, F<br>P5_0 to P5_7, P12_0 to P12_7, an | | | | -40.0 | mA | | | | Sum of I <sub>OH(peak)</sub> at P6_0 to P6_7, F<br>P8_0 to P8_4 | | | | -40.0 | mA | | | | Sum of I <sub>OH(peak)</sub> at P8_6, P8_7, P9<br>P10_0 to P10_7, P11_0 to P11_7, I | | | | -40.0 | mA | | IOH(peak) | High peak<br>output<br>current | P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7, P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7, P6_0 to P6_7, P7_2 to P7_7, P8_0 to P8_4, P8_6, P8_7, P9_0 to P9_7, P10_0 to P10_7, P11_0 to P11_7, P12_0 to P12_7, P13_0 to P13_7, P14_0, P14_1 | | | | -10.0 | mA | | I <sub>OH(avg)</sub> | High<br>average<br>output<br>current (1) | P0_0 to P0_7, P1_0 to P1_7, P2_0 P3_0 to P3_7, P4_0 to P4_7, P5_0 P6_0 to P6_7, P7_2 to P7_7, P8_0 P9_0 to P9_7, P10_0 to P10_7, P1 P12_0 to P12_7, P13_0 to P13_7, | to P5_7,<br>to P8_4, P8_6, P8_7,<br>1_0 to P11_7, | | | -5.0 | mA | <sup>1.</sup> The average output current is the mean value within 100 ms. able 31.3 Recommended Operating Conditions (2/3) $V_{CC1} = V_{CC2} = 2.7 \text{ to } 5.5 \text{ V at T}_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C} / -40^{\circ}\text{C to } 85^{\circ}\text{C} \text{ unless otherwise specified.}$ | Symbol | | Parameter | | | Standard | | Unit | |-----------------------|-----------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|-------| | Symbol | | | Farameter | Min. | Тур. | Max. | Offic | | I <sub>OL(sum)</sub> | Low peak output current | P2_0 to P2 | <sub>peak)</sub> at P0_0 to P0_7, P1_0 to P1_7,<br>_7, P8_6, P8_7, P9_0 to P9_7,<br>10_7, P11_0 to P11_7, P14_0 to P14_1 | | | 80.0 | mA | | | | P5_0 to P5 | <sub>peak)</sub> at P3_0 to P3_7, P4_0 to P4_7,<br>_7, P6_0 to P6_7, P7_0 to P7_7,<br>_5, P12_0 to P12_7, P13_0 to P13_7 | | | 80.0 | mA | | I <sub>OL(peak)</sub> | Low peak<br>output<br>current | P3_0 to P3<br>P6_0 to P6<br>P9_0 to P9 | _7, P1_0 to P1_7, P2_0 to P2_7, _7, P4_0 to P4_7, P5_0 to P5_7, _7, P7_0 to P7_7, P8_0 to P8_7, _7, P10_0 to P10_7, P11_0 to P11_7, 12_7, P13_0 to P13_7, P14_0, P14_1 | | | 10.0 | mA | | I <sub>OL(avg)</sub> | Low<br>average<br>output<br>current (1) | P3_0 to P3<br>P6_0 to P6<br>P9_0 to P9 | _7, P1_0 to P1_7, P2_0 to P2_7, _7, P4_0 to P4_7, P5_0 to P5_7, _7, P7_0 to P7_7, P8_0 to P8_7, _7, P10_0 to P10_7, P11_0 to P11_7, 12_7, P13_0 to P13_7, P14_0, P14_1 | | | 5.0 | mA | | f <sub>(XIN)</sub> | Main clock oscillation | • | V <sub>CC1</sub> = 2.7 V to 5.5 V | 2 | | 20 | MHz | | f <sub>(XCIN)</sub> | Sub clock | oscillation fre | quency | | 32.768 | 50 | kHz | | f <sub>(PLL)</sub> | PLL clock of frequency | oscillation | V <sub>CC1</sub> = 2.7 V to 5.5 V | 10 | | 32 | MHz | | f <sub>(BCLK)</sub> | CPU opera | tion clock | | 2 | | 32 | MHz | | t <sub>SU(PLL)</sub> | PLL freque | • | V <sub>CC1</sub> = 5.0 V | | | 2 | ms | | | synthesize<br>stabilization | | V <sub>CC1</sub> = 3.0 V | | | 3 | ms | The average output current is the mean value within 100 ms. 1. #### **Table 31.4** Recommended Operating Conditions (3/3) (1) $V_{CC1} = 2.7 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_{opr} = -20 ^{\circ}\text{C to } 85 ^{\circ}\text{C}/-40 ^{\circ}\text{C to } 85 ^{\circ}\text{C unless otherwise specified.}$ The ripple voltage must not exceed $V_{r(VCC1)}$ and/or $dV_{r(VCC1)}/dt$ . | Symbol | Parameter | | Unit | | | | |-------------------|---------------------------------|--------------------------|------|------|-------|------| | Symbol | i alametei | Min. | Тур. | Max. | Offic | | | $V_{r(VCC1)}$ | Allowable ripple voltage | V <sub>CC1</sub> = 5.0 V | | | 0.5 | Vp-p | | | | V <sub>CC1</sub> = 3.0 V | | | 0.3 | Vp-p | | $dV_{r(VCC1)}/dt$ | Ripple voltage falling gradient | V <sub>CC1</sub> = 5.0 V | | | 0.3 | V/ms | | | | V <sub>CC1</sub> = 3.0 V | | | 0.3 | V/ms | #### Note: The device is operationally guaranteed under these operating conditions. 1. Figure 31.1 Ripple Waveform #### 31.1.3 A/D Conversion Characteristics # Table 31.5 A/D Conversion Characteristics (1/2) (1) $V_{CC1}$ = AV $_{CC}$ = 3.0 to 5.5 V $\geq$ V $_{CC2}$ $\geq$ V $_{REF}$ , V $_{SS}$ = AV $_{SS}$ = 0 V at T $_{opr}$ = -20°C to 85°C/-40°C to 85°C unless otherwise specified. | Symbol | Parameter | | N | leasuring Condition | | Standar | b | Unit | |-----------------|------------------------------|---------|--------------------------|-------------------------------------------------------------------------------------------------------|------|---------|------|-------| | Gymbol | i arameter | | | leasuring Condition | Min. | Тур. | Max. | Offic | | - | Resolution | | AV <sub>CC</sub> = | $V_{CC1} \ge V_{CC2} \ge V_{REF}$ | | | 10 | Bits | | I <sub>NL</sub> | Integral non-linearity error | 10 bits | V <sub>CC1</sub> = 5.0 V | AN0 to AN7 input,<br>AN0_0 to AN0_7 input,<br>AN2_0 to AN2_7 input,<br>ANEX0, ANEX1 input<br>(Note 2) | | | ±3 | LSB | | | | | V <sub>CC1</sub> = 3.3 V | AN0 to AN7 input,<br>AN0_0 to AN0_7 input,<br>AN2_0 to AN2_7 input,<br>ANEX0, ANEX1 input<br>(Note 2) | | | ±3 | LSB | | | | | V <sub>CC1</sub> = 3.0 V | AN0 to AN7 input,<br>AN0_0 to AN0_7 input,<br>AN2_0 to AN2_7 input,<br>ANEX0, ANEX1 input<br>(Note 2) | | | ±3 | LSB | | - | Absolute accuracy | 10 bits | V <sub>CC1</sub> = 5.0 V | AN0 to AN7 input,<br>AN0_0 to AN0_7 input,<br>AN2_0 to AN2_7 input,<br>ANEX0, ANEX1 input<br>(Note 2) | | | ±3 | LSB | | | | | V <sub>CC1</sub> = 3.3 V | AN0 to AN7 input,<br>AN0_0 to AN0_7 input,<br>AN2_0 to AN2_7 input,<br>ANEX0, ANEX1 input<br>(Note 2) | | | ±3 | LSB | | | | | V <sub>CC1</sub> = 3.0 V | AN0 to AN7 input,<br>AN0_0 to AN0_7 input,<br>AN2_0 to AN2_7 input,<br>ANEX0, ANEX1 input<br>(Note 2) | | | ±3 | LSB | - 1. Use when $AV_{CC} = V_{CC1}$ . - 2. Flash memory rewrite disabled. Except for the analog input pin, set the pins to be measured as input ports and connect them to V<sub>SS</sub>. See Figure 31.2 "A/D Accuracy Measure Circuit". Figure 31.2 A/D Accuracy Measure Circuit Table 31.6 A/D Conversion Characteristics (2/2) (1) $V_{CC1} = AV_{CC} = 3.0 \text{ to } 5.5 \text{ V} \\ \ge V_{CC2} \\ \ge V_{REF}, V_{SS} = AV_{SS} \\ = 0 \text{ V at T}_{opr} \\ = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified.}$ | Symbol | Parameter | | Measuring Condition | Standard | | | Unit | |-------------------|-------------------------|----------------------|---------------------------------------------------------------------|----------|------|------------------|------| | D <sub>NL</sub> [ | | | Weasuring Condition | Min. | Тур. | Max. | Orm | | φAD | A/D operating clock | | $4.0~\textrm{V} \leq \textrm{V}_{\textrm{CC1}} \leq 5.5~\textrm{V}$ | 2 | | 25 | MHz | | | frequency | ANEX0 to ANEX1 input | $3.2 \text{ V} \le \text{V}_{\text{CC1}} \le 4.0 \text{ V}$ | 2 | | 16 | MHz | | | | liiput | $3.0~\textrm{V} \leq \textrm{V}_{\textrm{CC1}} \leq 3.2~\textrm{V}$ | 2 | | 10 | MHz | | | | AN0_0 to AN0_7 | $4.0 \text{ V} \le \text{V}_{CC2} \le 5.5 \text{ V}$ | 2 | | 25 | MHz | | | input, AN2_ | input, AN2_0 to | $3.2 \text{ V} \le \text{V}_{CC2} \le 4.0 \text{ V}$ | 2 | | 16 | MHz | | | | AN2_7 input | $3.0~\textrm{V} \leq \textrm{V}_{\textrm{CC2}} \leq 3.2~\textrm{V}$ | 2 | | 10 | MHz | | - | Tolerance level imped | dance | | | 3 | | kΩ | | D <sub>NL</sub> | Differential non-linear | rity error | (4) | | | ±1 | LSB | | - | Offset error | | (4) | | | ±3 | LSB | | - | Gain error | | (4) | | | ±3 | LSB | | t <sub>CONV</sub> | 10-bit conversion time | е | V <sub>CC1</sub> = 5 V, φAD = 25 MHz | 1.60 | | | μS | | t <sub>SAMP</sub> | Sampling time | | | 0.60 | | | μS | | $V_{REF}$ | Reference voltage | | | 3.0 | | V <sub>CC1</sub> | V | | $V_{IA}$ | Analog input voltage | (2), (3) | | 0 | | $V_{REF}$ | V | #### Notes: - 1. Use when $AV_{CC} = V_{CC1}$ . - 2. When $V_{CC1} \ge V_{CC2}$ , set as below: Analog input voltage (AN0 to AN7, ANEX0, and ANEX1) $\leq$ V<sub>CC1</sub> Analog input voltage (AN0\_0 to AN0\_7 and AN2\_0 to AN2\_7) $\leq$ V<sub>CC2</sub>. - 3. When analog input voltage is over reference voltage, the result of A/D conversion is 3FFh. - 4. Flash memory rewrite disabled. Except for the analog input pin, set the pins to be measured as input ports and connect them to V<sub>SS</sub>. See Figure 31.2 "A/D Accuracy Measure Circuit". #### 31.1.4 D/A Conversion Characteristics **Table 31.7 D/A Conversion Characteristics** $V_{CC1} = AV_{CC} = V_{REF} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = AV_{SS} = 0 \text{ V at } T_{opr} = -20 ^{\circ}\text{C to } 85 ^{\circ}\text{C}/-40 ^{\circ}\text{C to } 85 ^{\circ}\text{C unless otherwise specified.}$ | Symbol | Parameter | Measuring Condition | | Unit | | | |-------------------|--------------------------------------|-----------------------------------------|------|------|------|-------| | Symbol | Falametei | ivieasuring Condition | Min. | Тур. | Max. | Offic | | - | Resolution | | | | 8 | Bits | | - | Absolute Accuracy | | | | 2.5 | LSB | | t <sub>SU</sub> | Setup Time | | | | 3 | μS | | R <sub>O</sub> | Output Resistance | | 5 | 6 | 8.2 | kΩ | | I <sub>VREF</sub> | Reference Power Supply Input Current | See Notes <sup>1</sup> and <sup>2</sup> | | | 1.5 | mA | - 1. This applies when using one D/A converter, with the D/A register for the unused D/A converter set to 00h. - 2. The current consumption of the A/D converter is not included. Also, the I<sub>VREF</sub> of the D/A converter will flow even if the ADSTBY bit in the ADCON1 register is 0 (A/D operation stopped (standby)). # 31.1.5 Flash Memory Electrical Characteristics # Table 31.8 CPU Clock When Operating Flash Memory (f(BCLK)) $V_{CC1}$ = 2.7 to 5.5 V, $T_{opr}$ = -20°C to 85°C/-40°C to 85°C unless otherwise specified. | Symbol | Parameter | Conditions | | Unit | | | |-----------|-----------------------------------|-----------------------------------------------------------|------|------------|-------------------|-------| | Symbol | Faianielei | Conditions | Min. | Тур. | Max. | Offic | | - | CPU rewrite mode | | | | 10 <sup>(1)</sup> | MHz | | f(SLOW_R) | Slow read mode | | | | 5 (3) | MHz | | - | Low current consumption read mode | | | fC(32.768) | 35 | kHz | | - | Data flash read | $2.7 \text{ V} \le \text{V}_{CC1} \le 3.0 \text{ V}$ | | | 16 <sup>(2)</sup> | MHz | | | | $3.0 \text{ V} < \text{V}_{\text{CC1}} \le 5.5 \text{ V}$ | | | 20 (2) | MHz | #### Notes: - 1. Set the PM17 bit in the PM1 register to 1 (one wait). - 2. When the frequency is over this value, set the FMR17 bit in the FMR1 register to 0 (one wait) or the PM17 bit in the PM1 register to 1 (one wait) - 3. Set the PM17 bit in the PM1 register to 1 (one wait). When using 125 kHz on-chip oscillator clock or sub clock as the CPU clock source, a wait is not necessary. #### Table 31.9 Flash Memory (Program ROM 1, 2) Electrical Characteristics $V_{CC1} = 2.7$ to 5.5 V at $T_{opr} = 0$ °C to 60°C (option: -40°C to 85°C), unless otherwise specified. | Symbol | Parameter | Conditions | | rd | Unit | | |------------------------|-------------------------------------------------------------------|---------------------------------------------------------|-----------|------|-----------------------------|-------| | Symbol | r alailletei | Conditions | Min. | Тур. | Max. | Offic | | - | Program and erase cycles (1), (3), (4) | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | 1,000 (2) | | | times | | - | 2 word program time | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | | 150 | 4000 | μS | | - | Lock bit program time | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | | 70 | 3000 | μS | | - | Block erase time | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | | 0.2 | 3.0 | S | | t <sub>d(SR-SUS)</sub> | Time delay from suspend request until suspend | | | | $5 + \frac{3}{f(BCLK)}$ | ms | | - | Interval from erase start/restart until following suspend request | | 0 | | - | μS | | - | Suspend interval necessary for auto-erasure to complete (7) | | 20 | | | ms | | - | Time from suspend until erase restart | | | | $30 + \frac{1}{f_{(BCLK)}}$ | μS | | - | Program, erase voltage | | 2.7 | | 5.5 | V | | - | Read voltage | $T_{opr}$ = -20°C to 85°C/-40°C to 85°C | 2.7 | | 5.5 | V | | - | Program, erase temperature | | 0 | | 60 | °C | | t <sub>PS</sub> | Flash memory circuit stabilization wait time | | | | 50 | μS | | - | Data hold time (6) | Ambient temperature = 55°C | 20 | | | year | - 1. Definition of program and erase cycles: - The program and erase cycles refer to the number of per-block erasures. If the program and erase cycles are n (n = 1,000), each block can be erased n times. For example, if a block is erased after writing 2 word data 16,384 times, each to a different address, this counts as one program and erase cycles. Data cannot be written to the same address more than once without erasing the block (rewrite prohibited). - 2. Cycles to guarantee all electrical characteristics after program and erase. (1 to Min. value can be guaranteed). - 3. In a system that executes multiple programming operations, the actual erasure count can be reduced by writing to sequential addresses in turn so that as much of the block as possible is used up before performing an erase operation. It is advisable to retain data on the erasure cycles of each block and limit the number of erase operations to a certain number. - 4. If an error occurs during block erase, attempt to execute the clear status register command, then execute the block erase command at least three times until the erase error does not occur. - 5. Customers desiring program/erase failure rate information should contact a Renesas Electronics sales office. - The data hold time includes time that the power supply is off or the clock is not supplied. - After an erase start or erase restart, if an interval of at least 20 ms is not set before the next suspend request, the erase sequence cannot be completed. Table 31.10 Flash Memory (Data Flash) Electrical Characteristics $V_{CC1}$ = 2.7 to 5.5 V at $T_{opr}$ = -20 to 85°C/-40 to 85°C, unless otherwise specified. | Symbol | Parameter | Conditions | | Standard | | | | |------------------------|------------------------------------------------------------------------|---------------------------------------------------------|------------|----------|-----------------------------|-------|--| | Symbol | Faiailletei | Conditions | Min. | Тур. | Max. | Unit | | | - | Program and erase cycles (1), (3), (4) | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | 10,000 (2) | | | times | | | - | 2 word program time | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | | 300 | 4000 | μS | | | - | Lock bit program time | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | | 140 | 3000 | μS | | | - | Block erase time | $V_{CC1} = 3.3 \text{ V}, T_{opr} = 25^{\circ}\text{C}$ | | 0.2 | 3.0 | S | | | t <sub>d(SR-SUS)</sub> | Time delay from suspend request until suspend | | | | $5 + \frac{3}{f(BCLK)}$ | ms | | | - | Interval from erase start/restart until following suspend request | | 0 | | | μS | | | - | Suspend interval necessary for auto-erasure to complete <sup>(7)</sup> | | 20 | | | ms | | | - | Time from suspend until erase restart | | | | $30 + \frac{1}{f_{(BCLK)}}$ | μS | | | - | Program, erase voltage | | 2.7 | | 5.5 | V | | | - | Read voltage | | 2.7 | | 5.5 | V | | | - | Program, erase temperature | | -20/-40 | | 85 | °C | | | t <sub>PS</sub> | Flash memory circuit stabilization wa | ait time | | | 50 | μS | | | - | Data hold time (6) | Ambient temperature = 55°C | 20 | | | year | | - 1. Definition of program and erase cycles - The program and erase cycles refer to the number of per-block erasures. - If the program and erase cycles are n (n = 10,000), each block can be erased n times. - For example, if a 4 KB block is erased after writing 2 word data 1,024 times, each to a different address, this counts as one program and erase cycles. Data cannot be written to the same address more than once without erasing the block (rewrite prohibited). - 2. Cycles to guarantee all electrical characteristics after program and erase. (1 to Min. value can be guaranteed). - 3. In a system that executes multiple programming operations, the actual erasure count can be reduced by writing to sequential addresses in turn so that as much of the block as possible is used up before performing an erase operation. For example, when programming groups of 16 bytes, the effective number of rewrites can be minimized by programming up to 256 groups before erasing them all in one operation. In addition, averaging the erasure cycles between blocks A and B can further reduce the actual erasure cycles. It is also advisable to retain data on the erasure cycles of each block and limit the number of erase operations to a certain number. - 4. If an error occurs during block erase, attempt to execute the clear status register command, then execute the block erase command at least three times until the erase error does not occur. - 5. Customers desiring program/erase failure rate information should contact a Renesas Electronics sales office. - 6. The data hold time includes time that the power supply is off or the clock is not supplied. - 7. After an erase start or erase restart, if an interval of at least 20 ms is not set before the next suspend request, the erase sequence cannot be completed. # 31.1.6 Voltage Detector and Power Supply Circuit Electrical Characteristics #### Table 31.11 Voltage Detector 0 Electrical Characteristics The measurement condition is $V_{CC1} = 2.7$ to 5.5 V, $T_{opr} = -20$ °C to 85°C/-40°C to 85°C, unless otherwise specified. | Symbol | Parameter | Condition | ; | Unit | | | |---------------------|----------------------------------------------------------|-----------------------------------------------------------|-------|------|------|----| | Symbol | raiametei | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | Offic | | | | | V <sub>det0</sub> | Voltage detection level Vdet0_0 (1) | When V <sub>CC1</sub> is falling. | 1.80 | 1.90 | 2.10 | V | | | Voltage detection level Vdet0_2 (1) | When V <sub>CC1</sub> is falling. | 2.70 | 2.85 | 3.00 | V | | - | Voltage detector 0 response time (3) | When V <sub>CC1</sub> falls from 5 V to (Vdet0_0 - 0.1) V | | | 200 | μS | | - | Voltage detector self power consumption | VC25 = 1, V <sub>CC1</sub> = 5.0 V | | 1.5 | | μΑ | | t <sub>d(E-A)</sub> | Waiting time until voltage detector operation starts (2) | | | | 100 | μS | #### Notes: - Select the voltage detection level with the VDSEL1 bit in the OFS1 address. - Necessary time until the voltage detector operates when setting to 1 again after setting the VC25 bit in the VCR2 register to 0. - 3. Time from when passing the $V_{\mbox{\scriptsize det0}}$ until when a voltage monitor 0 reset is generated. #### Table 31.12 Voltage Detector 1 Electrical Characteristics The measurement condition is $V_{CC1} = 2.7$ to 5.5 V, $T_{opr} = -20$ °C to 85°C/-40°C to 85°C, unless otherwise specified. | Symbol | Parameter | Condition | ( | d | Unit | | |---------------------|------------------------------------------------------------------------|-----------------------------------------------------------|------|------|------|-------| | Symbol | i didiffetei | Condition | Min. | Тур. | Max. | Offic | | V <sub>det1</sub> | Voltage detection level Vdet1_6 (1) | When V <sub>CC1</sub> is falling. | 2.80 | 3.10 | 3.40 | V | | | Voltage detection level Vdet1_B (1) | When V <sub>CC1</sub> is falling. | 3.55 | 3.85 | 4.15 | V | | | Voltage detection level Vdet1_F (1) | When V <sub>CC1</sub> is falling. | 4.15 | 4.45 | 4.75 | V | | - | Hysteresis width when V <sub>CC1</sub> of voltage detector 1 is rising | | | 0.15 | | V | | - | Voltage detector 1 response time (3) | When V <sub>CC1</sub> falls from 5 V to (Vdet1_0 - 0.1) V | | | 200 | μS | | - | Voltage detector self power consumption | VC26 = 1, V <sub>CC1</sub> = 5.0 V | | 1.7 | | μΑ | | t <sub>d(E-A)</sub> | Waiting time until voltage detector operation starts (2) | | | | 100 | μS | - 1. Select the voltage detection level with bits VD1S0 to VD1S3 in the VD1LS register. - Necessary time until the voltage detector operates when setting to 1 again after setting the VC26 bit in the VCR2 register to 0. - 3. Time from when passing the $V_{det1}$ until when a voltage monitor 1 reset is generated. Table 31.13 Voltage Detector 2 Electrical Characteristics The measurement condition is $V_{CC1}$ = 2.7 to 5.5 V, $T_{opr}$ = -20°C to 85°C/-40°C to 85°C, unless otherwise specified. | Symbol | Parameter | Condition | ; | d | Unit | | |---------------------|--------------------------------------------------------------------------|--------------------------------------------------------------|------|------|--------|-------| | Symbol | Falametei | Condition | Min. | Тур. | 15 200 | OTILL | | V <sub>det2</sub> | Voltage detection level Vdet2_0 | When V <sub>CC1</sub> is falling | 3.70 | 4.00 | 4.30 | V | | - | Hysteresis width at the rising of V <sub>CC1</sub> in voltage detector 2 | | | 0.15 | | V | | - | Voltage detector 2 response time (2) | When V <sub>CC1</sub> falls from 5<br>V to (Vdet2_0 - 0.1) V | | | 200 | μS | | - | Voltage detector self power consumption | VC27 = 1, V <sub>CC1</sub> = 5.0 V | | 1.7 | | μА | | t <sub>d(E-A)</sub> | Waiting time until voltage detector operation starts (1) | | | | 100 | μS | #### Notes: - Necessary time until the voltage detector operates after setting to 1 again after setting the VC27 bit in the VCR2 register to 0. - 2. Time from when passing the V<sub>det2</sub> until when a voltage monitor 2 reset is generated. #### Table 31.14 Power-On Reset Circuit The measurement condition is $V_{CC1}$ = 2.0 to 5.5 V, $T_{opr}$ = -20°C to 85°C/ -40°C to 85°C, unless otherwise specified. | Symbol | Parameter | Condition | Ş | Unit | | | |---------------------|--------------------------------------------------------|-----------|------|------|-------|-------| | Symbol | i alametei | Condition | Min. | Тур. | Max. | Orme | | V <sub>por1</sub> | Voltage at which power-on reset enabled <sup>(1)</sup> | | | | 0.5 | V | | t <sub>rth</sub> | External power V <sub>CC1</sub> rise gradient | | 2.0 | | 50000 | mV/ms | | t <sub>w(por)</sub> | Time necessary to enable power-on reset | | 300 | | | ms | #### Note: To use the power-on reset function, enable voltage monitor 0 reset by setting the LVDAS bit in the OFS1 address to 0. Also, set the VDSEL1 bit to 0 (Vdet0\_2). Figure 31.3 Power-On Reset Circuit Electrical Characteristics **Table 31.15 Power Supply Circuit Timing Characteristics** The measurement condition is $V_{CC1}$ = 2.7 to 5.5 V and $T_{opr}$ = 25°C, unless otherwise specified. | Symbol | Parameter | Condition | 5 | Unit | | | |---------------------|-----------------------------------------------------------|-----------|------|------|------|------| | Symbol | i didiffetei | Condition | Min. | Тур. | Max. | Onit | | t <sub>d(P-R)</sub> | Internal power supply stability time when power is on (1) | | | | 5 | ms | | t <sub>d(R-S)</sub> | STOP release time | | | | 150 | μS | | t <sub>d(W-S)</sub> | Low power mode wait mode release time | | | | 150 | μS | #### Note: 1. Waiting time until the internal power supply generator stabilizes when power is on. Figure 31.4 Power Supply Circuit Timing Diagram # 31.1.7 Oscillator Electrical Characteristics # Table 31.16 40 MHz On-Chip Oscillator Electrical Characteristics (1/2) $V_{CC1}$ = 2.7 to 5.5 V, $T_{opr}$ = -20°C to 85°C/-40°C to 85°C, unless otherwise specified. | Symbol | Parameter | Condition | 5 | Unit | | | |---------------------|------------------------------------------------------|-------------------------------------|------|------|------|-------| | | raiailletei | Condition | Min. | Тур. | Max. | Offic | | f <sub>OCO40M</sub> | 40 MHz on-chip oscillator frequency | Average frequency in a 10 ms period | 38 | 40 | 42 | MHz | | | Wait time until 40 MHz on-chip oscillator stabilizes | | | | 2 | ms | #### Table 31.17 125 kHz On-Chip Oscillator Electrical Characteristics $V_{CC1}$ = 2.7 to 5.5 V, $T_{opr}$ = -20°C to 85°C/-40°C to 85°C, unless otherwise specified. | Symbol | Parameter | Condition | 5 | Unit | | | |--------------------------|-------------------------------------------------------|-------------------------------------|------|------|------|-------| | Symbol | i didiffetei | Condition | Min. | Тур. | Max. | OTIIL | | f <sub>OCO-S</sub> | 125 kHz on-chip oscillator frequency | Average frequency in a 10 ms period | 100 | 125 | 150 | kHz | | tsu(f <sub>OCO-S</sub> ) | Wait time until 125 kHz on-chip oscillator stabilizes | | | | 20 | μS | # 31.2 Electrical Characteristics ( $V_{CC1} = V_{CC2} = 5 \text{ V}$ ) #### 31.2.1 Electrical Characteristics $V_{CC1} = V_{CC2} = 5 \text{ V}$ Table 31.18 Electrical Characteristics (1) (1) $V_{CC1} = V_{CC2} = 4.2$ to 5.5 V, $V_{SS} = 0$ V at $T_{opr} = -20^{\circ}$ C to 85°C/ $-40^{\circ}$ C to 85°C, $f_{(BCLK)} = 32$ MHz unless otherwise specified. | Symbol | | Parameter | | Measuring | Star | ndard | | Unit | |-----------------|------------------------|------------------------------------------------------------------------|------------------------------------|----------------------------|------------------------|-------|------------------|------| | Symbol | | Parameter | | Condition | Min. | Тур. | Max. | Unit | | V <sub>OH</sub> | High output voltage | P6_0 to P6_7, P7_2 to P8_6, P8_7, P9_0 to P11_0 to P11_7, P14_ | P9_7, P10_0 to P10_7, | $I_{OH} = -5 \text{ mA}$ | V <sub>CC1</sub> – 2.0 | | V <sub>CC1</sub> | V | | | | P0_0 to P0_7, P1_0 to<br>P3_0 to P3_7, P4_0 to<br>P12_0 to P12_7, P13_ | P4_7, P5_0 to P5_7, | I <sub>OH</sub> = -5 mA | V <sub>CC2</sub> – 2.0 | | V <sub>CC2</sub> | | | V <sub>OH</sub> | High output<br>voltage | P11_0 to P11_7, P14_ | P9_7, P10_0 to P10_7,<br>_0, P14_1 | I <sub>OH</sub> = -200 μA | V <sub>CC1</sub> – 0.3 | | V <sub>CC1</sub> | V | | | | P0_0 to P0_7, P1_0 to<br>P3_0 to P3_7, P4_0 to<br>P12_0 to P12_7, P13_ | P4_7, P5_0 to P5_7, | I <sub>OH</sub> = -200 μA | V <sub>CC2</sub> – 0.3 | | V <sub>CC2</sub> | | | V <sub>OH</sub> | High output | voltage XOUT | HIGH POWER | $I_{OH} = -1 \text{ mA}$ | V <sub>CC1</sub> – 2.0 | | $V_{CC1}$ | V | | | | | LOW POWER | $I_{OH} = -0.5 \text{ mA}$ | V <sub>CC1</sub> – 2.0 | | $V_{CC1}$ | | | Hig | High output | voltage XCOUT | HIGH POWER | With no load applied | | 2.6 | | V | | | | | LOW POWER | With no load applied | | 2.2 | | | | V <sub>OL</sub> | Low output voltage | P6_0 to P6_7, P7_0 to<br>P9_0 to P9_7, P10_0<br>P11_0 to P11_7, P14_ | to P10_7, | I <sub>OL</sub> = 5 mA | | | 2.0 | V | | | | P0_0 to P0_7, P1_0 to<br>P3_0 to P3_7, P4_0 to<br>P12_0 to P12_7, P13_ | P4_7, P5_0 to P5_7, | I <sub>OL</sub> = 5 mA | | | 2.0 | | | V <sub>OL</sub> | Low output voltage | P6_0 to P6_7, P7_0 to P9_0 to P9_7, P10_0 P11_0 to P11_7, P14_ | to P10_7, | I <sub>OL</sub> = 200 μA | | | 0.45 | V | | | | P0_0 to P0_7, P1_0 to<br>P3_0 to P3_7, P4_0 to<br>P12_0 to P12_7, P13_ | P4_7, P5_0 to P5_7, | I <sub>OL</sub> = 200 μA | | | 0.45 | | | V <sub>OL</sub> | Low output | voltage XOUT | HIGH POWER | I <sub>OL</sub> = 1 mA | | | 2.0 | V | | | | | LOW POWER | I <sub>OL</sub> = 0.5 mA | | | 2.0 | | | | Low output v | voltage XCOUT | HIGH POWER | With no load applied | | 0 | | V | | | | | LOW POWER | With no load applied | | 0 | | | Note: 1. When $V_{CC1} \neq V_{CC2}$ , refer to 5 V or 3 V standard depending on the voltage. $V_{CC1} = V_{CC2} = 5 \text{ V}$ Table 31.19 Electrical Characteristics (2) (1) $V_{CC1} = V_{CC2} = 4.2 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V at } T_{opr} = -20^{\circ} \text{C to } 85^{\circ} \text{C} / -40^{\circ} \text{C to } 85^{\circ} \text{C}, f_{(BCLK)} = 32 \text{ MHz unless otherwise specified.}$ | 0 1 : | | | Measuring | Sta | ındard | | I Imia | |-----------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------|--------|------|--------| | Symbol | | Parameter | Condition | Min. | Тур. | Max. | Unit | | V <sub>T+</sub> - V <sub>T-</sub> | Hysteresis | HOLD, RDY, TAOIN to TA4IN, TB0IN to TB5IN, INTO to INT7, NMI, ADTRG, CTS0 to CTS2, CTS5 to CTS7, SCL0 to SCL2, SCL5 to SCL7, SDA0 to SDA2, SDA5 to SDA7, CLK0 to CLK7, TA0OUT to TA4OUT, KIO to KI3, RXD0 to RXD2, RXD5 to RXD7, SIN3, SIN4, \$\overline{SD}\$, PMC0, PMC1, SCLMM, SDAMM, CEC, ZP, IDU, IDV, IDW | | 0.5 | | 2.0 | V | | V <sub>T+</sub> - V <sub>T-</sub> | Hysteresis | RESET | | 0.5 | | 2.5 | V | | I <sub>IH</sub> | High input<br>current | P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7, P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7, P6_0 to P6_7, P7_0 to P7_7, P8_0 to P8_7, P9_0 to P9_7, P10_0 to P10_7, P11_0 to P11_7, P12_0 to P12_7, P13_0 to P13_7, P14_0, P14_1 XIN, RESET, CNVSS, BYTE | V <sub>I</sub> = 5 V | | | 5.0 | μА | | I <sub>IL</sub> | Low input<br>current | P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7, P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7, P6_0 to P6_7, P7_0 to P7_7, P8_0 to P8_7, P9_0 to P9_7, P10_0 to P10_7, P11_0 to P11_7, P12_0 to P12_7, P13_0 to P13_7, P14_0, P14_1 XIN, RESET, CNVSS, BYTE | V <sub>I</sub> = 0 V | | | -5.0 | μА | | R <sub>PULLUP</sub> | Pull-up<br>resistance | P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7, P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7, P6_0 to P6_7, P7_2 to P7_7, P8_0 to P8_4, P8_6, P8_7, P9_0 to P9_7, P10_0 to P10_7, P11_0 to P11_7, P12_0 to P12_7, P13_0 to P13_7, P14_0, P14_1 | V <sub>I</sub> = 0 V | 30 | 50 | 100 | kΩ | | R <sub>fXIN</sub> | Feedback re | esistance XIN | | | 1.5 | | МΩ | | $V_{RAM}$ | RAM retenti | on voltage | In stop mode | 1.8 | | | V | Note: 1. When $V_{CC1} \neq V_{CC2}$ , refer to 5 V or 3 V standard depending on the voltage. $V_{CC1} = V_{CC2} = 5 V$ **Table 31.20 Electrical Characteristics (3)**R5F36506CNFA, R5F36506CNFB, R5F3650ECNFB, R5F36506CDFA, R5F36506CDFB, R5F3650ECDFA, R5F3650ECDFB $V_{CC1} = V_{CC2} = 4.2 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V at } T_{opr} = -20 ^{\circ}\text{C to } 85 ^{\circ}\text{C} / -40 ^{\circ}\text{C to } 85 ^{\circ}\text{C}, f_{(BCLK)} = 32 \text{ MHz unless otherwise specified.}$ | Symbol | Parameter | | Measuring Condition | Standar<br>Min. Typ. | Max. | Unit | |--------------------|------------------------------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------|------| | R <sub>fXCIN</sub> | Feedback resistance<br>XCIN | | | 8 | | ΜΩ | | cc | Power supply current<br>In single-chip, mode, | High-speed mode | f <sub>(BCLK)</sub> = 32 MHz<br>XIN = 4 MHz (square wave), PLL multiplied by 8<br>125 kHz on-chip oscillator stopped | 24.0 | | mA | | | the output pin are open and other pins are V <sub>SS</sub> | | f <sub>(BCLK)</sub> =32 MHz, A/D conversion XIN = 4 MHz (square wave), PLL multiplied by 8 125 kHz on-chip oscillator stopped | 24.7 | | mA | | | | | f <sub>(BCLK)</sub> = 20 MHz<br>XIN = 20 MHz (square wave)<br>125 kHz on-chip oscillator stopped | 16.0 | | mA | | | | 40 MHz on-chip oscillator mode | Main clock stopped 40 MHz on-chip oscillator on, divide-by-4 (f <sub>(BCLK)</sub> = 10 MHz) 125 kHz on-chip oscillator stopped | 17.0 | | mA | | | | 125 kHz on-chip oscillator mode | Main clock stopped 40 MHz on-chip oscillator stopped, 125 kHz on-chip oscillator on, no division FMR22 = 1 (slow read mode) | 500.0 | | μА | | | | Low-power mode | f <sub>(BCLK)</sub> = 32 kHz<br>In low-power mode<br>FMR22 = FMR23 = 1<br>On flash memory <sup>(1)</sup> | 160.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 kHz<br>In low-power mode<br>On RAM <sup>(1)</sup> | 45.0 | | μА | | | | Wait mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator on Peripheral clock operating T <sub>opr</sub> = 25°C | 20.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 kHz (oscillation capacity High) 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock operating T <sub>opr</sub> = 25°C | 11.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 kHz (oscillation capacity Low) 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock operating T <sub>opr</sub> = 25°C | 6.0 | | μА | | | | | XIN = 6 MHz 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock f1 provision disabled except timers (PCKSTP1A = 1) Main clock as a timer clock source (PCKSTP11 = 0, PCKSTP17 = 1) A given timer operating | 1.2 | | mA | | | | Stop mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock stopped Topr = 25°C | 1.7 | | μА | | | | During flash<br>memory program | f <sub>(BCLK)</sub> = 10 MHz, PM17 = 1 (one wait)<br>V <sub>CC1</sub> = 5.0 V | 20.0 | | mA | | | | During flash<br>memory erase | $f_{(BCLK)} = 10 \text{ MHz}, \text{ PM17} = 1 \text{ (one wait)}$<br>$V_{CC1} = 5.0 \text{ V}$ | 30.0 | | mA | This indicates the memory in which the program to be executed exists. $V_{CC1} = V_{CC2} = 5 V$ **Table 31.21 Electrical Characteristics (4)**R5F3651ECNFC, R5F3651KCNFC, R5F3650KCNFA, R5F3650KCNFB, R5F3651MCNFC, R5F3650MCNFA, R5F3650MCNFB, R5F3651NCNFC, R5F3650NCNFA, R5F3650NCNFB, R5F3651ECDFC, R5F3651KCDFC, R5F3650KCDFA, R5F3650KCDFB, R5F3651MCDFC, R5F3650MCDFA, R5F3650MCDFB, R5F3651NCDFC, R5F3650NCDFA, R5F3650NCDFB $V_{CC1} = V_{CC2} = 4.2 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C} / -40^{\circ}\text{C to } 85^{\circ}\text{C}, f_{(BCLK)} = 32 \text{ MHz unless otherwise specified.}$ | Symbol | Parameter | | Measuring Condition | Min. | Standard<br>Typ. | Max. | Uni | |--------------------|-----------------------|------------------------------------|-----------------------------------------------------------|----------|------------------|---------|--------------------------------------------------| | R <sub>fXCIN</sub> | Feedback resistance | | | 1411111 | | TVICA. | MG | | ., | XCIN | | | | 8 | | MΩ | | СС | Power supply current | High-speed mode | f <sub>(BCLK)</sub> = 32 MHz | | | | | | | | | XIN = 4 MHz (square wave), PLL multiplied by 8 | | 26.0 | | m/ | | | In single-chip, mode, | | 125 kHz on-chip oscillator stopped | | | | | | | the output pin are | | f <sub>(BCLK)</sub> = 32 MHz, A/D conversion | | | | | | | open and other pins | | XIN = 4 MHz (square wave), PLL multiplied by 8 | | 27.0 | | m/ | | | are V <sub>SS</sub> | | 125 kHz on-chip oscillator stopped | | | | | | | | | f <sub>(BCLK)</sub> = 20 MHz | | | | | | | | | XIN = 20 MHz (square wave) | | 17.0 | | m/ | | | | | 125 kHz on-chip oscillator stopped | | | | | | | | 40 MHz on-chip | Main clock stopped | | | | | | | | oscillator mode | 40 MHz on-chip oscillator on, | | 10.0 | | | | | | | divide-by-4 (f(BCLK) = 10 MHz) | | 18.0 | | m | | | | | 125 kHz on-chip oscillator stopped | | | | | | | | 125 kHz on-chip | Main clock stopped | | | | | | | | oscillator mode | 40 MHz on-chip oscillator stopped | | 550.0 | | μA | | | | | 125 kHz on-chip oscillator on, no division | | 550.0 | | μ | | | | | FMR22 = 1 (slow read mode) | | | | | | | | Low-power mode | $f_{(BCLK)} = 32 \text{ kHz}$ | | | | | | | | | In low-power mode | | 470.0 | | | | | | | FMR22 = FMR23 = 1 | | 170.0 | | μ | | | | | on flash memory (1) | | | | | | | | | f <sub>(BCLK)</sub> = 32 kHz | | | | | | | | | In low-power mode | | 45.0 | | μ | | | | | on RAM <sup>(1)</sup> | | 10.0 | | Per | | | | Wait mode | Main clock stopped | | | | | | | | Wait mode | 40 MHz on-chip oscillator stopped | | | | | | | | | 125 kHz on-chip oscillator on | | 20.5 | | | | | | | Peripheral clock operating | | 20.5 | | μ | | | | | T <sub>opr</sub> = 25°C | | | | | | | | | $f_{(BCLK)} = 32 \text{ kHz (oscillation capacity High)}$ | | | | - | | | | | | | | | | | | | | 40 MHz on-chip oscillator stopped | | 44.0 | | | | | | | 125 kHz on-chip oscillator stopped | | 11.0 | | μ/ | | | | | Peripheral clock operating | | | | | | | | | $T_{opr} = 25^{\circ}C$ | | | | | | | | | f <sub>(BCLK)</sub> = 32 kHz (oscillation capacity low) | | | | | | | | | 40 MHz on-chip oscillator stopped | | | | | | | | | 125 kHz on-chip oscillator stopped | | 6.0 | | μ | | | | | Peripheral clock operating | | | | | | | | | $T_{opr} = 25^{\circ}C$ | | | | | | | | | XIN = 6 MHz | | | | | | | | | 40 MHz on-chip oscillator stopped | | | | | | | | | 125 kHz on-chip oscillator stopped | | | | | | | | | Peripheral clock f1 provision disabled except | | 4.0 | | | | | | | timers (PCKSTP1A = 1) | | 1.2 | | m. | | | | | Main clock as a timer clock source | | | | | | | | | (PCKSTP11 = 0, PCKSTP17 = 1) | | | | | | | | A given timer operating | | | | | | | | Stop mode | Main clock stopped | | | | | | | | | | 40 MHz on-chip oscillator stopped | | | | | | | | 125 kHz on-chip oscillator stopped | | 1.7 | | μ | | | | | | Peripheral clock stopped | | | | " | | | | | $T_{opr} = 25^{\circ}C$ | | | | | | | | During flash memory | f <sub>(BCLK)</sub> = 10 MHz, PM17 = 1 (one wait) | | | | <del> </del> | | | | program | V <sub>CC1</sub> = 5.0 V | | 20.0 | | m. | | | | | f <sub>(BCLK)</sub> = 10 MHz, PM17 = 1 (one wait) | | | | <u> </u> | | | | During flash memory | | | 30.0 | | m | | | | erase | $V_{CC1} = 5.0 \text{ V}$ | <u>L</u> | | <u></u> | L | This indicates the memory in which the program to be executed exists. $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ # 31.2.2 Timing Requirements (Peripheral Functions and Others) $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.2.2.1 Reset Input (RESET Input) # Table 31.22 Reset Input (RESET Input) | Symbol | Parameter | Stan | Unit | | |----------------------|-----------------------------|------|------|-------| | | T drameter | Min. | Max. | Offic | | t <sub>w(RSTL)</sub> | RESET input low pulse width | 10 | | μS | Figure 31.5 Reset Input (RESET Input) # 31.2.2.2 External Clock Input Table 31.23 External Clock Input (XIN Input) (1) | Symbol | Parameter | Stan | Unit | | |-------------------|---------------------------------------|------|------|------| | | T drameter | Min. | Max. | Onit | | t <sub>c</sub> | External clock input cycle time | 50 | | ns | | t <sub>w(H)</sub> | External clock input high pulse width | 20 | | ns | | t <sub>w(L)</sub> | External clock input low pulse width | 20 | | ns | | t <sub>r</sub> | External clock rise time | | 9 | ns | | t <sub>f</sub> | External clock fall time | | 9 | ns | Note: 1. The condition is $V_{CC1} = V_{CC2} = 3.0$ to 5.0 V. Figure 31.6 External Clock Input (XIN Input) $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # **31.2.2.3** Timer A Input Table 31.24 Timer A Input (Counter Input in Event Counter Mode) | Symbol | Parameter | Standard | dard | Unit | |---------------------|------------------------------|----------|------|------| | | Faidilletei | Min. | Max. | | | $t_{c(TA)}$ | TAilN input cycle time | 100 | | ns | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 40 | | ns | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 40 | | ns | # Table 31.25 Timer A Input (Gating Input in Timer Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | | | Min. | Max. | Offic | | t <sub>c(TA)</sub> | TAilN input cycle time | 400 | | ns | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 200 | | ns | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 200 | | ns | Table 31.26 Timer A Input (External Trigger Input in One-Shot Timer Mode) | Symbol | Parameter | Standard | Unit | | |---------------------|------------------------------|----------|------|---------| | | i alametei | Min. | Max. | l Oliii | | $t_{c(TA)}$ | TAilN input cycle time | 200 | | ns | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 100 | | ns | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 100 | | ns | Table 31.27 Timer A Input (External Trigger Input in Pulse Width Modulation Mode and Programmable Output Mode) | Symbol | Parameter | Standa | Standard | | - Unit | |---------------------|------------------------------|--------|----------|----|--------| | | i alametei | Min. | Max. | | | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 100 | | ns | | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 100 | | ns | | Figure 31.7 Timer A Input $$V_{CC1} = V_{CC2} = 5 V$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ Table 31.28 Timer A Input (Two-Phase Pulse Input in Event Counter Mode) | Symbol | Parameter | Standa | dard | Unit | |-----------------------------|-------------------------|--------|------|------| | | Falametei | Min. | Max. | | | $t_{c(TA)}$ | TAilN input cycle time | 800 | | ns | | t <sub>su(TAIN-TAOUT)</sub> | TAiOUT input setup time | 200 | | ns | | t <sub>su(TAOUT-TAIN)</sub> | TAilN input setup time | 200 | | ns | Figure 31.8 Timer A Input (Two-Phase Pulse Input in Event Counter Mode) $$V_{CC1} = V_{CC2} = 5 V$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # **31.2.2.4** Timer B Input Table 31.29 Timer B Input (Counter Input in Event Counter Mode) | Symbol | Parameter | Standard | ndard | Unit | |---------------------|------------------------------------------------------|----------|-------|-------| | | Falametei | Min. | Max. | Offic | | t <sub>c(TB)</sub> | TBiIN input cycle time (counted on one edge) | 100 | | ns | | t <sub>w(TBH)</sub> | TBiIN input high pulse width (counted on one edge) | 40 | | ns | | t <sub>w(TBL)</sub> | TBilN input low pulse width (counted on one edge) | 40 | | ns | | t <sub>c(TB)</sub> | TBiIN input cycle time (counted on both edges) | 200 | | ns | | t <sub>w(TBH)</sub> | TBilN input high pulse width (counted on both edges) | 80 | | ns | | t <sub>w(TBL)</sub> | TBilN input low pulse width (counted on both edges) | 80 | | ns | # Table 31.30 Timer B Input (Pulse Period Measurement Mode) | Symbol | Parameter | Standard | | Unit | |---------------------|------------------------------|----------|------|-------| | | i arameter | Min. | Max. | Offic | | t <sub>c(TB)</sub> | TBiIN input cycle time | 400 | | ns | | t <sub>w(TBH)</sub> | TBiIN input high pulse width | 200 | | ns | | t <sub>w(TBL)</sub> | TBiIN input low pulse width | 200 | | ns | Table 31.31 Timer B Input (Pulse Width Measurement Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | | | Min. | Max. | Offic | | $t_{c(TB)}$ | TBiIN input cycle time | 400 | | ns | | t <sub>w(TBH)</sub> | TBiIN input high pulse width | 200 | | ns | | t <sub>w(TBL)</sub> | TBiIN input low pulse width | 200 | | ns | Figure 31.9 Timer B Input $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ #### 31.2.2.5 Serial Interface Table 31.32 Serial Interface | Symbol | Parameter | Stan | Unit | | |----------------------|-----------------------------|------|------|-------| | Symbol | i didilielei | Min. | Max. | Offic | | t <sub>c(CK)</sub> | CLKi input cycle time | 200 | | ns | | t <sub>w(CKH)</sub> | CLKi input high pulse width | 100 | | ns | | t <sub>w(CKL)</sub> | CLKi input low pulse width | 100 | | ns | | t <sub>d(C-Q)</sub> | TXDi output delay time | | 80 | ns | | t <sub>h(C-Q)</sub> | TXDi hold time | 0 | | ns | | t <sub>su(D-C)</sub> | RXDi input setup time | 70 | | ns | | t <sub>h(C-D)</sub> | RXDi input hold time | 90 | | ns | Figure 31.10 Serial Interface # 31.2.2.6 External Interrupt INTi Input Table 31.33 External Interrupt INTi Input | Symbol | Parameter | Stan | Unit | | |---------------------|-----------------------------|------|------|-------| | | | Min. | Max. | Offic | | t <sub>w(INH)</sub> | INTi input high pulse width | 250 | | ns | | t <sub>w(INL)</sub> | INTi input low pulse width | 250 | | ns | Figure 31.11 External Interrupt INTi Input $$V_{CC1} = V_{CC2} = 5 V$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.2.2.7 Multi-master I<sup>2</sup>C-bus Table 31.34 Multi-master I<sup>2</sup>C-bus | Symbol | pol Parameter | Standard Clock Mode | | Fast-mode | | - Unit | |---------------------|---------------------------------|---------------------|------|-------------|------|--------| | Symbol | | Min. | Max. | Min. | Max. | Unit | | t <sub>BUF</sub> | Bus free time | 4.7 | | 1.3 | | μS | | t <sub>HD;STA</sub> | Hold time in start condition | 4.0 | | 0.6 | | μS | | $t_{LOW}$ | Hold time in SCL clock 0 status | 4.7 | | 1.3 | | μS | | $t_R$ | SCL, SDA signals' rising time | | 1000 | 20 + 0.1 Cb | 300 | ns | | t <sub>HD;DAT</sub> | Data hold time | 0 | | 0 | 0.9 | μS | | t <sub>HIGH</sub> | Hold time in SCL clock 1 status | 4.0 | | 0.6 | | μS | | f <sub>F</sub> | SCL, SDA signals' falling time | | 300 | 20 + 0.1 Cb | 300 | ns | | t <sub>su;DAT</sub> | Data setup time | 250 | | 100 | | ns | | t <sub>su;STA</sub> | Setup time in restart condition | 4.7 | | 0.6 | | μS | | t <sub>su;STO</sub> | Stop condition setup time | 4.0 | | 0.6 | | μS | Figure 31.12 Multi-master I<sup>2</sup>C-bus $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.2.3 Timing Requirements (Memory Expansion Mode and Microprocessor Mode) Table 31.35 Memory Expansion Mode and Microprocessor Mode | Symbol | ymbol Parameter | Stan | Unit | | |---------------------------|------------------------------------------------------------|------|----------|-------| | Symbol | | Min. | Max. | Offic | | t <sub>ac1(RD-DB)</sub> | Data input access time (for setting with no wait) | | (Note 1) | ns | | t <sub>ac2(RD-DB)</sub> | Data input access time (for setting with 1 to 3 waits) | | (Note 2) | ns | | t <sub>ac3(RD-DB)</sub> | Data input access time (when accessing multiplex bus area) | | (Note 3) | ns | | t <sub>ac4(RD-DB)</sub> | Data input access time (for setting with 2φ + 3φ or more) | | (Note 4) | ns | | t <sub>su(DB-RD)</sub> | Data input setup time | 50 | | ns | | t <sub>su(RDY-BCLK)</sub> | RDY input setup time | 80 | | ns | | t <sub>h(RD-DB)</sub> | Data input hold time | 0 | | ns | | t <sub>h(BCLK-RDY)</sub> | RDY input hold time | 0 | | ns | #### Notes: Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 45[ns]$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{(n+0.5)\times 10^9}{f_{(BCLK)}}$$ – 45[ns] n is 1 for 1 wait setting, 2 for 2 waits setting and 3 for 3 waits setting. 3. Calculated according to the BCLK frequency as follows: $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 45[ns] \qquad \text{n is 2 for 2 waits setting, and 3 for 3 waits setting.}$$ 4. Calculated according to the BCLK frequency as follows: $$\frac{n \times 10^9}{f_{(BCLK)}} - 45 [ns] \qquad \text{n is 3 for } 2\phi + 3\phi, \, 4 \, \text{for } 2\phi + 4\phi, \, 4 \, \text{for } 3\phi + 4\phi, \, \text{and 5 for } 4\phi + 5\phi.$$ Figure 31.13 Timing Diagram $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ # 31.2.4 Switching Characteristics (Memory Expansion Mode and Microprocessor Mode) $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C} \text{ to } 85^{\circ}\text{C}/-40^{\circ}\text{C} \text{ to } 85^{\circ}\text{C} \text{ unless otherwise specified})$ # 31.2.4.1 In No Wait State Setting Table 31.36 Memory Expansion Mode and Microprocessor Mode (in No Wait State Setting) | Cumbal | Darameter | Measuring | Standard | | l lait | |--------------------------|----------------------------------------------------|--------------|----------|------|--------| | Symbol | Parameter | Condition | Min. | Max. | Unit | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 25 | ns | | t <sub>h(BCLK-AD)</sub> | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD)</sub> | Address output hold time (in relation to RD) | | 0 | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 25 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 15 | ns | | t <sub>h(BCLK-ALE)</sub> | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | Figure 31.14 | | 25 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | | | 25 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) (3) | | (Note 4) | | ns | #### Notes: 1. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}}$$ – $40[ns]$ f<sub>(BCLK)</sub> is 12.5 MHz or less. 2. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 10[ns]$$ 3. This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pull-up (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times ln(1-V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL} = 0.2V_{CC2}$ , C = 30 pF, R = 1 k $\Omega$ , hold time of output low level is $$t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \ln(1 - 0.2 \text{V}_{\text{CC2}}/\text{V}_{\text{CC2}})$$ $$= 6.7 \text{ ns}$$ 4. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 20[ns]$$ Hold time is equal to or less than 0 ns when the BCLK frequency exceeds 25 MHz. Figure 31.14 Ports P0 to P14 Measurement Circuit Figure 31.15 Timing Diagram $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ #### **Switching Characteristics** $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.2.4.2 In 1 to 3 Waits Setting and When Accessing External Area Table 31.37 Memory Expansion Mode and Microprocessor Mode (in 1 to 3 Waits Setting and When Accessing External Area) | Cumbal | Parameter | Measuring | Standard | | I Imit | |---------------------------|----------------------------------------------------|--------------|----------|------|--------| | Symbol | | Condition | Min. | Max. | Unit | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 25 | ns | | t <sub>h(BCLK-AD</sub> ) | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD</sub> ) | Address output hold time (in relation to RD) | | 0 | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 25 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 15 | ns | | t <sub>h(BCLK-ALE</sub> ) | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | Figure 31.14 | | 25 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | | | 25 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR)(3) | | (Note 4) | | ns | #### Notes: 1. Calculated according to the BCLK frequency as follows: calculated according to the BCLK frequency as follows: $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 40[ns] \qquad \text{n is 1 for 1 wait setting, 2 for 2 waits setting and 3 for 3 waits setting.} \\ \text{When n = 1, f}_{(BCLK)} \text{ is 12.5 MHz or less.}$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{0.5\times10^9}{f_{(BCLK)}}-10[ns]$$ 3. This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pull-up (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times \ln(1 - V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL}=0.2V_{CC2},~C=30$ pF, R = 1 k $\Omega$ , hold time of output low level is $$t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \ln(1 - 0.2\text{V}_{CC2}/\text{V}_{CC2})$$ $$= 6.7 \text{ ns}.$$ 4. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(RCLK)}} - 20[ns]$$ Hold time is equal to or less than 0 ns when the BCLK frequency exceeds 25 MHz. M16C/65C Group 31. Electrical Characteristics Figure 31.16 Timing Diagram $V_{CC1} = V_{CC2} = 5 \text{ V}$ ## **Switching Characteristics** $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C} \text{ to } 85^{\circ}\text{C}/-40^{\circ}\text{C} \text{ to } 85^{\circ}\text{C} \text{ unless otherwise specified})$ # 31.2.4.3 In 2 or 3 Waits Setting, and When Accessing External Area and Using Multiplexed Bus Table 31.38 Memory Expansion Mode and Microprocessor Mode (in 2 or 3 Waits Setting, and When Accessing External Area and Using Multiplexed Bus) (5) | Cumbal | Parameter | Measuring | Standard | | Unit | |--------------------------|-------------------------------------------------------|---------------------|----------|------|------| | Symbol | Parameter | Condition | Min. | Max. | Unit | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 25 | ns | | t <sub>h(BCLK-AD)</sub> | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD)</sub> | Address output hold time (in relation to RD) | | (Note 1) | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 1) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 25 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-CS)</sub> | Chip select output hold time (in relation to RD) | | (Note 1) | | ns | | t <sub>h(WR-CS)</sub> | Chip select output hold time (in relation to WR) | | (Note 1) | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | | | 25 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | _ | | 25 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | See<br>Figure 31.14 | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | - Igaio o III I | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 2) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) | | (Note 6) | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time (in relation to BCLK) | | | 15 | ns | | t <sub>h(BCLK-ALE)</sub> | ALE signal output hold time (in relation to BCLK) | | -4 | | ns | | t <sub>d(AD-ALE)</sub> | ALE signal output delay time (in relation to Address) | | (Note 3) | | ns | | t <sub>h(AD-ALE)</sub> | ALE signal output hold time (in relation to Address) | | (Note 4) | | ns | | t <sub>d(AD-RD)</sub> | RD signal output delay from the end of address | | 0 | | ns | | t <sub>d(AD-WR)</sub> | WR signal output delay from the end of address | | 0 | | ns | | t <sub>dz(RD-AD)</sub> | Address output floating start time | | | 8 | ns | #### Notes Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(RCLK)}} - 10[ns]$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 40 [ns] \;\; \text{n is 2 for 2-wait setting, 3 for 3-wait setting.}$$ 3. Calculated according to the BCLK frequency as follows: $$\frac{0.5\times10^9}{f_{(BCLK)}} - 25[ns]$$ 4. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 15[ns]$$ 5. When using multiplex bus, set f<sub>(BCLK)</sub> 12.5 MHz or less. 6. Calculated according to the BCLK frequency as follows: $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 20[ns]$ Figure 31.17 Timing Diagram $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C} \text{ to } 85^{\circ}\text{C}/-40^{\circ}\text{C} \text{ to } 85^{\circ}\text{C} \text{ unless otherwise specified})$ # 31.2.4.4 In Wait State Setting $2\phi$ + $3\phi$ , $2\phi$ + $4\phi$ , $3\phi$ + $4\phi$ , and $4\phi$ + $5\phi$ , and When Accessing External Area Table 31.39 Memory Expansion Mode and Microprocessor Mode (in Wait State Setting 2 $\phi$ + 3 $\phi$ , 2 $\phi$ + 4 $\phi$ , 3 $\phi$ + 4 $\phi$ , and 4 $\phi$ + 5 $\phi$ , and When Accessing External Area) | Cumbal | Parameter | Measuring | Stan | dard | Unit | |---------------------------|----------------------------------------------------|--------------|----------|------|-------| | Symbol | Falametei | Condition | Min. | Max. | Offic | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 25 | ns | | t <sub>h(BCLK-AD</sub> ) | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD</sub> ) | Address output hold time (in relation to RD) | | 0 | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 25 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 15 | ns | | t <sub>h(BCLK-ALE</sub> ) | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | Figure 31.14 | | 25 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | | | 25 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) (3) | | (Note 4) | | ns | #### Notes: 1. Calculated according to the BCLK frequency as follows: $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 40[ns] \hspace{1cm} \text{n is 3 for } 2\phi + 3\phi, \, 4 \, \text{for } 2\phi + 4\phi, \, 4 \, \text{for } 3\phi + 4\phi, \, \text{and 5 for } 4\phi + 5\phi.$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 10[ns]$$ This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pull-up (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times ln(1 - V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL}$ = 0.2 $V_{CC2}$ , C = 30 pF, R = 1 k $\Omega$ , hold time of output low level is $$t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \ln(1 - 0.2\text{V}_{\text{CC2}}/\text{V}_{\text{CC2}})$$ Hold time is equal to or less than 0 ns when the BCLK frequency exceeds 25 MHz. Figure 31.18 Timing Diagram $$V_{CC1} = V_{CC2} = 5 \text{ V}$$ $(V_{CC1} = V_{CC2} = 5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C/-}40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified)}$ # 31.2.4.5 In Wait State Setting $2\phi$ + $3\phi$ , $2\phi$ + $4\phi$ , $3\phi$ + $4\phi$ , and $4\phi$ + $5\phi$ , and When Inserting 1 to 3 Recovery Cycles and Accessing External Area Table 31.40 Memory Expansion and Microprocessor Modes (in Wait State Setting $2\phi + 3\phi$ , $2\phi + 4\phi$ , $3\phi + 4\phi$ , and $4\phi + 5\phi$ , and When Inserting 1 to 3 Recovery Cycles and Accessing External Area) | Symbol | Parameter | Measuring | Stan | Unit | | |---------------------------|----------------------------------------------------|--------------|----------|------|-------| | Symbol | Falametei | Condition | Min. | Max. | Offic | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 25 | ns | | t <sub>h(BCLK-AD</sub> ) | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD</sub> ) | Address output hold time (in relation to RD) | | (Note 4) | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 25 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 15 | ns | | t <sub>h(BCLK-ALE</sub> ) | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | Figure 31.14 | | 25 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | | | 25 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) (3) | | (Note 5) | | ns | #### Notes: 1. Calculated according to the BCLK frequency as follows: $$\frac{n \times 10^9}{f_{(BCLK)}} - 40[ns] \qquad \text{n is 3 for } 2\phi + 3\phi, 4 \text{ for } 2\phi + 4\phi, 4 \text{ for } 3\phi + 4\phi, \text{ and 5 for } 4\phi + 5\phi.$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{m\times 10^9}{f_{(BCLK)}} - 10[ns] \qquad \qquad \text{m is 1 when 1 recovery cycle is inserted, 2 when 2 recovery cycles are inserted, and 3 when 3 recovery cycles are inserted.}$$ This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pull-up (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times ln(1-V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL} = 0.2V_{CC2}$ , C = 30 pF, R = 1 k $\Omega$ , hold time of output low level is $$t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \text{ln}(1 - 0.2\text{V}_{\text{CC2}}/\text{V}_{\text{CC2}})$$ = 6.7 ns. I. Calculated according to the BCLK frequency as follows: $$\frac{m \times 10^9}{f_{(BCLK)}} + 0 [ns]$$ m is 1 when 1 recovery cycle is inserted, 2 when 2 recovery cycles are inserted, and 3 when 3 recovery cycles are inserted. 5. Calculated according to the BCLK frequency as follows: $$\frac{m \times 10^9}{f_{(BCLK)}} - 20[ns]$$ m is 1 when 1 recovery cycle is inserted, 2 when 2 recovery cycles are inserted, and 3 when 3 recovery cycles are inserted. DBi Figure 31.19 Timing Diagram # 31.3 Electrical Characteristics ( $V_{CC1} = V_{CC2} = 3 \text{ V}$ ) # 31.3.1 Electrical Characteristics VCC1 = VCC2 = 3 V Table 31.41 Electrical Characteristics (1) (1) $V_{CC1} = V_{CC2} = 2.7 \text{ to } 3.3 \text{ V}, V_{SS} = 0 \text{ V at T}_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C} / -40^{\circ}\text{C to } 85^{\circ}\text{C}, f_{(BCLK)} = 32 \text{ MHz unless otherwise specified.}$ | Symbol | Parameter | | Measuring Condition | Standard | | | Unit | | |----------------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------|------------------------|------|------------------|------| | Symbol | | raiametei | | Weasuring Condition | Min. | Тур. | Max. | OIII | | V <sub>OH</sub> | High<br>output<br>voltage | P6_0 to P6_7, P7_2 to P7_7<br>P8_6, P8_7, P9_0 to P9_7, I<br>P11_0 to P11_7, P14_0, P14 | P10_0 to P10_7, | I <sub>OH</sub> = -1 mA | V <sub>CC1</sub> – 0.5 | | V <sub>CC1</sub> | V | | | | P0_0 to P0_7, P1_0 to P1_7<br>P3_0 to P3_7, P4_0 to P4_7<br>P12_0 to P12_7, P13_0 to P | , P5_0 to P5_7, | I <sub>OH</sub> = -1 mA | V <sub>CC2</sub> – 0.5 | | V <sub>CC2</sub> | | | V <sub>OH</sub> | High output | voltage XOUT | HIGH POWER | $I_{OH} = -0.1 \text{ mA}$ | V <sub>CC1</sub> – 0.5 | | V <sub>CC1</sub> | V | | | | | LOW POWER | I <sub>OH</sub> = -50 μA | V <sub>CC1</sub> – 0.5 | | $V_{CC1}$ | | | | High output | voltage XCOUT | HIGH POWER | With no load applied | | 2.6 | | V | | | | | LOW POWER | With no load applied | | 2.2 | | | | V <sub>OL</sub> | Low output voltage | P6_0 to P6_7, P7_0 to P7_7<br>P9_7, P10_0 to P10_7, P11_ | | I <sub>OL</sub> = 1 mA | | | 0.5 | V | | | | P0_0 to P0_7, P1_0 to P1_7<br>P3_0 to P3_7, P4_0 to P4_7<br>P12_0 to P12_7, P13_0 to P | , P5_0 to P5_7, | I <sub>OL</sub> = 1 mA | | | 0.5 | | | | | CEC | | I <sub>OL</sub> = 1 mA | | 0 | 0.5 | V | | V <sub>OL</sub> | Low output | | HIGH POWER | I <sub>OL</sub> = 0.1 mA | | | 0.5 | V | | ·OL | | | LOW POWER | I <sub>OL</sub> = 50 μA | | | 0.5 | | | | Low output | voltage XCOUT | HIGH POWER | With no load applied | | 0 | 0.0 | V | | | Low output | voltage 70001 | LOW POWER | With no load applied | | 0 | | • | | V <sub>T+</sub> -V <sub>T-</sub> | Hysteresis | HOLD, RDY, TAOIN to TA4IN INT7, NMI, ADTRG, CTS0 to SCL0 to SCL2, SCL5 to SCL to SDA7, CLK0 to CLK7, TAIKI3, RXD0 to RXD2, RXD5 to PMC0, PMC1, SCLMM, SDA | I, TB0IN to TB5IN, INTO to CTS2, CTS5 to CTS7,7, SDA0 to SDA2, SDA5 COUT to TA4OUT, KIO to RXD7, SIN3, SIN4, SD, | | 0.2 | | 1.0 | V | | | | CEC | | | 0.2 | 0.5 | 1.0 | V | | | | RESET | | | 0.2 | | 1.8 | V | | lн | High input<br>current | P0_0 to P0_7, P1_0 to P1_7<br>P3_0 to P3_7, P4_0 to P4_7<br>P6_0 to P6_7, P7_0 to P7_7<br>P9_0 to P9_7, P10_0 to P10<br>P12_0 to P12_7, P13_0 to P<br>XIN, RESET, CNVSS, BYTE | 7, P5_0 to P5_7,<br>7, P8_0 to P8_7,<br>1_7, P11_0 to P11_7,<br>113_7, P14_0, P14_1 | V <sub>I</sub> = 3 V | | | 4.0 | μА | | _ | Leakage cu | rrent in powered-off state | CEC | V <sub>CC1</sub> = 0 V | | | 1.8 | μА | | l <sub>IL</sub> | Low input<br>current | P0_0 to P0_7, P1_0 to P1_7<br>P3_0 to P3_7, P4_0 to P4_7<br>P6_0 to P6_7, P7_0 to P7_7<br>P9_0 to P9_7, P10_0 to P10<br>P12_0 to P12_7, P13_0 to P<br>XIN, RESET, CNVSS, BYTE | 7, P5_0 to P5_7,<br>7, P8_0 to P8_7,<br>1_7, P11_0 to P11_7,<br>113_7, P14_0, P14_1 | V <sub>I</sub> = 0 V | | | -4.0 | μА | | R <sub>PULLUP</sub> | Pull-up<br>resistance | P0_0 to P0_7, P1_0 to P1_7<br>P3_0 to P3_7, P4_0 to P4_7<br>P6_0 to P6_7, P7_2 to P7_7<br>P8_6, P8_7, P9_0 to P9_7, I<br>P11_0 to P11_7, P12_0 to P<br>P13_7, P14_0, P14_1 | 7, P2_0 to P2_7,<br>7, P5_0 to P5_7,<br>7, P8_0 to P8_4,<br>P10_0 to P10_7, | V <sub>I</sub> = 0 V | 50 | 80 | 150 | kΩ | | R <sub>fXIN</sub> | Feedback re | esistance XIN | | I | | 3.0 | | МΩ | | VILAT | | | | | | | | 1 | Note: 1. When $V_{CC1} \neq V_{CC2}$ , refer to 5 V or 3 V standard depending on the voltage. $V_{CC1} = V_{CC2} = 3 V$ Table 31.42 Electrical Characteristics (2) R5F36506CNFA, R5F36506CNFB, R5F36506CDFA, R5F3650ECNFA, R5F3650ECNFB, R5F3650ECDFA, R5F3650ECDFB $V_{CC1} = V_{CC2} = 2.7 \text{ to } 3.3 \text{ V}, V_{SS} = 0 \text{ V at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C} / -40^{\circ}\text{C to } 85^{\circ}\text{C}, f_{(BCLK)} = 32 \text{ MHz unless otherwise specified.}$ | Symbol | Parameter | | Measuring Condition | Standar<br>Min. Typ. | Max. | Unit | |--------------------|------------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------|------| | R <sub>fXCIN</sub> | Feedback resistance<br>XCIN | | | 16 | | ΜΩ | | I <sub>CC</sub> | Power supply current In single-chip, mode, | High-speed mode | f <sub>(BCLK)</sub> = 32 MHz<br>XIN = 4 MHz (square wave), PLL multiplied by 8<br>125 kHz on-chip oscillator stopped | 24.0 | | mA | | | the output pin are open and other pins are V <sub>SS</sub> | | f <sub>(BCLK)</sub> = 32 MHz, A/D conversion XIN = 4 MHz (square wave), PLL multiplied by 8 125 kHz on-chip oscillator stopped | 24.7 | | mA | | | | | f <sub>(BCLK)</sub> = 20 MHz<br>XIN = 20 MHz (square wave)<br>125 kHz on-chip oscillator stopped | 16.0 | | mA | | | | 40 MHz on-chip oscillator mode | Main clock stopped 40 MHz on-chip oscillator on, divide-by-4 (f <sub>(BCLK)</sub> = 10 MHz) 125 kHz on-chip oscillator stopped | 17.0 | | mA | | | | 125 kHz on-chip<br>oscillator mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator on, no division FMR22 = 1 (slow read mode) | 450.0 | | μА | | | | Low-power mode | f <sub>(BCLK)</sub> = 32 MHz<br>In low-power mode<br>FMR 22 = FMR23 = 1<br>On flash memory <sup>(1)</sup> | 160.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 MHz<br>In low-power mode<br>On RAM <sup>(1)</sup> | 40.0 | | μА | | | | Wait mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator on Peripheral clock operating Topr = 25°C | 20.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 MHz (oscillation capacity High) 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock operating T <sub>opr</sub> = 25°C | 8.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 kHz (oscillation capacity Low) 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock operating T <sub>opr</sub> = 25°C | 4.0 | | μА | | | | | XIN = 6 MHz 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock f1 provision disabled except timers (PCKSTP1A = 1) Main clock as a timer clock source (PCKSTP11 = 0, PCKSTP17 = 1) A given timer operating | 0.5 | | mA | | | | Stop mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock stopped $T_{opr} = 25^{\circ}C$ | 1.6 | | μА | | | | During flash<br>memory program | $f_{(BCLK)} = 10 \text{ MHz}, \text{ PM17} = 1 \text{ (one wait)}$<br>V <sub>CC1</sub> = 3.0 V | 20.0 | | mA | | | | During flash<br>memory erase | $f_{(BCLK)} = 10 \text{ MHz}, \text{ PM17} = 1 \text{ (one wait)}$<br>$V_{CC1} = 3.0 \text{ V}$ | 30.0 | | mA | Note: 1. This indicates the memory in which the program to be executed exists. $V_{CC1} = V_{CC2} = 3 \text{ V}$ ### Table 31.43 Electrical Characteristics (3) (1/2) R5F3651ECNFC, R5F3651KCNFC, R5F3650KCNFA, R5F3650KCNFB, R5F3651MCNFC, R5F3650MCNFA, R5F3650MCNFB, R5F3651NCNFC, R5F3650NCNFA, R5F3650NCNFB, $R5F3651ECDFC,\,R5F3651KCDFC,\,R5F3650KCDFA,\,R5F3650KCDFB,\,R5F3651MCDFC,\,R5F3650MCDFA,\,R5F3650MCDFB,\,R5F3651NCDFC,\,R5F3650NCDFA,\,R5F3650NCDFB$ $V_{CC1} = V_{CC2} = 2.7 \text{ to } 3.3 \text{ V}, V_{SS} = 0 \text{ V at T}_{opr} = -20 ^{\circ}\text{C to } 85 ^{\circ}\text{C} / -40 ^{\circ}\text{C to } 85 ^{\circ}\text{C}, \\ f_{(BCLK)} = 32 \text{ MHz unless otherwise specified.}$ | Symbol | Parameter | | Measuring Condition | | Standard | | Unit | |--------------------|-------------------------------------------------------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|------| | | | | Woodaring Condition | Min. | Тур. | Max. | Oint | | R <sub>fXCIN</sub> | Feedback resistance XCIN | | | | 16 | | МΩ | | lcc | Power supply current In single-chip, mode, the output pin are open and other pins are V <sub>SS</sub> | High-speed mode | f <sub>(BCLK)</sub> = 32 MHz<br>XIN = 4 MHz (square wave),<br>PLL multiplied by 8<br>125 kHz on-chip oscillator stopped | | 26.0 | | mA | | | | | f <sub>(BCLK)</sub> = 32 MHz, A/D conversion XIN = 4 MHz (square wave), PLL multiplied by 8 125 kHz on-chip oscillator stopped | | 27.0 | | mA | | | | | f <sub>(BCLK)</sub> = 20 MHz<br>XIN = 20 MHz (square wave)<br>125 kHz on-chip oscillator stopped | | 17.0 | | mA | | | | 40 MHz on-chip oscillator mode | Main clock stopped 40 MHz on-chip oscillator on, divide-by-4 (f(BCLK) = 10 MHz) 125 kHz on-chip oscillator stopped | | 18.0 | | mA | | | | 125 kHz on-chip<br>oscillator mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator on, no division FMR22 = 1 (slow read mode) | | 500.0 | | μА | | | | Low-power mode | f <sub>(BCLK)</sub> = 32 MHz<br>In low-power mode, FMR 22 = FMR23 = 1<br>on flash memory <sup>(1)</sup> | | 170.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 MHz<br>In low-power mode,<br>on RAM <sup>(1)</sup> | | 40.0 | | μА | | | | Wait mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator on Peripheral clock operating T <sub>opr</sub> = 25°C | | 20.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 MHz (oscillation capacity High) 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock operating T <sub>opr</sub> = 25°C | | 8.0 | | μА | | | | | f <sub>(BCLK)</sub> = 32 kHz (oscillation capacity Low) 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock operating T <sub>opr</sub> = 25°C | | 4.0 | | μА | | | | | XIN = 6 MHz 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock f1 provision disabled except timers (PCKSTP1A = 1) Main clock as a timer clock source (PCKSTP11 = 0, PCKSTP17 = 1) A given timer operating | | 0.5 | | mA | Note: 1. This indicates the memory in which the program to be executed exists. $V_{CC1} = V_{CC2} = 3 V$ ### Table 31.44 Electrical Characteristics (3) (2/2) R5F3651ECNFC, R5F3651KCNFC, R5F3650KCNFA, R5F3650KCNFB, R5F3651MCNFC, R5F3650MCNFA, R5F3650MCNFB, R5F3651NCNFC, R5F3650NCNFA, R5F3650NCNFB, R5F3651ECDFC, R5F3651KCDFC, R5F3650KCDFA, R5F3650KCDFB, R5F3651MCDFC, R5F3650MCDFA, R5F3650MCDFB, R5F3651NCDFC, R5F3650NCDFA, R5F3650NCDFB $V_{CC1} = V_{CC2} = 2.7 \text{ to } 3.3 \text{ V}, V_{SS} = 0 \text{ V at T}_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C} / -40^{\circ}\text{C to } 85^{\circ}\text{C}, f_{(BCLK)} = 32 \text{ MHz unless otherwise specified.}$ | Symbol | Parameter | | Measuring Condition | | Standard | | | |-----------------|--------------------------------------------------------------------------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|------| | Symbol | Farameter | | Measuring Condition | Min. | Тур. | Max. | Unit | | I <sub>CC</sub> | Power supply current<br>In single-chip, mode,<br>the output pin are<br>open and other pins | Stop mode | Main clock stopped 40 MHz on-chip oscillator stopped 125 kHz on-chip oscillator stopped Peripheral clock stopped $T_{opr} = 25^{\circ}C$ | | 1.6 | | μА | | | are V <sub>SS</sub> | During flash<br>memory program | $f_{(BCLK)} = 10 \text{ MHz}, \text{ PM17} = 1 \text{ (one wait)}$<br>$V_{CC1} = 3.0 \text{ V}$ | | 20.0 | | mA | | | | During flash<br>memory erase | $f_{(BCLK)} = 10 \text{ MHz}, \text{ PM17} = 1 \text{ (one wait)}$<br>$V_{CC1} = 3.0 \text{ V}$ | | 30.0 | | mA | $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ # 31.3.2 Timing Requirements (Peripheral Functions and Others) $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.3.2.1 Reset Input (RESET Input) # Table 31.45 Reset Input (RESET Input) | Symbol | Parameter | Stan | dard | Unit | | |----------------------|-----------------------------|------|------|-------|--| | Symbol | i alametei | Min. | Max. | Offic | | | t <sub>w(RSTL)</sub> | RESET input low pulse width | 10 | | μS | | Figure 31.20 Reset Input (RESET Input) # 31.3.2.2 External Clock Input Table 31.46 External Clock Input (XIN Input) (1) | Symbol | Parameter | Stan | Unit | | |-------------------|---------------------------------------|------|------|-------| | Symbol | | Min. | Max. | Offic | | t <sub>c</sub> | External clock input cycle time | 50 | | ns | | t <sub>w(H)</sub> | External clock input high pulse width | 20 | | ns | | $t_{w(L)}$ | External clock input low pulse width | 20 | | ns | | t <sub>r</sub> | External clock rise time | | 9 | ns | | t <sub>f</sub> | External clock fall time | | 9 | ns | Note: 1. The condition is $V_{CC1} = V_{CC2} = 2.7$ to 3.0 V. Figure 31.21 External Clock Input (XIN Input) $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # **31.3.2.3** Timer A Input Table 31.47 Timer A Input (Counter Input in Event Counter Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | Symbol | | Min. | Max. | Offic | | t <sub>c(TA)</sub> | TAilN input cycle time | 150 | | ns | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 60 | | ns | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 60 | | ns | Table 31.48 Timer A Input (Gating Input in Timer Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | Symbol | Falanielei | Min. | Max. | Offic | | t <sub>c(TA)</sub> | TAilN input cycle time | 600 | | ns | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 300 | | ns | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 300 | | ns | Table 31.49 Timer A Input (External Trigger Input in One-Shot Timer Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | Symbol | raidilletei | | Max. | Offic | | t <sub>c(TA)</sub> | TAilN input cycle time | 300 | | ns | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 150 | | ns | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 150 | | ns | Table 31.50 Timer A Input (External Trigger Input in Pulse Width Modulation Mode and Programmable Output Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | | | Min. | Max. | Offic | | t <sub>w(TAH)</sub> | TAilN input high pulse width | 150 | | ns | | t <sub>w(TAL)</sub> | TAilN input low pulse width | 150 | | ns | Figure 31.22 Timer A Input $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ Table 31.51 Timer A Input (Two-Phase Pulse Input in Event Counter Mode) | Symbol | Parameter | Stan | Unit | | |-----------------------------|-------------------------|------|------|-------| | | | Min. | Max. | Offic | | t <sub>c(TA)</sub> | TAilN input cycle time | 2 | | μS | | t <sub>su(TAIN-TAOUT)</sub> | TAiOUT input setup time | 500 | | ns | | t <sub>su(TAOUT-TAIN)</sub> | TAilN input setup time | 500 | | ns | Figure 31.23 Timer A Input (Two-Phase Pulse Input in Event Counter Mode) $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.3.2.4 Timer B Input Table 31.52 Timer B Input (Counter Input in Event Counter Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------------------------------|------|------|-------| | | i alametei | Min. | Max. | Offic | | t <sub>c(TB)</sub> | TBiIN input cycle time (counted on one edge) | 150 | | ns | | t <sub>w(TBH)</sub> | TBiIN input high pulse width (counted on one edge) | 60 | | ns | | t <sub>w(TBL)</sub> | TBilN input low pulse width (counted on one edge) | 60 | | ns | | t <sub>c(TB)</sub> | TBilN input cycle time (counted on both edges) | 300 | | ns | | t <sub>w(TBH)</sub> | TBilN input high pulse width (counted on both edges) | 120 | | ns | | t <sub>w(TBL)</sub> | TBilN input low pulse width (counted on both edges) | 120 | | ns | Table 31.53 Timer B Input (Pulse Period Measurement Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | | | Min. | Max. | Offic | | $t_{c(TB)}$ | TBilN input cycle time | 600 | | ns | | t <sub>w(TBH)</sub> | TBilN input high pulse width | 300 | | ns | | t <sub>w(TBL)</sub> | TBilN input low pulse width | 300 | | ns | Table 31.54 Timer B Input (Pulse Width Measurement Mode) | Symbol | Parameter | Stan | Unit | | |---------------------|------------------------------|------|------|-------| | | | Min. | Max. | Offic | | $t_{c(TB)}$ | TBilN input cycle time | 600 | | ns | | t <sub>w(TBH)</sub> | TBiIN input high pulse width | 300 | | ns | | tw(TBL) | TBilN input low pulse width | 300 | | ns | Figure 31.24 Timer B Input $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ ### 31.3.2.5 Serial Interface Table 31.55 Serial Interface | Symbol | Parameter | Stan | Unit | | |----------------------|-----------------------------|------|------|-------| | Symbol | Falantetei | Min. | Max. | Offic | | t <sub>c(CK)</sub> | CLKi input cycle time | 300 | | ns | | t <sub>w(CKH)</sub> | CLKi input high pulse width | 150 | | ns | | t <sub>w(CKL)</sub> | CLKi input low pulse width | 150 | | ns | | t <sub>d(C-Q)</sub> | TXDi output delay time | | 160 | ns | | t <sub>h(C-Q)</sub> | TXDi hold time | 0 | | ns | | t <sub>su(D-C)</sub> | RXDi input setup time | 100 | | ns | | t <sub>h(C-D)</sub> | RXDi input hold time | 90 | | ns | Figure 31.25 Serial Interface # 31.3.2.6 External Interrupt INTi Input # Table 31.56 External Interrupt INTi Input | Symbol | Parameter | Stan | Unit | | |---------------------|-----------------------------|------|------|-------| | | | Min. | Max. | Offic | | $t_{w(INH)}$ | INTi input high pulse width | 380 | | ns | | t <sub>w(INL)</sub> | INTi input low pulse width | 380 | | ns | Figure 31.26 External Interrupt INTi Input $$V_{CC1} = V_{CC2} = 3 V$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.3.2.7 Multi-master I<sup>2</sup>C-bus Table 31.57 Multi-master I<sup>2</sup>C-bus | Symbol | Parameter | Standard Clock Mode | | Fast-mode | | - Unit | |---------------------|---------------------------------|---------------------|------|-------------|------|--------| | Symbol | | Min. | Max. | Min. | Max. | Offic | | t <sub>BUF</sub> | Bus free time | 4.7 | | 1.3 | | μS | | t <sub>HD;STA</sub> | Hold time in start condition | 4.0 | | 0.6 | | μS | | $t_{LOW}$ | Hold time in SCL clock 0 status | 4.7 | | 1.3 | | μS | | t <sub>R</sub> | SCL, SDA signals' rising time | | 1000 | 20 + 0.1 Cb | 300 | ns | | t <sub>HD;DAT</sub> | Data hold time | 0 | | 0 | 0.9 | μS | | t <sub>HIGH</sub> | Hold time in SCL clock 1 status | 4.0 | | 0.6 | | μS | | f <sub>F</sub> | SCL, SDA signals' falling time | | 300 | 20 + 0.1 Cb | 300 | ns | | t <sub>su;DAT</sub> | Data setup time | 250 | | 100 | | ns | | t <sub>su;STA</sub> | Setup time in restart condition | 4.7 | | 0.6 | | μS | | t <sub>su;STO</sub> | Stop condition setup time | 4.0 | | 0.6 | | μS | Figure 31.27 Multi-master I<sup>2</sup>C-bus $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.3.3 Timing Requirements (Memory Expansion Mode and Microprocessor Mode) Table 31.58 Memory Expansion Mode and Microprocessor Mode | Symbol | Parameter | Stan | Unit | | |---------------------------|-----------------------------------------------------------------------|------|----------|-------| | Symbol | Falantetei | Min. | Max. | Offic | | t <sub>ac1(RD-DB)</sub> | Data input access time (for setting with no wait) | | (Note 1) | ns | | t <sub>ac2(RD-DB)</sub> | Data input access time (for setting with wait) | | (Note 2) | ns | | t <sub>ac3(RD-DB)</sub> | Data input access time (when accessing multiplex bus area) | | (Note 3) | ns | | t <sub>ac4(RD-DB)</sub> | Data input access time (for setting with 2 $\phi$ + 3 $\phi$ or more) | | (Note 4) | ns | | t <sub>su(DB-RD)</sub> | Data input setup time | 60 | | ns | | t <sub>su(RDY-BCLK)</sub> | RDY input setup time | 85 | | ns | | t <sub>h(RD-DB)</sub> | Data input hold time | 0 | | ns | | t <sub>h(BCLK-RDY)</sub> | RDY input hold time | 0 | | ns | #### Notes: Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 60[ns]$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{(n+0.5)\times 10^9}{f_{(BCLK)}}-60[ns] \quad \text{n is 1 for 1 wait setting, 2 for 2 waits setting and 3 for 3 waits setting.}$$ 3. Calculated according to the BCLK frequency as follows: $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 60[ns] \qquad \text{n is 2 for 2 waits setting, 3 for 3 waits setting.}$$ 4. Calculated according to the BCLK frequency as follows: $$\frac{n \times 10^9}{f_{(BCLK)}} - 60[ns] \qquad \text{n is 3 for 2} \ \phi + 3 \ \phi, \ 4 \ \text{for 2} \ \phi + 4 \ \phi, \ 4 \ \text{for 3} \ \phi + 4 \ \phi, \ 5 \ \text{for 4} \ \phi + 5 \ \phi,.$$ Figure 31.28 Timing Diagram $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ # 31.3.4 Switching Characteristics (Memory Expansion Mode and Microprocessor Mode) $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C} \text{ to } 85^{\circ}\text{C}/-40^{\circ}\text{C} \text{ to } 85^{\circ}\text{C} \text{ unless otherwise specified})$ # 31.3.4.1 In No Wait State Setting Table 31.59 Memory Expansion and Microprocessor Modes (in No Wait State Setting) | Symbol | Doromotor | Measuring | Standard | | Unit | |--------------------------|----------------------------------------------------|-----------------|----------|------|------| | Cyrribor | Parameter | Condition | Min. | Max. | Unit | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 30 | ns | | t <sub>h(BCLK-AD)</sub> | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD)</sub> | Address output hold time (in relation to RD) | | 0 | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 30 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 25 | ns | | t <sub>h(BCLK-ALE)</sub> | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | Figure<br>31.29 | | 30 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | 7 | | 30 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | 7 | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) (3) | | (Note 4) | | ns | #### Notes: 1. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 40[ns] \qquad \text{f}_{(BCLK)} \text{ is 12.5 MHz or less.}$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{0.5\times10^9}{f_{(BCLK)}}-15[ns]$$ 3. This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pull-up (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times ln(1 - V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL} = 0.2V_{CC2}$ , C = 30 pF, R = 1 k $\Omega$ , hold time of output low level is $t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \ln(1 - 0.2 \text{V}_{\text{CC2}}/\text{V}_{\text{CC2}})$ = 6.7 ns 4. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 25[ns]$$ Hold time is equal to or less than 0 ns when the BCLK frequency exceeds 20 MHz. RENESAS Figure 31.29 Ports P0 to P14 Measurement Circuit Figure 31.30 Timing Diagram $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ #### 31.3.4.2 In 1 to 3 Waits Setting and When Accessing External Area Table 31.60 Memory Expansion Mode and Microprocessor Mode (in 1 to 3 Waits Setting and When **Accessing External Area)** | Symbol | Parameter | Measuring | Standard | | Unit | |--------------------------|----------------------------------------------------|-------------------|----------|------|-------| | Cymbol | i alametei | Condition | Min. | Max. | Offic | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 30 | ns | | t <sub>h(BCLK-AD)</sub> | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD)</sub> | Address output hold time (in relation to RD) | | 0 | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 30 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 25 | ns | | t <sub>h(BCLK-ALE)</sub> | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | — Figure<br>31.29 | | 30 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | | | 30 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) (3) | | (Note 4) | | ns | #### Notes: Calculated according to the BCLK frequency as follows: 1. $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 40[ns] \qquad \qquad \text{n is 1 for 1 wait setting, 2 for 2 waits setting and 3 for 3 waits setting.} \\ \text{When n = 1, f}_{(BCLK)} \text{ is 12.5 MHz or less.}$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 15[ns]$$ This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pull-up (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times ln(1-V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL}$ = 0.2 $V_{CC2}$ , C = 30 pF, R = 1 k $\Omega$ , hold time of output low level is $$t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \ln(1 - 0.2\text{V}_{CC2}/\text{V}_{CC2})$$ $$= 6.7 \, \text{ns}$$ 4. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 25[ns]$$ Hold time is equal to or less than 0 ns when the BCLK frequency exceeds 20 MHz. RENESAS M16C/65C Group 31. Electrical Characteristics Figure 31.31 Timing Diagram $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.3.4.3 In 2 or 3 Waits Setting, and When Accessing External Area and Using Multiplexed Bus Table 31.61 Memory Expansion Mode and Microprocessor Mode (in 2 or 3 Waits Setting, and When Accessing External Area and Using Multiplexed Bus) (5) | Symbol | Parameter | Measuring | Standard | | Unit | |--------------------------|-------------------------------------------------------|---------------------|----------|------|-------| | Symbol | Falametei | Condition | Min. | Max. | Offic | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 50 | ns | | t <sub>h(BCLK-AD)</sub> | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD)</sub> | Address output hold time (in relation to RD) | | (Note 1) | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 6) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 50 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-CS)</sub> | Chip select output hold time (in relation to RD) | | (Note 1) | | ns | | t <sub>h(WR-CS)</sub> | Chip select output hold time (in relation to WR) | | (Note 1) | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | | | 40 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | _ | | 40 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | See<br>Figure 31.29 | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | - 1 Iguro 01.20 | | 50 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 2) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) | | (Note 7) | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time (in relation to BCLK) | | | 25 | ns | | t <sub>h(BCLK-ALE)</sub> | ALE signal output hold time (in relation to BCLK) | | -4 | | ns | | t <sub>d(AD-ALE)</sub> | ALE signal output delay time (in relation to Address) | | (Note 3) | | ns | | t <sub>h(AD-ALE)</sub> | ALE signal output hold time (in relation to Address) | | (Note 4) | | ns | | t <sub>d(AD-RD)</sub> | RD signal output delay from the end of address | | 0 | | ns | | t <sub>d(AD-WR)</sub> | WR signal output delay from the end of address | | 0 | | ns | | t <sub>dz(RD-AD)</sub> | Address output floating start time | | | 8 | ns | ### Notes: 1. Calculated according to the BCLK frequency as follows: $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 10[ns]$ 2. Calculated according to the BCLK frequency as follows: $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 50 [ns] \qquad \text{n is 2 for 2 waits setting, 3 for 3 waits setting.}$$ 3. Calculated according to the BCLK frequency as follows: $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 40 [ns]$ 4. Calculated according to the BCLK frequency as follows: $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 15 [ns]$ 5. When using multiplexed bus, set f<sub>(BCLK)</sub> 12.5 MHz or less. 6. Calculated according to the BCLK frequency as follows: $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 15[ns]$ 7. Calculated according to the BCLK frequency as follows: $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 25[ns]$ Figure 31.32 Timing Diagram $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.3.4.4 In Wait State Setting $2\phi$ + $3\phi$ , $2\phi$ + $4\phi$ , $3\phi$ + $4\phi$ , and $4\phi$ + $5\phi$ , and When Accessing External Area Table 31.62 Memory Expansion and Microprocessor Modes (in Wait State Setting $2\phi + 3\phi$ , $2\phi + 4\phi$ , $3\phi + 4\phi$ , and $4\phi + 5\phi$ , and When Accessing External Area) | Symbol | Parameter | Measuring | Standard | | Unit | |---------------------------|----------------------------------------------------|--------------|----------|------|-------| | | | Condition | Min. | Max. | Offic | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 30 | ns | | t <sub>h(BCLK-AD</sub> ) | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD</sub> ) | Address output hold time (in relation to RD) | | 0 | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 30 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 25 | ns | | t <sub>h(BCLK-ALE</sub> ) | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | Figure 31.29 | | 30 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | | | 30 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) (3) | | (Note 4) | | ns | #### Notes: 1. Calculated according to the BCLK frequency as follows: $$\frac{(n-0.5)\times 10^9}{f_{(BCLK)}} - 40[ns] \qquad \text{n is 3 for } 2\phi + 3\phi, \, 4 \text{ for } 2\phi + 4\phi, \, 4 \text{ for } 3\phi + 4\phi, \, \text{and 5 for } 4\phi + 5\phi.$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{0.5 \times 10^9}{f_{(BCLK)}} - 15[ns]$$ 3. This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pullup (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times ln(1 - V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL}$ = 0.2 $V_{CC2}$ , C = 30 pF, R = 1 k $\Omega$ , hold time of output low level is $$t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \ln(1 - 0.2 \text{V}_{CC2}/\text{V}_{CC2})$$ $= 6.7 \, \text{ns}$ Hold time is equal to or less than 0 ns when the BCLK frequency exceeds 20 MHz. RENESAS M16C/65C Group 31. Electrical Characteristics Figure 31.33 Timing Diagram $$V_{CC1} = V_{CC2} = 3 \text{ V}$$ $(V_{CC1} = V_{CC2} = 3 \text{ V}, V_{SS} = 0 \text{ V}, \text{ at } T_{opr} = -20^{\circ}\text{C to } 85^{\circ}\text{C}/-40^{\circ}\text{C to } 85^{\circ}\text{C unless otherwise specified})$ # 31.3.4.5 In Wait State Setting $2\phi+3\phi$ , $2\phi+4\phi$ , $3\phi+4\phi$ , and $4\phi+5\phi$ , and Inserting 1 to 3 Recovery Cycles and Accessing External Area Table 31.63 Memory Expansion Mode and Microprocessor Mode (in Wait State Setting $2\phi + 3\phi$ , $2\phi + 4\phi$ , $3\phi + 4\phi$ , and $4\phi + 5\phi$ , and Inserting 1 to 3 Recovery Cycles and Accessing External Area) | Symbol | Parameter | Measuring | Standard | | Linit | |---------------------------|----------------------------------------------------|--------------|----------|------|-------| | | | Condition | Min. | Max. | Unit | | t <sub>d(BCLK-AD)</sub> | Address output delay time | | | 30 | ns | | t <sub>h(BCLK-AD</sub> ) | Address output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>h(RD-AD</sub> ) | Address output hold time (in relation to RD) | | (Note 4) | | ns | | t <sub>h(WR-AD)</sub> | Address output hold time (in relation to WR) | | (Note 2) | | ns | | t <sub>d(BCLK-CS)</sub> | Chip select output delay time | | | 30 | ns | | t <sub>h(BCLK-CS)</sub> | Chip select output hold time (in relation to BCLK) | | 0 | | ns | | t <sub>d(BCLK-ALE)</sub> | ALE signal output delay time | | | 25 | ns | | t <sub>h(BCLK-ALE</sub> ) | ALE signal output hold time | See | -4 | | ns | | t <sub>d(BCLK-RD)</sub> | RD signal output delay time | Figure 31.29 | | 30 | ns | | t <sub>h(BCLK-RD)</sub> | RD signal output hold time | | 0 | | ns | | t <sub>d(BCLK-WR)</sub> | WR signal output delay time | | | 30 | ns | | t <sub>h(BCLK-WR)</sub> | WR signal output hold time | | 0 | | ns | | t <sub>d(BCLK-DB)</sub> | Data output delay time (in relation to BCLK) | | | 40 | ns | | t <sub>d(DB-WR)</sub> | Data output delay time (in relation to WR) | | (Note 1) | | ns | | t <sub>h(WR-DB)</sub> | Data output hold time (in relation to WR) (3) | | (Note 5) | | ns | ### Notes: 1. Calculated according to the BCLK frequency as follows: $$\frac{n\times 10^9}{f_{(BCLK)}} - 40[ns] \qquad \qquad \text{n is 3 for } 2\phi + 3\phi, \, 4 \text{ for } 2\phi + 4\phi, \, 4 \text{ for } 3\phi + 4\phi, \, \text{and 5 for } 4\phi + 5\phi.$$ 2. Calculated according to the BCLK frequency as follows: $$\frac{m\times 10^9}{f_{(BCLK)}} - 15[ns]$$ m is 1 when 1 recovery cycle is inserted, 2 when 2 recovery cycles are inserted, and 3 when 3 recovery cycles are inserted. This standard value shows the timing when the output is off, and does not show hold time of data bus. Hold time of data bus varies with capacitor volume and pull-up (pull-down) resistance value. Hold time of data bus is expressed in $$t = -CR \times ln(1 - V_{OL}/V_{CC2})$$ by a circuit of the right figure. For example, when $V_{OL}$ = 0.2 $V_{CC2}$ , C = 30 pF, R = 1 $k\Omega$ , hold time of output low level is $t = -30 \text{ pF} \times 1 \text{ k}\Omega \times \ln(1 - 0.2 \text{V}_{CC2}/\text{V}_{CC2})$ = 6.7 ns. 4. Calculated according to the BCLK frequency as follows: $$\frac{m\times 10^9}{f_{(BCLK)}} + 0 [ns] \\ \text{m is 1 when 1 recovery cycle is inserted, 2 when 2 recovery cycles are inserted, and 3 when 3 recovery cycles are inserted.}$$ 5. Calculated according to the BCLK frequency as follows: $$\frac{m \times 10^9}{f_{(BCLK)}} - 25[ns]$$ m is 1 when 1 recovery cycle is inserted, 2 when 2 recovery cycles are inserted, and 3 when 3 recovery cycles are inserted. Figure 31.34 Timing Diagram # 32. Usage Notes ### 32.1 Notes on Noise Connect a bypass capacitor (approximately $0.1 \, \mu F$ ) across pins VCC1 and VSS, and pins VCC2 and VSS using the shortest and thickest possible wiring. Figure 32.1 shows the Bypass Capacitor Connection. Figure 32.1 Bypass Capacitor Connection # 32.2 Notes on SFRs # 32.2.1 Register Settings Table 32.1 lists Registers with Write-Only Bits and registers whose function differs between reading and writing. Set these registers with immediate values. Do not use read-modify-write instructions. When establishing the next value by altering the existing value, write the existing value to the RAM as well as to the register. Transfer the next value to the register after making changes in the RAM. Read-modify-write instructions can be used when writing to the no register bits. Table 32.1 Registers with Write-Only Bits | Address | Register | Symbol | | |----------------|-----------------------------------------------------|--------|--| | 0249h | UART0 Bit Rate Register | U0BRG | | | 024Bh to 024Ah | UART0 Transmit Buffer Register | U0TB | | | 0259h | UART1 Bit Rate Register | U1BRG | | | 025Bh to 025Ah | UART1 Transmit Buffer Register | U1TB | | | 0269h | UART2 Bit Rate Register | U2BRG | | | 026Bh to 026Ah | UART2 Transmit Buffer Register | U2TB | | | 0273h | SI/O3 Bit Rate Register | S3BRG | | | 0277h | SI/O4 Bit Rate Register | S4BRG | | | 0289h | UART5 Bit Rate Register | U5BRG | | | 028Bh to 028Ah | UART5 Transmit Buffer Register | U5TB | | | 0299h | UART6 Bit Rate Register | U6BRG | | | 029Bh to 029Ah | UART6 Transmit Buffer Register | U6TB | | | 02A9h | UART7 Bit Rate Register | U7BRG | | | 02ABh to 02AAh | UART7 Transmit Buffer Register | U7TB | | | 02B6h | I2C0 Control Register 1 | S3D0 | | | 02B8h | I2C0 Status Register 0 | S10 | | | 0303h to 0302h | Timer A1-1 Register | TA11 | | | 0305h to 0304h | Timer A2-1 Register | TA21 | | | 0307h to 0306h | Timer A4-1 Register | TA41 | | | 030Ah | Three-Phase Output Buffer Register 0 | IDB0 | | | 030Bh | Three-Phase Output Buffer Register 1 | IDB1 | | | 030Ch | Dead Time Timer | DTT | | | 030Dh | Timer B2 Interrupt Generation Frequency Set Counter | ICTB2 | | | 0327h to 0326h | Timer A0 Register | TA0 | | | 0329h to 0328h | Timer A1 Register | TA1 | | | 032Bh to 032Ah | Timer A2 Register | TA2 | | | 032Dh to 032Ch | Timer A3 Register | TA3 | | | 032Fh to 032Eh | Timer A4 Register | TA4 | | | 037Dh | Watchdog Timer Refresh Register | WDTR | | | 037Eh | Watchdog Timer Start Register | WDTS | | Table 32.2 Read-Modify-Write Instructions | Function | Mnemonic | | | | |----------------------|------------------------------------------------------------------------------------|--|--|--| | Transfer | MOVDir | | | | | Bit processing | BCLR, BMCnd, BNOT, BSET, BTSTC, and BTSTS | | | | | Shifting | ROLC, RORC, ROT, SHA, and SHL | | | | | Arithmetic operation | ABS, ADC, ADCF, ADD, DEC, DIV, DIVU, DIVX, EXTS, INC, MUL, MULU, NEG, SBB, and SUB | | | | | Decimal operation | DADC, DADD, DSBB, and DSUB | | | | | Logical operation | AND, NOT, OR, and XOR | | | | | Jump | ADJNZ, SBJNZ | | | | # 32.3 Notes on Protection After setting the PRC2 bit to 1 (write enabled), by writing to a given SFR, the PRC2 bit becomes 0 (write disabled). Change the registers protected by the PRC2 bit in the next instruction after setting the PRC2 bit to 1. Make sure there are no interrupts or DMA transfers between the instruction that sets the PRC2 bit to 1 and the next instruction. # 32.4 Notes on Resets # 32.4.1 Power Supply Rising Gradient When supplying power to the MCU, make sure that the power supply voltage applied to the VCC1 pin meets the SVCC conditions. | Symbol | Parameter | | Standard | | | Unit | |--------|------------------------------------------------------------------|----------------------|----------|------|-------|------| | Symbol | | Min. | Тур. | Max. | Offic | | | SVcc | Power supply Vcc1 rising gradient (Voltage range: 0 to 2.0 V) | | 0.05 | | | V/ms | | | Power supply Vcc1 rising gradient (Voltage range: 2.0 V to Vcc1) | 3.6 V < VCC1 ≤ 5.5 V | | | 5.5 | V/ms | Figure 32.2 SVCC Timing (3.6 V < VCC1) Figure 32.3 SVCC Timing (VCC1 $\leq$ 3.6 V) #### 32.4.2 Power-On Reset Use the voltage monitor 0 reset together with the power-on reset. To use the power-on reset, set the LVDAS bit in the OFS1 address to 0 (voltage monitor 0 reset enabled after hardware reset) and the VDSEL1 bit to 0 (Vdet0\_2). In this case, the voltage monitor 0 reset is enabled (the VW0C0 bit and bit 6 in the VW0C register are 1, and the VC25 bit in the VCR2 register is 1) after power-on reset. Do not disable these bits by a program. # 32.4.3 OSDR Bit (Oscillation Stop Detect Reset Detect Flag) When an oscillator stop detect reset is generated, the MCU is reset and then stopped. This state is canceled by hardware reset or voltage monitor 0 reset. Note that the OSDR bit in the RSTFR register is not affected by a hardware reset, but becomes 0 (not detected) from a voltage monitor 0 reset. #### 32.5 Notes on Clock Generator ### 32.5.1 Oscillator Using a Crystal or a Ceramic Resonator To connect a crystal/ceramic resonator follow the instructions below: • The oscillation characteristics are tied closely to the user's board design. Perform a careful evaluation of the board before connecting an oscillator. - Oscillator structure depends on a crystal/ceramic resonator. The M16C/65C Group MCU contains a feedback resistor, but an additional external feedback resistor may be required. Contact the manufacturer of crystal/ceramic resonator regarding circuit constants, as they are dependent on the a crystal/ceramic resonator or stray capacitance of the mounted circuit. - Check output from the CLKOUT pin to confirm that the clock generated by the oscillator is properly transmitted to the MCU. The procedure for outputting a clock from the CLKOUT pin is listed below. Set the clock output from the CLKOUT pin to 25 MHz or lower. Outputting the main clock - (1) Set the PRC0 bit in the PRCR register to 1 (write enabled). - (2) Set the CM11 bit in the CM1 register, the CM07 bit in the CM0 register, and the CM21 bit in the CM2 register all to 0 (main clock selected). - (3) Select the clock output from the CLKOUT pin (see the table below). - (4) Set the PRC0 bit in the PRCR register to 0 (write disabled). Table 32.3 Output from CLKOUT Pin When Selecting Main Clock | Bit Setting | | | | | |----------------|-------------------|-------------------------------------------------|--|--| | PCLKR register | CM0 register | Output from the CLKOUT Pin | | | | PCLK5 bit | Bits CM01 to CM00 | | | | | 1 | 00b | Clock with the same frequency as the main clock | | | | 0 | 10b | Main clock divided by 8 | | | | 0 | 11b | Main clock divided by 32 | | | Outputting the sub clock - (1) Set the PRC0 bit in the PRCR register to 1 (write enabled). - (2) Set the CM07 bit in the CM0 register to 1 (sub clock selected). - (3) Set the PCLK5 bit in the PCLKR register to 0, and bits CM01 to CM00 in the CM0 register to 01b (fC output from CLKOUT pin). - (4) Set the PRC0 bit in the PRCR register to 0 (write disabled). Figure 32.4 Oscillator Example #### 32.5.2 Noise Countermeasure # 32.5.2.1 Clock I/O Pin Wiring - Connect the shortest possible wiring to the clock I/O pin. - Connect (a) the capacitor's ground lead connected to the crystal/ceramic resonator, and (b) the MCU's VSS pin, with the shortest possible wiring (maximum 20 mm). Figure 32.5 Clock I/O Pin Wiring #### Reason: When noise enters the clock I/O pin, the clock waveform becomes unstable, which causes an error in operation or a program runaway. Also, if a potential difference attributed to the noise occurs between the VSS level of the MCU and the VSS level of the crystal/ceramic resonator, an accurate clock is not input to the MCU. # 32.5.2.2 Large Current Signal Line For large currents that exceed the MCU's current range, wire the signal lines as far away from the MCU as possible (especially the crystal/ceramic resonator). #### Reason: In the system using the MCU, there are signal lines for controlling motors, LEDs, and thermal heads. When a large current flows through these signal lines, noise is generated due to mutual inductance. Figure 32.6 Large Current Signal Line Wiring # 32.5.2.3 Signal Line Whose Level Changes at a High-Speed For a signal line whose level changes at a high-speed, wire it as far away from the crystal/ceramic resonator and its wiring pattern as possible. Do not wire it across or extend it parallel to a clock-related signal line or other signal lines which are sensitive to noise. #### Reason: A signal whose level changes at a high-speed (such as the signal from the TAiOUT pin) affects other signal lines due to the level change at rising or falling edges. Specifically, when the signal line crosses the clock-related signal line, the clock waveform becomes unstable, which causes an error in operation or a program runaway. Figure 32.7 Wiring of Signal Line Whose Level Changes at High-Speed ### 32.5.3 CPU Clock (Technical update number: TN-M16C-109-0309) When an external clock is input from the XIN pin and the main clock is used as the CPU clock, do not stop the external clock. # 32.5.4 Oscillator Stop/Restart Detect Function - In the following cases, set the CM20 bit to 0 (oscillator stop/restart detect function disabled), and then change the setting of each bit. - When the CM05 bit is set to 1 (main clock stopped) - When the CM10 bit is set to 1 (stop mode) - To enter wait mode while using the oscillator stop/restart detect function, set the CM02 bit to 0 (peripheral function clock f1 not turned off during wait mode). - This function cannot be used if the main clock frequency is 2 MHz or lower. In that case, set the CM20 bit to 0 (oscillator stop/restart detect function disabled). - While the CM27 bit is 1 (oscillation stop/restart detect interrupt), when the FRA01 bit is 1 (40 MHz on-chip oscillator selected), set the FRA00 bit to 1 (40 MHz on-chip oscillator on). (Do not set the FRA00 bit to 0 while FRA01 bit is 1, and vice versa.) # 32.5.5 PLL Frequency Synthesizer To use the PLL frequency synthesizer, stabilize the supply voltage within the acceptable range of power supply ripple. Table 32.4 Acceptable Range of Power Supply Ripple | Symbol | Parameter | | Standard | | | Unit | |-----------|-------------------------------------------------|--------------|----------|------|-------|------| | Symbol | | Min. | Тур. | Max. | Offic | | | f(ripple) | Power supply ripple allowable frequency (VCC1) | | | | 10 | kHz | | | Power supply ripple allowable amplitude voltage | (VCC1 = 5 V) | | | 0.5 | V | | | | (VCC1 = 3 V) | | | 0.3 | V | | | Power supply ripple rising/falling gradient | (VCC1 = 5 V) | | | 0.3 | V/ms | | | | (VCC1 = 3 V) | | | 0.3 | V/ms | Figure 32.8 Voltage Fluctuation Timing #### 32.6 Notes on Power Control #### 32.6.1 CPU Clock When switching the CPU clock source, wait until oscillation of the switched clock source is stable. After exiting stop mode, wait until oscillation stabilizes before changing the division. #### 32.6.2 Wait Mode • Insert four or more NOP instructions following the WAIT instruction. When entering wait mode, because the instruction queue prefetches instructions that follow the WAIT instruction, prefetched instructions are sometimes executed prior to the interrupt routine used to exit wait mode. As shown below, when the instruction to set the I flag to 1 is allocated just before the WAIT instruction, interrupt requests are not accepted before the WAIT instruction is executed. The following is an example program for entering wait mode: Program Example: FSET I ; WAIT ; Enter wait mode NOP ; Insert at least four NOP instructions NOP NOP - Do not enter wait mode from PLL operating mode. To enter wait mode from PLL operating mode, first enter medium-speed mode, then set the PLC07 bit to 0 (PLL off). - Do not enter wait mode from low current consumption read mode. To enter wait mode from low current consumption read mode, set the FMR23 bit in the FMR2 register to 0 (low current consumption read mode disabled). - Do not enter wait mode from CPU rewrite mode. To enter wait mode from CPU rewrite mode, first set the FMR01 bit in the FMR0 register to 0 (CPU rewrite mode disabled), then disable the DMA transfer. - Set the PLC07 bit in the PLC0 register to 0 (PLL off). When the PLC07 bit is 1 (PLL on), current consumption cannot be reduced even in wait mode. ### **32.6.3** Stop Mode - When exiting stop mode by a hardware reset, drive the RESET pin low for 20 fOCO-S cycles or more. - Set the MR0 bit in the TAiMR register (i = 0 to 4) to 0 (pulse not output) when using timer A to exit stop mode. - When entering stop mode, insert a JMP.B instruction immediately after executing an instruction that sets the CM10 bit in the CM1 register to 1 (stop mode), and then insert at least four NOP instructions. When entering stop mode, the instruction queue reads ahead the instructions following the instruction which sets the CM10 bit to 1. Thus, some of the instructions may be executed before the MCU enters stop mode or before the interrupt routine for returning from stop mode. As shown below, when the instruction to set the I flag to 1 is allocated just before the instruction to set the CM10 bit to 1, interrupt requests are not accepted before entering stop mode. The following is an example program for entering stop mode: Program Example: FSET BSET 0, CM1; Enter stop mode JMP.B L2 ; Insert a JMP.B instruction L2: NOP ; At least four NOP instructions NOP NOP Do not enter stop mode from PLL operating mode. To enter stop mode from PLL operating mode, first enter medium-speed mode, then set the PLC07 bit to 0 (PLL off). - Do not enter stop mode from low current consumption read mode. To enter stop mode from low current consumption read mode, set the FMR23 bit in the FMR2 register to 0 (low current consumption read mode disabled). - Do not enter stop mode from CPU rewrite mode. To enter stop mode from CPU rewrite mode, first set the FMR01 bit in the FMR0 register to 0 (CPU rewrite mode disabled), then disable the DMA transfer. - Do not enter stop mode when the oscillator stop/restart detect function is enabled. To enter stop mode, set the CM20 bit in the CM2 register to 0 (oscillator stop/restart detect function disabled). - Do not enter stop mode when the FMR01 bit is 1 (CPU rewrite mode enabled), and do not enter stop mode when the flash memory is stopped (bits FMR01 and FMSTP are 1). # 32.6.4 Low Current Consumption Read Mode - Enter low current consumption read mode through slow read mode (see Figure 9.5 "Setting and Canceling Low Current Consumption Read Mode" for details). - When the FMR23 bit in the FMR2 register is 1 (low current consumption read mode enabled), do not set the FMSTP bit to 1 (flash memory stopped). Also, when the FMSTP bit is 1, do not set the FMR23 bit to 1. - When the FMR01 bit in the FMR0 register to 1 (CPU rewrite mode enabled), do not set the FMR23 bit in the FMR2 register to 1 (low current consumption read mode enable). ### 32.6.5 Slow Read Mode • When the FMR01 bit in the FMR0 register to 1 (CPU rewrite mode enabled), do not set the FMR22 bit in the FMR2 register to 1 (slow read mode enabled). #### 32.7 Notes on Bus # 32.7.1 Reading Data Flash When 2.7 V $\leq$ VCC1 $\leq$ 3.0 V and f(BCLK) $\geq$ 16 MHz, or when 3.0 V < VCC1 $\leq$ 5.5 V and f(BCLK) $\geq$ 20 MHz, one wait must be inserted to read the data flash. Use the PM17 bit or the FMR17 bit to insert one wait. #### 32.7.2 External Bus When a hardware reset, power-on reset, or voltage monitor 0 reset is performed with a high-level input on the CNVSS pin, the internal ROM cannot be read. # 32.7.3 External Access Immediately after Writing to the SFRs When accessing an external device after writing to the SFRs, the write signal and $\overline{CSi}$ signal switch simultaneously. Thus, adjust the capacity of each signal so as not to delay the write signal. ### 32.7.4 Wait and $\overline{RDY}$ Do not use the RDY function when bits CSEi1W to CSEi0W in the CSE register are 11b. ### 32.7.5 HOLD HOLD input is unavailable. Connect the HOLD pin to VCC2 via a resistor (pull-up). # 32.8 Notes on Programmable I/O Ports Note • For the 100-pin package, do not access the addresses of registers P11 to P14, PD11 to PD14, or PUR3. # 32.8.1 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/ $\overline{CTS2}/\overline{RTS2}/\overline{TA1IN/V}$ , P7\_4/TA2OUT/W, P7 5/TA2IN/W, P8 0/TA4OUT/RXD5/SCL5/U, P8 1/TA4IN/CTS5/RTS5/U #### 32.8.2 Influence of SI/O3 and SI/O4 When the SMi2 bit in the SiC register is set to 1 (SOUTi output disabled), the target pin becomes high-impedance regardless of which pin function being used. # 32.8.3 100-Pin Package Do not access the addresses assigned to registers P11 to P14, PD11 to PD14, and the PUR3 register. ### 32.9 Notes on Interrupts # 32.9.1 Reading Address 00000h Do not read address 00000h by a program. When a maskable interrupt request is accepted, the CPU reads interrupt information (interrupt number and interrupt request priority level) from address 00000h during the interrupt sequence. At this time, the IR bit of the accepted interrupt is cleared to 0 (interrupt not requested). If address 00000h is read by a program, the IR bit for the interrupt which has the highest priority among the enabled interrupts becomes 0. This may cause problems such as interrupts being canceled or an unexpected interrupt request being generated. # 32.9.2 SP Setting Set a value in the SP (USP, ISP) before accepting an interrupt. The SP (USP, ISP) is set to 0000h after reset. Therefore, if an interrupt is accepted before setting a value in the SP (USP, ISP), the program may go out of control. Set a value in the ISP at the beginning of the program. For the first instruction after reset only, all interrupts are disabled. # 32.9.3 NMI Interrupt - When not using the NMI interrupt, set the PM24 bit in the PM2 register to 0 (NMI interrupt disabled). - The $\overline{\text{NMI}}$ interrupt is disabled after reset. The $\overline{\text{NMI}}$ interrupt is enabled by setting the PM24 bit in the PM2 register to 1. Set the PM24 bit to 1 when a high-level signal is applied to the $\overline{\text{NMI}}$ pin. When the PM24 bit is set to 1 while a low-level signal is applied, an $\overline{\text{NMI}}$ interrupt is generated. Once the $\overline{\text{NMI}}$ interrupt is enabled, it cannot be disabled until the MCU is reset. - The MCU cannot enter stop mode while the PM24 bit is 1 (\overline{NMI}\) interrupt enabled) and input on the \overline{NMI}\) pin is low. When input on the \overline{NMI}\) pin is low, the CM10 bit in the CM1 register is fixed to 0. - Do not enter wait mode while the PM24 bit is 1 (\overline{NMI}\) interrupt enabled) and a low signal is input to the \overline{NMI}\) pin. When the \overline{NMI}\) pin is driven low, the CPU clock remains active even though the CPU stops, and therefore, the current consumption of the chip does not drop. In this case, the normal condition is restored by the next interrupt generation. - Set the low- and high-level durations of the input signal to the NMI pin to 2 CPU clock cycles + 300 ns or more. ### 32.9.4 Changing an Interrupt Source When the interrupt source is changed, the IR bit in the interrupt control register may become 1 (interrupt requested). To use an interrupt, change the interrupt source, and then set the IR bit to 0 (interrupt not requested). In this section, the changing of an interrupt source refers to all elements used in changing the interrupt source, polarity, and timing assigned to each software interrupt number. Therefore, if a mode change of any peripheral function involves changing the source, polarity or timing of an interrupt, be sure to clear the IR bit for that interrupt to 0 (interrupt not requested) after making such changes. Refer to the descriptions of the individual peripheral functions for details of the interrupts. Figure 32.9 shows the Procedure for Changing the Interrupt Generate Source. Figure 32.9 Procedure for Changing the Interrupt Generate Source ### 32.9.5 Rewriting the Interrupt Control Register To modify the interrupt control register, follow either of the procedures below: - Modify in places where no interrupt requests corresponding to the interrupt control register may occur. - If an interrupt request can be generated, disable that interrupt and then rewrite the interrupt control register. When using the I flag to disable an interrupt, set the I flag as shown in the sample program code below. (Refer to 32.9.6 "Instruction to Rewrite the Interrupt Control Register" for rewriting the interrupt control registers using the sample program code.) Examples 1 through 3 show how to prevent the I flag from becoming 1 (interrupt enabled) before the contents of the interrupt control register is rewritten, owing to the effects of the internal bus and the instruction queue buffer. Example 1: Using the NOP instruction to pause the program until the interrupt control register is modified ``` INT_SWITCH1: FCLR I ; Disable interrupts. AND.B #00H, 0055H ; Set the TA0IC register to 00h. NOP ; NOP FSET I ; Enable interrupts. ``` Example 2: Using a dummy read to delay the FSET instruction ``` INT_SWITCH2: FCLR I ; Disable interrupts. AND.B #00H, 0055H ; Set the TA0IC register to 00h. MOV.W MEM, R0 ; Dummy read. FSET I ; Enable interrupts. ``` Example 3: Using the POPC instruction to change the I flag ``` INT_SWITCH3: PUSHC FLG FCLR I ; Disable interrupts. AND.B #00H, 0055H ; Set the TA0IC register to 00h. POPC FLG ; Enable interrupts. ``` ### 32.9.6 Instruction to Rewrite the Interrupt Control Register - Do not use the BTSTC and BTSTS instructions to rewrite the interrupt control registers. - Use the AND, OR, BCLR, BSET, or MOV instruction to rewrite interrupt control registers. When an interrupt request is generated for the register being rewritten while executing an AND, OR, BCLR, or BSET instruction, the IR bit becomes 1 (interrupt requested) and remains 1. # 32.9.7 INT Interrupt • Either a low level of at least tw(INL) width or a high level of at least tw(INH) width is necessary for the signal input to pins INTO through INT7, regardless of the CPU operation clock. • If the POL bit in registers INT0IC to INT7IC, bits IFSR7 to IFSR0 in the IFSR register, or bits IFSR31 to IFSR30 in the IFSR3A register are changed, the IR bit may inadvertently become 1 (interrupt requested). Be sure to set the IR bit to 0 (interrupt not requested) after changing any of these register bits. # 32.10 Notes on the Watchdog Timer After the watchdog timer interrupt is generated, use the WDTR register to refresh the watchdog timer counter. #### 32.11 Notes on DMAC # 32.11.1 Write to the DMAE Bit in the DMiCON Register (i = 0 to 3) (Technical update number: TN-M16C-92-0306) When both of the following conditions are met, follow steps (1) and (2) below. #### Conditions - Write 1 (DMAi is in active state) to the DMAE bit when it is 1. - A DMA request may be generated simultaneously when writing to the DMAE bit. #### Steps - (1) Set bits DMAE and DMAS in the DMiCON register to 1 simultaneously. (1) - (2) Make sure the DMAi circuit is in an initialized state <sup>(2)</sup> by a program. If DMAi is not in an initialized state, repeat these two steps. #### Notes: - 1.The DMAS bit does not change even if set to 1. However, it becomes 0 when set to 0 (DMA not requested). Therefore, when writing to the DMiCON register to set the DMAE bit to 1, set the value to be written to the DMAS bit to 1 to retain its state immediately before writing. Similarly, when writing to the DMAE bit with a read-modify-write instruction, set the DMAS bit to 1 to retain the DMA request that was generated while executing the instruction. - 2.Read the TCRi register to verify whether DMAi is in an initialized state. If the read value is equal to the value that was written to the TCRi register before the DMA transfer started, DMAi is in an initialized state. When a DMA request is generated after writing to the DMAE bit, the read value is a value written to the TCRi register minus 1. If the read value is a value in the middle of a transfer, DMAi is not in an initialized state. ### 32.11.2 Changing the DMA Request Source When the DMS bit or any of bits from DSEL4 to DSEL0 in the DMiSL register is changed, the DMAS bit in the DMiCON sometimes becomes 1 (DMA requested). Set the DMAS bit to 0 (DMA not requested) after changing the DMS bit or bits DSEL4 to DSEL0 in the DMiSL register. #### 32.12 Notes on Timer A ### 32.12.1 Common Notes on Multiple Modes ### 32.12.1.1 Register Setting The timer stops after reset. Set the mode, count source, counter value, etc., using registers TAiMR, TAi, TAi1, UDF, TRGSR, PWMFS, TACS0 to TACS2, TAPOFS, TCKDIVC0, PCLKR, and bits TAZIE, TA0TGL, and TA0TGH in the ONSF register before setting the TAiS bit in the TABSR register to 1 (count started) (i = 0 to 4). Set the TCDIV00 bit in the TCKDIVC0 register before setting other registers associated with timer A. After changing the TCDIV00 bit, set other registers associated with timer A again. Always make sure registers TAiMR, UDF, TRGSR, PWMFS, TACS0 to TACS2, TAPOFS, TCKDIVC0, PCLKR, and bits TAZIE, TA0TGL, TA0TGH in the ONSF register are modified while the TAiS bit is 0 (count stopped), regardless of whether after reset or not. ### 32.12.1.2 Event or Trigger When bits TAiTGH to TAiTGL in the registers ONSF or TRGSR are 01b, 10b, or 11b, an event or a trigger occurs when an interrupt request of the selected timer is generated. An event or trigger occurs while an interrupt is disabled because an interrupt request signal is generated regardless of the I flag, IPL, or interrupt control registers. For some modes of the timers selected using bits TAiTGH to TAiTGL, an interrupt request is generated by a source other than overflow or underflow. For example, when using pulse-period measurement mode or pulse-width measurement mode in timer B2, an interrupt request is generated at an active edge of the measurement pulse. For details, refer to the "Interrupt request generation timing" in each mode's specification table. #### 32.12.1.3 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/CTS2/RTS2/TA1IN/ $\overline{V}$ , P7\_4/TA2OUT/W, P7 5/TA2IN/W, P8 0/TA4OUT/RXD5/SCL5/U, P8 1/TA4IN/CTS5/RTS5/U #### 32.12.1.4 Main Clock When using the main clock for the timer A and timer B count source (PCKSTP17 bit in the PCLKSTP1 register is 1), adhere the following: - Set the PCKSTP11 bit in the PCLKSTP1 register to 0 (f1 supply enabled). - The main clock can be used in PLL operating mode, high-speed mode, medium-speed mode, or wait mode. Do not use the main clock for the timer A and timer B count source in other modes. - When the PCKSTP17 bit is set to 1 and timer A or timer B operates in wait mode, set the CM02 bit to 0 (peripheral function clock f1 does not stop in wait mode). ## 32.12.2 Timer A (Timer Mode) # 32.12.2.1 Reading the Timer The counter value can be read from the TAi register at any time while counting. However, if the counter is read at the same time as it is reloaded, the read value is FFFFh. Also, if the counter is read before it starts counting, or after a value is set in the TAi register while not counting, the set value is read. # 32.12.3 Timer A (Event Counter Mode) # 32.12.3.1 Reading the Timer While counting, the counter value can be read at any time by reading the TAi register. However, while reloading, FFFFh can be read in underflow, and 0000h in overflow. When the counter is read before it starts counting and after a value is set in the TAi register while not counting, the set value is read. ## 32.12.4 Timer A (One-Shot Timer Mode) ### 32.12.4.1 Stop While Counting When setting the TAiS bit to 0 (count stopped), the following occurs: - The counter stops counting and reload register values are reloaded. - The TAiOUT pin outputs a low-level signal when the POFSi bit in the TAPOFS register is 0, and outputs a high-level signal when it is 1. - After one cycle of the CPU clock, the IR bit in the TAilC register becomes 1 (interrupt requested). ### 32.12.4.2 Delay between the Trigger Input and Timer Output As the one-shot timer output is synchronized with an internally generated count source, when an external trigger is selected, a maximum 1.5 cycle delay of the count source occurs between the trigger input to the TAilN pin and timer output. ### 32.12.4.3 Changing Operating Modes The IR bit becomes 1 when the timer operating mode is set by any of the following: - Selecting one-shot timer mode after reset - Changing the operating mode from timer mode to one-shot timer mode - Changing the operating mode from event counter mode to one-shot timer mode To use the timer Ai interrupt (IR bit), set the IR bit to 0 after the changes listed above are made. ### 32.12.4.4 Retrigger When a trigger occurs while counting, the counter reloads the reload register to continue counting after generating a retrigger and decrementing once. To generate a trigger while counting, generate a retrigger after at least one cycle of the timer count source has elapsed following the previous trigger. When an external trigger is generated, do not generate a retrigger for 300 ns before the count value becomes 0000h. The one-shot timer may stop counting. # 32.12.5 Timer A (Pulse Width Modulation Mode) ### 32.12.5.1 Changing Operating Modes The IR bit becomes 1 when setting a timer operating mode with any of the following: - Selecting PWM mode or programmable output mode after reset - Changing the operating mode from timer mode to PWM mode or programmable output mode - Changing the operating mode from event counter mode to PWM mode or programmable output mode To use the timer Ai interrupt (IR bit), set the IR bit to 0 by a program after the changes listed above are made. ### 32.12.5.2 Stop While Counting When setting the TAiS bit to 0 (count stopped) during PWM pulse output, the following occur: When the POFSi bit in the TAPOFS register is 0: - Counting stops - When the TAiOUT pin is high, the output level goes low and the IR bit becomes 1. - When the TAiOUT pin is low, both the output level and the IR bit remain unchanged. When the POFSi bit in the TAPOFS register is 1: - · Counting stops. - When the TAiOUT pin output is low, the output level goes high and the IR bit is set to 1. - When the TAiOUT pin output is high, both the output level and the IR bit remain unchanged. # 32.12.6 Timer A (Programmable Output Mode) # 32.12.6.1 Changing the Operating Mode The IR bit becomes 1 when setting a timer operating mode with any of the following: - Selecting PWM mode or programmable output mode after reset - Changing the operating mode from timer mode to PWM mode or programmable output mode - Changing the operating mode from event counter mode to PWM mode or programmable output mode To use the timer Ai interrupt (IR bit), set the IR bit to 0 by a program after the changes listed above are made. ### 32.12.6.2 Stop While Counting When setting the TAiS bit to 0 (count stopped) during pulse output, the following occur: When the POFSi bit in the TAPOFS register is 0: - · Counting stops. - When the TAiOUT pin is high, the output level goes low. - When the TAiOUT pin is low, the output level remains unchanged. - The IR bit remains unchanged. When the POFSi bit in the TAPOFS register is 1: - Counting stops - When the TAiOUT pin output is low, the output level goes high. - When the TAiOUT pin output is high, the output level remains unchanged. - The IR bit remains unchanged. # 32.13 Notes on Timer B ### 32.13.1 Common Notes on Multiple Modes ### 32.13.1.1 Register Setting The timer is stopped after reset. Set the mode, count source, etc., using registers TBiMR, TBCS0 to TBCS3, TBi, TCKDIVC0, PCLKR, PPWFS1, and PPWFS2 before setting the TBiS bit in the TABSR or TBSR register to 1 (count started) (i = 0 to 5). Rewrite registers TBiMR, TBCS0 to TBCS3, TCKDIVC0, PCLKR, PPWFS1, and PPWFS2 while the TBiS bit is 0 (count stopped), regardless of whether after reset or not. #### 32.13.1.2 Main Clock When using the main clock for the timer A and timer B count source (PCKSTP17 bit in the PCLKSTP1 register is 1), adhere the following: - Set the PCKSTP11 bit in the PCLKSTP1 register to 0 (f1 supply enabled). - The main clock can be used in PLL operating mode, high-speed mode, medium-speed mode, or wait mode. Do not use the main clock for the timer A and timer B count source in other modes. - When the PCKSTP17 bit is set to 1 and timer A or timer B operates in wait mode, set the CM02 bit to 0 (peripheral function clock f1 does not stop in wait mode). ### 32.13.2 Timer B (Timer Mode) # 32.13.2.1 Reading the Timer While counting, the counter value can be read at any time by reading the TBi register. However, FFFFh is read while reloading. When the counter is read before it starts counting and after a value is set in the TBi register while not counting, the set value is read. ### 32.13.3 Timer B (Event Counter Mode) # 32.13.3.1 Reading the Timer While counting, the counter value can be read at any time by reading the TBi register. However, FFFFh is read while reloading. When the counter is read before it starts counting and after a value is set in the TBi register while not counting, the set value is read. #### 32.13.3.2 Event When the TCK1 bit in the TBiMR register is 1, an event occurs when an interrupt request of the selected timer is generated. An event or trigger occurs while an interrupt is disabled because an interrupt request signal is generated regardless of the I flag, IPL, or interrupt control registers. When the timer selected by the TCK1 bit uses pulse-period measurement mode or pulse-width measurement mode, an interrupt request is generated at an active edge of the measurement pulse. # 32.13.4 Timer B (Pulse Period/Pulse Width Measurement Modes) ### 32.13.4.1 MR3 Bit in the TBiMR Register To clear the MR3 bit to 0 by writing to the TBiMR register while the TBiS bit is 1 (count started), be sure to set the same value as previously set to bits TMOD0, TMOD1, MR0, MR1, TCK0, and TCK1, and set bit 4 to 0. # 32.13.4.2 Interrupts The IR bit in the TBiIC register becomes 1 (interrupt requested) when an active edge of a measurement pulse is input, or timer Bi overflows (i = 0 to 5). The source of an interrupt request can be determined by setting the MR3 bit in the TBiMR register within the interrupt routine. Use the IR bit in the TBilC register to detect overflows only. Use the MR3 bit only to determine the interrupt source. # 32.13.4.3 Event or Trigger When timer Bi in pulse-period measurement mode or pulse-width measurement mode is used as an event or trigger for timer A or timer B other than timer Bi, an event or trigger occurs at both the overflow and active edge of the measurement pulse. ### 32.13.4.4 Operations between Count Start and the First Measurement When a count is started and the first active edge is input, an undefined value is transferred to the reload register. At this time, a timer Bi interrupt request is not generated. The value of the counter is undefined after reset. If the count is started in this state, the MR3 bit may become 1 and a timer Bi interrupt request may be generated after the count starts before an active edge is input. When a value is set in the TBi register while the TBiS bit is 0 (count stopped), the same value is written to the counter. #### 32.13.4.5 Pulse Period Measurement Mode When an active edge and overflow are generated simultaneously, input is not recognized at the active edge because an interrupt request is generated only once. Use this mode so an overflow is not generated, or use pulse width measurement mode. ### 32.13.4.6 Pulse Width Measurement Mode In pulse width measurement, pulse widths are measured successively. Check whether the measurement result is a high-level width or a low-level width in the user program. When an interrupt request is generated, read the TBilN pin level in the interrupt routine, and check whether it is the edge of an input pulse or overflow. The TBilN pin level can be read from bits in the register of ports sharing a pin. # 32.14 Notes on Three-Phase Motor Control Timer Function #### 32.14.1 Timer A and Timer B Refer to 17.5 "Notes on Timer A" and 18.5 "Notes on Timer B". # 32.14.2 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/CTS2/RTS2/TA1IN/ $\overline{V}$ , P7\_4/TA2OUT/W, P7\_5/TA2IN/ $\overline{W}$ , P8\_0/TA4OUT/RXD5/SCL5/U, P8\_1/TA4IN/ $\overline{CTS5}/\overline{RTS5}/\overline{U}$ #### 32.15 Notes on Real-Time Clock ### 32.15.1 Starting and Stopping the Count The real-time clock uses the TSTART bit for instructing the count to start or stop, and the TCSTF bit which indicates count started or stopped. Bits TSTART and TCSTF are in the RTCCR1 register. The real-time clock starts counting and the TCSTF bit becomes 1 (count started) when the TSTART bit is set to 1 (count started). It takes up to two cycles of the count source until the TCSTF bit becomes 1 after setting the TSTART bit to 1. During this time, do not access registers associated with the real-time clock (1) other than the TCSTF bit. Similarly, when setting the TSTART bit to 0 (count stopped), the real-time clock stops counting and the TCSTF bit becomes 0 (count stopped). It takes up to three cycles of the count source until the TCSTF bit becomes 0 after setting the TSTART bit to 0. During this time, do not access registers associated with the real-time clock other than the TCSTF bit. #### Note: 1. Registers associated with the real-time clock: RTCSEC, RTCMIN, RTCHR, RTCWK, RTCCR1, RTCCR2, RTCCSR, RTCCSEC, RTCCMIN, and RTCCHR. # 32.15.2 Register Settings (Time Data, etc.) Write to the following registers/bits when the real-time clock is stopped: - Registers RTCSEC, RTCMIN, RTCHR, RTCWK, and RTCCR2 - Bits H12H24 and RTCPM in the RTCCR1 register - Bits RCS0 to RCS4 in the RTCCSR register The real-time clock is stopped when bits TSTART and TCSTF in the RTCCR1 register are 0 (real-time clock stopped). Set the RTCCR2 register after setting the registers and bits mentioned above (immediately before the real-time clock count starts). Figure 20.4 shows Time and Day Change Procedure (No Compare Mode or Compare Mode 1), and Figure 20.5 shows Time and Day Change Procedure (Compare Mode 2 or Compare Mode 3). # 32.15.3 Register Settings (Compare Data) Write to the following registers when the BSY bit in the RTCSEC register is 0 (not while data is updated). Registers RTCCSEC, RTCCMIN, and RTCCHR ### 32.15.4 Time Reading Procedure in Real-Time Clock Mode In real-time clock mode, read time data bits <sup>(1)</sup> when the BSY bit in the RTCSEC register is 0 (not while data is updated). When reading multiple registers, if data is rewritten between reading registers, an errant time will be read. To prevent this, use one of the following steps when reading: - Using an interrupt - In the real-time clock periodic interrupt routine, read the values necessary from the appropriate time data bits. - Monitoring by a program 1 Monitor the IR bit in the RTCTIC register by a program and read necessary values of time data bits after the IR bit becomes 1 (periodic interrupt requested). - Monitoring by a program 2 Read the time data according to Figure 32.10 "Time Data Reading". Figure 32.10 Time Data Reading - Using read results if they are the same value twice - (1) Read the values necessary from time data bits. - (2) Read the same bit as (1) and compare the contents. - (3) If the contents match, adopt that value as the correct value. If the contents do not match, repeat until the read contents match with the previous contents. Also, when reading multiple registers, read them as continuously as possible. #### Note: 1. Time data bits are as follows: Bits SC12 to SC10 and SC03 to SC00 in the RTCSEC register Bits MN12 to MN10 and MN03 to MN00 in the RTCMIN register Bits HR11 to HR10 and HR03 to HR00 in the RTCHR register Bits WK2 to WK0 in the RTCWK register The RTCPM bit in the RTCCR1 register # 32.16 Notes on Remote Control Signal Receiver ### 32.16.1 Starting/Stopping PMCi The EN bit in the PMCiCON0 register controls the start/stop of PMCi. The ENFLG bit in the PMCiCON2 register indicates that operation started/stopped. The PMCi circuit starts operating by setting the EN bit to 1 (operation enabled) and the ENFLG bit becomes 1 (operating). After setting the EN bit to 1, it takes up to two cycles of the count source before the ENFLG bit becomes 1. When the EN bit is set to 0 (operation disabled), the PMCi circuit stops operating and the ENFLG bit becomes 0 (operation stopped). After setting the EN bit to 0, it takes up to one cycle of the count source before the ENFLG bit becomes 0. Between setting the EN bit to 1 and the ENFLG bit becoming 1, and while the ENFLG bit is 1, do not access bits in the PMCi associated registers (registers listed in Table 22.4 and Table 22.5 "Registers") except for the ENFLG bit. ### 32.16.2 Reading the Register When the following registers are read while data changes, an undefined value may be read. Flags in registers PMCiCON2 and PMCiSTS Registers PMCiTIM, PMC0DAT0 to PMC0DAT5, and PMC0RBIT Follow the procedures below to avoid reading an undefined value. #### In pattern match mode Using an interrupt Set the DRINT bit in the PMCiINT register to 1 (data reception complete interrupt enabled) and read the registers within the PMCi interrupt routine. Monitoring by a program 1 Set the DRINT bit in the PMCiINT register to 1 (data reception complete interrupt enabled) and monitor the IR bit in the PMCiIC register by a program. Read the registers when the IR bit becomes 1 (interrupt request is generated). - Monitoring by a program 2 - (1) Monitor the DRFLG bit in the PMCiSTS register. - (2) When the DRFLG bit becomes 1, monitor the DRFLG bit until it becomes 0. - (3) Read the necessary content of the registers when the DRFLG bit becomes 0. #### In input capture mode Using an interrupt Set the TIMINT bit in the PMCiINT register to 1 (timer measure interrupt enabled) and read the registers within the PMCi interrupt routine. Monitoring by a program 1 Set the TIMINT bit in the PMCiINT register to 1 (timer measure interrupt enabled) and monitor the IR bit in the PMCiIC register by a program. Read the registers when the IR bit becomes 1 (interrupt request is generated). If the register data may change at the same time as the register is read even with above countermeasures, read the register more than once to determine whether the read value is correct. ### 32.16.3 Rewriting the Register Rewrite the registers and bits related to PMC excluding the EN bit in the PMCiCON0 register when both of the EN bit in the PMCiCON0 register and the ENFLG bit in the PMCiCON2 register are 0 (PMCi stops). # 32.16.4 Combined Operation When using combined operation, set same value to bits TYP1 to TYP0 in the PMC0CON1 register and bits TYP1 to TYP0 in the PMC1CON1 register. # 32.17 Notes on Serial Interface UARTi (i = 0 to 2, 5 to 7) ### 32.17.1 Common Notes on Multiple Modes # 32.17.1.1 Influence of SD When a low-level signal is applied to the $\overline{SD}$ pin while the IVPCR1 bit in the TB2SC register is 1 (three-phase output forcible cutoff by input on $\overline{SD}$ pin enabled), the following pins become high-impedance: P7\_2/CLK2/TA1OUT/V, P7\_3/ $\overline{CTS2}/\overline{RTS2}/\overline{TA1IN/V}$ , P7\_4/ $\overline{TA2OUT/W}$ , P7\_5/TA2IN/W, P8\_0/TA4OUT/RXD5/SCL5/U, P8\_1/TA4IN/CTS5/RTS5/U ### 32.17.1.2 Register Setting Set the OCOSEL0 or OCOSEL1 bit in the UCLKSEL0 register before setting other registers associated with UART0 to UART2 or UART5 to UART7. After changing the OCOSEL0 or OCOSEL1 bit, set other registers associated with UART0 to UART2 or UART5 to UART7 again. ### 32.17.1.3 CLKi Output (Technical update number: TN-16C-A178A/E) When using the N-channel open drain output as an output mode of the CLKi pin, use following procedure to change the pin function: When changing the pin function from the port to CLKi. - (1) Set bits SMD2 to SMD0 in the UiMR register to a value other than 000b to select serial interface mode. - (2) Set the NODC bit in the UiSMR3 register to 1. When changing the pin function from CLKi to the port. - (1) Set the NODC bit to 0. - (2) Set bits SMD2 to SMD0 to 000b to disable the serial interface. ### 32.17.2 Clock Synchronous Serial I/O Mode ### 32.17.2.1 Transmission/Reception When the $\overline{RTS}$ function is used with an external clock, the $\overline{RTSi}$ pin (i = 0 to 2, 5 to 7) outputs a low-level signal, which informs the transmitting side that the MCU is ready for a receive operation. The $\overline{RTSi}$ pin outputs a high-level signal when a receive operation starts. Therefore, transmit timing and receive timing can be synchronized by connecting the $\overline{RTSi}$ pin to the $\overline{CTSi}$ pin on the transmitting side. The $\overline{RTS}$ function is disabled when an internal clock is selected. ### 32.17.2.2 Transmission If the transmission is started while an external clock is selected and the TXEPT bit in the UiC0 register (i = 0 to 2, 5 to 7) is 1 (no data present in transmit register), meet the last requirement at either of the following timings: External clock level: - The CKPOL bit in the UiC0 register is 0 (transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising edge) and the external clock is high. - The CKPOL bit is 1 (transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling edge) and the external clock is low. Requirements to start transmission (in no particular order): - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). - When the CTS function is selected, input on the CTSi pin is low. ### 32.17.2.3 Reception In clock synchronous serial I/O mode, a shift clock is generated by activating a transmitter. Set the UARTi-associated registers for a transmit operation even if the MCU is used for a receive operations only. Dummy data is output from the TXDi pin (i = 0 to 2, 5 to 7) while receiving. When an internal clock is selected, a shift clock is generated by setting the TE bit in the UiC1 register to 1 (transmission enabled) and placing dummy data in the UiTB register. When an external clock is selected, set the TE bit to 1 (transmission enabled), set dummy data in the UiTB register, and input an external clock to the CLKi pin to generate a shift clock. If data is received consecutively, an overrun error occurs when the RI bit in the UiC1 register is 1 (data present in the UiRB register) and the next receive data is received in the UARTi receive register. Then, the OER bit in the UiRB register becomes 1 (overrun error occurred). At this time, the UiRB register is undefined. When an overrun error occurs, program the transmitting and receiving sides to retransmit the previous data. If an overrun error occurs again, the IR bit in the SiRIC register remains unchanged. To receive data consecutively, set dummy data in the low-order byte in the UiTB register for each receive operation. If the reception is started while an external clock is selected and the TXEPT bit in the UiC0 register is 1 (no data present in transmit register), meet the last requirement at either of the timings below. #### External clock level: - The CKPOL bit in the UiC0 register is 0 (transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising edge) and the external clock is high. - The CKPOL bit is 1 (transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling edge) and the external clock is low. Requirements to start reception (in no particular order): - The RE bit in the UiC1 register is 1 (reception enabled). - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). ### 32.17.3 Special Mode 1 (I<sup>2</sup>C Mode) ### 32.17.3.1 Generating Start and Stop Conditions (Technical update number: TN-16C-130A/EA) When generating start, stop, and restart conditions, set the STSPSEL bit in the UiSMR4 register (i = 0 to 2, 5 to 7) to 0 and wait for more than a half cycle of the transmit/receive clock. Then set each condition generation bit (STAREQ, RSTAREQ, and STPREQ) from 0 to 1. #### 32.17.3.2 IR Bit Set the following bits first, and then set the IR bit in each UARTi interrupt control register to 0 (interrupt not requested). Bits SMD2 to SMD0 in the UiMR register, the IICM bit in the UiSMR register, the IICM2 bit in the UiSMR2 register, the CKPH bit in the UiSMR3 register # 32.17.3.3 Low/High-level Input Voltage and Low-level Output Voltage The low-level input voltage, high-level input voltage, and low-level output voltage differ from the I<sup>2</sup>C-bus specification. Refer to the recommended operating conditions for I/O ports which share the pins with SCL and SDA I<sup>2</sup>C-bus specification High level input voltage ( $V_{IH}$ ) = min. 0.7 $V_{CC}$ Low level input voltage $(V_{IL})$ = max. 0.3 $V_{CC}$ ### 32.17.3.4 Setup and Hold Times When Generating a Start/Stop Condition When generating a start condition, the hold time ( $t_{HD}$ :STA) is a half cycle of the SCL clock. When generating a stop condition, the setup time ( $t_{SU}$ :STO) is a half cycle of the SCL clock. When the SDA digital delay function is enabled, take delay time into consideration (see 23.3.3.7 "SDA Digital Delay"). The following shows a calculation example of hold and setup times when generating a start/stop condition. Calculation example when setting 100 kbps - UiBRG count source: f1 = 20 MHz - UiBRG register setting value: n = 100 1 - SDA digital delay setting value: DL2 to DL0 are 101b (5 or 6 cycles of UiBRG count source) ``` f_{SCL} (theoretical value) = f1 / (2(n+1)) = 20 MHz / (2 × (99 + 1)) = 100 kbps t_{DL} = delay cycle count / f1 = 6 / 20 MHz = 0.3 \mu s t_{HD:STA} (theoretical value) = 1 / (2f_{SCL} (theoretical value)) = 1 / (2 × 100 kbps) = 5 \mu s t_{SU:STO} (theoretical value) = 1 / (2f_{SCL} (theoretical value)) = 1 / (2 × 100 kbps) = 5 \mu s t_{HD:STA} (actual value) = t_{HD:STA} (theoretical value) - t_{DL} = 5 \mu s - 0.3 \mu s = 4.7 \mu s t_{SU:STO} (actual value) = t_{SU:STO} (theoretical value) + t_{DL} = 5 \mu s + 0.3 \mu s = 5.3 \mu s ``` Figure 32.11 Setup and Hold Times When Generating Start and Stop Conditions # 32.17.3.5 Restrictions on the Bit Rate When Using the UiBRG Count Source In I<sup>2</sup>C mode, set the UiBRG register to a value of 03h or greater. A maximum of three UiBRG count source cycles are necessary until the internal circuit acknowledges the SCL clock level. The connectable I<sup>2</sup>C-bus bit rate is one-third or less than the UiBRG count source speed. If a value between 00h to 02h is set to the UiBRG register, bit slippage may occur. #### 32.17.3.6 Restart Condition in Slave Mode When a restart condition is detected in slave mode, the successive processes may not be executed correctly. In slave mode, do not use a restart condition. ### 32.17.3.7 Requirements to Start Transmission/Reception in Slave Mode When transmission/reception is started in slave mode and the TXEPT bit in the UiC0 register is 1 (no data present in transmit register), meet the last requirement when the external clock is high. Requirements to start transmission (in no particular order): - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). Requirements to start reception (in no particular order): - The RE bit in the UiC1 register is 1 (reception enabled). - The TE bit in the UiC1 register is 1 (transmission enabled). - The TI bit in the UiC1 register is 0 (data present in the UiTB register). ## 32.17.4 Special Mode 4 (SIM Mode) (Technical update number: TN-M16C-101-0309) After reset, a transmit interrupt request is generated by setting bits U2IRS and U2ERE in the U2C1 register to 1 (transmission completed, error signal output), then setting the TE bit to 1 (transmission enabled) and the transmission data to the U2TB register. Therefore, when using SIM mode, make sure to set the IR bit to 0 (interrupt not requested) after setting these bits. #### 32.18 Notes on SI/O3 and SI/O4 ### 32.18.1 SOUTi Pin Level When SOUTi Output Is Disabled When the SMi2 bit in the SiC register is set to 1 (SOUTi output disabled), the target pin becomes high-impedance regardless of which pin function being used. #### 32.18.2 External Clock Control The data written to the SiTRR register shifts each time the external clock is input. When completing data transmission/reception of the eighth bit, read or write to the SiTRR register before inputting the clock for the next data transmission/reception. ### 32.18.3 Register Access Set the SM22 bit in the S34C2 register before setting other registers associated with SI/O3 and SI/O4. After changing the SM22 bit, set other registers associated with SI/O3 and SI/O4 again. # 32.18.4 Register Access When Using the External Clock When the SMi6 bit in the SiC register is 0 (external clock), write to the SMi7 bit in the SiC register and SiTRR register under the following conditions: - When the SMi4 bit in the SiC register is 0 (transmit data is output at the falling edge of transmit/receive clock and receive data is input at the rising edge): CLKi input is high. - When the SMi4 bit in the SiC register is 1 (transmit data is output at the rising edge of transmit/receive clock and receive data is input at the falling edge): CLKi input is low. ### 32.18.5 SiTRR Register Access Write transmit data to the SiTRR register while transmission/reception is stopped. Read receive data from the SiTRR register while transmission/reception is stopped. The IR bit in the SiIC register becomes 1 (interrupt requested) during output of the eighth bit. When the SM26 bit (SOUT3) or SM27 bit (SOUT4) in the S34C2 register is 0 (high-impedance after transmission), the SOUTi pin becomes high-impedance when the transmit data is written to the SiTRR register immediately after an interrupt request is generated, and the hold time of the transmit data becomes shorter. ### 32.18.6 Pin Function Switch When Using the Internal Clock (Technical update number: TN-16C-121A/EA) If the SMi3 bit in the SiC register (i = 3, 4) changes from 0 (I/O port) to 1 (SOUTi output, CLKi function) when setting the SMi2 bit to 0 (SOUTi output) and the SMi6 bit to 1 (internal clock), the SOUTi initial value set to the SOUTi pin by the SMi7 bit may be output for about 10 ns. Then, the SOUTi pin becomes high-impedance. If the output level from the SOUTi pin when the SMi3 bit changes from 0 to 1 becomes a problem, set the SOUTi initial value by the SMi7 bit. ### 32.18.7 Operation after Reset When Selecting the External Clock When the SMi6 bit in the SiC register is 0 (external clock) after reset, the IR bit in the SiIC register becomes 1 (interrupt requested) by inputting an external clock for 8 bits to the CLKi pin. This will also occur even when the SMi3 bit in the SiC register is 0 (serial interface disabled) or before a value is written to the SiTRR register. ### 32.19 Notes on Multi-master I<sup>2</sup>C-bus Interface #### 32.19.1 Limitation on CPU Clock When the CM07 bit in the CM0 register is 1 (CPU clock is a sub clock), do not access the registers listed in Table 25.4 "Registers". Set the CM07 bit to 0 (main clock, PLL clock, or on-chip oscillator clock) to access these registers. ### 32.19.2 Register Access Refer to the notes below when accessing the I<sup>2</sup>C interface control registers. The period from the rising edge of the first clock of the slave address or 1-byte data transmission/reception to the falling edge of an ACK clock is considered to be the transmission/reception period. When the ACKCLK bit is 0 (no ACK clock), the transmission/reception period is from the rising edge of the first clock of the slave address or 1-byte data transmission/reception to the falling edge of the eighth clock. ### 32.19.2.1 S00 Register Do not write to the S00 register during transmission/reception. ### 32.19.2.2 S1D0 Register Do not change bits other than the IHR bit in the S1D0 register during transmission/reception. ### 32.19.2.3 S20 Register Do not change bits other than the ACKBIT bit in the S20 register during transmission/reception. # 32.19.2.4 S3D0 Register - Do not use the bit managing instruction (read-modify-write instruction) to access the S3D0 register. Use the MOV instruction to write to this register. - Rewrite bits ICK1 and ICK0 when the ES0 bit in the S1D0 register is 0 (I2C interface disabled). ### 32.19.2.5 S4D0 Register Rewrite bits ICK4 to ICK2 when the ES0 bit in the S1D0 register is 0 (I<sup>2</sup>C interface disabled). ### 32.19.2.6 S10 Register - Do not use the bit managing instruction (read-modify-write instruction) to access the S10 register. Use the MOV instruction to write to this register. - Do not write to the S10 register when bits MST and TRX change their values. Refer to operation examples in 25.3 "Operations" for bits MST and TRX change. #### 32.19.3 Low/High-level Input Voltage and Low-level Output Voltage The low-level input voltage, high-level input voltage, and low-level output voltage differ from the I<sup>2</sup>C-bus specification. Refer to the recommended operating conditions for I/O ports which share the pins with SCL and SDA. I<sup>2</sup>C-bus specification High level input voltage ( $V_{IH}$ ) = min. 0.7 $V_{CC}$ Low level input voltage ( $V_{II}$ ) = max. 0.3 $V_{CC}$ #### 32.20 Notes on CEC # 32.20.1 Registers and Bit Operation The registers and bits of the CEC function are synchronized with the count source. Therefore, the internal circuit starts to operate from the next count source timing, while the values of the register are changed immediately after rewriting the register. When rewriting the same bit successively or reading the bit changed under the influence of another bit, wait for one or more cycles of the count source. Example: when rewriting the same bit successively - (1) Change the bit to 0. - (2) Wait for one or more cycles of the count source. - (3) Change the same bit to 1. Example: when reading the bit rewritten under the influence of another bit (after reception is disabled, to ensure that the CRERRFLG bit in the CECFLG register becomes 0 (no reception error detected)). - (1) Set the CRXDEN bit in the CECC3 register to 0 (reception disabled) - (2) Wait for one or more cycles of the count source. - (3) Read the CRERRFLG bit in the CECFLG register. ### 32.20.2 VIH of the CEC pin VIH of the CEC pin does not meet the CEC standard value. Apply VIH to the CEC pin or use the CEC external circuit shown in Figure 32.12 "CEC External Circuit" to change the CEC pin input voltage to VIH of the CEC pin or above. Figure 32.12 CEC External Circuit #### 32.21 Notes on A/D Converter ## 32.21.1 Analog Input Voltage Set the analog input voltage as follows: analog input voltage (AN\_0 to AN\_7, ANEX0, and ANEX1) $\leq$ VCC1 analog input voltage (AN0\_0 to AN0\_7 and AN2\_7 to AN2\_7) $\leq$ VCC2 ### 32.21.2 Analog Input Pin Do not use any pin from AN4 to AN7 as analog input pin if any pin from $\overline{\text{KI0}}$ to $\overline{\text{KI3}}$ is used as a key input interrupt. # 32.21.3 Pin Configuration To prevent operation errors due to noise or latchup, and to reduce conversion errors, place capacitors between the AVSS pin and the AVCC pin, the VREF pin, and analog inputs (ANi (i = 0 to 7), ANEXi, ANO\_i, and AN2\_i). Also, place a capacitor between the VCC1 pin and VSS pin. Figure 32.13 Example of Pin Configuration #### 32.21.4 Register Access Set registers associated with A/D converter after setting the CKS3 bit in the ADCON2 register. However the other bits in the ADCON2 register and the CKS3 bit can be set at the same time. After changing the CKS3 bit, set the others in the same way. Write registers ADCON0 (excluding the ADST bit), ADCON1, and ADCON2 when A/D conversion stops (before a trigger is generated). After A/D conversion stops, set the ADSTBY bit in the ADCON1 register from 1 to 0. #### 32.21.5 A/D Conversion Start When rewriting the ADSTBY bit in the ADCON1 register from 0 (A/D operation stopped) to 1 (A/D operation enabled), wait for one $\phi$ AD cycle or more before starting A/D conversion. ### 32.21.6 A/D Operation Mode Change When the A/D operation mode has been changed, reselect analog input pins by using bits CH2 to CH0 in the ADCON0 register or bits SCAN1 to SCAN0 in the ADCON1 register. ### 32.21.7 State When Forcibly Terminated If A/D conversion in progress is halted by setting the ADST bit in the ADCON0 register to 0 (A/D conversion stopped), the conversion result is undefined. In addition, the unconverted ADi register (i = 0 to 7) may also become undefined. Do not use any value in ADi registers when setting the ADST bit to 0 by a program during A/D conversion. ### 32.21.8 A/D Open-Circuit Detection Assist Function The conversion result in open-circuit depends on the external circuit. Use this function only after careful evaluation of the system. Do not use this function when VCC1 > VCC2. When A/D conversion starts after changing the AINRST register, follow these steps: - (1) Change bits AINRST1 to AINRST0 in the AINRST register. - (2) Wait for one cycle of $\phi AD$ . - (3) Set the ADST bit in the ADCON0 register to 1 (A/D conversion started). ### 32.21.9 Detecting Completion of A/D Conversion In one-shot mode and single sweep mode, use the IR bit in the ADIC register to detect completion of A/D conversion. When not using an interrupt, set the IR bit to 0 by a program after detection. When 1 is written to the ADST bit in the ADCON0 register, the ADST bit becomes 1 (A/D conversion When 1 is written to the ADST bit in the ADCON0 register, the ADST bit becomes 1 (A/D conversion start) after start processing time elapses (see Table 27.7 "Cycles of A/D Conversion Item"). Therefore when reading the ADST bit immediately after writing 1, 0 (A/D conversion stop) may be read. Figure 32.14 ADST Bit Operation # 32.21.10 **\$AD** Divide fAD so $\phi$ AD conforms to the standard frequency. In particular, consider the maximum and minimum values of fOCO40M when the CKS3 bit in the ADCON2 register is 1 (fOCO40M is fAD). # 32.22 Notes on D/A Converter # 32.22.1 When Not Using the D/A Converter When not using the D/A converter, set the DAiE bit (i = 0, 1) in the DACON register to 0 (output disabled) and the DAi register to 00h in order to minimize unnecessary current consumption and prevent current flow to the R-2R resistor. # 32.23 Notes on Flash Memory Note There are no P11 to P14 in the 100-pin package. For the 100-pin package, do not use these pins for the entry of user boot function. # 32.23.1 OFS1 Address and ID Code Storage Address The OFS1 address and ID code storage address are part of flash memory. When writing a program to flash memory, write an appropriate value to those addresses simultaneously. In the OFS1 address, the MCU state after reset and the function to prevent rewrite in parallel I/O mode are selected. The OFS1 address is 0FFFFFh. This is the most significant address of block 0 in program ROM 1 and upper address of reset vector. Also, the ID code storage address is in block 0 and upper address of the interrupt vector. The ID code check function cannot be disabled. Even if the protect using the ID code check function is unnecessary, input the appropriate ID code when using a serial programmer or debugger. Without the appropriate ID code, the serial programmer or debugger cannot be used. ex) Set FEh to the OFS1 address When using an address control instruction and logical addition: .org 0FFFFCh RESET: .lword start | 0FE000000h When using an address control instruction: .org 0FFFFCh RESET: .addr start .byte 0FEh (Program format varies depending on the compiler. Refer to the compiler manual.) ### 32.23.2 Reading Data Flash When $2.7 \text{ V} \le \text{VCC1} \le 3.0 \text{ V}$ and $f(\text{BCLK}) \ge 16 \text{ MHz}$ , or $3.0 \text{ V} < \text{VCC1} \le 5.5 \text{ V}$ and $f(\text{BCLK}) \ge 20 \text{ MHz}$ , one wait must be inserted to execute the program on the data flash and read the data. Set the PM17 in the PM1 register or FMR17 bit in the FMR1 register to insert one wait. M16C/65C Group 32. Usage Notes #### 32.23.3 CPU Rewrite Mode ## 32.23.3.1 Operating Speed Select a CPU clock frequency of 10 MHz or less by setting the CM06 bit in the CM0 register and bits CM17 and CM16 in the CM1 register before entering CPU rewrite mode (EW0 or EW1 mode). Also, set the PM17 bit in the PM1 register to 1 (wait state). #### 32.23.3.2 CPU Rewrite Mode Select Change FMR01 bit in the FMR0 register, FMR11 bit in the FMR1 register, and FMR60 bit in the FMR6 register while in the following state: - The PM24 bit in the PM2 register is 0 (NMI interrupt disabled). - High is input to the NMI pin. Change the FMR60 bit while the FMR00 bit in the FMR0 register is 1 (ready). #### 32.23.3.3 Prohibited Instructions Do not use the following instructions in EW0 mode: UND instruction, INTO instruction, JMPS instruction, JSRS instruction, and BRK instruction. ## 32.23.3.4 Interrupts (EW0 Mode and EW1 Mode) - Do not use an address match interrupt during command execution because the address match interrupt vector is located in ROM. - Do not use a non-maskable interrupt during block 0 erase because fixed vector is located in block 0. ## 32.23.3.5 Rewrite (EW0 Mode) If the power supply voltage drops while rewriting the block where the rewrite control program is stored, the rewrite control program is not correctly rewritten. This may prevent the flash memory from being rewritten. If this error occurs, use standard serial I/O mode or parallel I/O mode for rewriting. ### 32.23.3.6 Rewrite (EW1 Mode) Do not rewrite any blocks in which the rewrite control program is stored. #### 32.23.3.7 DMA transfer In EW0 mode, do not use flash memory as a source of the DMA transfer. In EW1 mode, do not generate a DMA transfer while the FMR00 bit in the FMR0 register is 0 (auto programming or auto erasing). #### 32.23.3.8 Wait Mode To enter wait mode, set the FMR01 bit in the FMR0 register to 0 (CPU rewrite mode disabled) before executing the WAIT instruction. #### 32.23.3.9 Stop Mode To enter stop mode, set the FMR01 bit to 0 (CPU rewrite mode disabled), and then disable DMA transfer before setting the CM10 bit in the CM 1 register to 1 (stop mode). M16C/65C Group 32. Usage Notes #### 32.23.3.10 Software Command Observe the notes below when using the following commands. - Program - Block erase - Lock bit program - Read lock bit status - Block blank check - (a) The FMR00 bit in the FMR0 register indicates the status while executing these commands. Do not execute other commands while the FMR00 bit is 0 (busy). - (b) Use these commands in 40 MHz on-chip oscillator mode, high-speed mode, medium-speed mode, and PLL operating mode. Do not change clock modes while the FMR00 bit in the FMR0 register is 0 (busy). - (c) After executing the program, block erase, or lock bit program command, perform a full status check per command (Do not execute multiple commands or same command more than once before performing a full status check). - (d) Do not execute the program, block erase, lock bit program, or block blank check command when either or both bits FMR06 and FMR07 in the FMR0 register are 1 (error). - (e) Do not use these commands in slow read mode (when the FMR22 bit is 1) or low current consumption read mode (when both bits FMR22 and FMR23 are 1). #### 32.23.3.11 PM13 Bit The PM13 bit in the PM1 register becomes 1 while the FMR01 bit in the FMR0 register is 1 (CPU rewrite mode enabled). The PM13 bit returns to the former value by setting the FMR01 bit to 0 (CPU rewrite mode disabled). When the PM13 bit is changed during CPU rewrite mode, the value of the PM13 bit after being changed is not reflected until the FMR01 bit is set to 0. ### 32.23.3.12 Area Where the Rewrite Control Program is Executed Bits PM10 and PM13 in the PM1 register become 1 in CPU rewrite mode. Execute the rewrite program in internal RAM or an external area which can be used when both bits PM10 and PM13 are 1. Do not use the area (40000h to BFFFFh) where accessible space is expanded when the PM13 bit is 0 and 4-MB mode is set. #### 32.23.3.13 Program and Erase Cycles and Execution Time Execution time of the program, block erase, and lock bit program commands becomes longer as the number of programming and erasing increases. ### 32.23.3.14 Suspending the Auto-Erase and Auto-Program Operations When the program, block erase, and lock bit program commands are suspended, the blocks for those commands must be erased. Execute the program and lock bit program commands again after erasing. Those commands are suspended by the following reset or interrupts: - Hardware, power-on, voltage monitor 0, voltage monitor 1, voltage monitor 2, oscillator stop detect, watchdog timer, software resets. - NMI, watchdog timer, oscillator stop/restart detect, voltage monitor 1, and voltage monitor 2 interrupts. M16C/65C Group 32. Usage Notes #### 32.23.4 User Boot ### 32.23.4.1 User Boot Mode Program Note the following when using user boot mode: - When using user boot mode, make sure to allocate the program to be executed to program ROM 2. - Bits VDSEL1 and LVDAS in the OFS1 address are disabled in boot mode. - When restarting the MCU in user boot mode after starting it in user boot mode, RAM becomes undefined. - If addresses 13FF8h to 13FFBh are all 00h, the MCU does not enter standard serial I/O mode. Therefore, the programmer or on-chip debugger cannot be connected. - As the reset sequence differs, the time necessary for starting the program is longer than in singlechip mode. - Functions in user boot mode cannot be debugged by the on-chip debugging emulator or full spec emulator. - While using user boot mode, do not change the input level of the pin used for user boot entry. However, if there is a possibility that the input level may change, perform the necessary processes in user boot mode, then restart the MCU in single-chip mode before the input level changes. - To use user boot mode after standard serial I/O mode, turn off the power when exiting standard serial I/O mode, and then turn on the power again (cold start). The MCU enters user boot mode under the right conditions. # **Appendix 1. Package Dimensions** The information on the latest package dimensions or packaging may be obtained from "Packages" on the Renesas Electronics website. # Appendix 2. Differences between M16C/65 and M16C/65C ## Appendix Table 2.1 Differences between M16C/65 and M16C/65C (Specifications) | Item | M16C/65 | M16C/65C | |---------------------------------|-------------------------|-----------------------------------------------| | Enable/disable peripheral clock | N/A | Available (bits PCKSTP1A and PCKSTP11 | | provision | | in the PCLKSTP1 register) | | Timer A/timer B clock source | f1 only | f1 or main clock (the PCKSTP17 bit in the | | selection | IT Offig | PCLKSTP1 register) | | Flash memory, suspend function | N/A | Available | | | Whole area is usable | Conditional: | | Usable area of program ROM 1 | when the PM13 bit is 1, | PM13 bit = 0: max. D0000h to FFFFFh | | | and the IRON bit is 1. | PM13 bit = 1: max. 80000h to FFFFh | | Electrical characteristics | | Characteristics of voltage detector, power-on | | Liectifical Characteristics | | reset circuit, and oscillator improved. | Refer to the User's Manual: Hardware for details. ## Appendix Table 2.2 Differences between M16C/65 and M16C/65C (Bus Timing) | Item | | M16C/65 | M16C/65C | |------------------------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------| | Timing requirement VCC1 = VCC2 = 5 V | tsu(DB-RD) | Min. 40[ns] | Min. 50[ns] | | Timing requirement VCC1 = VCC2 = 3 V | tsu(DB-RD) | Min. 50[ns] | Min. 60[ns] | | Switching characteristics<br>VCC1 = VCC2 = 5 V | th(WR-DB)<br>Minimum value | No recovery cycle $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 10[ns]$ Recovery cycle inserted $\frac{m \times 10^9}{f_{(BCLK)}} - 10[ns]$ | No recovery cycle $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 20[ns]$ Recovery cycle inserted $\frac{m \times 10^9}{f_{(BCLK)}} - 20[ns]$ | | Switching characteristics | th(WR-AD)<br>Minimum value | No recovery cycle $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 10[ns]$ Recovery cycle inserted $\frac{m \times 10^9}{f_{(BCLK)}} - 10[ns]$ | No recovery cycle $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 15[ns]$ Recovery cycle inserted $\frac{m \times 10^9}{f_{(BCLK)}} - 15[ns]$ | | VCC1 = VCC2 = 3 V | th(WR-DB)<br>Minimum value | No recovery cycle $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 10[ns]$ Recovery cycle inserted $\frac{m \times 10^9}{f_{(BCLK)}} - 10[ns]$ | No recovery cycle $\frac{0.5 \times 10^9}{f_{(BCLK)}} - 25[ns]$ Recovery cycle inserted $\frac{m \times 10^9}{f_{(BCLK)}} - 25[ns]$ | | Switching characteristic | th(BCLK-DB) | Min. 0[ns] | (Standard not available) | m: Inserted recovery cycle numbers Refer to the User's Manual: Hardware for details. | REGISTER INDEX | DM0IC to DM3IC2 | 14 | |---------------------------------------|-------------------|----| | | DM0SL2 | 59 | | A | DM1CON2 | 58 | | ^ | DM1SL2 | 59 | | 100 100 | DM2CON2 | 58 | | AD0 to AD7642 | DM2SL2 | 59 | | ADCON0644 | DM3CON2 | | | ADCON1646 | DM3SL2 | | | ADCON2 643 | DTT3 | | | ADIC214 | | 00 | | AIER 219 | F | | | AIER2 219 | E | | | AINRST 641 | | | | | EWC1 | 54 | | В | EWR1 | 55 | | В | | | | BCNIC214 | F | | | | | | | С | FMR0123, 6 | | | • | FMR16 | 84 | | 00004 | FMR2124, 6 | 85 | | CCRB1 | FMR36 | 86 | | CCRB2 | FMR66 | 87 | | CCTB1615 | FRA01 | 07 | | CCTB2615 | | | | CEC1IC214 | 1 | | | CEC2IC214 | • | | | CECC1 606 | LOTTO | | | CECC2 607 | ICTB23 | | | CECC3 609 | IDB0, IDB1 | | | CECC4 611 | IFSR2 | | | CECFLG 613 | IFSR2A2 | 17 | | CISEL614 | IFSR3A2 | 16 | | CM0 | IICIC2 | 14 | | CM1 | INTOIC to INT2IC2 | 15 | | CM2101 | INT3IC2 | 15 | | CPSRF | INT4IC2 | 15 | | · · · · · · · · · · · · · · · · · · · | INT5IC2 | | | CRADRI1 | INT6IC | | | CRADRI2617 | INT7IC2 | | | CRCD 674 | INVC0 | | | CRCIN 674 | INVC1 | | | CRCMR 674 | IIVVC1 | 37 | | CRCSAR 673 | •- | | | CSE 153 | K | | | CSPR245 | | | | CSR 152 | KUPIC2 | 14 | | D | N | | | DA0, DA1669 | NMIDF204, 2 | 22 | | DACON | , | | | DAR0 to DAR3256 | 0 | | | DBR173 | • | | | DM0CON258 | OFS158, 248, 6 | 20 | | 2200 | OF3130, 240, 0 | Og | | ONSF284 | RTCCMIN | | |------------------------------------|------------------|-----| | | RTCCR1 | | | P | RTCCR2 | | | | RTCCSEC | 401 | | P0 to P14202 | RTCCSR | 400 | | PCLKR 103, 275, 325, 478, 544, 559 | RTCHR | 394 | | PCLKSTP1 103, 276, 326 | RTCMIN | 393 | | PCR | RTCSEC | 392 | | PD0 to PD14 | RTCTIC | 214 | | PDRF | RTCWK | 395 | | PFCR | | | | PLC0 | S | | | PM0 | 9 | | | | S00 | E60 | | PM1 | S0D0 to S0D2 | | | PM2 106, 213 | | | | PMC0CON0, PMC1CON0 | SORIC to S2RIC | | | PMC0CON1, PMC1CON1 | S0TIC to S2TIC | | | PMC0CON2, PMC1CON2 | S10 | | | PMC0CON3, PMC1CON3 | S11 | | | PMC0CPC | S1D0 | | | PMC0CPD445 | S20 | | | PMC0D0PMAX, PMC1D0PMAX 441 | S2D0 | | | PMC0D0PMIN, PMC1D0PMIN441 | S34C2 | | | PMC0D1PMAX, PMC1D1PMAX441 | S3BRG, S4BRG | | | PMC0D1PMIN, PMC1D1PMIN441 | S3C, S4C | | | PMC0DAT0 to PMC0DAT5443 | S3D0 | | | PMC0HDPMAX, PMC1HDPMAX 439 | S3IC | | | PMC0HDPMIN, PMC1HDPMIN439 | S3TRR, S4TRR | 544 | | PMC0IC214 | S4D0 | 571 | | PMC0INT, PMC1INT438 | S4IC | 215 | | PMC0RBIT442 | S4RIC | 214 | | PMC0STS, PMC1STS435 | S5RIC to S7RIC | 214 | | PMC0TIM, PMC1TIM 442 | S5TIC | 214 | | PMC1IC214 | S6TIC | 214 | | PPWFS1, PPWFS2329 | S7TIC | 214 | | PRCR50 | SAR0 to SAR3 | | | PRG2C148 | SCLDAIC | 214 | | PUR0197 | | | | PUR1198 | т | | | PUR2199 | • | | | PUR3200 | TA0 to TA4 | 202 | | PWMCON0 418 | | | | PWMCON1 | TAOIC to TA4IC | | | PWMFS | TAOMR to TAOMR | | | PWMPRE0, PWMPRE1 419 | TA1, TA2, TA4 | | | PWMREG0, PWMREG1 419 | TA11, TA21, TA41 | | | 1 VVIVII. LEGO, 1 VVIVII. LEGI | TABSR | · | | В | TACS0 to TACS2 | | | R | TAOW | | | BMARA, BMARA | TAPOFS | | | RMAD0 to RMAD3220 | TB0 to TB5 | | | RSTFR57 | TB01 | | | RTCCHR 403 | TB0IC to TB2IC | | | RTCCIC214 | TB0MR | 333 | | TB11 | 328 | | 80, 244 | |--------------------------------|---------|------|---------| | TB1MR | 333 | VWCE | 75 | | TB2 | | | | | TB21 | | | W | | TB2MR | | | | | TB2SC | | WDC | 247 | | TB31 | | WDTR | 246 | | TB3IC | | WDTS | 246 | | TB3MR | | | | | TB41 | | | | | TB4IC | 214 | | | | TB4MR | | | | | TB51 | 328 | | | | TB5IC | | | | | TB5MR | 333 | | | | TBCS0 to TBCS3 | 330 | | | | TBSR | 332 | | | | TCKDIVC027 | 7, 331 | | | | TCR0 to TCR3 | 257 | | | | TPRC | 363 | | | | TRGSR | 285 | | | | | | | | | U | | | | | | | | | | U0BCNIC | 214 | | | | U0BRG to U2BRG, U5BRG to U7BRG | 480 | | | | U0C0 to U2C0, U5C0 to U7C0 | 481 | | | | U0C1 to U2C1, U5C1 to U7C1 | 483 | | | | U0MR to U2MR, U5MR to U7MR | 479 | | | | U0RB to U2RB, U5RB to U7RB | 484 | | | | U0SMR to U2SMR, U5SMR to U7SMR | R . 491 | | | | U0SMR2 to U2SMR2, | | | | | U5SMR2 to U7SMR2 | 490 | | | | U0SMR3 to U2SMR3, | | | | | U5SMR3 to U7SMR3 | 489 | | | | U0SMR4 to U2SMR4, | | | | | U5SMR4 to U7SMR4 | 487 | | | | U0TB to U2TB, U5TB to U7TB | | | | | U1BCNIC | | | | | U5BCNIC | | | | | U6BCNIC | | | | | U7BCNIC | | | | | UCLKSEL0 | | | | | UCON | | | | | UDF | | | | | | | | | | V | | | | | VCR1 | 73 | | | | VCR2 | | | | | VD1LS | | | | | VW0C | | | | | | | | | ## 1. Items revised or added in this version | REVISION HISTORY | M16C/65C Group User's Manual: Hardware | |------------------|----------------------------------------| | Rev. | Date | | Description | |------|--------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Nev. | Date | Page | Summary | | 1.10 | Jul 31, 2012 | Overview | | | | | 6 | Table 1.5 Product List (N-Version), Table 1.6 Product List (D-Version): Changed development statuses. | | | | Resets | | | | | 56 | 6.2.1 Processor Mode Register 0 (PM0): | | | | 30 | Added the description regarding PM02, PM04 to PM07 to the register explanation. | | | | 64 | 6.4.3 Power-On Reset Function: Changed "the rise gradient is trth or more" to "the rise gradient is trth" in the second line of the first paragraph. | | | | 64 | Figure 6.5 Power-On Reset Circuit and Operation Example: Changed tw(por1) to tw(por). | | | | Clock Gen | erator | | | | 94 | Figure 8.1 System Clock Generator: Changed a part of the configuration in the PLL frequency synthesizer. | | | | 96 | 8.2.1 Processor Mode Register 0 (PM0): Added the description regarding PM02, PM04 to PM07 to the register explanation. | | | | 111 | 8.3.6 Sub Clock (fC): Deleted P8_5 in the parenthesis in step (1). | | | | Processor | Mode | | | | 145 | 10.2.1 Processor Mode Register 0 (PM0): Added the description regarding PM02, PM04 to PM07 to the register explanation. | | | | 146 | 10.2.2 Processor Mode Register 1 (PM1): Added the description regarding PM11, PM14 and PM15 to the register explanation. | | | | Bus | | | | | 163 | Table 11.8 Pin Functions for Each Processor Mode: • Added note 7. | | | | Brogramm | Changed the Memory Expansion Mode column for P3_0. able I/O Ports | | | | _ | Figure 13.8 I/O Ports (N-channel Open Drain Output), Figure 13.9 I/O Ports (NMI): | | | | 191, 192 | Partially modified. | | | | Inree-Pna | se Motor Control Timer Function | | | | 350, 370,<br>375 | Table 19.2 Three-Phase Motor Control Timer Function Specifications (2/2), Table 19.9 Three-Phase Mode 0 Specifications, and Table 19.12 Three-Phase Mode 1 Specifications: Modified the Specification column of the Three-phase PWM output width. | | | | Remote Co | ontrol Signal Receiver | | | | 440 | Figure 22.4 Setting Values of the Header Pattern and Data Patterns: Added the explanation. | | | | 455 | Table 22.13 Registers and Setting Values in Pattern Match Mode (Combined Operation) (1/2): Changed the PMC1 column of the PMCiCON1 register for bits TYP0 and TYP1. | | | | 470 | 22.5.4 Combined Operation: Added. | | | | Serial Inte | rface UARTi (i = 0 to 2, 5 to 7) | | | | 479 | 23.2.3 UARTi Transmit/Receive Mode Register (UiMR) (i = 0 to 2, 5 to 7): Added the description regarding I <sup>2</sup> C mode. | | | | 480, 484 | 23.2.5 UARTi Transmit Buffer Register (UiTB) (i = 0 to 2, 5 to 7), 23.2.8 UARTi Receive Buffer Register (UiRB) (i = 0 to 2, 5 to 7): Modified the Reset Value. | | | | 510 | Table 23.15 I/O Pin Functions in I <sup>2</sup> C Mode: Added note 1. | | | | Multi-mast | er I <sup>2</sup> C-bus Interface | | | | 602 | 25.5.3 Low/High-level Input Voltage and Low-level Output Voltage: Added. | | | | CRC Calcu | llator | | | | 674 | 29.2.3 CRC Data Register (CRCD): Added the explanation. | | | | 676 | Figure 29.2 CRC Calculation When Using CRC-CCITT and Figure 29.3 CRC Calculation When Using CRC-16: Changed. | | | | Flash Mem | | | | | 681 | 30.3.1 Flash Memory Control Register 0 (FMR0): Changed the description of steps in the FMSTP bit explanation. | | | | Electrical ( | Characteristics | | | | Vcc = 5 V | | | | | 745, 746 | Table 31.20 Electrical Characteristics (3) and Table 31.21 Electrical Characteristics (4): Changed the Measuring Condition column of 40 MHz on-chip oscillator for the 40 MHz on-chip oscillator mode in the I <sub>CC</sub> . | | | i | • | | | REVISION HISTORY | M16C/65C Group User's Manual: Hardware | |------------------|----------------------------------------| | | | | Rev. | Date | | Description | | |--------|--------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | I KOV. | Date | Page | Summary | | | 1.10 | Jul 31, 2012 | Vcc = 3 V | | | | | | 767, 768 | Table 31.42 Electrical Characteristics (2) and Table 31.43 Electrical Characteristics (3) (1/2): Changed the Measuring Condition column of 40 MHz on-chip oscillator for the 40 MHz on-chip oscillator mode in the I <sub>CC</sub> . | | | | | Usage Not | es | | | | | 819 | 32.16.4 Combined Operation: Added. | | | | | 825 | 32.19.3 Low/High-level Input Voltage and Low-level Output Voltage: Added | | Refer to 2. "Items revised or added in previous versions" for the items revised or added in previous versions. # 2. Items revised or added in previous versions | NEVIOLON FILOTON WITOO/000 Gloup God 3 Mandai. Haldware | REVISION HISTORY | M16C/65C Group User's Manual: Hardware | |-----------------------------------------------------------|------------------|----------------------------------------| |-----------------------------------------------------------|------------------|----------------------------------------| | Rev. | Date | | Description | |-------|--------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | itov. | | Page | Summary | | 0.10 | Oct 29, 2010 | - | First Edition issued. | | 1.00 | Feb 07, 2011 | Overall | Changed terminologies are as follows: • "oscillation/oscillator circuit" to "oscillator" • "oscillator" to "a crystal/ceramic resonator" • "oscillator manufacturer" to "manufacturer of crystal/ceramic resonator" • "on-chip oscillator oscillation circuit" to "on-chip oscillator" | | | | Overview | | | | | 3, 5 | Table 1.2 Specifications for the 128-Pin Package (2/2), Table 1.4 Specifications for the 100-Pin Package (2/2): Changed the Description column of the Current Consumption row. | | | | 6 | Table 1.5 Product List (N-Version), Table 1.6 Product List (D-Version): Changed the development status. | | | | Clock Gen | | | | | 108 | 8.3.2 PLL Clock: Modified the explanation of how to generate PLL clock from the main clock. | | | | Power Cor | 9.6.3 Stop Mode: Changed "before the WAIT instruction is executed" to "before entering stop mode" in the last sentence of the third bullet. | | | | Interrupt | | | | | 235 | 14.10 Key Input Interrupt: Modified the explanation of the condition for the IR bit in the KUPIC register to become 1. | | | | Timer B | | | | | 326, 327 | 18.2.4 Timer Bi Register (TBi) (i = 0 to 5), 18.2.5 Timer Bi-1 Register (TBi1) (i = 0 to 5): Modified the Reset Value. | | | | Serial Inte | rface UARTi | | | | 502 | Figure 23.13 Receive Timing in UART Mode: Modified "UiBRG count source" to "Clock divided by UiBRG". | | | | Multi-Mast | er I <sup>2</sup> C-bus Interface | | | | 590 | Figure 25.15 Operation When Transmitted/Received a Slave Address or Data: Changed the description of bits TRX, ADR0, and AAS in parenthesis for when a slave address is received. | | | | Flash Men<br>695 | Table 30.12 Modes after Executing Commands (in EW0 Mode): Changed the Mode after Executing Command of the Clear status register. | | | | Electrical | Characteristics | | | | VCC = 5 | V | | | | 744, 745 | Table 31.20 Electrical Characteristics (3), Table 31.21 Electrical Characteristics (4): Added conditions when XIN is 6MHz to the Wait mode measuring condition. | | | | 754, 757,<br>759, 761,<br>763 | In Switching Characteristics (Memory Expansion Mode and Microprocessor Mode), Table 31.36, Table 31.37, Table 31.38, Table 31.39, Table 31.40: • Deleted the th(BCLK-DB) row. • Changed the formula of th(WR-DB) for minimum standard. | | | | 756, 758,<br>760, 762,<br>764 | Figure 31.15, Figure 31.16, Figure 31.17, Figure 31.18, Figure 31.19: Deleted the description of th(BCLK-DB), and changed the formula of th(WR-DB) in the Write timing. | | | | VCC = 3 | V | | | | 766, 767 | Table 31.42 Electrical Characteristics (2), Table 31.43 Electrical Characteristics (3) (1/2): Added conditions when XIN is 6MHz to the Wait mode measuring condition. | | | | 775, 777,<br>780, 782,<br>784 | In Switching Characteristics (Memory Expansion Mode and Microprocessor Mode), Table 31.58, Table 31.59, Table 31.60, Table 31.61, Table 31.62: • Deleted the th(BCLK-DB) row. • Changed the formula of th(WR-AD) for minimum standard. • Changed the formula of th(WR-DB) for minimum standard. | | | | 779, 781,<br>783, 785,<br>787 | Figure 31.30, Figure 31.31, Figure 31.32, Figure 31.33, Figure 31.34: • Deleted the description of th(BCLK-DB), and changed the formulas of th(WR-AD) and th(WR-DB) in the Write timing. | | REVISION HISTORY | M16C/65C Group User's Manual: Hardware | |------------------|----------------------------------------| | | · | | Rev. | Date | Description | | | |------|------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|--| | | | Page | Summary | | | 1.00 | Feb 07, 2011 | Usage Notes | | | | | | | 32.6.3 Stop Mode: Changed "before the WAIT instruction is executed" to "before entering stop mode" in the last sentence of the third bullet. | | | | Appendix 2. Differences between M16C/65 and M16C/65C | | 2. Differences between M16C/65 and M16C/65C | | | | | 834 | Appendix 2. Differences between M16C/65 and M16C/65C: Added | | M16C/65C Group User's Manual: Hardware Publication Date: Rev.0.10 Oct 29, 2010 Rev.1.10 Jul 31, 2012 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. 2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130 Renesas Electronics Canada Limited 1101 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada Tel: +1-905-898-5441, Fax: +1-905-898-3220 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-65030, Fax: +49-211-6503-1327 Renesas Electronics (China) Co., Ltd. 7th Floor, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100083, P.R.China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679 Renesas Electronics (Shanghai) Co., Ltd. Unit 204, 205, AZIA Center, No.1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China Tel: +86-21-5877-1818, Fax: +86-21-6887-7858 / -7898 Renesas Electronics Hong Kong Limited Unit 1601-1613, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: +852-2886-9318, Fax: +852 2886-9022/9044 Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei, Taiwan Tel: +886-2-8175-9600, Fax: +886 2-8175-9670 Renesas Electronics Singapore Pte. Ltd. 1 harbourFront Avenue, #06-10, keppel Bay Tower, Singapore 098632 Tel: +65-6213-0200, Fax: +65-6278-8001 Renesas Electronics Malaysia Sdn.Bhd. Unit 906, 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 Korea Co., Ltd. 11F., Samik Lavied' or Bldg., 720-2 Yeoksam-Dong, Kangnam-Ku, Seoul 135-080, Korea Tel: +82-2-558-3737, Fax: +82-2-558-5141 © 2012 Renesas Electronics Corporation. All rights reserved. Colophon 1.1 M16C/65C Group