# R32C/161 Group User's Manual: Hardware RENESAS MCU M16C Family / R32C/100 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 von - 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 registers. 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 29 chapters covering 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 R32C/161 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 | R32C/161 Group<br>Datasheet | R01DS0078EJ0120 | | 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. | R32C/161 Group<br>User's Manual:<br>Hardware | This publication | | User's Manual:<br>Software/Software<br>Manual | Descriptions of instruction set | R32C/100 Series<br>Software Manual | REJ09B0267-0100 | | Application Note | -Usages -Applications -Sample programs -Programing 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. \*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** | 1. Ov | erview | 1 | |-------|-----------------------------------------------------------------------|----| | 1.1 | Features | 1 | | 1.1.1 | Applications | 1 | | 1.1.2 | Performance Overview | 2 | | 1.2 | Product Information | 4 | | 1.3 | Block Diagram | 6 | | 1.4 | Pin Assignment | 7 | | 1.5 | Pin Definitions and Functions | 10 | | 2. Ce | ntral Processing Unit (CPU) | 12 | | 2.1 | General Purpose Registers | 13 | | 2.1.1 | Data Registers (R2R0, R3R1, R6R4, and R7R5) | 13 | | 2.1.2 | Address Registers (A0, A1, A2, and A3) | 13 | | 2.1.3 | Static Base Register (SB) | 13 | | 2.1.4 | Frame Base Register (FB) | 13 | | 2.1.5 | Program Counter (PC) | 13 | | 2.1.6 | Interrupt Vector Table Base Register (INTB) | 13 | | 2.1.7 | User Stack Pointer (USP) and Interrupt Stack Pointer (ISP) | 13 | | 2.1.8 | Flag Register (FLG) | 13 | | 2.2 | Fast Interrupt Registers | 15 | | 2.2.1 | Save Flag Register (SVF) | 15 | | 2.2.2 | Save PC Register (SVP) | 15 | | 2.2.3 | Vector Register (VCT) | 15 | | 2.3 | DMAC-associated Registers | 15 | | 2.3.1 | DMA Mode Registers (DMD0, DMD1, DMD2, and DMD3) | 15 | | 2.3.2 | DMA Terminal Count Registers (DCT0, DCT1, DCT2, and DCT3) | | | 2.3.3 | DMA Terminal Count Reload Registers (DCR0, DCR1, DCR2, and DCR3) | 15 | | 2.3.4 | DMA Source Address Registers (DSA0, DSA1, DSA2, and DSA3) | | | 2.3.5 | DMA Source Address Reload Registers (DSR0, DSR1, DSR2, and DSR3) | | | 2.3.6 | DMA Destination Address Registers (DDA0, DDA1, DDA2, and DDA3) | | | 2.3.7 | DMA Destination Address Reload Registers (DDR0, DDR1, DDR2, and DDR3) | 15 | | 3. Me | mory | 16 | | 4. Sp | ecial Function Registers (SFRs) | 17 | | 5. Re | sets | 70 | | 5.1 | Hardware Reset | 70 | | 5.2 | Software Reset | 72 | | 5.3 | Watchdog Timer Reset | 72 | | 5.4 | Reset Vector | 73 | | 6. Po | wer Management | 74 | |---------|-------------------------------------------------|-----| | 6.1 | Voltage Regulators for Internal Logic | 74 | | 6.1.1 | Decoupling Capacitor | 75 | | 6.2 | Low Voltage Detector | 76 | | 6.2.1 | Operational State of Low Voltage Detector | 79 | | 6.2.2 | Low Voltage Detection Interrupt | 79 | | 6.2.3 | Application Example of the Low Voltage Detector | 80 | | 7. Clo | ock Generator | 81 | | 7.1 | Clock Generator Types | 81 | | 7.1.1 | Main Clock | 90 | | 7.1.2 | Sub Clock (fC) | 91 | | 7.1.3 | PLL Clock | 92 | | 7.1.4 | On-chip Oscillator Clock | 95 | | 7.2 | Oscillator Stop Detection | 96 | | 7.2.1 | How to Use Oscillator Stop Detection | 96 | | 7.3 | Base Clock | 96 | | 7.4 | CPU Clock and Peripheral Bus Clock | 97 | | 7.5 | Peripheral Clock | 97 | | 7.6 | Clock Output Function | 98 | | 7.7 | Power Control | 99 | | 7.7.1 | Normal Operating Mode | 100 | | 7.7.2 | Wait Mode | 105 | | 7.7.3 | Stop Mode | 108 | | 7.8 | System Clock Protection | 110 | | 7.9 | Notes on Clock Generator | 111 | | 7.9.1 | Sub Clock | 111 | | 7.9.2 | Power Control | 111 | | 8. Bu | S | 112 | | 8.1 | Bus Setting | 112 | | 8.2 | Peripheral Bus Timing Setting | 113 | | 9. Pro | otection | 114 | | 9.1 | Protect Register (PRCR Register) | 114 | | 9.2 | Protect Register 2 (PRCR2 Register) | | | 9.3 | Protect Register 3 (PRCR3 Register) | | | 9.4 | Protect Register 4 (PRCR4 Register) | | | 9.5 | Protect Release Register (PRR Register) | | | 10. Int | errupts | 118 | | 10.1 | Interrupt Types | | | | Software Interrupts | 110 | | 10.3 | Hardware Interrupts | 120 | |-------|--------------------------------------------------|-----| | 10.3. | .1 Special Interrupts | 120 | | 10.3. | .2 Peripheral Interrupts | 120 | | 10.4 | Fast Interrupt | 121 | | 10.5 | Interrupt Vectors | 121 | | 10.5. | .1 Fixed Vector Table | 122 | | 10.5. | .2 Relocatable Vector Table | 122 | | 10.6 | Interrupt Request Acceptance | 127 | | 10.6. | .1 I Flag and IPL | 127 | | 10.6. | .2 Interrupt Control Registers | 128 | | 10.6. | .3 Wake-up IPL Setting Register | 131 | | 10.6. | .4 Interrupt Sequence | 132 | | 10.6. | .5 Interrupt Response Time | 133 | | 10.6. | .6 IPL after Accepting an Interrupt Request | 134 | | 10.6. | .7 Register Saving | 134 | | 10.7 | Register Restoring from Interrupt Handler | 135 | | 10.8 | Interrupt Priority | 135 | | 10.9 | Priority Resolver | 135 | | 10.10 | External Interrupt | 137 | | 10.11 | NMI | 138 | | 10.12 | Intelligent I/O Interrupt | 139 | | 10.13 | Notes on Interrupts | 142 | | 10.13 | 3.1 ISP Setting | 142 | | 10.13 | 3.2 NMI | 142 | | 10.13 | 3.3 External Interrupts | 142 | | 11. W | /atchdog Timer | 143 | | 12. D | MAC | 147 | | 12.1 | Transfer Cycle | 156 | | 12.1. | .1 Effect of Transfer Address and Data Bus Width | 156 | | 12.1. | .2 Effect of Bus Timing | 157 | | 12.2 | DMA Transfer Cycle | 159 | | 12.3 | Channel Priority and DMA Transfer Timing | 160 | | 12.4 | Notes on DMAC | 161 | | 12.4. | .1 DMAC-associated Register Settings | 161 | | 12.4. | .2 Reading DMAC-associated Registers | 161 | | 13. D | MAC II | 162 | | 13.1 | DMAC II Settings | 162 | | 13.1. | .1 Registers RIPL1 and RIPL2 | 163 | | 13 1 | 2 DMAC II Index | 164 | | 13.1.3 | Interrupt Control Register of the Peripherals | 167 | |---------|--------------------------------------------------------|-----| | 13.1.4 | Relocatable Vector Table of the Peripherals | 167 | | 13.1.5 | IRLT Bit in the IIOiIE Register (i = 0 to 11) | 167 | | 13.2 | DMAC II Operation | 167 | | 13.3 | Transfer Types | 167 | | 13.3.1 | Memory-to-memory Transfer | 167 | | 13.3.2 | Immediate Data Transfer | 168 | | 13.3.3 | Calculation Result Transfer | 168 | | 13.4 | Transfer Modes | 168 | | 13.4.1 | Single Transfer | 168 | | 13.4.2 | Burst Transfer | 168 | | 13.4.3 | Multiple Transfer | 168 | | 13.5 | Chain Transfer | 169 | | 13.6 | DMA II Transfer Complete Interrupt | 169 | | 13.7 | Execution Time | 170 | | 14. Pro | ogrammable I/O Ports | 171 | | 14.1 | Port Pi Register (Pi register, i = 0 to 9) | 173 | | 45 Tim | | | | 15. Tim | | 174 | | 15.1 | Timer A | | | 15.1.1 | Timer Mode | | | 15.1.2 | | | | 15.1.3 | | | | 15.1.4 | | | | 15.2 | Timer B | | | 15.2.1 | Timer Mode | | | 15.2.2 | Event Counter Mode | 199 | | 15.2.3 | Pulse Period/Pulse-width Measure Mode | 202 | | 15.3 | Notes on Timers | 205 | | 15.3.1 | Timer A and Timer B | 205 | | 15.3.2 | Timer A | 205 | | 15.3.3 | Timer B | 207 | | 16. Thi | ee-phase Motor Control Timers | 208 | | 16.1 | Modulation Modes of Three-phase Motor Control Timers | 214 | | 16.2 | Timer B2 | 215 | | 16.3 | Timers A4, A1, and A2 | 217 | | 16.4 | Simultaneous Conduction Prevention and Dead Time Timer | | | 16.5 | Three-phase Motor Control Timer Operation | 222 | | 16.6 | Notes on Three-phase Motor Control Timers | | | | Shutdown | 225 | | 16.6.2 | Register Setting | 225 | |------------|----------------------------------------------------|-----| | 17. Serial | I Interface | 226 | | 17.1 Sy | ynchronous Serial Interface Mode | 240 | | 17.1.1 | Reset Procedure on Transmit/Receive Error | 245 | | 17.1.2 | CLK Polarity | 245 | | 17.1.3 | LSB First and MSB First Selection | 246 | | 17.1.4 | Continuous Receive Mode | 246 | | 17.1.5 | Serial Data Logic Inversion | 247 | | 17.1.6 | CTS/RTS Function | 247 | | 17.2 As | synchronous Serial Interface Mode (UART Mode) | 248 | | 17.2.1 | Bit Rate | 253 | | 17.2.2 | Reset Procedure on Transmit/Receive Error | 254 | | 17.2.3 | LSB First and MSB First Selection | 254 | | 17.2.4 | Serial Data Logic Inversion | 255 | | 17.2.5 | TXD and RXD I/O Polarity Inversion | 256 | | 17.2.6 | CTS/RTS Function | 256 | | 17.3 Sp | pecial Mode 1 (I <sup>2</sup> C Mode) | 257 | | 17.3.1 | Start Condition and Stop Condition Detection | 263 | | 17.3.2 | Start Condition and Stop Condition Generation | 263 | | 17.3.3 | Arbitration | 264 | | 17.3.4 | SCL Control and Clock Synchronization | 265 | | 17.3.5 | SDA Output | 267 | | 17.3.6 | SDA Input | 267 | | 17.3.7 | Acknowledge | 267 | | 17.3.8 | Initialization of Transmit/Receive Operation Reset | 267 | | 17.4 Sp | pecial Mode 2 | 268 | | 17.4.1 | SSi Input Pin Function (i = 0 to 2) | 270 | | 17.4.2 | Clock Phase Setting | 271 | | 17.5 No | otes on Serial Interface | 273 | | 17.5.1 | Changing the UiBRG Register (i = 0 to 4) | 273 | | 17.5.2 | Pin Output | 273 | | 17.5.3 | Synchronous Serial Interface Mode | 273 | | 17.5.4 | Special Mode 1 (I <sup>2</sup> C Mode) | 273 | | 17.5.5 | Reset Procedure on Communication Error | 274 | | 18. A/D C | Converter | 275 | | 18.1 Mo | ode Descriptions | 283 | | 18.1.1 | One-shot Mode | | | 18.1.2 | Repeat Mode | 284 | | 18.1.3 | Single Sweep Mode | | | 18 1 4 | Reneat Sween Mode 0 | 286 | | 18.1.5 Repeat Sweep Mode 1 | 287 | |---------------------------------------------------------------------------------|-----| | 18.2 Functions | 288 | | 18.2.1 Resolution Selection | 288 | | 18.2.2 Sample and Hold Function | 288 | | 18.2.3 Trigger Selection | 288 | | 18.2.4 DMAC Operating Mode | 288 | | 18.2.5 Function-extended Analog Input Pins | 289 | | 18.2.6 External Operating Amplifier (Op-Amp) Connection Mode | 289 | | 18.2.7 Self Test/Open-circuit Detection Assist | 290 | | 18.2.8 Power Saving | 291 | | 18.2.9 Output Impedance of Sensor Equivalent Circuit under A/D Conversion | 291 | | 18.3 Notes on A/D Converter | 293 | | 18.3.1 Notes on Designing Boards | 293 | | 18.3.2 Notes on Programming | 294 | | 19. CRC Calculator | 295 | | 20. X-Y Conversion | 298 | | 20.1 Data Conversion When Reading | 299 | | 20.2 Data Conversion When Writing | 301 | | 21 Intelligent I/O | 302 | | 21. Intelligent I/O | | | 21.1 Base Timer | | | 21.2 Time Measurement | | | 21.3 Waveform Generation | | | 21.3.1 Single-phase Waveform Output Mode | | | 21.3.3 Set/Reset Waveform Output Mode (SR Waveform Output Mode) | | | 21.3.4 Phase Shift Waveform Output Mode | | | 21.3.5 Digital Debounce Circuit | | | 21.5.5 Digital Debounce Circuit | 334 | | 22. Serial Bus Interface | 336 | | 22.1 Synchronous Serial Communication Mode and 4-wire Serial Bus Mode | 337 | | 22.1.1 Transmit/Receive Clock | 349 | | 22.1.2 Transmit/Receive Shift Register | 351 | | 22.1.3 Data I/O Pin and SS0 Shift Register | 353 | | 22.1.4 Interrupt Requests | 354 | | 22.1.5 Communication Modes and Pin Functions | 355 | | 22.1.6 Synchronous Serial Communication Mode | 356 | | 22.1.7 4-wire Serial Bus Mode | 363 | | 22.2 Note on Serial Bus Interface | 370 | | 22.2.1 Note on Synchronous Serial Communication Mode and 4-wire Serial Rus Mode | 370 | | 23. LIN | I Module | 371 | |---------|---------------------------------------------------------------------------------------|-----| | 23.1 | LIN Module Associated Registers | 373 | | 23.1.1 | LIN Common Registers | 373 | | 23.1.2 | LIN Channel Dedicated Registers | 373 | | 23.1.3 | Register Window and Channel Switching | 374 | | 23.2 | Operating Modes | 387 | | 23.2.1 | LIN Reset Mode | 388 | | 23.2.2 | LIN Operating Mode | 388 | | 23.2.3 | LIN Wake-up Mode | 388 | | 23.3 | Operational Overview | 389 | | 23.3.1 | Header Transmission | 389 | | 23.3.2 | Response Transmission | 390 | | 23.3.3 | Response Reception | 391 | | 23.4 | Baud Rate Generator | 392 | | 23.5 | Data Transmission and Reception | 394 | | 23.5.1 | Data Transmission | 394 | | 23.5.2 | Data Reception | 395 | | 23.6 | Buffer Processing of Transmit/Receive Data | 396 | | 23.6.1 | Transmission of LIN Frame | 396 | | 23.6.2 | Reception of LIN Frame | 397 | | 23.7 | Wake-up Transmission and Reception | 398 | | 23.7.1 | Wake-up Transmission | 398 | | 23.7.2 | Wake-up Reception | 399 | | 23.8 | Low Power Mode Control Using Input Signal Low Detection | 400 | | 23.9 | Operational Status | 401 | | 23.10 | Error Status | 402 | | 23.10. | 1 Error Status Types | 402 | | 23.10. | 2 LIN Error Detection Targets | 403 | | 23.11 | LIN Interrupts | 404 | | 24. CA | N Module | 405 | | 24.1 | CAN SFRs | 408 | | 24.1.1 | CANi Control Register (CiCTLR) (i = 0, 1) | 409 | | 24.1.2 | CANi Clock Select Register (CiCLKR) (i = 0, 1) | 413 | | 24.1.3 | CANi Bit Configuration Register (CiBCR) (i = 0, 1) | 414 | | 24.1.4 | CANi Mask Register k (CiMKRk) (i = 0, 1; k = 0 to 7) | 416 | | 24.1.5 | CANi FIFO Received ID Compare Register n (CiFIDCR0 and CiFIDCR1) (i = 0, 1; n = 0, 1) | 417 | | 24.1.6 | | | | 24.1.7 | | | | 24.1.8 | , , , , , , , , , , , , , , , , , , , , | | | 24.1.9 | | | | 24.1.1 | CANi Receive FIFO Control Register (CiRFCR) (i = 0, 1) | 428 | |---------|------------------------------------------------------------------|-----| | 24.1.1 | CANi Receive FIFO Pointer Control Register (CiRFPCR) (i = 0, 1) | 431 | | 24.1.1 | CANi Transmit FIFO Control Register (CiTFCR) (i = 0, 1) | 432 | | 24.1.1 | CANi Transmit FIFO Pointer Control Register (CiTFPCR) (i = 0, 1) | 434 | | 24.1.1 | CANi Status Register (CiSTR) (i = 0, 1) | 435 | | 24.1.1 | CANi Mailbox Search Mode Register (CiMSMR) (i = 0, 1) | 438 | | 24.1.1 | CANi Mailbox Search Status Register (CiMSSR) (i = 0, 1) | 439 | | 24.1.1 | CANi Channel Search Support Register (CiCSSR) (i = 0, 1) | 441 | | 24.1.1 | CANi Acceptance Filter Support Register (CiAFSR) (i = 0, 1) | 442 | | 24.1.1 | CANi Error Interrupt Enable Register (CiEIER) (i = 0, 1) | 443 | | 24.1.2 | CANi Error Interrupt Factor Judge Register (CiEIFR) (i = 0, 1) | 445 | | 24.1.2 | CANi Receive Error Count Register (CiRECR) (i = 0, 1) | 448 | | 24.1.2 | CANi Transmit Error Count Register (CiTECR) (i = 0, 1) | 449 | | 24.1.2 | CANi Error Code Store Register (CiECSR) (i = 0, 1) | 450 | | 24.1.2 | CANi Time Stamp Register (CiTSR) (i = 0, 1) | 452 | | 24.1.2 | CANi Test Control Register (CiTCR) (i = 0, 1) | 453 | | 24.2 | Operating Modes | 456 | | 24.2.1 | CAN Reset Mode | 457 | | 24.2.2 | CAN Halt Mode | 458 | | 24.2.3 | CAN Sleep Mode | 459 | | 24.2.4 | CAN Operation Mode (Excluding Bus-off State) | 460 | | 24.2.5 | CAN Operation Mode (Bus-off State) | 461 | | 24.3 | CAN Communication Speed Configuration | 462 | | 24.3.1 | CAN Clock Configuration | 462 | | 24.3.2 | Bit Timing Configuration | 462 | | 24.3.3 | Bit rate | 463 | | 24.4 | Mailbox and Mask Register Structure | 464 | | 24.5 | Acceptance Filtering and Masking Function | 466 | | 24.6 | Reception and Transmission | 469 | | 24.6.1 | Reception | 470 | | 24.6.2 | Transmission | 472 | | 24.7 | CAN Interrupts | 473 | | 25. I/O | Pins | 474 | | 25.1 | Port Pi Direction Register (PDi Register, i = 0 to 9) | 475 | | 25.2 | Output Function Select Registers | 476 | | 25.3 | Input Function Select Registers | 487 | | 25.4 | Pull-up Control Registers 0 to 2 (Registers PUR0 to PUR2) | 490 | | 25.5 | Port Control Register (PCR Register) | 492 | | 25.6 | Configuring Unused Pins | 493 | | 26. Fla | sh Memory | 495 | |----------------------|-----------------------------------------------------------------------------|-----| | 26.1 | Overview | 495 | | 26.2 | Flash Memory Protection | 497 | | 26.2.1 | Lock Bit Protection | 497 | | 26.2.2 | ROM Code Protection | 497 | | 26.2.3 | ID Code Protection | 498 | | 26.3 | CPU Rewrite Mode | 499 | | 26.3.1 | Flash Memory Rewrite Bus Timing | 506 | | 26.3.2 | Software Commands | 510 | | 26.3.3 | Mode Transition | 511 | | 26.3.4 | Issuing Software Commands | 512 | | 26.3.5 | Status Check | 518 | | 26.4 | Standard Serial I/O Mode | 519 | | 26.5 | Parallel I/O mode | 522 | | 26.6 | Notes on Flash Memory Rewriting | 523 | | 26.6.1 | Note on Power Supply | 523 | | 26.6.2 | Note on Hardware Reset | 523 | | 26.6.3 | Note on Flash Memory Protection | 523 | | 26.6.4 | Notes on Programming | 523 | | 26.6.5 | Notes on Interrupts | 523 | | 26.6.6 | Notes on Rewrite Control Program | 524 | | 26.6.7 | Notes on Number of Program/Erase Cycles and Software Command Execution Time | 524 | | 26.6.8 | Other Notes | 524 | | 27. E <sup>2</sup> F | PROM Emulation Data Flash | 525 | | 27.1 | Overview | | | 27.2 | Block Configuration | | | 27.3 | Operational Procedures | | | 27.4 | Note on E <sup>2</sup> dataFlash | | | 28. Ele | ctrical Characteristics | 534 | | 29. Usa | age Notes | 569 | | 29.1 | Notes on Board Designing | 569 | | 29.1.1 | Power Supply Pins | 569 | | 29.1.2 | Supply Voltage | | | 29.2 | Notes on Register Setting | | | 29.2.1 | Registers with Write-only Bits | | | 29.3 | Notes on Clock Generator | | | 29.3.1 | Sub Clock | | | 29.3.2 | Power Control | | | | Notes on Interrupts | 573 | | 29.4.1 | ISP Setting | 573 | |---------|------------------------------------------------------------------------------|-----| | 29.4.2 | NMI | 573 | | 29.4.3 | External Interrupts | 573 | | 29.5 | Notes on DMAC | 574 | | 29.5.1 | DMAC-associated Register Settings | 574 | | 29.5.2 | Reading DMAC-associated Registers | 574 | | 29.6 | Notes on Timers | 575 | | 29.6.1 | Timer A and Timer B | 575 | | 29.6.2 | Timer A | 575 | | 29.6.3 | Timer B | 577 | | 29.7 | Notes on Three-phase Motor Control Timers | 578 | | 29.7.1 | Shutdown | 578 | | 29.7.2 | Register Setting | 578 | | 29.8 | Notes on Serial Interface | 579 | | 29.8.1 | Changing the UiBRG Register (i = 0 to 4) | 579 | | 29.8.2 | Pin Output | 579 | | 29.8.3 | Synchronous Serial Interface Mode | 579 | | 29.8.4 | Special Mode 1 (I <sup>2</sup> C Mode) | 579 | | 29.8.5 | Reset Procedure on Communication Error | 580 | | 29.9 | Notes on A/D Converter | 581 | | 29.9.1 | Notes on Designing Boards | 581 | | 29.9.2 | Notes on Programming | 582 | | 29.10 | Note on Serial Bus Interface | 583 | | 29.10. | Note on Synchronous Serial Communication Mode and 4-wire Serial Bus Mode | 583 | | 29.11 | Notes on Flash Memory Rewriting | 584 | | 29.11. | 1 Note on Power Supply | 584 | | 29.11. | Note on Hardware Reset | 584 | | 29.11. | Note on Flash Memory Protection | 584 | | 29.11. | Notes on Programming | 584 | | 29.11. | Notes on Interrupts | 584 | | 29.11. | Notes on Rewrite Control Program | 585 | | 29.11. | Notes on Number of Program/Erase Cycles and Software Command Execution Time. | 585 | | 29.11. | 3 Other Notes | 585 | | 29.12 | Note on E <sup>2</sup> dataFlash | 586 | | Appendi | x 1. Package Dimensions | 587 | | INDEX | | 588 | # R32C/161 Group RENESAS MCU R01UH0226EJ0120 Rev.1.20 Jul 04, 2012 #### 1. Overview #### 1.1 Features The M16C Family offers a robust platform of 32-/16-bit CISC microcomputers (MCUs) featuring high ROM code efficiency, extensive EMI/EMS noise immunity, ultra-low power consumption, high-speed processing in actual applications, and numerous and varied integrated peripherals. Extensive device scalability from low- to high-end, featuring a single architecture as well as compatible pin assignments and peripheral functions, provides support for a vast range of application fields. The R32C/100 Series is a high-end microcontroller series in the M16C Family. With a 4-Gbyte memory space, it achieves maximum code efficiency and high-speed processing with 32-bit CISC architecture, multiplier, multiply-accumulate unit, and floating point unit. The selection from the broadest choice of on-chip peripheral devices — UART, CRC, DMAC, A/D converter, timers, I<sup>2</sup>C, and watchdog timer enables to minimize external components. The R32C/100 Series, in particular, provides the R32C/161 Group, a product specific to vehicle network. This product, provided as 80-pin plastic molded LQFP package, has two channels of CAN module, one channel of LIN module, and standard peripherals. #### 1.1.1 Applications Automotive, audio, communication equipment, industrial equipment, etc. #### 1.1.2 Performance Overview Tables 1.1 and 1.2 show the performance overview of the R32C/161 Group. Table 1.1 Performance Overview (1/2) | Unit | Function | Explanation | |-------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CPU | Central processing unit | R32C/100 Series CPU Core • Basic instructions: 108 • Minimum instruction execution time: 20.83 ns (f(CPU) = 48 MHz) • Multiplier: 32-bit × 32-bit → 64-bit • Multiply-accumulate unit: 32-bit × 32-bit + 64-bit → 64-bit • IEEE-754 compatible FPU: Single precision • 32-bit barrel shifter • Operating mode: Single-chip mode | | Memory | | Flash memory: 128/256 Kbytes RAM: 12/20 Kbytes Data flash: 4 Kbytes × 2 blocks E <sup>2</sup> dataFlash: none <sup>(1)</sup> /4 Kbytes Refer to Table 1.3 for details | | Voltage | Low voltage | Optional <sup>(2)</sup> | | Detector | detector | Low voltage detection interrupt | | Clock | Clock generator | <ul> <li>4 circuits (main clock, sub clock, PLL, on-chip oscillator)</li> <li>Oscillation stop detector: Main clock oscillator stop/restart detection</li> <li>Frequency divide circuit: Divide-by-2 to divide-by-24 selectable</li> <li>Low power modes: Wait mode, stop mode</li> </ul> | | Interrupts | | Interrupt vectors: 261 External interrupt inputs: NMI, NT × 6 Interrupt priority levels: 7 | | Watchdog Ti | mer | 15 bits × 1 (selectable input frequency from prescaler output) Automatic timer start function is available | | DMA | DMAC | 4 channels • Cycle-steal transfer mode • Request sources: 44 • 2 transfer modes: Single transfer, repeat transfer | | | DMAC II | Triggered by an interrupt request of any peripheral 3 characteristic transfer functions: Immediate data transfer, calculation result transfer, chain transfer | | I/O Ports | Programmable<br>I/O ports | <ul> <li>2 input-only ports</li> <li>64 CMOS I/O ports</li> <li>A pull-up resistor is selectable for every 4 input ports</li> </ul> | #### Notes: - 1. Contact a Renesas Electronics sales office to use the non-E<sup>2</sup>dataFlash version. - 2. Contact a Renesas Electronics sales office to use the optional features. Table 1.2 Performance Overview (2/2) | Unit | Function | Explanation | | | |------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Timer | Timer A | 16-bit timer × 5 Timer mode, event counter mode, one-shot timer mode, pulse-width modulation (PWM) mode Two-phase pulse signal processing in event counter mode (two-phase encoder input) × 3 | | | | | Timer B | 16-bit timer × 6 Timer mode, event counter mode, pulse frequency measurement mode, pulse-width measurement mode | | | | | Three-phase motor control timer | Three-phase motor control timer × 1 (timers A1, A2, A4, and B2 used) 8-bit programmable dead time timer | | | | Serial<br>Interface | UART0 to UART4 | Asynchronous/synchronous serial interface × 5 channels • I <sup>2</sup> C-bus (UART0 to UART2) • Special mode 2 (UART0 to UART2) | | | | A/D Converter | | 10-bit resolution × 23 channels Sample and hold functionality integrated Self test/Open-circuit detection assist | | | | CRC Calculate | or | CRC-CCITT (X <sup>16</sup> + X <sup>12</sup> + X <sup>5</sup> + 1) | | | | X-Y Converter | • | 16 bits × 16 bits | | | | Intelligent I/O | | Time measurement (input capture): 16 bits × 8 Digital debounce circuit contained Waveform generation (output compare): 16 bits × 8 Phase shift waveform output mode contained | | | | Serial Bus Interface | | 1 channel • Synchronous serial communication mode • 4-wire serial bus mode Programmable character length: 8 to 16 bits | | | | LIN Module | | 1 channel | | | | CAN Module | | 2 channels CAN functionality compliant with ISO 11898-1 32 mailboxes | | | | Flash Memory | | Programming and erasure supply voltage: VCC = 3.0 to 5.5 V Minimum endurance: 1,000 program/erase cycles Security protection: ROM code protect, ID code protect Debugging: On-chip debug, on-board flash programming | | | | E <sup>2</sup> dataFlash | | Minimum endurance: 100,000 program/erase cycles | | | | Operating Frequency/Supply Voltage | | 48 MHz/VCC = 3.0 to 5.5 V | | | | Operating Temperature | | -40°C to 85°C (J version) -40°C to 105°C (L version) (1) -40°C to 125°C (K version) | | | | Current Consumption | | 31 mA (VCC = 5.0 V, f(CPU) = 48 MHz)<br>8 μA (VCC = 3.3 V, f(XCIN) = 32.768 kHz, wait mode) | | | | Package | | 80-pin plastic molded LQFP (PLQP0080KB-A) | | | #### Note: 1. Contact a Renesas Electronics sales office to use the L version products. #### 1.2 Product Information Table 1.3 lists the product information and Figure 1.1 shows the details of the part number. Table 1.3 R32C/161 Group Product List As of July, 2012 | Part Number | Package Code (1) | ROM Capacity (2) | RAM Capacity | E <sup>2</sup> dataFlash | Remarks | |-------------|------------------|--------------------------|--------------|--------------------------|---------------| | R5F64610JFP | | | | | J Version | | R5F64610LFP | | 128 Kbytes<br>+ 8 Kbytes | | , | L Version (3) | | R5F64610KFP | | | 12 Kbytes | | K Version | | R5F6461EJFP | | | 12 Kbyles | NA <sup>(3)</sup> | J Version | | R5F6461ELFP | | | | | L Version (3) | | R5F6461EKFP | PLQP0080KB-A | | | | K Version | | R5F64611JFP | PLQP0000ND-A | | | 4 Kbytes | J Version | | R5F64611LFP | | | | | L Version (3) | | R5F64611KFP | | 256 Kbytes | 20 Kbytes | | K Version | | R5F6461FJFP | | + 8 Kbytes | 20 Kbytes | NA <sup>(3)</sup> | J Version | | R5F6461FLFP | | | | | L Version (3) | | R5F6461FKFP | | | | | K Version | #### Notes: - 1. The old package code is as follows: PLQP0080KB-A: 80P6Q-A - 2. "+ 8 Kbytes" in the ROM capacity column indicates the data flash capacity. - 3. Contact a Renesas Electronics sales office to use the non-E²dataFlash version or the L version products. Figure 1.1 Part Numbering #### 1.3 Block Diagram Figure 1.2 shows a block diagram of the R32C/161 Group. Figure 1.2 R32C/161 Group Block Diagram #### 1.4 Pin Assignment Figure 1.3 shows the pin assignment (top view) and Tables 1.4 and 1.5 show the pin characteristics. Figure 1.3 Pin Assignment (top view) Table 1.4 Pin Characteristics (1/2) | Pin<br>No. | Control<br>Pin | Port | Interrupt<br>Pin | Timer Pin | UART / SBI Pin | Intelligent I/O<br>Pin | LIN /<br>CAN Module Pin | Analog<br>Pin | |------------|----------------|------|------------------|-----------------|-----------------|------------------------|---------------------------------|---------------| | 1 | | P9_3 | | TB3IN | | | | | | 2 | VDC0 | | | | | | | | | 3 | | P9_1 | | | | | | | | 4 | VDC1 | | | | | | | | | 5 | NSD | | | | | | | | | 6 | CNVSS | | | | | | | | | 7 | XCIN | P8_7 | | | | | | | | 8 | XCOUT | P8_6 | | | | | | | | 9 | RESET | | | | | | | | | 10 | XOUT | | | | | | | | | 11 | VSS | | | | | | | | | 12 | XIN | | | | | | | | | 13 | VCC | | | | | | | | | 14 | | P8_5 | NMI | | | | | | | 15 | | P8_4 | INT2 | | | | | | | 16 | | P8_3 | ĪNT1 | | | | CAN0IN/CAN0WU/<br>CAN1IN/CAN1WU | | | 17 | | P8_2 | ĪNT0 | | | | CAN0OUT/<br>CAN1OUT | | | 18 | | P7_6 | | | CTS2/RTS2/SS2 | | CAN0OUT | | | 19 | | P7_5 | | | CLK2 | | LIN0IN/CAN0IN/<br>CAN0WU | | | 20 | | P7_4 | | | RXD2/SCL2/STXD2 | | LIN0OUT | | | 21 | | P7_0 | | | TXD2/SDA2/SRXD2 | | | | | 22 | | P6_7 | | TA3IN | | | | | | 23 | | P6_5 | | TA0IN/<br>TB5IN | | | | | | 24 | | P5_7 | | | TXD0/SDA0/SRXD0 | IIO0_7 | | | | 25 | | P5_6 | | | RXD0/SCL0/STXD0 | IIO0_6 | | | | 26 | | P5_5 | | | CLK0 | IIO0_5 | | | | 27 | | P5_4 | | | CTS0/RTS0/SS0 | IIO0_4 | | | | 28 | CLKOUT | P5_3 | | | | IIO0_3 | | | | 29 | | P5_2 | | | | IIO0_2 | | | | 30 | | P5_1 | | | | IIO0_1 | | | | 31 | | P5_0 | | | | IIO0_0 | | | | 32 | | P4_7 | | | TXD1/SDA1/SRXD1 | | | | | 33 | | P4_6 | | | RXD1/SCL1/STXD1 | | | | | 34 | | P4_5 | | | CLK1 | | LIN0IN | | | 35 | | P4_4 | | | CTS1/RTS1/SS1 | | LIN0OUT | | | 36 | | P4_3 | | | TXD3/SSO0 | | | | | 37 | | P4_2 | | | RXD3/SSI0 | | | | | 38 | | P4_1 | | | CLK3/SSCK0 | | | | | 39 | | P4_0 | | | CTS3/RTS3/SCS0 | | | | Table 1.5 Pin Characteristics (2/2) | rabi | able 1.5 Pin Characteristics (2/2) | | | | | | | | |------------|------------------------------------|------|------------------|-------------------|----------------|------------------------|-------------------------|---------------| | Pin<br>No. | Control<br>Pin | Port | Interrupt<br>Pin | Timer Pin | UART / SBI Pin | Intelligent I/O<br>Pin | LIN /<br>CAN Module Pin | Analog<br>Pin | | 40 | | P3_7 | | TA4IN/<br>TB1IN/Ū | CTS4/RTS4 | | | | | 41 | | P3_6 | | TA4OUT/U | TXD4 | | | | | 42 | | P3_5 | | TA2IN/W | RXD4 | | | | | 43 | | P3_4 | | TA2OUT/W | CLK4 | | | | | 44 | | P3_3 | | TA1IN/V | | | | | | 45 | | P3_2 | | TA1OUT/V | | | | | | 46 | | P3_1 | | TA3OUT | | UD0B | LINOIN | | | 47 | VCC | | | | | | | | | 48 | | P3_0 | | TA0OUT | | UD0A | LIN0OUT | | | 49 | VSS | | | | | | | | | 50 | | P2_7 | | | | | | AN2_7 | | 51 | | P2_6 | | | | | | AN2_6 | | 52 | | P2_5 | | | | | | AN2_5 | | 53 | | P2_4 | | | | | | AN2_4 | | 54 | | P2_3 | | | | | | AN2_3 | | 55 | | P2_2 | | | | | | AN2_2 | | 56 | | P2_1 | | | | | | AN2_1 | | 57 | | P2_0 | | | | | | AN2_0 | | 58 | | P1_7 | ĪNT5 | | | IIO0_7 | | | | 59 | | P1_6 | ĪNT4 | | | IIO0_6 | | | | 60 | | P1_5 | ĪNT3 | | | IIO0_5 | | | | 61 | | P1_4 | | TB0IN | | IIO0_4 | | AN_4 | | 62 | | P1_3 | | | SCS0 | IIO0_3 | | AN_3 | | 63 | | P1_2 | | | SSI0 | IIO0_2 | | AN_2 | | 64 | | P1_1 | | | SSCK0 | IIO0_1 | | AN_1 | | 65 | | P1_0 | | | SSO0 | 1100_0 | | AN_0 | | 66 | | P0_7 | | | | | | AN0_7 | | 67 | | P0_6 | | | | | | AN0_6 | | 68 | | P0_5 | | | | | | AN0_5 | | 69 | | P0_4 | | | | | | AN0_4 | | 70 | | P0_3 | | | | | | AN0_3 | | 71 | | P0_2 | | | | | | AN0_2 | | 72 | | P0_1 | | | | | | AN0_1 | | 73 | | P0_0 | | | | | | AN0_0 | | 74 | | P9_7 | | TB2IN | RXD4 | | | ADTRG | | 75 | AVSS | | | | | | | | | 76 | | P9_6 | | | TXD4 | | CAN1OUT | ANEX1 | | 77 | VREF | | | | | | | | | 78 | AVCC/<br>VCC | | | | | | | | | 79 | | P9_5 | | | CLK4 | | CAN1IN/CAN1WU | ANEX0 | | 80 | | P9_4 | | TB4IN | CTS4/RTS4 | | | | #### 1.5 Pin Definitions and Functions Tables 1.6 and 1.7 shows the pin definitions and functions. Table 1.6 Pin Definitions and Functions (1/2) | Function | Symbol | I/O | Description | |------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power supply | VCC, VSS | I | Applicable as follows: VCC = 3.0 to 5.5 V, VSS = 0 V | | Connecting pins for decoupling capacitor | VDC0, VDC1 | _ | A decoupling capacitor for internal voltage should be connected between VDC0 and VDC1 | | Analog power supply | AVCC, AVSS | I | Power supply for the A/D converter. AVSS should be connected to VSS | | Reset input | RESET | I | The MCU is reset when this pin is driven low | | CNVSS | CNVSS | I | This pin should be connected to VSS via a resistor | | Debug port | NSD | I/O | This pin is to communicate with a debugger. It should be connected to VCC via a resistor of 1 to 4.7 k $\Omega$ | | Main clock input | XIN | I | Input/output for the main clock oscillator. A crystal, or a ceramic resonator should be connected between | | Main clock output | XOUT | 0 | pins XIN and XOUT. An external clock should be input at the XIN while leaving the XOUT open | | Sub clock input | XCIN | 1 | Input/output for the sub clock oscillator. A crystal oscillator should be connected between pins XCIN | | Sub clock output | XCOUT | 0 | and XCOUT. An external clock should be input at the XCIN while leaving the XCOUT open | | Clock output | CLKOUT | 0 | Output of the clock with the same frequency as low speed clocks, f8, or f32 | | External interrupt input | INTO to INT5 | I | Input for external interrupts | | NMI input | P8_5/NMI | I | Input for NMI | | 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>P6_5, P6_7,<br>P7_0, P7_4 to P7_6,<br>P8_2 to P8_4,<br>P8_6, P8_7,<br>P9_3 to P9_7 | I/O | I/O ports in CMOS. Each port can be programmed to input or output under the control of the direction register. Pull-up resistors are selected for the following 4-pin units, but are enabled only for the input pins: Pi_0 to Pi_3 and Pi_4 to Pi_7 (i = 0 to 9) | | Input port | P9_1 | I | Input port in CMOS. Pull-up resistors are selectable for P9_1 and P9_3 | Table 1.7 Pin Definitions and Functions (2/2) | Function | Symbol | I/O | Description | |----------------------------------------|----------------------------------------------------|-----|----------------------------------------------------------------------------------------------------| | Timer A | TA0OUT to TA4OUT | I/O | Timers A0 to A4 input/output | | | TA0IN to TA4IN | I | Timers A0 to A4 input | | Timer B | TB0IN to TB5IN | I | Timers B0 to B5 input | | Three-phase motor control timer output | U, Ū, V, V, W, W | 0 | Three-phase motor control timer output | | Serial interface | CTS0 to CTS4 | I | Handshake input | | | RTS0 to RTS4 | 0 | Handshake output | | | CLK0 to CLK4 | I/O | Transmit/receive clock input/output | | | RXD0 to RXD4 | ı | Serial data input | | | TXD0 to TXD4 | 0 | Serial data output | | I <sup>2</sup> C-bus | SDA0 to SDA2 | I/O | Serial data input/output | | (simplified) | SCL0 to SCL2 | I/O | Transmit/receive clock input/output | | Serial interface | STXD0 to STXD2 | 0 | Serial data output in slave mode | | special functions | SRXD0 to SRXD2 | I | Serial data input in slave mode | | | SS0 to SS2 | I | Input to control serial interface special functions | | A/D converter | AN_0 to AN_4,<br>AN0_0 to AN0_7,<br>AN2_0 to AN2_7 | I | Analog input for the A/D converter | | | ADTRG | I | External trigger input for the A/D converter | | | ANEX0 | I/O | Expanded analog input for the A/D converter and output in external op-amp connection mode | | | ANEX1 | I | Expanded analog input for the A/D converter | | Reference voltage input | VREF | I | Reference voltage input for the A/D converter and D/A converter | | Intelligent I/O | IIO0_0 to IIO0_7 | I/O | Input/output for the Intelligent I/O group 0. Either input capture or output compare is selectable | | | UD0A, UD0B | I | Input for the two-phase encoder | | Serial bus interface | SSO0 | I/O | Serial data output. Functions as serial data input/output in 4-wire serial bus mode | | | SSI0 | I/O | Serial data input. Functions as serial data input/<br>output in 4-wire serial bus mode | | | SSCK0 | I/O | Transmit/receive clock input/output | | | SCS0 | I/O | Input/output to control the synchronous serial interface | | LIN module | LIN0OUT | 0 | Transmit data output for the LIN communications | | | LINOIN | I | Receive data input for the LIN communications | | CAN module | CANOIN, CAN1IN | I | Receive data input for the CAN communications | | | CAN0OUT, CAN1OUT | 0 | Transmit data output for the CAN communications | | | CANOWU, CAN1WU | ı | Input for the CAN wake-up interrupt | ## 2. Central Processing Unit (CPU) The CPU contains the registers shown below. There are two register banks each consisting of registers R2R0, R3R1, R6R4, R7R5, A0 to A3, SB, and FB. Figure 2.1 CPU Registers #### 2.1 General Purpose Registers #### 2.1.1 Data Registers (R2R0, R3R1, R6R4, and R7R5) These 32-bit registers are primarily used for transfers and arithmetic/logic operations. Each of the registers can be divided into upper and lower 16-bit registers, e.g. R2R0 can be divided into R2 and R0, R3R1 can be divided into R3 and R1, etc. Moreover, data registers R2R0 and R3R1 can be divided into four 8-bit data registers: upper (R2H and R3H), mid-upper (R2L and R3L), mid-lower (R0H and R1H), and lower (R0L and R1L). #### 2.1.2 Address Registers (A0, A1, A2, and A3) These 32-bit registers have functions similar to data registers. They are also used for address register indirect addressing and address register relative addressing. #### 2.1.3 Static Base Register (SB) This 32-bit register is used for SB relative addressing. #### 2.1.4 Frame Base Register (FB) This 32-bit register is used for FB relative addressing. #### 2.1.5 Program Counter (PC) This 32-bit counter indicates the address of the instruction to be executed next. #### 2.1.6 Interrupt Vector Table Base Register (INTB) This 32-bit register indicates the start address of a relocatable vector table. #### 2.1.7 User Stack Pointer (USP) and Interrupt Stack Pointer (ISP) Two types of 32-bit stack pointers (SPs) are provided: user stack pointer (USP) and interrupt stack pointer (ISP). Use the stack pointer select flag (U flag) to select either the user stack pointer (USP) or the interrupt stack pointer (ISP). The U flag is bit 7 in the flag register (FLG). Refer to 2.1.8 "Flag Register (FLG)" for details. To minimize the overhead of interrupt sequence due to less memory access, set the user stack pointer (USP) or the interrupt stack pointer (ISP) to a multiple of 4. #### 2.1.8 Flag Register (FLG) This 32-bit register indicates the CPU status. #### 2.1.8.1 Carry Flag (C flag) This flag retains a carry, borrow, or shifted-out bit generated by the arithmetic logic unit (ALU). #### 2.1.8.2 Debug Flag (D flag) This flag is only for debugging. Only set this bit to 0. #### 2.1.8.3 Zero Flag (Z flag) This flag becomes 1 when the result of an operation is 0; otherwise it is 0. #### 2.1.8.4 Sign Flag (S flag) This flag becomes 1 when the result of an operation is a negative value; otherwise it is 0. #### 2.1.8.5 Register Bank Select Flag (B flag) This flag selects a register bank. It indicates 0 when register bank 0 is selected, and 1 when register bank 1 is selected. #### 2.1.8.6 Overflow Flag (O flag) This flag becomes 1 when the result of an operation overflows; otherwise it is 0. #### 2.1.8.7 Interrupt Enable Flag (I flag) This flag enables maskable interrupts. To disable maskable interrupts, set this flag to 0. To enable them, set this flag to 1. When an interrupt is accepted, the flag becomes 0. #### 2.1.8.8 Stack Pointer Select Flag (U flag) To select the interrupt stack pointer (ISP), set this flag to 0. To select the user stack pointer (USP), set this flag to 1. It becomes 0 when a hardware interrupt is accepted or when an INT instruction designated by a software interrupt number from 0 to 127 is executed. #### 2.1.8.9 Floating-point Underflow Flag (FU flag) This flag becomes 1 when an underflow occurs in a floating-point operation; otherwise it is 0. It also becomes 1 when the operand contains invalid numbers (subnormal numbers). #### 2.1.8.10 Floating-point Overflow Flag (FO flag) This flag becomes 1 when an overflow occurs in a floating-point operation; otherwise it is 0. It also becomes 1 when the operand contains invalid numbers (subnormal numbers). #### 2.1.8.11 Processor Interrupt Priority Level (IPL) The processor interrupt priority level (IPL), consisting of 3 bits, selects a processor interrupt priority level from level 0 to 7. An interrupt is enabled when the interrupt request level is higher than the selected IPL. When the processor interrupt priority level (IPL) is set to 111b (level 7), all interrupts are disabled. #### 2.1.8.12 Fixed-point Radix Point Designation Bit (DP bit) This bit designates the radix point. It also specifies which portion of the fixed-point multiplication result to extract. It is used for the MULX instruction. #### 2.1.8.13 Floating-point Rounding Mode (RND) The 2-bit floating-point rounding mode selects a rounding mode for floating-point calculation results. #### 2.1.8.14 Reserved Only set this bit to 0. The read value is undefined. #### 2.2 Fast Interrupt Registers The following three registers are provided to minimize the overhead of the interrupt sequence. Refer to 10.4 "Fast Interrupt" for details. #### 2.2.1 Save Flag Register (SVF) This 32-bit register is used to save the flag register when a fast interrupt occurs. #### 2.2.2 Save PC Register (SVP) This 32-bit register is used to save the program counter when a fast interrupt occurs. #### 2.2.3 Vector Register (VCT) This 32-bit register is used to indicate a jump address when a fast interrupt occurs. #### 2.3 DMAC-associated Registers There are seven types of DMAC-associated registers. Refer to 12. "DMAC" for details. #### 2.3.1 DMA Mode Registers (DMD0, DMD1, DMD2, and DMD3) These 32-bit registers are used to set DMA transfer mode, bit rate, etc. #### 2.3.2 DMA Terminal Count Registers (DCT0, DCT1, DCT2, and DCT3) These 24-bit registers are used to set the number of DMA transfers. #### 2.3.3 DMA Terminal Count Reload Registers (DCR0, DCR1, DCR2, and DCR3) These 24-bit registers are used to set the reloaded values for DMA terminal count registers. #### 2.3.4 DMA Source Address Registers (DSA0, DSA1, DSA2, and DSA3) These 32-bit registers are used to set DMA source addresses. #### 2.3.5 DMA Source Address Reload Registers (DSR0, DSR1, DSR2, and DSR3) These 32-bit registers are used to set the reloaded values for DMA source address registers. #### 2.3.6 DMA Destination Address Registers (DDA0, DDA1, DDA2, and DDA3) These 32-bit registers are used to set DMA destination addresses. # 2.3.7 DMA Destination Address Reload Registers (DDR0, DDR1, DDR2, and DDR3) These 32-bit registers are used to set reloaded values for DMA destination address registers. R32C/161 Group 3. Memory #### 3. Memory Figure 3.1 shows the memory map of the R32C/161 Group. The R32C/161 Group provides a 4-Gbyte address space from 00000000h to FFFFFFFh. The internal ROM is mapped from address FFFFFFFh in the inferior direction. For example, the 256-Kbyte internal ROM is mapped from FFFC0000h to FFFFFFFh. The fixed interrupt vector table contains the start address of interrupt handlers and is mapped from FFFFFFDCh to FFFFFFFh. The internal RAM is mapped from address 00000400h in the superior direction. For example, the 20-Kbyte internal RAM is mapped from 00000400h to 000053FFh. Besides being used for data storage, the internal RAM functions as a stack(s) for subroutine calls and/or interrupt handlers. Special function registers (SFRs), which are control registers for peripheral functions, are mapped from 00000000h to 000003FFh, and from 00040000h to 0004FFFFh. Unoccupied SFR locations are reserved, and no access is allowed. Figure 3.1 Memory Map # 4. Special Function Registers (SFRs) SFRs are memory-mapped peripheral registers that control the operation of peripherals. Table 4.1 SFR List (1) to Table 4.53 SFR List (53) list the SFR details. Table 4.1 SFR List (1) | Register | Symbol | Reset Value | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | | | | | | | | | | Clock Control Register | CCR | 0001 1000b | | | | | | Flash Memory Control Register | FMCR | 0000 0001b | | Protect Release Register | PRR | 00h | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | FEBC | 0000h | | | | | | | PBC | 0504h | | | | | | | | | | | | | | | Clock Control Register Flash Memory Control Register Protect Release Register Flash Memory Rewrite Bus Control Register Peripheral Bus Control Register | Clock Control Register Clock Release Register FMCR Protect Release Register PRR Flash Memory Rewrite Bus Control Register FEBC Peripheral Bus Control Register PMCR PRR FMCR FMCR PRR FMCR FMCR PRR FMCR FMCR PRR FMCR FMCR PRR FMCR | X: Undefined Blanks are reserved. No access is allowed. Table 4.2 SFR List (2) | Reset Value | Symbol | Register | Address | |-------------|----------|---------------------------------------------------------------------------|---------| | | | | 000060h | | XXXX X000b | TB5IC | Timer B5 Interrupt Control Register | 000061h | | | | | 000062h | | XXXX X000b | S2RIC | UART2 Receive/ACK Interrupt Control Register | 000063h | | | | | 000064h | | | | | 000065h | | | | | 000066h | | | | | 000067h | | XXXX X000b | DM0IC | DMA0 Transfer Complete Interrupt Control Register | 000068h | | XXXX X000b | BCN0IC | UART0 Start Condition/Stop Condition Detection Interrupt Control Register | | | XXXX X000b | DM2IC | DMA2 Transfer Complete Interrupt Control Register | | | XXXX X000b | AD0IC | A/D Converter 0 Convert Completion Interrupt Control Register | | | XXXX X000b | TAOIC | Timer A0 Interrupt Control Register | | | XXXX X000b | IIO0IC | Intelligent I/O Interrupt Control Register 0 | | | XXXX X000b | TA2IC | Timer A2 Interrupt Control Register | | | XXXX X000b | IIO2IC | Intelligent I/O Interrupt Control Register 2 | | | XXXX X000b | TA4IC | Timer A4 Interrupt Control Register | | | XXXX X000b | IIO4IC | Intelligent I/O Interrupt Control Register 4 | | | XXXX X000b | SORIC | UART0 Receive/ACK Interrupt Control Register | | | XXXX X000b | IIO6IC | Intelligent I/O Interrupt Control Register 6 | | | XXXX X000b | S1RIC | UART1 Receive/ACK Interrupt Control Register | | | XXXX X000b | IIO8IC | Intelligent I/O Interrupt Control Register 8 | | | XXXX X000b | TB1IC | Timer B1 Interrupt Control Register | | | XXXX X000b | IIO10IC | Intelligent I/O Interrupt Control Register 10 | | | XXXX X000b | TB3IC | Timer B3 Interrupt Control Register | | | | | · | 000079h | | XX00 X000b | INT5IC | INT5 Interrupt Control Register | 00007Ah | | XXXX X000b | COWIC | CAN0 Wake-up Interrupt Control Register | | | XX00 X000b | INT3IC | INT3 Interrupt Control Register | 00007Ch | | | | - | 00007Dh | | XX00 X000b | INT1IC | INT1 Interrupt Control Register | 00007Eh | | XXXX X000b | LLDIC | LIN Low Detection Interrupt Control Register | 00007Fh | | | | - | 000080h | | XXXX X000b | S2TIC | UART2 Transmit/NACK Interrupt Control Register | 000081h | | | <u> </u> | · • | 000082h | | | <u> </u> | | 000083h | | | | | 000084h | | | | | 000085h | | | | | 000086h | | XXXX X000b | BCN2IC | UART2 Start Condition/Stop Condition Detection Interrupt | | | XX | BCN2IC | Control Register | | X: Undefined Blanks are reserved. No access is allowed. Table 4.3 SFR List (3) | Address | Register | Symbol | Reset Value | |---------|---------------------------------------------------------------------------|---------|-------------| | | DMA1 Transfer Complete Interrupt Control Register | DM1IC | XXXX X000b | | 000089h | UART1 Start Condition/Stop Condition Detection Interrupt Control Register | BCN1IC | XXXX X000b | | 00008Ah | DMA3 Transfer Complete Interrupt Control Register | DM3IC | XXXX X000b | | 00008Bh | | | | | | Timer A1 Interrupt Control Register | TA1IC | XXXX X000b | | | Intelligent I/O Interrupt Control Register 1 | IIO1IC | XXXX X000b | | 00008Eh | Timer A3 Interrupt Control Register | TA3IC | XXXX X000b | | 00008Fh | Intelligent I/O Interrupt Control Register 3 | IIO3IC | XXXX X000b | | 000090h | UART0 Transmit/NACK Interrupt Control Register | S0TIC | XXXX X000b | | | Intelligent I/O Interrupt Control Register 5 | IIO5IC | XXXX X000b | | 000092h | UART1 Transmit/NACK Interrupt Control Register | S1TIC | XXXX X000b | | | Intelligent I/O Interrupt Control Register 7 | IIO7IC | XXXX X000b | | | Timer B0 Interrupt Control Register | TB0IC | XXXX X000b | | | Intelligent I/O Interrupt Control Register 9 | IIO9IC | XXXX X000b | | | Timer B2 Interrupt Control Register | TB2IC | XXXX X000b | | | Intelligent I/O Interrupt Control Register 11 | IIO11IC | XXXX X000b | | | Timer B4 Interrupt Control Register | TB4IC | XXXX X000b | | 000099h | | | | | | INT4 Interrupt Control Register | INT4IC | XX00 X000b | | | CAN1 Wake-up Interrupt Control Register | C1WIC | XXXX X000b | | | INT2 Interrupt Control Register | INT2IC | XX00 X000b | | 00009Dh | | | | | | INT0 Interrupt Control Register | INT0IC | XX00 X000b | | 00009Fh | | | | | | Intelligent I/O Interrupt Request Register 0 | IIO0IR | 0000 00X1b | | | Intelligent I/O Interrupt Request Register 1 | IIO1IR | 0000 00X1b | | | Intelligent I/O Interrupt Request Register 2 | IIO2IR | 0000 0001b | | | Intelligent I/O Interrupt Request Register 3 | IIO3IR | 0000 00X1b | | | Intelligent I/O Interrupt Request Register 4 | IIO4IR | 0000 00X1b | | | Intelligent I/O Interrupt Request Register 5 | IIO5IR | 0000 00X1b | | | Intelligent I/O Interrupt Request Register 6 | IIO6IR | 0000 00X1b | | | Intelligent I/O Interrupt Request Register 7 | IIO7IR | 000X 00X1b | | | Intelligent I/O Interrupt Request Register 8 | IIO8IR | 0000 0001b | | | Intelligent I/O Interrupt Request Register 9 | IIO9IR | 0000 0001b | | | Intelligent I/O Interrupt Request Register 10 | IIO10IR | 0000 0001b | | | Intelligent I/O Interrupt Request Register 11 | IIO11IR | 0000 00X1b | | 0000ACh | | | | | 0000ADh | | | | | 0000AEh | | | | | 0000AFh | | | | X: Undefined Blanks are reserved. No access is allowed. Table 4.4 SFR List (4) | | Of 11 2.15t (4) | | | |----------|-----------------------------------------------------|---------|-------------| | Address | Register | Symbol | Reset Value | | 0000B0h | Intelligent I/O Interrupt Enable Register 0 | IIO0IE | 00h | | | Intelligent I/O Interrupt Enable Register 1 | IIO1IE | 00h | | | Intelligent I/O Interrupt Enable Register 2 | IIO2IE | 00h | | 0000B3h | Intelligent I/O Interrupt Enable Register 3 | IIO3IE | 00h | | | Intelligent I/O Interrupt Enable Register 4 | IIO4IE | 00h | | 0000B5h | Intelligent I/O Interrupt Enable Register 5 | IIO5IE | 00h | | 0000B6h | Intelligent I/O Interrupt Enable Register 6 | IIO6IE | 00h | | 0000B7h | Intelligent I/O Interrupt Enable Register 7 | IIO7IE | 00h | | | Intelligent I/O Interrupt Enable Register 8 | IIO8IE | 00h | | | Intelligent I/O Interrupt Enable Register 9 | IIO9IE | 00h | | | Intelligent I/O Interrupt Enable Register 10 | IIO10IE | 00h | | | Intelligent I/O Interrupt Enable Register 11 | IIO11IE | 00h | | 0000BCh | | | | | 0000BDh | | | | | 0000BEh | | | | | 0000BFh | | | | | | Serial Bus Interface 0 Interrupt Control Register | SS0IC | XXXX X000b | | | CAN0 Transmit Interrupt Control Register | COTIC | XXXX X000b | | 0000C2h | | 00110 | 7000070000 | | | CAN0 Error Interrupt Control Register | C0EIC | XXXX X000b | | 0000C4h | | OULIO | 70000 | | | CAN1 Receive Interrupt Control Register | C1RIC | XXXX X000b | | 0000C5h | | OTRIO | XXXX X000D | | 0000C0ff | | | | | 0000C7fi | | | | | 0000C8f1 | | | | | 0000C9h | | | | | 0000CAn | | | | | | | | | | 0000CCh | | | | | 0000CDh | | | | | 0000CEh | | | | | 0000CFh | | 0.000 | 1000111001 | | | CAN0 Transmit FIFO Interrupt Control Register | C0FTIC | XXXX X000b | | 0000D1h | | | | | | CAN1 Transmit FIFO Interrupt Control Register | C1FTIC | XXXX X000b | | 0000D3h | | | | | 0000D4h | | | | | | LIN0 Interrupt Control Register | LOIC | XXXX X000b | | 0000D6h | | | | | 0000D7h | | | | | | E <sup>2</sup> dataFlash Interrupt Control Register | E2FIC | XXXX X000b | | 0000D9h | | | | | 0000DAh | | | | | 0000DBh | | | | | 0000DCh | | | | | | UART3 Transmit Interrupt Control Register | S3TIC | XXXX X000b | | 0000DEh | • | | | | | UART4 Transmit Interrupt Control Register | S4TIC | XXXX X000b | | | l | = | | Table 4.5 SFR List (5) | Address | Register | Symbol | Reset Value | |-------------|----------------------------------------------|-------------|-------------| | 0000E0h | | | | | 0000E1h | CAN0 Receive Interrupt Control Register | C0RIC | XXXX X000b | | 0000E2h | | | | | 0000E3h | CAN1 Transmit Interrupt Control Register | C1TIC | XXXX X000b | | 0000E4h | | | | | 0000E5h | CAN1 Error Interrupt Control Register | C1EIC | XXXX X000b | | 0000E6h | | | | | 0000E7h | | | | | 0000E8h | | | | | 0000E9h | | | | | 0000EAh | | | | | 0000EBh | | | | | 0000ECh | | | | | 0000EDh | | | | | 0000EEh | | | | | 0000EFh | | | | | | CAN0 Receive FIFO Interrupt Control Register | C0FRIC | XXXX X000b | | 0000F1h | | | | | 0000F2h | CAN1 Receive FIFO Interrupt Control Register | C1FRIC | XXXX X000b | | 0000F3h | | | | | 0000F4h | | | | | 0000F5h | | | | | 0000F6h | | | | | 0000F7h | | | | | 0000F8h | | | | | 0000F9h | | | | | 0000FAh | | | | | 0000FBh | | | | | 0000FCh | | | | | | UART3 Receive Interrupt Control Register | S3RIC | XXXX X000b | | 0000FEh | | | | | | UART4 Receive Interrupt Control Register | S4RIC | XXXX X000b | | 000100h | | | | | 000101h | | | | | 000102h | | | | | 000103h | | | | | 000104h | | | | | 000105h | | | | | 000106h | | | | | 000107h | | | | | V: Undofina | | <del></del> | | Table 4.6 SFR List (6) | Address | Register | Symbol | Reset Value | |------------|---------------------------------------------------------|-------------|---------------| | 000108h to | 1 togistor | Cynnoon | 1 tooct value | | 00010011t0 | | | | | 000170h | | <u> </u> | | | 000171h | | | | | 000172h | | | | | 000173h | | | | | 000174h | | | | | 000175h | | | | | 000176h | | | | | 000177h | | | | | 000178h | | | | | 000179h | | | | | 00017Ah | | | | | 00017Bh | | | | | 00017Ch | | | | | 00017Dh | | | | | 00017Eh | | | | | 00017Fh | | | | | | Group 0 Time Measurement/Waveform Generation Register 0 | G0TM0/G0PO0 | XXXXh | | 000181h | | | | | | Group 0 Time Measurement/Waveform Generation Register 1 | G0TM1/G0PO1 | XXXXh | | 000183h | | | | | | Group 0 Time Measurement/Waveform Generation Register 2 | G0TM2/G0PO2 | XXXXh | | 000185h | | | | | | Group 0 Time Measurement/Waveform Generation Register 3 | G0TM3/G0PO3 | XXXXh | | 000187h | | | | | | Group 0 Time Measurement/Waveform Generation Register 4 | G0TM4/G0PO4 | XXXXh | | 000189h | | | | | | Group 0 Time Measurement/Waveform Generation Register 5 | G0TM5/G0PO5 | XXXXh | | 00018Bh | | | | | | Group 0 Time Measurement/Waveform Generation Register 6 | G0TM6/G0PO6 | XXXXh | | 00018Dh | | | | | | Group 0 Time Measurement/Waveform Generation Register 7 | G0TM7/G0PO7 | XXXXh | | 00018Fh | | 0000000 | 0000 1/000 | | | Group 0 Waveform Generation Control Register 0 | G0POCR0 | 0000 X000b | | | Group 0 Waveform Generation Control Register 1 | G0POCR1 | 0X00 X000b | | | Group 0 Waveform Generation Control Register 2 | G0POCR2 | 0X00 X000b | | | Group 0 Waveform Generation Control Register 3 | G0POCR3 | 0X00 X000b | | | Group 0 Waveform Generation Control Register 4 | G0POCR4 | 0X00 X000b | | | Group 0 Waveform Generation Control Register 5 | G0POCR5 | 0X00 X000b | | | Group 0 Waveform Generation Control Register 6 | G0POCR6 | 0X00 X000b | | | Group 0 Waveform Generation Control Register 7 | G0POCR7 | 0X00 X000b | | | Group 0 Time Measurement Control Register 0 | G0TMCR0 | 00h | | | Group 0 Time Measurement Control Register 1 | G0TMCR1 | 00h | | | Group 0 Time Measurement Control Register 2 | G0TMCR2 | 00h | | | Group 0 Time Measurement Control Register 3 | G0TMCR3 | 00h | | | Group 0 Time Measurement Control Register 4 | G0TMCR4 | 00h | | | Group 0 Time Measurement Control Register 5 | G0TMCR5 | 00h | | | Group 0 Time Measurement Control Register 6 | G0TMCR6 | 00h | | 00019Fh | Group 0 Time Measurement Control Register 7 | G0TMCR7 | 00h | Table 4.7 SFR List (7) | | Of R Elst (1) | | | |-------------|-----------------------------------------------|--------|-------------| | Address | Register | Symbol | Reset Value | | | Group 0 Base Timer Register | G0BT | XXXXh | | 0001A1h | | | | | | Group 0 Base Timer Control Register 0 | G0BCR0 | 0000 0000b | | | Group 0 Base Timer Control Register 1 | G0BCR1 | 0000 0000b | | | Group 0 Time Measurement Prescaler Register 6 | G0TPR6 | 00h | | 0001A5h | Group 0 Time Measurement Prescaler Register 7 | G0TPR7 | 00h | | 0001A6h | Group 0 Function Enable Register | G0FE | 00h | | | Group 0 Function Select Register | G0FS | 00h | | 0001A8h | | | | | 0001A9h | | | | | 0001AAh | | | | | 0001ABh | | | | | 0001ACh | | | | | 0001ADh | | | | | 0001AEh | | | | | 0001AFh | | | | | 0001B0h | | | | | 0001B1h | | | | | 0001B2h | | | | | 0001B3h | | | | | 0001B4h | | | | | 0001B5h | | | | | 0001B6h | | | | | 0001B7h | | | | | 0001B8h | | | | | 0001B9h | | | | | 0001BAh | | | | | 0001BBh | | | | | 0001BCh | | | | | 0001BDh | | | | | 0001BEh | | | | | 0001BFh | | | | | 0001C0h | | | | | 0001C1h | | | | | 0001C2h | | | | | 0001C3h | | | | | 0001C4h | | | | | 0001C5h | | | | | 0001C6h | | | | | 0001C7h | | | | | 0001C8h | | | | | 0001C9h | | | | | 0001CAh | | | | | 0001CRh | | | | | 0001CBh | | | | | 0001CCh | | | | | 0001CBh | | | | | 0001CEn | | | | | Y: Undefine | | | | Table 4.8 SFR List (8) | Address | Register | Symbol | Reset Value | |---------|--------------------------------------------------|--------|-------------| | 0001D0h | | , | | | 0001D1h | | | | | 0001D2h | | | | | 0001D3h | | | | | 0001D4h | | | | | 0001D5h | | | | | 0001D6h | | | | | 0001D7h | | | | | 0001D8h | | | | | 0001D9h | | | | | 0001DAh | | | | | 0001DBh | | | | | 0001DCh | | | | | 0001DDh | | | | | 0001DEh | | | | | 0001DFh | | | | | | UART3 Transmit/Receive Mode Register | U3MR | 00h | | | UART3 Bit Rate Register | U3BRG | XXh | | | UART3 Transmit Buffer Register | U3TB | XXXXh | | 0001E3h | | | | | | UART3 Transmit/Receive Control Register 0 | U3C0 | 00X0 1000b | | | UART3 Transmit/Receive Control Register 1 | U3C1 | XXXX 0010b | | | UART3 Receive Buffer Register | U3RB | XXXXh | | 0001E7h | | | | | | UART4 Transmit/Receive Mode Register | U4MR | 00h | | | UART4 Bit Rate Register | U4BRG | XXh | | | UART4 Transmit Buffer Register | U4TB | XXXXh | | 0001EBh | | | | | | UART4 Transmit/Receive Control Register 0 | U4C0 | 00X0 1000b | | | UART4 Transmit/Receive Control Register 1 | U4C1 | XXXX 0010b | | | UART4 Receive Buffer Register | U4RB | XXXXh | | 0001EFh | | | | | | UART3, UART4 Transmit/Receive Control Register 2 | U34CON | X000 0000b | | 0001F1h | | | | | 0001F2h | | | | | 0001F3h | | | | | 0001F4h | | | | | 0001F5h | | | | | 0001F6h | | | | | 0001F7h | | | | | 0001F8h | | | | | 0001F9h | | | | | 0001FAh | | | | | 0001FBh | | | | | 0001FCh | | | | | 0001FDh | | | | | 0001FEh | | | | | 0001FFh | | | | Table 4.9 SFR List (9) | Address | Register | Symbol | Reset Value | |-------------|----------------------------------------------------------|-----------|-------------| | | Group0 Phase Shift Waveform Output Mode Clock Division | G0SDR | 00h | | | Setting Register | | | | 000201h | Group0 Phase Shift Waveform Output Mode Control Register | G0PSCR | 00h | | 000202h | | | | | 000203h | | | | | 000204h | | | | | 000205h | | | | | 000206h | | | | | 000207h | | | | | | Timer B Event Clock Select Register | TBECKS | 0000 0000b | | 000209h | Ŭ | | | | 00020Ah | | | | | 00020Bh | | | | | 00020Ch | | | | | 00020Dh | | | | | 00020Eh | | | | | 00020Fh | | | | | | IIO0_7 Digital Debounce Register | IC07DDR | FFh | | 000211h | | | | | 000212h | | | | | 000213h | | | | | 000214h | | | | | 000211h | | | | | 000216h | | | | | 000217h | | | | | 000217h | | | | | 000219h | | | | | 00021Ah | | | | | 000217th | | | | | 00021Dh | | | | | 000210h | | | | | 00021Eh | | | | | 00021Eh | | | | | | Timer A1 Mirror Register | TA1M | XXXXh | | 000220h | | | 700001 | | | Timer A1-1 Mirror Register | TA11M | XXXXh | | 000222h | <u> </u> | ., | 700011 | | | Timer A2 Mirror Register | TA2M | XXXXh | | 000224h | | ., 12111 | 700011 | | | Timer A2-1 Mirror Register | TA21M | XXXXh | | 000220h | _ | ., 1111 | 700001 | | | Timer A4 Mirror Register | TA4M | XXXXh | | 000228h | | ואדרוו | | | | Timer A4-1 Mirror Register | TA41M | XXXXh | | 00022An | <del>-</del> | I/AT LIVI | | | 00022Bii | | | | | 00022Ch | | | | | 00022Dh | | | | | 00022En | | | | | X: Undefine | | | | Table 4.10 SFR List (10) | Address | Register | Symbol | Reset Value | |------------|-------------------------------------------|-------------|-------------| | 000230h to | | | | | 0002BFh | | | | | | X0 Register/Y0 Register | X0R/Y0R | XXXXh | | 0002C1h | N/4 P | 24470447 | 2000 | | | X1 Register/Y1 Register | X1R/Y1R | XXXXh | | 0002C3h | VA D. 1.4. 0/0 D. 1.4 | | 2000 | | | X2 Register/Y2 Register | X2R/Y2R | XXXXh | | 0002C5h | V0 D | ) (OD 0 (OD | 20004 | | | X3 Register/Y3 Register | X3R/Y3R | XXXXh | | 0002C7h | V4.B. : 1. 0/4.B. : 1 | V4D0/4D | 20004 | | | X4 Register/Y4 Register | X4R/Y4R | XXXXh | | 0002C9h | VED : ( AVED : ( | V5D (V5D | 20004 | | | X5 Register/Y5 Register | X5R/Y5R | XXXXh | | 0002CBh | V0 D : 1 0/0 D : 1 | V0D 0 0 D | 20004 | | | X6 Register/Y6 Register | X6R/Y6R | XXXXh | | 0002CDh | V7 Danietan/V7 Danietan | V7D 4/7D | VVVVI | | | X7 Register/Y7 Register | X7R/Y7R | XXXXh | | 0002CFh | VO Danieta (VO Danieta) | VODAVOD | VVVVI- | | | X8 Register/Y8 Register | X8R/Y8R | XXXXh | | 0002D1h | VO Danieta (VO Danieta) | VODAVOD | VVVVI- | | | X9 Register/Y9 Register | X9R/Y9R | XXXXh | | 0002D3h | V10 Desister W10 Desister | V40D0/40D | VVVVL | | | X10 Register/Y10 Register | X10R/Y10R | XXXXh | | 0002D5h | V44 Dominton/V44 Dominton | V44D0/44D | VVVVL | | | X11 Register/Y11 Register | X11R/Y11R | XXXXh | | 0002D7h | V10 Desister W10 Desister | V42DA/42D | VVVVL | | 0002D8h | X12 Register/Y12 Register | X12R/Y12R | XXXXh | | | X13 Register/Y13 Register | V12D/V12D | VVVVh | | 0002DAn | X13 Register/113 Register | X13R/Y13R | XXXXh | | | X14 Register/Y14 Register | X14R/Y14R | XXXXh | | 0002DCh | X14 Register/114 Register | X14R/114R | ^^^ | | | X15 Register/Y15 Register | X15R/Y15R | XXXXh | | 0002DEII | A 15 Register/1 15 Register | A 15R/T 15R | ^^^ | | | X-Y Control Register | XYC | XXXX XX00b | | 0002E0H | A-1 Control Register | XIC | ^^^ ^ | | 0002E1h | | | | | 0002E3h | | | | | | UART1 Special Mode Register 4 | U1SMR4 | 00h | | | UART1 Special Mode Register 3 | U1SMR3 | 00h | | | UART1 Special Mode Register 2 | U1SMR2 | 00h | | | UART1 Special Mode Register | U1SMR | 00h | | | UART1 Transmit/Receive Mode Register | U1MR | 00h | | | UART1 Bit Rate Register | U1BRG | XXh | | | UART1 Transmit Buffer Register | U1TB | XXXXh | | 0002EAn | C. I. C. F. Transmit Daner Register | 0110 | 700011 | | | UART1 Transmit/Receive Control Register 0 | U1C0 | 0000 1000b | | | UART1 Transmit/Receive Control Register 1 | U1C1 | 0000 1000b | | | UART1 Receive Buffer Register | U1RB | XXXXh | | | OF ILLE I LECCINE DUILE I LEGISIEI | טוויטן | MANAMI | **Table 4.11** SFR List (11) | Address | Register | Symbol | Reset Value | |---------|-------------------------------------------------------|--------|-------------| | 0002F0h | | | | | 0002F1h | | | | | 0002F2h | | | | | 0002F3h | | | | | 0002F4h | | | | | 0002F5h | | | | | 0002F6h | | | | | 0002F7h | | | | | 0002F8h | | | | | 0002F9h | | | | | 0002FAh | | | | | 0002FBh | | | | | 0002FCh | | | | | 0002FDh | | | | | 0002FEh | | | | | 0002FFh | | | | | | Count Start Register for Timers B3, B4, and B5 | TBSR | 000X XXXXb | | 000301h | , , | | | | | Timer A1-1 Register | TA11 | XXXXh | | 000303h | • | | | | 000304h | Timer A2-1 Register | TA21 | XXXXh | | 000305h | 3 | | | | | Timer A4-1 Register | TA41 | XXXXh | | 000307h | | | | | | Three-phase PWM Control Register 0 | INVC0 | 00h | | | Three-phase PWM Control Register 1 | INVC1 | 00h | | | Three-phase Output Buffer Register 0 | IDB0 | XX11 1111b | | | Three-phase Output Buffer Register 1 | IDB1 | XX11 1111b | | | Dead Time Timer | DTT | XXh | | | Timer B2 Interrupt Generating Frequency Set Counter | ICTB2 | XXh | | 00030Eh | Time: 22 interrupt contrating i requestly cot counter | 10.22 | 7011 | | 00030Fh | | | | | | Timer B3 Register | TB3 | XXXXh | | 000311h | Timor Bo Hogistor | 1.50 | 700001 | | | Timer B4 Register | TB4 | XXXXh | | 000313h | | | 700011 | | | Timer B5 Register | TB5 | XXXXh | | 000315h | Time: Bo regiote: | 150 | 700041 | | 000316h | | | | | 000310h | | | | | 000317H | | | | | 000310h | | | | | 000319H | | | | | | Timer B3 Mode Register | TB3MR | 00XX 0000b | | | Timer B4 Mode Register | TB4MR | 00XX 0000b | | | Timer B5 Mode Register | TB5MR | 00XX 0000b | | 00031Dh | Timer D2 Mode Vediatei | I DOWN | 00000 | | | | | | | 00031Fh | | | | X: Undefined **Table 4.12** SFR List (12) | Address | Register | Symbol | Reset Value | |-------------|-------------------------------------------|--------|-------------| | 000320h | _ | • | | | 000321h | | | | | 000322h | | | | | 000323h | | | | | 000324h | | | | | 000325h | | | | | 000326h | | | | | 000327h | | | | | 000328h | | | | | 000329h | | | | | 00032Ah | | | | | 00032Bh | | | | | 00032Ch | | | | | 00032Dh | | | | | 00032Eh | | | | | 00032Fh | | | | | 000330h | | | | | 000331h | | | | | 000332h | | | | | 000333h | | | | | 000334h | UART2 Special Mode Register 4 | U2SMR4 | 00h | | | UART2 Special Mode Register 3 | U2SMR3 | 00h | | | UART2 Special Mode Register 2 | U2SMR2 | 00h | | | UART2 Special Mode Register | U2SMR | 00h | | | UART2 Transmit/Receive Mode Register | U2MR | 00h | | | UART2 Bit Rate Register | U2BRG | XXh | | | UART2 Transmit Buffer Register | U2TB | XXXXh | | 00033Bh | | | | | | UART2 Transmit/Receive Control Register 0 | U2C0 | 0000 1000b | | | UART2 Transmit/Receive Control Register 1 | U2C1 | 0000 0010b | | | UART2 Receive Buffer Register | U2RB | XXXXh | | 00033Fh | | | | | | Count Start Register | TABSR | 0000 0000b | | | Clock Prescaler Reset Register | CPSRF | 0XXX XXXXb | | | One-shot Start Register | ONSF | 0000 0000b | | 000343h | Trigger Select Register | TRGSR | 0000 0000b | | | Increment/Decrement Select Register | UDF | 0000 0000b | | 000345h | | | | | | Timer A0 Register | TA0 | XXXXh | | 000347h | | | | | | Timer A1 Register | TA1 | XXXXh | | 000349h | | | | | | Timer A2 Register | TA2 | XXXXh | | 00034Bh | | | | | | Timer A3 Register | TA3 | XXXXh | | 00034Dh | | | | | | Timer A4 Register | TA4 | XXXXh | | 00034Fh | | | | | X. Undefine | <u> </u> | | | X: Undefined Table 4.13 SFR List (13) | Address | Register | Symbol | Reset Value | |---------------------|-------------------------------------------|--------|-------------| | | Timer B0 Register | TB0 | XXXXh | | 000351h | | | | | | Timer B1 Register | TB1 | XXXXh | | 000353h | | | | | | Timer B2 Register | TB2 | XXXXh | | 000355h | | | | | | Timer A0 Mode Register | TAOMR | 0000 0000b | | | Timer A1 Mode Register | TA1MR | 0000 0000b | | | Timer A2 Mode Register | TA2MR | 0000 0000b | | | Timer A3 Mode Register | TA3MR | 0000 0000b | | | Timer A4 Mode Register | TA4MR | 0000 0000b | | | Timer B0 Mode Register | TB0MR | 00XX 0000b | | | Timer B1 Mode Register | TB1MR | 00XX 0000b | | 00035Dh | Timer B2 Mode Register | TB2MR | 00XX 0000b | | | Timer B2 Special Mode Register | TB2SC | XXXX XXX0b | | | Count Source Prescaler Register | TCSPR | 0000 0000b | | 000360h | | | | | 000361h | | | | | 000362h | | | | | 000363h | | | | | | UART0 Special Mode Register 4 | U0SMR4 | 00h | | | UART0 Special Mode Register 3 | U0SMR3 | 00h | | | UART0 Special Mode Register 2 | U0SMR2 | 00h | | | UART0 Special Mode Register | U0SMR | 00h | | | UART0 Transmit/Receive Mode Register | U0MR | 00h | | | UARTO Bit Rate Register | U0BRG | XXh | | | UART0 Transmit Buffer Register | U0TB | XXXXh | | 00036Bh | _ | 0015 | 7000(1) | | | UART0 Transmit/Receive Control Register 0 | U0C0 | 0000 1000b | | | UART0 Transmit/Receive Control Register 1 | U0C1 | 0000 1000b | | | UART0 Receive Buffer Register | U0RB | XXXXh | | 00036Fh | _ | CONE | 7000(1) | | 000370h | | + | | | 000371h | | + | | | 000371h | | + | | | 000372h | | + | | | 000374h | | + | | | 00037411<br>000375h | | | | | 000373h | | | | | 000376H | | | | | 00037711<br>000378h | | | | | 000378H | | | | | 000379H | | | | | 00037An | | | | | | CRC Data Register | CRCD | XXXXh | | 00037Ch | | CKCD | ^^^ | | | CRC Input Register | CRCIN | XXh | | | , , | CRCIN | ٨٨١١ | | 00037Fh | | | | X: Undefined **Table 4.14** SFR List (14) | 14016 4.14 | 3FK LISt (14) | | | |-------------|-------------------------|---------|-------------| | Address | Register | Symbol | Reset Value | | 000380h | A/D0 Register 0 | AD00 | 00XXh | | 000381h | | | | | 000382h | A/D0 Register 1 | AD01 | 00XXh | | 000383h | | | | | 000384h | A/D0 Register 2 | AD02 | 00XXh | | 000385h | | | | | 000386h | A/D0 Register 3 | AD03 | 00XXh | | 000387h | | | | | 000388h | A/D0 Register 4 | AD04 | 00XXh | | 000389h | | | | | 00038Ah | A/D0 Register 5 | AD05 | 00XXh | | 00038Bh | | | | | 00038Ch | A/D0 Register 6 | AD06 | 00XXh | | 00038Dh | | | | | | A/D0 Register 7 | AD07 | 00XXh | | 00038Fh | | | | | 000390h | | | | | 000391h | | | | | 000392h | | | | | | A/D0 Control Register 5 | AD0CON5 | 00h | | | A/D0 Control Register 2 | AD0CON2 | X00X X000b | | | A/D0 Control Register 3 | AD0CON3 | XXXX X000b | | | A/D0 Control Register 0 | AD0CON0 | 00h | | | A/D0 Control Register 1 | AD0CON1 | 00h | | 000398h | | 7.2000 | | | 000399h | | | | | 00039Ah | | | | | 00039Bh | | | | | 00039Ch | | | | | 00039Dh | | | | | 00039Eh | | | | | 00039Fh | | | | | 0003A0h | | | | | 0003A1h | | | | | 0003A2h | | | | | 0003A3h | | | | | 0003A4h | | | | | 0003A5h | | | | | 0003A6h | | | | | 0003A0h | | | | | 0003A71 | | | | | 0003A9h | | | | | 0003A9h | | | | | 0003AAn | | | | | 0003ABh | | | | | 0003ACh | | | | | 0003ADh | | | | | 0003AEN | | | | | V. Undefine | | | | X: Undefined **Table 4.15** SFR List (15) | Address | Register | Symbol | Reset Value | |---------|----------------------------|--------|-------------| | 0003B0h | | | | | 0003B1h | | | | | 0003B2h | | | | | 0003B3h | | | | | 0003B4h | | | | | 0003B5h | | | | | 0003B6h | | | | | 0003B7h | | | | | 0003B8h | | | | | 0003B9h | | | | | 0003BAh | | | | | 0003BBh | | | | | 0003BCh | | | | | 0003BDh | | | | | 0003BEh | | | | | 0003BFh | | | | | | Port P0 Register | P0 | XXh | | | Port P1 Register | P1 | XXh | | | Port P0 Direction Register | PD0 | 0000 0000b | | | Port P1 Direction Register | PD1 | 0000 0000b | | | Port P2 Register | P2 | XXh | | | Port P3 Register | P3 | XXh | | | Port P2 Direction Register | PD2 | 0000 0000b | | | Port P3 Direction Register | PD3 | 0000 0000b | | | Port P4 Register | P4 | XXh | | | Port P5 Register | P5 | XXh | | | Port P4 Direction Register | PD4 | 0000 0000b | | | Port P5 Direction Register | PD5 | 0000 0000b | | | Port P6 Register | P6 | XXh | | | Port P7 Register | P7 | XXh | | | Port P6 Direction Register | PD6 | 0000 0000b | | | Port P7 Direction Register | PD7 | 0000 0000b | | | Port P8 Register | P8 | XXh | | | Port P9 Register | P9 | XXh | | | Port P8 Direction Register | PD8 | 00X0 0000b | | | Port P9 Direction Register | PD9 | 0000 0000b | | 0003D4h | | | | | 0003D5h | | | | | 0003D6h | | | | | 0003D7h | | | | | 0003D8h | | | | | 0003D9h | | | | | 0003DAh | | | | | 0003DBh | | | | | 0003DCh | | | | | 0003DDh | | | | | 0003DEh | | | | | 0003DFh | | | | **Table 4.16** SFR List (16) | Address | Register | Symbol | Reset Value | |---------|----------------------------|--------|-------------| | 0003E0h | | | | | 0003E1h | | | | | 0003E2h | | | | | 0003E3h | | | | | 0003E4h | | | | | 0003E5h | | | | | 0003E6h | | | | | 0003E7h | | | | | 0003E8h | | | | | 0003E9h | | | | | 0003EAh | | | | | 0003EBh | | | | | 0003ECh | | | | | 0003EDh | | | | | 0003EEh | | | | | 0003EFh | | | | | | Pull-up Control Register 0 | PUR0 | 0000 0000b | | | Pull-up Control Register 1 | PUR1 | XXXX 0000b | | | Pull-up Control Register 2 | PUR2 | 0000 0000b | | 0003F3h | | | | | 0003F4h | | | | | 0003F5h | | | | | 0003F6h | | | | | 0003F7h | | | | | 0003F8h | | | | | 0003F9h | | | | | 0003FAh | | | | | 0003FBh | | | | | 0003FCh | | | | | 0003FDh | | | | | 0003FEh | | | | | 0003FFh | Port Control Register | PCR | XXXX XXX0b | **Table 4.17** SFR List (17) | Address | Register | Symbol | Reset Value | |-----------------------------------------------------|---------------------------------------------|--------|----------------| | 040000h | Flash Memory Control Register 0 | FMR0 | 0X01 XX00b | | | Flash Memory Status Register 0 | FMSR0 | 1000 0000b | | 040002h | , | | | | 040003h | | | | | 040004h | | | | | 040005h | | | | | 040006h | | | | | 040007h | | | | | 040008h | Flash Register Protection Unlock Register 0 | FPR0 | 00h | | 040009h | Flash Memory Control Register 1 | FMR1 | 0000 0010b | | 04000Ah | Block Protect Bit Monitor Register 0 | FBPM0 | X?X? ????b (1) | | 04000Bh | Block Protect Bit Monitor Register 1 | FBPM1 | XXX? ?XXXb (1) | | 04000Ch | | | | | 04000Dh | | | | | 04000Eh | | | | | 04000Fh | | | | | 040010h | | | | | 040011h | | | | | 040012h | | | | | 040013h | | | | | 040014h | | | | | 040015h | | | | | 040016h | | | | | 040017h | | | | | 040018h | | | | | 040019h | | | | | 04001Ah | | | | | 04001Bh | | | | | 04001Ch | | | | | 04001Dh | | | | | 04001Eh | | | | | 04001Fh | | | | | 040020h | PLL Control Register 0 | PLC0 | 0000 0001b | | | PLL Control Register 1 | PLC1 | 0001 1111b | | 040022h | | | | | 040023h | | | | | 040024h | PLL Status Register | PLS | 1XXX XX00b | | 040025h | | | | | 040026h | | | | | 040027h | | | | | 040028h | | | | | 040029h | | | | | 04002Ah | | | | | 04002Bh | | | | | 04002Ch | | | | | 04002Dh | | | | | 04002Eh | | | | | 04002Fh | | | | | 04002Ah<br>04002Bh<br>04002Ch<br>04002Dh<br>04002Eh | | | | Blanks are reserved. No access is allowed. ## Note: 1. The reset value reflects the value of the protect bit for each block in the flash memory. Table 4.18 SFR List (18) | Address | Register | Symbol | Reset Value | |------------|------------------------------------------|--------|-------------| | 040030h to | | | | | 04003Fh | | | | | 040040h | | | | | 040041h | | | | | 040042h | | | | | 040043h | | | | | 040044h | Processor Mode Register 0 | PM0 | 1000 0000b | | 040045h | | | | | | System Clock Control Register 0 | CM0 | 0000 1000b | | | System Clock Control Register 1 | CM1 | 0010 0000b | | 040048h | Processor Mode Register 3 | PM3 | 00h | | 040049h | | | | | 04004Ah | Protect Register | PRCR | XXXX X000b | | 04004Bh | | | | | | Protect Register 3 | PRCR3 | 0000 0000b | | 04004Dh | Oscillator Stop Detection Register | CM2 | 00h | | 04004Eh | | | | | 04004Fh | | | | | 040050h | | | | | 040051h | | | | | 040052h | | | | | 040053h | Processor Mode Register 2 | PM2 | 00h | | 040054h | | | | | 040055h | | | | | 040056h | | | | | 040057h | | | | | 040058h | | | | | 040059h | | | | | 04005Ah | Low Speed Mode Clock Control Register | CM3 | XXXX XX00b | | 04005Bh | | | | | 04005Ch | | | | | 04005Dh | | | | | 04005Eh | | | | | 04005Fh | | | | | 040060h | Voltage Regulator Control Register | VRCR | 0000 0000b | | 040061h | | | | | 040062h | Low Voltage Detector Control Register | LVDC | 0000 XX00b | | 040063h | | | | | | Detection Voltage Configuration Register | DVCR | 0000 XXXXb | | 040065h | | | | | 040066h | | | | | 040067h | | | | | 040068h to | | | | | 040093h | | | | **Table 4.19** SFR List (19) | Address | Register | Symbol | Reset Value | |---------|--------------------------------------------|--------|-------------| | 040094h | | | | | 040095h | | | | | 040096h | | | | | | Three-phase Output Buffer Control Register | IOBC | 0XXX XX0Xb | | | Input Function Select Register 0 | IFS0 | X0X0 X000b | | | Input Function Select Register 1 | IFS1 | XXXX X0X0b | | 04009Ah | Input Function Select Register 2 | IFS2 | 0000 0000b | | 04009Bh | | | | | 04009Ch | | | | | | Input Function Select Register 5 | IFS5 | XXX0 X0X0b | | | Input Function Select Register 6 | IFS6 | XXXX 0000b | | 04009Fh | | | | | | Port P0_0 Function Select Register | P0_0S | 0XXX X000b | | | Port P1_0 Function Select Register | P1_0S | 0XXX X000b | | | Port P0_1 Function Select Register | P0_1S | 0XXX X000b | | | Port P1_1 Function Select Register | P1_1S | 0XXX X000b | | | Port P0_2 Function Select Register | P0_2S | 0XXX X000b | | 0400A5h | Port P1_2 Function Select Register | P1_2S | 0XXX X000b | | | Port P0_3 Function Select Register | P0_3S | 0XXX X000b | | 0400A7h | Port P1_3 Function Select Register | P1_3S | 0XXX X000b | | 0400A8h | Port P0_4 Function Select Register | P0_4S | 0XXX X000b | | 0400A9h | Port P1_4 Function Select Register | P1_4S | 0XXX X000b | | | Port P0_5 Function Select Register | P0_5S | 0XXX X000b | | 0400ABh | Port P1_5 Function Select Register | P1_5S | XXXX X000b | | 0400ACh | Port P0_6 Function Select Register | P0_6S | 0XXX X000b | | 0400ADh | Port P1_6 Function Select Register | P1_6S | XXXX X000b | | 0400AEh | Port P0_7 Function Select Register | P0_7S | 0XXX X000b | | 0400AFh | Port P1_7 Function Select Register | P1_7S | XXXX X000b | | 0400B0h | Port P2_0 Function Select Register | P2_0S | 0XXX X000b | | 0400B1h | Port P3_0 Function Select Register | P3_0S | XXXX X000b | | 0400B2h | Port P2_1 Function Select Register | P2 1S | 0XXX X000b | | | Port P3_1 Function Select Register | P3_1S | XXXX X000b | | | Port P2_2 Function Select Register | P2 2S | 0XXX X000b | | | Port P3_2 Function Select Register | P3 2S | XXXX X000b | | | Port P2_3 Function Select Register | P2_3S | 0XXX X000b | | | Port P3_3 Function Select Register | P3_3S | XXXX X000b | | | Port P2_4 Function Select Register | P2_4S | 0XXX X000b | | | Port P3_4 Function Select Register | P3_4S | XXXX X000b | | | Port P2_5 Function Select Register | P2_5S | 0XXX X000b | | | Port P3_5 Function Select Register | P3_5S | XXXX X000b | | | Port P2_6 Function Select Register | P2_6S | 0XXX X000b | | | Port P3_6 Function Select Register | P3_6S | XXXX X000b | | | Port P2_7 Function Select Register | P2_7S | 0XXX X000b | | | Port P3 7 Function Select Register | P3_7S | XXXX X000b | **Table 4.20** SFR List (20) | Table 4.20 Of It List (20) | | | |--------------------------------------------|--------|----------------------------------------| | Address Register | Symbol | Reset Value | | 0400C0h Port P4_0 Function Select Register | P4_0S | XXXX X000b | | 0400C1h Port P5_0 Function Select Register | P5_0S | XXXX X000b | | 0400C2h Port P4_1 Function Select Register | P4_1S | XXXX X000b | | 0400C3h Port P5_1 Function Select Register | P5_1S | XXXX X000b | | 0400C4h Port P4_2 Function Select Register | P4_2S | XXXX X000b | | 0400C5h Port P5_2 Function Select Register | P5_2S | XXXX X000b | | 0400C6h Port P4_3 Function Select Register | P4_3S | XXXX X000b | | 0400C7h Port P5_3 Function Select Register | P5_3S | XXXX X000b | | 0400C8h Port P4_4 Function Select Register | P4_4S | XXXX X000b | | 0400C9h Port P5_4 Function Select Register | P5_4S | XXXX X000b | | 0400CAh Port P4_5 Function Select Register | P4_5S | XXXX X000b | | 0400CBh Port P5_5 Function Select Register | P5_5S | XXXX X000b | | 0400CCh Port P4_6 Function Select Register | P4_6S | XXXX X000b | | 0400CDh Port P5_6 Function Select Register | P5_6S | XXXX X000b | | 0400CEh Port P4_7 Function Select Register | P4 7S | XXXX X000b | | 0400CFh Port P5_7 Function Select Register | P5 7S | XXXX X000b | | 0400D0h | _ | | | 0400D1h Port P7_0 Function Select Register | P7_0S | XXXX X000b | | 0400D2h | | | | 0400D3h | | | | 0400D4h | | | | 0400D5h | | | | 0400D6h | | | | 0400D7h | | | | 0400D8h | | | | 0400D9h Port P7_4 Function Select Register | P7_4S | XXXX X000b | | 0400DAh Port P6_5 Function Select Register | P6_5S | XXXX X000b | | 0400DBh Port P7_5 Function Select Register | P7_5S | XXXX X000b | | 0400DCh | 17_00 | 7000070000 | | 0400DDh Port P7_6 Function Select Register | P7_6S | XXXX X000b | | 0400DEh Port P6_7 Function Select Register | P6 7S | XXXX X000b | | 0400DFh | 1 0_70 | 7000070000 | | 0400E0h | | | | 0400E1h | | | | 0400E2h | | | | 0400E3h | | | | 0400E3h Port P8_2 Function Select Register | P8_2S | XXXX X000b | | 0400E5h | F0_23 | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | 0400E6h Port P8_3 Function Select Register | D0 20 | XXXX X000b | | 0400E7h Port P9_3 Function Select Register | P8_3S | 0XXX X000b | | 0400E8h Port P8_4 Function Select Register | P9_3S | XXXX X000b | | | P8_4S | | | 0400E9h Port P9_4 Function Select Register | P9_4S | 0XXX X000b | | 0400ERh Port PO 5 Europian Sologt Register | D0 50 | DVVV VOOR | | 0400EBh Port P9_5 Function Select Register | P9_5S | 0XXX X000b | | 0400ECh Port P8_6 Function Select Register | P8_6S | XXXX X000b | | 0400EDh Port P9_6 Function Select Register | P9_6S | 0XXX X000b | | 0400EEh Port P8_7 Function Select Register | P8_7S | XXXX X000b | | 0400EFh Port P9_7 Function Select Register | P9_7S | XXXX X000b | **Table 4.21** SFR List (21) | Address | Register | Symbol | Reset Value | |------------|---------------------------------------|--------|-------------| | 0400F0h to | | | | | 04403Fh | | | | | 044040h | | | | | 044041h | | | | | 044042h | | | | | 044043h | | | | | 044044h | | | | | 044045h | | | | | 044046h | | | | | 044047h | | | | | 044048h | | | | | 044049h | | | | | 04404Ah | | | | | 04404Bh | | | | | 04404Ch | Protect Register 4 | PRCR4 | 0000 0000b | | | Watchdog Timer Clock Control Register | WDK | 0000 0000b | | 04404Eh | Watchdog Timer Start Register | WDTS | XXXX XXXXb | | 04404Fh | Watchdog Timer Control Register | WDC | 000X XXXXb | | 044050h | | | | | 044051h | | | | | 044052h | | | | | 044053h | | | | | 044054h | | | | | 044055h | | | | | 044056h | | | | | 044057h | | | | | 044058h | | | | | 044059h | | | | | 04405Ah | | | | | 04405Bh | | | | | 04405Ch | | | | | 04405Dh | | | | | | | | <b>+</b> | | 04405Eh | | | | **Table 4.22** SFR List (22) | Address | Register | Symbol | Reset Value | |------------|-----------------------------------------------------|-------------|-------------| | 044060h | - | | | | 044061h | | | | | 044062h | | | | | 044063h | | | | | 044064h | | | | | 044065h | | | | | 044066h | | | | | 044067h | | | | | 044068h | | | | | 044069h | | | | | 04406Ah | | | | | 04406Bh | | | | | 04406Ch | | | | | 04406Dh | | | | | 04406Eh | | | | | 04406Fh | External Interrupt Request Source Select Register 0 | IFSR0 | 0000 0000b | | 044070h | DMA0 Request Source Select Register 2 | DM0SL2 | XX00 0000b | | | DMA1 Request Source Select Register 2 | DM1SL2 | XX00 0000b | | 044072h | DMA2 Request Source Select Register 2 | DM2SL2 | XX00 0000b | | 044073h | DMA3 Request Source Select Register 2 | DM3SL2 | XX00 0000b | | 044074h | | | | | 044075h | | | | | 044076h | | | | | 044077h | | | | | 044078h | DMA0 Request Source Select Register | DM0SL | XXX0 0000b | | 044079h | DMA1 Request Source Select Register | DM1SL | XXX0 0000b | | 04407Ah | DMA2 Request Source Select Register | DM2SL | XXX0 0000b | | 04407Bh | DMA3 Request Source Select Register | DM3SL | XXX0 0000b | | 04407Ch | - | | | | 04407Dh | Wake-up IPL Setting Register 2 | RIPL2 | XX0X 0000b | | 04407Eh | | | | | 04407Fh | Wake-up IPL Setting Register 1 | RIPL1 | XX0X 0000b | | 044080h | External Interrupt Input Filter Select Register 0 | INTF0 | 0000 0000b | | 044081h | | | | | 044082h | External Interrupt Input Filter Select Register 1 | INTF1 | 0000 0000b | | 044083h | | | | | 044084h | | | | | 044085h | | | | | 044086h | | | | | 044087h | | | | | 044088h | | | | | 044089h | | | | | 04408Ah | | | | | 04408Bh | | | | | 04408Ch | | | | | 04408Dh | | | | | 04408Eh | | | | | 04408Fh | | | | | V. Hadafia | | <del></del> | | **Table 4.23** SFR List (23) | 044DFFh 044E0Dh LIN Channel Window Select/Input Signal Low Detection Status LCW 0000 0000b 044E01h LIN Baud Rate Generator Control Register LBRG 0000 0000b 044E02h LIN Baud Rate Prescaler 0 LBRP0 00h 044E03h LIN Baud Rate Prescaler 1 LBRP1 00h 044E04h LIN Mode Register 0 LMD0 0000 0000b 044E05h LIN Wake-up Setting Register LWUP 00h 044E06h LIN Wake-up Setting Register LBRK 0000 0000b 044E07h LIN Break Field Setting Register LBRK 0000 0000b 044E08h LIN Break Field Setting Register LBRK 0000 0000b 044E08h LIN Response Field Setting Register LBFC 0000 0000b 044E08h LIN ID Buffer Register LIDB 00h 044E08h LIN ID Buffer Register LBC 0000 0000b 044E08h LIN IIN Status Control Register LTC 0000 0000b 044E08h LIN Status Control Register LSC 0000 0000b 044E09h LIN Data 1 | Address | Register | Symbol | Reset Value | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------|--------|-----------------------------------------| | Lin Channel Window Select/Input Signal Low Detection Status Register LBRG 0000 0000b | 044090h to | | | | | Register | | | | | | 044E01h LIN Baud Rate Generator Control Register LBRG 0000 0000b 044E02h LIN Baud Rate Prescaler 0 LBRP0 00h 044E03h LIN Baud Rate Prescaler 1 LBRP1 00h 04E04h LIN Mode Register 0 LMD0 0000 0000b 044E05h LIN Mode Register 1 LMD1 00h 04E06h LIN Wake-up Setting Register LWUP 00h 04E08h LIN Break Field Setting Register LBRK 0000 0000b 04E09h LIN Space Setting Register LSPC 0000 0000b 044E08h LIN Response Field Setting Register LRFC 0000 0000b 044E08h LIN Status Control Register LSC 0000 0000b 044E0Bh LIN Status Control Register LSC 0000 0000b 044E0Bh LIN Status Register LTC 0000 0000b 044E0Bh LIN Status Register LST 0000 0000b 044E0Bh LIN Data 1 Buffer Register LST 0000 0000b 044E0Bh LIN Data 2 Buffer Register LDB1 00h | 044E00h | | LCW | 0000 0000b | | 044E02h LIN Baud Rate Prescaler 0 LBRP0 00h 044E03h LIN Baud Rate Prescaler 1 LBRP1 00h 044E04h LIN Mode Register 0 LMD0 0000 0000b 044E05h LIN Wake-up Setting Register LWUP 00h 044E06h LIN Wake-up Setting Register LWUP 00h 044E07h LIN Space Setting Register LBRK 0000 0000b 044E08h LIN Space Setting Register LSPC 0000 0000b 044E09h LIN Space Setting Register LRFC 0000 0000b 044E08h LIN ID Buffer Register LSC 0000 0000b 044E0Bh LIN Status Control Register LSC 0000 0000b 044E0Dh LIN Status Register LTC 0000 0000b 044E0Dh LIN Status Register LST 0000 0000b 044E0Dh LIN Status Register LST 0000 0000b 044E0Dh LIN Data 1 Buffer Register LBST 0000 0000b 044E0Dh LIN Data 2 Buffer Register LDB1 00h 044E10h | | | | | | 044E03h LIN Baud Rate Prescaler 1 LBRP1 00h 044E04h LIN Mode Register 0 LMD0 0000 0000b 044E05h LIN Mode Register 1 LMD1 00h 044E06h LIN Wake-up Setting Register LWUP 00h 044E08h LIN Break Field Setting Register LBRK 0000 0000b 044E09h LIN Space Setting Register LSPC 0000 0000b 044E09h LIN Response Field Setting Register LRFC 0000 0000b 044E09h LIN ID Buffer Register LIDB 00h 044E09h LIN Status Control Register LSC 0000 0000b 044E09h LIN Transmission Control Register LTC 0000 0000b 044E09h LIN Status Register LST 0000 0000b 044E09h LIN Error Status Register LST 0000 0000b 044E09h LIN Data 1 Buffer Register LDB1 00h 044E10h LIN Data 2 Buffer Register LDB2 00h 044E11h LIN Data 3 Buffer Register LDB3 00h 044E12h | | | | | | 044E04h LIN Mode Register 0 LMD0 0000 0000b 044E05h LIN Mode Register 1 LMD1 00h 044E06h LIN Wake-up Setting Register LWUP 00h 044E07h LIN Break Field Setting Register LBRK 0000 0000b 044E09h LIN Space Setting Register LSPC 0000 0000b 044E09h LIN Response Field Setting Register LRFC 0000 0000b 044E08h LIN Status Control Register LIDB 00h 044E08h LIN Status Control Register LSC 0000 0000b 044E0Bh LIN Transmission Control Register LSC 0000 0000b 044E0Bh LIN Status Register LST 0000 0000b 044E0Bh LIN Error Status Register LST 0000 0000b 044E0Bh LIN Data 1 Buffer Register LDB1 00h 044E0Bh LIN Data 2 Buffer Register LDB2 00h 044E1Dh LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 6 Buffer Register LDB6 00h 04 | | | _ | • • • • • • • • • • • • • • • • • • • • | | 044E05h LIN Mode Register 1 LMD1 00h 044E07h LIN Wake-up Setting Register LWUP 00h 044E07h Wake-up Setting Register LBRK 0000 0000b 044E08h LIN Break Field Setting Register LBRK 0000 0000b 044E09h LIN Space Setting Register LSPC 0000 0000b 044E08h LIN ID Buffer Register LIDB 00h 044E08h LIN Status Control Register LSC 0000 0000b 044E0Ch LIN Status Control Register LSC 0000 0000b 044E0Dh LIN Status Register LST 0000 0000b 044E0Dh LIN Status Register LEST 0000 0000b 044E0Ph LIN Error Status Register LEST 0000 0000b 044E0Ph LIN Data 1 Buffer Register LDB1 00h 044E10h LIN Data 2 Buffer Register LDB2 00h 044E11h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 6 Buffer Register LDB6 00h 044E15h <t< td=""><td></td><td></td><td></td><td></td></t<> | | | | | | 044E06h LIN Wake-up Setting Register LWUP 00h 044E07h 044E08h LIN Break Field Setting Register LBRK 0000 0000b 044E08h LIN Space Setting Register LSPC 0000 0000b 044E08h LIN Space Setting Register LSPC 0000 0000b 044E08h LIN ID Buffer Register LIDB 00h 044E08h LIN ID Buffer Register LIDB 00h 044E08h LIN Status Control Register LSC 0000 0000b 044E08h LIN Transmission Control Register LST 0000 0000b 044E08h LIN Status Register LST 0000 0000b 044E08h LIN Status Register LEST 0000 0000b 044E09h LIN Data 1 Buffer Register LDB1 00h 044E10h LIN Data 2 Buffer Register LDB2 00h 044E11h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 6 Buffer Register LDB5 00h 044E15h LIN Data 7 Buffer Register LDB6 00h | | | _ | | | 044E07h LIN Break Field Setting Register LBRK 0000 0000b 044E09h LIN Space Setting Register LSPC 0000 0000b 044E0Ah LIN Response Field Setting Register LRFC 0000 0000b 044E0Bh LIN ID Buffer Register LIDB 00h 044E0Ch LIN Status Control Register LSC 0000 0000b 044E0Ch LIN Transmission Control Register LTC 0000 0000b 044E0Eh LIN Status Register LST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E11h LIN Data 2 Buffer Register LDB2 00h 044E11h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 5 Buffer Register LDB4 00h 044E14h LIN Data 6 Buffer Register LDB6 00h 044E15h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E18h 044E18h 044E18h 044E1Dh | | | | | | 044E08h LIN Break Field Setting Register LBRK 0000 0000b 044E09h LIN Space Setting Register LSPC 0000 0000b 044E0Ah LIN Response Field Setting Register LRFC 0000 0000b 044E0Bh LIN ID Buffer Register LIDB 00h 044E0Ch LIN Status Control Register LSC 0000 0000b 044E0Dh LIN Transmission Control Register LTC 0000 0000b 044E0Eh LIN Status Register LST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E10h LIN Data 2 Buffer Register LDB2 00h 044E11h LIN Data 3 Buffer Register LDB3 00h 044E12h LIN Data 4 Buffer Register LDB4 00h 044E13h LIN Data 5 Buffer Register LDB5 00h 044E16h LIN Data 6 Buffer Register LDB7 00h 044E19h 044E18h 00h 00h 044E1Bh | | | LWUP | 00h | | 044E09h LIN Space Setting Register LSPC 0000 0000b 044E0Ah LIN Response Field Setting Register LRFC 0000 0000b 044E0Bh LIN ID Buffer Register LIDB 00h 044E0Ch LIN Status Control Register LSC 0000 0000b 044E0Dh LIN Transmission Control Register LTC 0000 0000b 044E0Eh LIN Status Register LST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E10h LIN Data 2 Buffer Register LDB2 00h 044E11h LIN Data 3 Buffer Register LDB3 00h 044E12h LIN Data 4 Buffer Register LDB4 00h 044E13h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E18h 00h 044E18h 044E1Bh 044E1 | | | | | | 044E0Ah LIN Response Field Setting Register LRFC 0000 0000b 044E0Bh LIN ID Buffer Register LIDB 00h 044E0Ch LIN Status Control Register LSC 0000 0000b 044E0Dh LIN Transmission Control Register LTC 0000 0000b 044E0Eh LIN Status Register LST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E10h LIN Data 2 Buffer Register LDB2 00h 044E11h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E13h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E18h 00h 00h 00h 00h 044E18h 00h 00h 00h 00h 00h 044E19 | | | | | | 044E0Bh LIN ID Buffer Register LIDB 00h 044E0Ch LIN Status Control Register LSC 0000 0000b 044E0Dh LIN Transmission Control Register LTC 0000 0000b 044E0Eh LIN Status Register LST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E11h LIN Data 2 Buffer Register LDB2 00h 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 8 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 04E19h 04E19h 04E19h 044E19h 04E1h 04E1h 04E1h 044E10h 04E1h 04E1h <td< td=""><td></td><td></td><td></td><td></td></td<> | | | | | | 044E0Ch LIN Status Control Register LSC 0000 0000b 044E0Dh LIN Transmission Control Register LTC 0000 0000b 044E0Eh LIN Status Register LST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E11h LIN Data 2 Buffer Register LDB2 00h 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB7 00h 044E16h LIN Data 8 Buffer Register LDB8 00h 044E18h 004E19h 004E19h 004E19h 044E18h 004E19h 004E19h 004E19h 044E10h 004E10h 004E10h 004E10h 004E10h | | | _ | | | 044E0Dh LIN Transmission Control Register LTC 0000 0000b 044E0Eh LIN Status Register LST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E11h LIN Data 2 Buffer Register LDB2 00h 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 004E18h 00h 00h 044E18h 004E18h 00h 00h 044E1Bh 004E1Bh 00h 00h 044E1Dh 004E1Bh 00h 00h 00h 00h 00h 00h 00h 00h 00h | | | | | | 044E0Eh LIN Status Register LEST 0000 0000b 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E11h LIN Data 2 Buffer Register LDB2 00h 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 8 Buffer Register LDB7 00h 044E18h 00h 00h 00h 044E19h 004E18h 00h 00h 044E10h 00h 00h 00h | | | | 0000 0000b | | 044E0Fh LIN Error Status Register LEST 0000 0000b 044E10h LIN Data 1 Buffer Register LDB1 00h 044E11h LIN Data 2 Buffer Register LDB2 00h 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E18h 044E18h 044E18h 044E10h 044E10h 044E10h 044E10h 044E1Dh 044E1Eh 044E1Bh 044E1Bh | | | | 0000 0000b | | 044E10h LIN Data 1 Buffer Register LDB1 00h 044E11h LIN Data 2 Buffer Register LDB2 00h 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 004E19h 004E1Ah 004E1Ah 044E1Bh 004E1Ch 004E1Ch 004E1Ch 044E1Dh 004E1Ch 004E1Ch 004E1Ch | | | | | | 044E11h LIN Data 2 Buffer Register LDB2 00h 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E19h 044E1Ah 044E1Ah 044E1Bh 044E1Ch 044E1Dh 044E1Dh 044E1Dh 044E1Bh 044E1Bh 044E1Bh | 044E0Fh | LIN Error Status Register | LEST | 0000 0000b | | 044E12h LIN Data 3 Buffer Register LDB3 00h 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E19h 044E1Ah 044E1Ah 044E1Ch 044E1Dh 044E1Dh 044E1Bh 044E1Bh 044E1Bh | | | LDB1 | 00h | | 044E13h LIN Data 4 Buffer Register LDB4 00h 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E19h 044E1Ah 044E1Ah 044E1Bh 044E1Ch 044E1Dh 044E1Dh 044E1Eh 044E1Bh 044E1Bh 044E1Bh | 044E11h | LIN Data 2 Buffer Register | LDB2 | 00h | | 044E14h LIN Data 5 Buffer Register LDB5 00h 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E19h 044E1Ah 044E1Ah 044E1Bh 044E1Ch 044E1Dh 044E1Dh 044E1Bh 044E1Bh 044E1Bh 044E1Bh | 044E12h | LIN Data 3 Buffer Register | LDB3 | 00h | | 044E15h LIN Data 6 Buffer Register LDB6 00h 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E19h 044E19h 044E1Bh 044E1Bh 044E1Ch 044E1Dh 044E1Dh 044E1Eh 044E1Eh | 044E13h | LIN Data 4 Buffer Register | LDB4 | 00h | | 044E16h LIN Data 7 Buffer Register LDB7 00h 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E19h 00h 00h 044E1Ah 044E1Bh 00h 00h 00h 044E1Ch 00h 00h 00h 00h 00h 044E1Dh 044E1Dh 00h | 044E14h | LIN Data 5 Buffer Register | LDB5 | 00h | | 044E17h LIN Data 8 Buffer Register LDB8 00h 044E18h 044E19h 044E14h 044E1Ah 044E1Bh 044E1Ch 044E1Dh 044E1Dh 044E1Eh | 044E15h | LIN Data 6 Buffer Register | LDB6 | 00h | | 044E18h 044E19h 044E1Ah 044E1Bh 044E1Ch 044E1Dh 044E1Bh 044E1Dh | 044E16h | LIN Data 7 Buffer Register | LDB7 | 00h | | 044E19h 044E1Ah 044E1Bh 044E1Ch 044E1Dh 044E1Dh | 044E17h | LIN Data 8 Buffer Register | LDB8 | 00h | | 044E1Ah 044E1Bh 044E1Ch 044E1Dh 044E1Dh | 044E18h | | | | | 044E1Bh 044E1Ch 044E1Dh 044E1Eh | 044E19h | | | | | 044E1Ch<br>044E1Dh<br>044E1Eh | 044E1Ah | | | | | 044E1Dh<br>044E1Eh | 044E1Bh | | | | | 044E1Eh | 044E1Ch | | | | | | 044E1Dh | | | | | 044E1Fh | 044E1Eh | | | | | | 044E1Fh | | | | X: Undefined **Table 4.24** SFR List (24) | Address | Register | Symbol | Reset Value | |-------------|--------------------------------|------------|-------------| | 044E20h to | | | | | 044EFFh | | | | | 044F00h | | | | | 044F01h | | | | | 044F02h | | | | | 044F03h | | | | | 044F04h | | | | | 044F05h | | | | | | SS0 Receive Data Register | SS0RDR | FFh | | | SS0 Receive Data Register (H) | SS0RDR (H) | FFh | | | SS0 Control Register H | SS0CRH | 00h | | | SS0 Control Register L | SS0CRL | 0111 1101b | | | SS0 Mode Register | SS0MR | 0001 0000b | | | SS0 Enable Register | SS0ER | 00h | | | SS0 Status Register | SS0SR | 00h | | | SS0 Mode Register 2 | SS0MR2 | 00h | | 044F0Eh | SS0 Transmit Data Register | SS0TDR | FFh | | 044F0Fh | SS0 Transmit Data Register (H) | SS0TDR (H) | FFh | | 044F10h | | | | | 044F11h | | | | | 044F12h | | | | | 044F13h | | | | | 044F14h | | | | | 044F15h | | | | | 044F16h | | | | | 044F17h | | | | | 044F18h | | | | | 044F19h | | | | | 044F1Ah | | | | | 044F1Bh | | | | | 044F1Ch | | | | | 044F1Dh | | | | | 044F1Eh | | | | | 044F1Fh | | | | | 044F20h | | | | | 044F21h | | | | | 044F22h | | | | | 044F23h | | | | | 044F24h | | | | | 044F25h | | | | | 044F26h | | | | | 044F27h | | | | | V: Undofino | | | | **Table 4.25** SFR List (25) | Address | Register | Symbol | Reset Value | |--------------------|-----------------------------------------------|--------|-------------| | 044F28h to | | | | | 044FDFh | | | | | 044FE0h | E <sup>2</sup> dataFlash Address Register | E2FA | XXXX 0000h | | 044FE1h | | | | | 044FE2h | | | | | 044FE3h | | | | | 044FE4h | | | | | 044FE5h | | | | | 044FE6h | | | | | 044FE7h | | | | | 044FE8h | E <sup>2</sup> dataFlash Instruction Register | E2FI | XX00h | | 044FE9h | | | | | 044FEAh | | | | | 044FEBh | | | | | | E <sup>2</sup> dataFlash Data Register | E2FD | XXXXh | | 044FEDh | | | | | 044FEEh | | | | | 044FEFh | | | | | | E <sup>2</sup> dataFlash Mode Register | E2FM | 0000 0000b | | 044FF1h | | | | | | E <sup>2</sup> dataFlash Control Register | E2FC | XXXX XXX0b | | 044FF3h | | | 700007000 | | | E <sup>2</sup> dataFlash Status Register 1 | E2FS1 | XXXX XXX0b | | 044FF5h | | LZI OI | 70000 70000 | | 044FF6h | | | | | 044FF7h | | | | | 044FF8h | | | | | 044FF9h | | | | | 044FFAh | | | | | 044FFBh | | | | | 044FFCh | | | | | | | | | | 044FFDh<br>044FFEh | | | | | 044FFEn<br>044FFFh | | | | | 044FFFn<br>045000h | | | | | | | E2FS0 | VVVV VVVVh | | | E <sup>2</sup> dataFlash Status Register 0 | E2F5U | XXXX XXXXb | | 045002h | | | | | 045003h | | | | | 045004h | | | | | 045005h | | | | | 045006h | | | | | 045007h | | | | | 045008h to | | | | | 045FFFh | | | | | 046000h to | | | | | 0467FFh | | | | **Table 4.26** SFR List (26) | Address | Register | Symbol | Reset Value | |-------------|------------------------------------|----------|-------------| | 046800h to | | | | | 0477FFh | | | | | 047800h C | CAN1 Mailbox 0: Message Identifier | C1MB0 | XXXX XXXXh | | 047801h | | | | | 047802h | | | | | 047803h | | | | | 047804h | | | | | 047805h C | CAN1 Mailbox 0: Data Length | | XXh | | 047806h C | CAN1 Mailbox 0: Data Field | | XXXX XXXX | | 047807h | | | XXXX XXXXh | | 047808h | | | | | 047809h | | | | | 04780Ah | | | | | 04780Bh | | | | | 04780Ch | | | | | 04780Dh | | | | | | AN1 Mailbox 0: Time Stamp | | XXXXh | | 04780Fh | P | | | | | CAN1 Mailbox 1: Message Identifier | C1MB1 | XXXX XXXXh | | 047811h | g | | | | 047812h | | | | | 047813h | | | | | 047814h | | | | | | AN1 Mailbox 1: Data Length | | XXh | | | CAN1 Mailbox 1: Data Field | | XXXX XXXX | | 047817h | With Maileox 1. Bata Flora | | XXXX XXXXh | | 047818h | | | | | 047819h | | | | | 04781Ah | | | | | 04781Bh | | | | | 04781Ch | | | | | 04781Dh | | | | | | CAN1 Mailbox 1: Time Stamp | | XXXXh | | 04781Fh | with Mailbox 1. Time Stamp | | 700011 | | | CAN1 Mailbox 2: Message Identifier | C1MB2 | XXXX XXXXh | | 047821h | | C IIVIDZ | 700000000 | | 047821h | | | | | 047823h | | | | | 047824h | | | | | | CAN1 Mailbox 2: Data Length | | XXh | | | CAN1 Mailbox 2: Data Field | | XXXX XXXX | | 047827h | , it i mailbox 2. Data i fold | | XXXX XXXXh | | 047828h | | | 70000000 | | 047829h | | | | | 047829h | | | | | 04782An | | | | | 04782Ch | | | | | 04782Dh | | | | | | CAN1 Mailbox 2: Time Stamp | | XXXXh | | 04782En C | ANT MAIDUX 2. TITLE STATTP | | ^^^ | | · Undefined | | | | **Table 4.27** SFR List (27) | | OTT LIST (ET) | | | |-------------|------------------------------------|----------|-------------------------| | Address | Register | Symbol | Reset Value | | | CAN1 Mailbox 3: Message Identifier | C1MB3 | XXXX XXXXh | | 047831h | | | | | 047832h | | | | | 047833h | | | | | 047834h | | | | | 047835h | CAN1 Mailbox 3: Data Length | | XXh | | 047836h | CAN1 Mailbox 3: Data Field | | XXXX XXXX | | 047837h | | | XXXX XXXXh | | 047838h | | | | | 047839h | | | | | 04783Ah | | | | | 04783Bh | | | | | 04783Ch | | | | | 04783Dh | | | | | | CAN1 Mailbox 3: Time Stamp | | XXXXh | | 04783Fh | <u> </u> | | 700001 | | | CAN1 Mailbox 4: Message Identifier | C1MB4 | XXXX XXXXh | | 047841h | | C IIVID4 | | | 047841h | | | | | 047842h | | | | | | | | | | 047844h | | | XXh | | | CAN1 Mailbox 4: Data Length | | | | | CAN1 Mailbox 4: Data Field | | XXXX XXXX<br>XXXX XXXXh | | 047847h | | | XXXX XXXXII | | 047848h | | | | | 047849h | | | | | 04784Ah | | | | | 04784Bh | | | | | 04784Ch | | | | | 04784Dh | | | | | | CAN1 Mailbox 4: Time Stamp | | XXXXh | | 04784Fh | | | | | | CAN1 Mailbox 5: Message Identifier | C1MB5 | XXXX XXXXh | | 047851h | | | | | 047852h | | | | | 047853h | | | | | 047854h | | | | | 047855h | CAN1 Mailbox 5: Data Length | | XXh | | 047856h | CAN1 Mailbox 5: Data Field | | XXXX XXXX | | 047857h | 1 | | XXXX XXXXh | | 047858h | 1 | | | | 047859h | | | | | 04785Ah | | | | | 04785Bh | | | | | 04785Ch | | | | | 04785Dh | | | | | | CAN1 Mailbox 5: Time Stamp | | XXXXh | | 04785Fh | | | 700011 | | Y: Undefine | | | | Table 4.28 SFR List (28) | Address Register | Symbol | Reset Value | |--------------------------------------------|---------|--------------| | 047860h CAN1 Mailbox 6: Message Identifier | C1MB6 | XXXX XXXXh | | 047861h | | | | 047862h | | | | 047863h | | | | 047864h | | | | 047865h CAN1 Mailbox 6: Data Length | | XXh | | 047866h CAN1 Mailbox 6: Data Field | | XXXX XXXX | | 047867h | | XXXX XXXXh | | 047868h | | | | 047869h | | | | 04786Ah | | | | 04786Bh | | | | 04786Ch | | | | 04786Dh | | | | 04786Eh CAN1 Mailbox 6: Time Stamp | | XXXXh | | 04786Fh | | | | 047870h CAN1 Mailbox 7: Message Identifier | C1MB7 | XXXX XXXXh | | 047871h | 2 | | | 047872h | | | | 047873h | | | | 047874h | | | | 047875h CAN1 Mailbox 7: Data Length | | XXh | | 047876h CAN1 Mailbox 7: Data Field | | XXXX XXXX | | 047877h | | XXXX XXXXh | | 047878h | | | | 047879h | | | | 04787Ah | | | | 04787Bh | | | | 04787Ch | | | | 04787Dh | | | | 04787Eh CAN1 Mailbox 7: Time Stamp | | XXXXh | | 04787Fh | | 700011 | | 047880h CAN1 Mailbox 8: Message Identifier | C1MB8 | XXXX XXXXh | | 047881h | O TWIDO | 700007000011 | | 047882h | | | | 047883h | | | | 047884h | | | | 047885h CAN1 Mailbox 8: Data Length | | XXh | | 047886h CAN1 Mailbox 8: Data Field | | XXXX XXXX | | 047887h | | XXXX XXXXh | | 047888h | | | | 047889h | | | | 04788Ah | | | | 04788Bh | | | | 04788Ch | | | | 04788Dh | | | | 04788Eh CAN1 Mailbox 8: Time Stamp | | XXXXh | | 04788Fh | | ^^^ | | V: Undefined | | | **Table 4.29** SFR List (29) | Tuble 4:20 Of R Elot (20) | | | |------------------------------------------------|----------|-------------| | Address Register | Symbol | Reset Value | | 047890h CAN1 Mailbox 9: Message Identifier | C1MB9 | XXXX XXXXh | | 047891h | | | | 047892h | | | | 047893h | | | | 047894h | | | | 047895h CAN1 Mailbox 9: Data Length | | XXh | | 047896h CAN1 Mailbox 9: Data Field | | XXXX XXXX | | 047897h | | XXXX XXXXh | | 047898h | | | | 047899h | | | | 04789Ah | | | | 04789Bh | | | | 04789Ch | | | | 04789Dh | | | | 04789Eh CAN1 Mailbox 9: Time Stamp | | XXXXh | | 04789Fh | | | | 0478A0h CAN1 Mailbox 10: Message Identifier | C1MB10 | XXXX XXXXh | | 0478A1h | | | | 0478A2h | | | | 0478A3h | | | | 0478A4h | | | | 0478A5h CAN1 Mailbox 10: Data Length | | XXh | | 0478A6h CAN1 Mailbox 10: Data Field | | XXXX XXXX | | 0478A7h | | XXXX XXXXh | | 0478A8h | | | | 0478A9h | | | | 0478AAh | | | | 0478ABh | | | | 0478ACh | | | | 0478ADh | | | | 0478AEh CAN1 Mailbox 10: Time Stamp | | XXXXh | | 0478AFh | | NOON! | | 0478B0h CAN1 Mailbox 11: Message Identifier | C1MB11 | XXXX XXXXh | | 0478B1h | Olivioli | | | 0478B2h | | | | 0478B3h | | | | 0478B4h | | | | 0478B5h CAN1 Mailbox 11: Data Length | | XXh | | 0478B6h CAN1 Mailbox 11: Data Length | | XXXX XXXX | | 0478B7h | | XXXX XXXXh | | 0476B7ff<br>0478B8h | | 7000700011 | | | | | | 0478B9h | | | | 0478BAh | | | | 0478BBh | | | | 0478BCh | | | | 0478BDh | | 10000 | | 0.470DEL 0.4514.14.19. 44.79.00 | | | | 0478BEh CAN1 Mailbox 11: Time Stamp<br>0478BFh | | XXXXh | Table 4.30 SFR List (30) | | Of 14 E134 (00) | | | |-------------|-------------------------------------|------------|-----------------------------------------| | Address | Register | Symbol | Reset Value | | | CAN1 Mailbox 12: Message Identifier | C1MB12 | XXXX XXXXh | | 0478C1h | | | | | 0478C2h | | | | | 0478C3h | | | | | 0478C4h | | | | | 0478C5h | CAN1 Mailbox 12: Data Length | | XXh | | 0478C6h | CAN1 Mailbox 12: Data Field | | XXXX XXXX | | 0478C7h | | | XXXX XXXXh | | 0478C8h | | | | | 0478C9h | | | | | 0478CAh | | | | | 0478CBh | | | | | 0478CCh | | | | | 0478CDh | | | | | | CAN1 Mailbox 12: Time Stamp | | XXXXh | | 0478CFh | <u>.</u> | | , , , , , , , , , , , , , , , , , , , , | | | CAN1 Mailbox 13: Message Identifier | C1MB13 | XXXX XXXXh | | 0478D1h | | O TIVIS TO | 7000(700011 | | 0478D2h | | | | | 0478D3h | | | | | 0478D4h | | | | | | CAN1 Mailbox 13: Data Length | | XXh | | | CAN1 Mailbox 13: Data Eerigiii | | XXXX XXXX | | 0478D7h | | | XXXX XXXXh | | 0478D711 | | | 7000(7000(1) | | 0478D9h | | | | | 0478DAh | | | | | | | | | | 0478DBh | | | | | 0478DCh | | | | | 0478DDh | | | 20004 | | | CAN1 Mailbox 13: Time Stamp | | XXXXh | | 0478DFh | | | | | | CAN1 Mailbox 14: Message Identifier | C1MB14 | XXXX XXXXh | | 0478E1h | | | | | 0478E2h | | | | | 0478E3h | | | | | 0478E4h | | | | | | CAN1 Mailbox 14: Data Length | | XXh | | | CAN1 Mailbox 14: Data Field | | XXXX XXXX | | 0478E7h | | | XXXX XXXXh | | 0478E8h | | | | | 0478E9h | | | | | 0478EAh | | | | | 0478EBh | | | | | 0478ECh | 1 | | | | 0478EDh | | | | | 0478EEh | CAN1 Mailbox 14: Time Stamp | | XXXXh | | 0478EFh | 1 | | | | Y: Undefine | | + | <del>_</del> | Table 4.31 SFR List (31) | Address Registe | r Symbol | Reset Value | |------------------------------------------|------------|-------------| | 0478F0h CAN1 Mailbox 15: Message Identif | | XXXX XXXXh | | 0478F1h | | | | 0478F2h | | | | 0478F3h | | | | 0478F4h | | | | 0478F5h CAN1 Mailbox 15: Data Length | | XXh | | 0478F6h CAN1 Mailbox 15: Data Field | | XXXX XXXX | | 0478F7h | | XXXX XXXXh | | 0478F8h | | | | 0478F9h | | | | 0478FAh | | | | 0478FBh | | | | 0478FCh | | | | 0478FDh | | | | 0478FEh CAN1 Mailbox 15: Time Stamp | | XXXXh | | 0478FFh | | | | 047900h CAN1 Mailbox 16: Message Identif | ier C1MB16 | XXXX XXXXh | | 047901h | | | | 047902h | | | | 047903h | | | | 047904h | | | | 047905h CAN1 Mailbox 16: Data Length | | XXh | | 047906h CAN1 Mailbox 16: Data Field | | XXXX XXXX | | 047907h | | XXXX XXXXh | | 047908h | | | | 047909h | | | | 04790Ah | | | | 04790Bh | | | | 04790Ch | | | | 04790Dh | | | | 04790Eh CAN1 Mailbox 16: Time Stamp | | XXXXh | | 04790Fh | | | | 047910h CAN1 Mailbox 17: Message Identif | ier C1MB17 | XXXX XXXXh | | 047911h | | | | 047912h | | | | 047913h | | | | 047914h | | | | 047915h CAN1 Mailbox 17: Data Length | | XXh | | 047916h CAN1 Mailbox 17: Data Field | | XXXX XXXX | | 047917h | | XXXX XXXXh | | 047918h | | | | 047919h | | | | 04791Ah | | | | 04791Bh | | | | 04791Ch | | | | 04791Dh | | | | 04791Eh CAN1 Mailbox 17: Time Stamp | | XXXXh | | 04791Fh | | | **Table 4.32** SFR List (32) | | ` , | | | |--------------------|-------------------------------------|-----------|-------------| | Address | Register | Symbol | Reset Value | | 047920h | CAN1 Mailbox 18: Message Identifier | C1MB18 | XXXX XXXXh | | 047921h | | | | | 047922h | | | | | 047923h | | | | | 047924h | | | | | 047925h | CAN1 Mailbox 18: Data Length | | XXh | | 047926h | CAN1 Mailbox 18: Data Field | | XXXX XXXX | | 047927h | | | XXXX XXXXh | | 047928h | | | | | 047929h | | | | | 04792Ah | | | | | 04792Bh | | | | | 04792Ch | | | | | 04792Dh | 1 | | | | | CAN1 Mailbox18: Time Stamp | | XXXXh | | 04792Fh | <u> </u> | | | | | CAN1 Mailbox 19: Message Identifier | C1MB19 | XXXX XXXXh | | 047931h | | 32 10 | | | 047932h | | | | | 047933h | | | | | 047934h | | | | | | CAN1 Mailbox 19: Data Length | | XXh | | | CAN1 Mailbox 19: Data Field | | XXXX XXXX | | 047937h | $\underline{J}$ | | XXXX XXXXh | | 047938h | | | | | 047939h | | | | | 04793Ah | | | | | 04793Bh | | | | | 04793Ch | | | | | 04793Dh | | | | | | CAN1 Mailbox 19: Time Stamp | | XXXXh | | 04793En | • | | NOONII | | | CAN1 Mailbox 20: Message Identifier | C1MB20 | XXXX XXXXh | | 047940h | | O TIVIDZO | | | 047941h | | | | | 047942h | | | | | 047943h | | | | | | CAN1 Mailbox 20: Data Length | | XXh | | | CAN1 Mailbox 20: Data Field | | XXXX XXXX | | 047946h | | | XXXX XXXXh | | 047947h | | | 7000700011 | | 047948h | | | | | 047949h<br>04794Ah | | | | | | | | | | 04794Bh | | | | | 04794Ch | | | | | 04794Dh | | | VVVVI- | | | CAN1 Mailbox 20: Time Stamp | | XXXXh | | 04794Fh | | | | Table 4.33 SFR List (33) | Address | Register | Symbol | Reset Value | |-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--------|------------------| | 047950h | CAN1 Mailbox 21: Message Identifier | C1MB21 | XXXX XXXXh | | 047951h | <u> </u> | | | | 047952h | | | | | 047953h | | | | | 047954h | | | | | 047955h | CAN1 Mailbox 21: Data Length | | XXh | | | CAN1 Mailbox 21: Data Field | | XXXX XXXX | | 047957h | | | XXXX XXXXh | | 047958h | | | | | 047959h | | | | | 04795Ah | | | | | 04795Bh | | | | | 04795Ch | | | | | 04795Dh | | | | | | CAN1 Mailbox 21: Time Stamp | | XXXXh | | 04795Fh | <u>.</u> | | | | | CAN1 Mailbox 22: Identifier | C1MB22 | XXXX XXXXh | | 047961h | | | | | 047962h | | | | | 047963h | | | | | 047964h | | | | | 047965h | CAN1 Mailbox 22: Data Length | | XXh | | | CAN1 Mailbox 22: Data Field | | XXXX XXXX | | 047967h | | | XXXX XXXXh | | 047968h | | | | | 047969h | | | | | 04796Ah | | | | | 04796Bh | | | | | 04796Ch | | | | | 04796Dh | | | | | 04796Eh | CAN1 Mailbox 22: Time Stamp | | XXXXh | | 04796Fh | · | | | | 047970h | | | | | | CAN1 Mailbox 23: Message Identifier | C1MB23 | XXXX XXXXh | | 047971h | CAN1 Mailbox 23: Message Identifier | C1MB23 | XXXX XXXXh | | 047971h<br>047972h | CAN1 Mailbox 23: Message Identifier | C1MB23 | XXXX XXXXh | | | CAN1 Mailbox 23: Message Identifier | C1MB23 | XXXX XXXXh | | 047972h | CAN1 Mailbox 23: Message Identifier | C1MB23 | XXXX XXXXh | | 047972h<br>047973h<br>047974h | CAN1 Mailbox 23: Message Identifier | C1MB23 | XXXX XXXXh | | 047972h<br>047973h<br>047974h<br>047975h | CAN1 Mailbox 23: Message Identifier | C1MB23 | | | 047972h<br>047973h<br>047974h<br>047975h | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh | | 047972h<br>047973h<br>047974h<br>047975h<br>047976h | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh<br>XXXX XXXX | | 047972h<br>047973h<br>047974h<br>047975h<br>047976h<br>047977h | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh<br>XXXX XXXX | | 047972h<br>047973h<br>047974h<br>047975h<br>047976h<br>047977h<br>047978h | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh<br>XXXX XXXX | | 047972h<br>047973h<br>047974h<br>047975h<br>047976h<br>047977h<br>047978h<br>047979h | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh<br>XXXX XXXX | | 047972h<br>047973h<br>047974h<br>047975h<br>047976h<br>047977h<br>047978h<br>047979h | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh<br>XXXX XXXX | | 047972h<br>047973h<br>047974h<br>047975h<br>047976h<br>047977h<br>047978h<br>047979h<br>04797Ah | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh<br>XXXX XXXX | | 047972h<br>047973h<br>047974h<br>047975h<br>047976h<br>047977h<br>047978h<br>047979h<br>04797Ah<br>04797Bh<br>04797Ch | CAN1 Mailbox 23: Message Identifier CAN1 Mailbox 23: Data Length CAN1 Mailbox 23: Data Field | C1MB23 | XXh<br>XXXX XXXX | **Table 4.34** SFR List (34) | Address | Register | Symbol | Reset Value | |---------|-----------------------------------------------------------|----------|-------------| | 047980h | CAN1 Mailbox 24: Message Identifier | C1MB24 | XXXX XXXXh | | 047981h | | | | | 047982h | <del> </del> | | | | 047983h | <del> </del> | | | | 047984h | | | | | | CAN1 Mailbox 24: Data Length | | XXh | | | CAN1 Mailbox 24: Data Field | | XXXX XXXX | | 047987h | | | XXXX XXXXh | | 047988h | | | | | 047989h | | | | | 04798Ah | | | | | 04798Bh | | | | | 04798Ch | | | | | 04798Dh | | | | | | CAN1 Mailbox 24: Time Stamp | | XXXXh | | 04798Fh | <u> </u> | | 700001 | | | CAN1 Mailbox 25: Message Identifier | C1MB25 | XXXX XXXXh | | 047991h | | C TWB25 | | | 047992h | | | | | 047993h | | | | | 047993h | | | | | | CAN1 Mailbox 25: Data Length | | XXh | | | CAN1 Mailbox 25: Data Length CAN1 Mailbox 25: Data Field | <u>_</u> | XXXX XXXX | | | | | XXXX XXXXh | | 047997h | | | ^^^ | | 047998h | | | | | 047999h | | | | | 04799Ah | | | | | 04799Bh | | | | | 04799Ch | | | | | 04799Dh | | | 20000 | | | CAN1 Mailbox 25: Time Stamp | | XXXXh | | 04799Fh | | | | | | CAN1 Mailbox 26: Message Identifier | C1MB26 | XXXX XXXXh | | 0479A1h | | | | | 0479A2h | | | | | 0479A3h | | | | | 0479A4h | | | | | | CAN1 Mailbox 26: Data Length | | XXh | | | CAN1 Mailbox 26: Data Field | | XXXX XXXX | | 0479A7h | | | XXXX XXXXh | | 0479A8h | | | | | 0479A9h | | | | | 0479AAh | | | | | 0479ABh | | | | | 0479ACh | 1 | | | | | 1 | | | | 0479ADh | | | | | | CAN1 Mailbox 26: Time Stamp | | XXXXh | **Table 4.35** SFR List (35) | Address Register | Symbol | Reset Value | |---------------------------------------------|--------|-------------| | 0479B0h CAN1 Mailbox 27: Message Identifier | C1MB27 | XXXX XXXXh | | 0479B1h | | | | 0479B2h | | | | 0479B3h | | | | 0479B4h | | | | 0479B5h CAN1 Mailbox 27: Data Length | | XXh | | 0479B6h CAN1 Mailbox 27: Data Field | | XXXX XXXX | | 0479B7h | | XXXX XXXXh | | 0479B8h | | | | 0479B9h | | | | 0479BAh | | | | 0479BBh | | | | 0479BCh | | | | 0479BDh | | | | 0479BEh CAN1 Mailbox 27: Time Stamp | | XXXXh | | 0479BFh | | | | 0479C0h CAN1 Mailbox 28: Message Identifier | C1MB28 | XXXX XXXXh | | 0479C1h | | | | 0479C2h | | | | 0479C3h | | | | 0479C4h | | | | 0479C5h CAN1 Mailbox 28: Data Length | | XXh | | 0479C6h CAN1 Mailbox 28: Data Field | | XXXX XXXX | | 0479C7h | | XXXX XXXXh | | 0479C8h | | | | 0479C9h | | | | 0479CAh | | | | 0479CBh | | | | 0479CCh | | | | 0479CDh | | | | 0479CEh CAN1 Mailbox 28: Time Stamp | | XXXXh | | 0479CFh | | 700001 | | 0479D0h CAN1 Mailbox 29: Message Identifier | C1MB29 | XXXX XXXXh | | 0479D1h | | | | 0479D2h | | | | 0479D3h | | | | 0479D4h | | | | 0479D5h CAN1 Mailbox 29: Data Length | | XXh | | 0479D6h CAN1 Mailbox 29: Data Field | | XXXX XXXX | | 0479D7h | | XXXX XXXXh | | 0479D8h | | | | 0479D9h | | | | 0479DAh | | | | 0479DBh | | | | 0479DCh | | | | 0479DDh | | | | 0479DBh CAN1 Mailbox 29: Time Stamp | | XXXXh | | 0479DFh CANT Malibox 29. Time Stamp | | | | Y: Undefined | | | Table 4.36 SFR List (36) | Address Register | Symbol | Reset Value | |---------------------------------------------|------------|-------------| | 0479E0h CAN1 Mailbox 30: Message Identifier | C1MB30 | XXXX XXXXh | | 0479E1h | | | | 0479E2h | | | | 0479E3h | | | | 0479E4h | | | | 0479E5h CAN1 Mailbox 30: Data Length | | XXh | | 0479E6h CAN1 Mailbox 30: Data Field | | XXXX XXXX | | 0479E7h | | XXXX XXXXh | | 0479E8h | | | | 0479E9h | | | | 0479EAh | | | | 0479EBh | | | | 0479ECh | | | | 0479EDh | | | | 0479EEh CAN1 Mailbox 30: Time Stamp | | XXXXh | | 0479EFh | | 7.0.0.0.1 | | 0479F0h CAN1 Mailbox 31: Message Identifier | C1MB31 | XXXX XXXXh | | 0479F1h | 3 111120 1 | 7000070000 | | 0479F2h | | | | 0479F3h | | | | 0479F4h | | | | 0479F5h CAN1 Mailbox 31: Data Length | | XXh | | 0479F6h CAN1 Mailbox 31: Data Field | | XXXX XXXX | | 0479F7h | | XXXX XXXXh | | 0479F8h | | 70000000 | | 0479F9h | | | | 0479FAh | | | | 0479FBh | | | | 0479FCh | | | | 0479FDh | | | | 0479FEh CAN1 Mailbox 31: Time Stamp | | XXXXh | | 0479FFh | | NOONII | | 04797711<br>047A00h CAN1 Mask Register 0 | C1MKR0 | XXXX XXXXh | | 047A00H CANT Wask Register 0 | CHWIRKO | | | 047A0111 | | | | 047A03h | | | | 047A03ff<br>047A04h CAN1 Mask Register 1 | C1MKR1 | XXXX XXXXh | | 047A04H CANT Wask Register 1 | O HWINK I | ^^^ | | 047A06h | | | | 047A00ft | | | | 047A08h CAN1 Mask Register 2 | C1MKR2 | XXXX XXXXh | | 047A09h CAN I Mask Register 2 | CIVINRZ | ^^^^ ^^^ | | 047A09h<br>047A0Ah | | | | | | | | 047A0Sh CANA Mask Basistan 2 | CAMIZEO | VVVV VVVI | | 047A0Ch CAN1 Mask Register 3 | C1MKR3 | XXXX XXXXh | | 047A0Dh | | | | 047A0Eh | | | | 047A0Fh | | | **Table 4.37** SFR List (37) | Address | Register | Symbol | Reset Value | |-------------|------------------------------------------|----------|----------------------------------------| | | | C1MKR4 | | | 047A10h | CAN1 Mask Register 4 | C IWKK4 | XXXX XXXXh | | | | | | | 047A12h | | | | | 047A13h | | O4N4KD5 | V///////////////////////////////////// | | | CAN1 Mask Register 5 | C1MKR5 | XXXX XXXXh | | 047A15h | | | | | 047A16h | | | | | 047A17h | | | | | | CAN1 Mask Register 6 | C1MKR6 | XXXX XXXXh | | 047A19h | | | | | 047A1Ah | | | | | 047A1Bh | | | | | 1 | CAN1 Mask Register 7 | C1MKR7 | XXXX XXXXh | | 047A1Dh | | | | | 047A1Eh | | | | | 047A1Fh | | | | | | CAN1 FIFO Received ID Compare Register 0 | C1FIDCR0 | XXXX XXXXh | | 047A21h | | | | | 047A22h | | | | | 047A23h | | | | | | CAN1 FIFO Received ID Compare Register 1 | C1FIDCR1 | XXXX XXXXh | | 047A25h | | | | | 047A26h | | | | | 047A27h | | | | | 047A28h | CAN1 Mask Invalid Register | C1MKIVLR | XXXX XXXXh | | 047A29h | | | | | 047A2Ah | | | | | 047A2Bh | | | | | 047A2Ch | CAN1 Mailbox Interrupt Enable Register | C1MIER | XXXX XXXXh | | 047A2Dh | | | | | 047A2Eh | | | | | 047A2Fh | | | | | 047A30h | | | | | 047A31h | | | | | 047A32h | | | | | 047A33h | | | | | 047A34h | | | | | 047A35h | | | | | 047A36h | | | | | 047A37h | | | | | 047A38h | | | | | 047A39h | | | | | 047A3Ah | | | | | 047A3Bh | | | | | 047A3Ch | | | | | 047A3Dh | | | | | 047A3Eh | | | | | 047A3Eh | | | | | 047A3111 | | | | | 047B1Fh | | | | | X: Undefine | | | | Table 4.38 SFR List (38) | Address | Register | Symbol | Reset Value | |---------|----------------------------------|----------|-------------| | | CAN1 Message Control Register 0 | C1MCTL0 | 00h | | | CAN1 Message Control Register 1 | C1MCTL1 | 00h | | | CAN1 Message Control Register 2 | C1MCTL2 | 00h | | | CAN1 Message Control Register 3 | C1MCTL3 | 00h | | | CAN1 Message Control Register 4 | C1MCTL4 | 00h | | | CAN1 Message Control Register 5 | C1MCTL5 | 00h | | 047B26h | CAN1 Message Control Register 6 | C1MCTL6 | 00h | | 047B27h | CAN1 Message Control Register 7 | C1MCTL7 | 00h | | | CAN1 Message Control Register 8 | C1MCTL8 | 00h | | | CAN1 Message Control Register 9 | C1MCTL9 | 00h | | 047B2Ah | CAN1 Message Control Register 10 | C1MCTL10 | 00h | | 047B2Bh | CAN1 Message Control Register 11 | C1MCTL11 | 00h | | 047B2Ch | CAN1 Message Control Register 12 | C1MCTL12 | 00h | | 047B2Dh | CAN1 Message Control Register 13 | C1MCTL13 | 00h | | 047B2Eh | CAN1 Message Control Register 14 | C1MCTL14 | 00h | | 047B2Fh | CAN1 Message Control Register 15 | C1MCTL15 | 00h | | 047B30h | CAN1 Message Control Register 16 | C1MCTL16 | 00h | | 047B31h | CAN1 Message Control Register 17 | C1MCTL17 | 00h | | 047B32h | CAN1 Message Control Register 18 | C1MCTL18 | 00h | | 047B33h | CAN1 Message Control Register 19 | C1MCTL19 | 00h | | 047B34h | CAN1 Message Control Register 20 | C1MCTL20 | 00h | | 047B35h | CAN1 Message Control Register 21 | C1MCTL21 | 00h | | 047B36h | CAN1 Message Control Register 22 | C1MCTL22 | 00h | | 047B37h | CAN1 Message Control Register 23 | C1MCTL23 | 00h | | 047B38h | CAN1 Message Control Register 24 | C1MCTL24 | 00h | | 047B39h | CAN1 Message Control Register 25 | C1MCTL25 | 00h | | 047B3Ah | CAN1 Message Control Register 26 | C1MCTL26 | 00h | | 047B3Bh | CAN1 Message Control Register 27 | C1MCTL27 | 00h | | 047B3Ch | CAN1 Message Control Register 28 | C1MCTL28 | 00h | | 047B3Dh | CAN1 Message Control Register 29 | C1MCTL29 | 00h | | 047B3Eh | CAN1 Message Control Register 30 | C1MCTL30 | 00h | | 047D2Fb | CAN1 Message Control Register 31 | C1MCTL31 | 00h | **Table 4.39** SFR List (39) | Address | Register | Symbol | Reset Value | |-------------|---------------------------------------------|---------|-------------| | 047B40h | CAN1 Control Register | C1CTLR | 0000 0101b | | 047B41h | | | 0000 0000b | | 047B42h | CAN1 Status Register | C1STR | 0000 0101b | | 047B43h | | | 0000 0000b | | 047B44h | CAN1 Bit Configuration Register | C1BCR | 00 0000h | | 047B45h | | | | | 047B46h | | | | | | CAN1 Clock Select Register | C1CLKR | 000X 0000b | | | CAN1 Receive FIFO Control Register | C1RFCR | 1000 0000b | | | CAN1 Receive FIFO Pointer Control Register | C1RFPCR | XXh | | | CAN1 Transmit FIFO Control Register | C1TFCR | 1000 0000b | | | CAN1 Transmit FIFO Pointer Control Register | C1TFPCR | XXh | | | CAN1 Error Interrupt Enable Register | C1EIER | 00h | | 047B4Dh | CAN1 Error Interrupt Factor Judge Register | C1EIFR | 00h | | 047B4Eh | CAN1 Receive Error Count Register | C1RECR | 00h | | 047B4Fh | CAN1 Transmit Error Count Register | C1TECR | 00h | | | CAN1 Error Code Store Register | C1ECSR | 00h | | 047B51h | CAN1 Channel Search Support Register | C1CSSR | XXh | | | CAN1 Mailbox Search Status Register | C1MSSR | 1000 0000b | | 047B53h | CAN1 Mailbox Search Mode Register | C1MSMR | 0000 0000b | | 047B54h | CAN1 Time Stamp Register | C1TSR | 0000h | | 047B55h | | | | | 047B56h | CAN1 Acceptance Filter Support Register | C1AFSR | XXXXh | | 047B57h | | | | | 047B58h | CAN1 Test Control Register | C1TCR | 00h | | 047B59h | | | | | 047B5Ah | | | | | 047B5Bh | | | | | 047B5Ch | | | | | 047B5Dh | | | | | 047B5Eh | | | | | 047B5Fh | | | | | 047B60h to | | | | | 047BFFh | | | | | V. Undofino | | | | X: Undefined **Table 4.40** SFR List (40) | Address Register | Symbol | Reset Value | |--------------------------------------------|--------|-------------| | 047C00h CAN0 Mailbox 0: Message Identifier | C0MB0 | XXXX XXXXh | | 047C01h | | | | 047C02h | | | | 047C03h | | | | 047C04h | | | | 047C05h CAN0 Mailbox 0: Data Length | | XXh | | 047C06h CAN0 Mailbox 0: Data Field | | XXXX XXXX | | 047C07h | | XXXX XXXXh | | 047C08h | | | | 047C09h | | | | 047C0Ah | | | | 047C0Bh | | | | 047C0Ch | | | | 047C0Dh | | | | 047C0Eh CAN0 Mailbox 0: Time Stamp | | XXXXh | | 047C0Fh | | | | 047C10h CAN0 Mailbox 1: Message Identifier | C0MB1 | XXXX XXXXh | | 047C11h | | | | 047C12h | | | | 047C13h | | | | 047C14h | | | | 047C15h CAN0 Mailbox 1: Data Length | | XXh | | 047C16h CAN0 Mailbox 1: Data Field | | XXXX XXXX | | 047C17h | | XXXX XXXXh | | 047C18h | | | | 047C19h | | | | 047C1Ah | | | | 047C1Bh | | | | 047C1Ch | | | | 047C1Dh | | | | 047C1Eh CAN0 Mailbox 1: Time Stamp | | XXXXh | | 047C1Fh | | 7000. | | 047C20h CAN0 Mailbox 2: Message Identifier | C0MB2 | XXXX XXXXh | | 047C21h | 32 | | | 047C22h | | | | 047C23h | | | | 047C24h | | | | 047C25h CAN0 Mailbox 2: Data Length | | XXh | | 047C26h CAN0 Mailbox 2: Data Field | | XXXX XXXX | | 047C27h | | XXXX XXXXh | | 047C28h | | | | 047C29h | | | | 047C2Ah | | | | 047C2Bh | | | | 047C2Ch | | | | 047C2Dh | | | | 047C2Eh CAN0 Mailbox 2: Time Stamp | | XXXXh | | 047C2Fh | | 700011 | | Y: Undefined | | | **Table 4.41** SFR List (41) | Address Register | Symbol | Reset Value | |-------------------------------------------------|---------|-------------------------| | 047C30h CAN0 Mailbox 3: Message Identifier | C0MB3 | XXXX XXXXh | | 047C31h | | | | 047C32h | | | | 047C33h | | | | 047C34h | | | | 047C35h CAN0 Mailbox 3: Data Length | | XXh | | 047C36h CAN0 Mailbox 3: Data Field | | XXXX XXXX | | 047C37h | | XXXX XXXXh | | 047C38h | | | | 047C39h | | | | 047C3Ah | | | | 047C3Bh | | | | 047C3Ch | | | | 047C3Dh | | | | 047C3Eh CAN0 Mailbox 3: Time Stamp | | XXXXh | | 047C3Fh | | WWIII | | 047C40h CAN0 Mailbox 4: Message Identifier | C0MB4 | XXXX XXXXh | | 047C40h | COIVID4 | ^^^ | | 047C4111<br>047C42h | | | | 047C42ff<br>047C43h | | | | 047C44h | | | | 047C44ff<br>047C45h CAN0 Mailbox 4: Data Length | | XXh | | 047C46h CAN0 Mailbox 4: Data Field | | XXXX XXXX | | 047C47h | | XXXX XXXXh | | 047C47fi<br>047C48h | | 7000 700011 | | 047C49h | | | | 047C49ft<br>047C4Ah | | | | 047C4Bh | | | | 047C4Ch | | | | | | | | 047C4Eh CANO Mailhau 4. Tiran Starra | | VVVVI | | 047C4Eh CAN0 Mailbox 4: Time Stamp 047C4Fh | | XXXXh | | | 00MD5 | WWW WWW. | | 047C50h CAN0 Mailbox 5: Message Identifier | C0MB5 | XXXX XXXXh | | 047C51h | | | | 047C52h | | | | 047C54h | | | | 047C55h CANO Mailbay 5: Data Langth | | VVh | | 047C55h CANO Mailbox 5: Data Length | | XXh | | 047C56h CAN0 Mailbox 5: Data Field | | XXXX XXXX<br>XXXX XXXXh | | 047C57h | | ^^^^ ^ | | 047C58h | | | | 047C59h | | | | 047C5Ah | | | | 047C5Bh | | | | 047C5Ch | | | | 047C5Dh | | | | 047C5Eh CAN0 Mailbox 5: Time Stamp | | XXXXh | | 047C5Fh | | | **Table 4.42** SFR List (42) | Address Register | Symbol | Reset Value | |------------------------------------------------------------------------|---------|-----------------------------------------| | 047C60h CAN0 Mailbox 6: Message Identifier | C0MB6 | XXXX XXXXh | | 047C61h | | | | 047C62h | | | | 047C63h | | | | 047C64h | | | | 047C65h CAN0 Mailbox 6: Data Length | | XXh | | 047C66h CAN0 Mailbox 6: Data Field | | XXXX XXXX | | 047C67h | | XXXX XXXXh | | 047C68h | | | | 047C69h | | | | 047C6Ah | | | | 047C6Bh | | | | 047C6Ch | | | | 047C6Dh | | | | 047C6Eh CAN0 Mailbox 6: Time Stamp | | XXXXh | | 047C6Fh | | | | 047C70h CAN0 Mailbox 7: Message Identifier | C0MB7 | XXXX XXXXh | | 047C71h | 30000 | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | 047C72h | | | | 047C73h | | | | 047C74h | | | | 047C75h CAN0 Mailbox 7: Data Length | | XXh | | 047C76h CAN0 Mailbox 7: Data Field | | XXXX XXXX | | 047C77h | | XXXX XXXXh | | 047C78h | | 70000700011 | | 047C79h | | | | 047C7Ah | | | | 047C7Bh | | | | 047C7Ch | | | | 047C7Dh | | | | 047C7Eh CAN0 Mailbox 7: Time Stamp | | XXXXh | | 047C7Fh | | XXXXII | | 047C80h CAN0 Mailbox 8: Message Identifier | C0MB8 | XXXX XXXXh | | 047C81h | COIVIDO | | | 047C82h | | | | 047C83h | | | | 047C84h | | | | | | XXh | | 047C85h CAN0 Mailbox 8: Data Length 047C86h CAN0 Mailbox 8: Data Field | | | | 047C87h CANU Malibox 8: Data Field | | XXXX XXXX<br>XXXX XXXXh | | | | ^^^ | | 047C88h | | | | 047C89h | | | | 047C8Ah | | | | 047C8Bh | | | | 047C8Ch | | | | 047C8Dh | | 2000 | | 047C8Eh CAN0 Mailbox 8: Time Stamp | | XXXXh | | 047C8Fh | | | **Table 4.43** SFR List (43) | Address | Register | Symbol | Reset Value | |----------|-------------------------------------|---------|-----------------------------------------| | 047C90h | CAN0 Mailbox 9: Message Identifier | C0MB9 | XXXX XXXXh | | 047C91h | | | | | 047C92h | | | | | 047C93h | | | | | 047C94h | | | | | 047C95h | CAN0 Mailbox 9: Data Length | | XXh | | | CAN0 Mailbox 9: Data Field | | XXXX XXXX | | 047C97h | | | XXXX XXXXh | | 047C98h | | | | | 047C99h | | | | | 047C9Ah | | | | | 047C9Bh | | | | | 047C9Ch | | | | | 047C9Dh | | | | | | CAN0 Mailbox 9: Time Stamp | | XXXXh | | 047C9Fh | <u>.</u> | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | CAN0 Mailbox 10: Message Identifier | C0MB10 | XXXX XXXXh | | 047CA1h | _ | COMPTO | 7000700011 | | 047CA111 | | | | | 047CA3h | | | | | 047CA3h | | | | | | CAN0 Mailbox 10: Data Length | | XXh | | | CANO Mailbox 10: Data Eerigin | | XXXX XXXX | | 047CA011 | | | XXXX XXXXh | | 047CA7fi | | | 70000700011 | | 047CA011 | | | | | 047CA9h | | | | | 047CAAn | | | | | 047CABh | | | | | | | | | | 047CADh | | | VVVVh | | | CAN0 Mailbox 10: Time Stamp | | XXXXh | | 047CAFh | | 0014044 | VVVV VVVVI | | | CAN0 Mailbox 11: Message Identifier | C0MB11 | XXXX XXXXh | | 047CB1h | | | | | 047CB2h | | | | | 047CB3h | | | | | 047CB4h | | | VVI | | | CANO Mailbox 11: Data Length | | XXh | | | CAN0 Mailbox 11: Data Field | | XXXX XXXX<br>XXXX XXXXh | | 047CB7h | | | ^^^ ^ | | 047CB8h | | | | | 047CB9h | | | | | 047CBAh | | | | | 047CBBh | | | | | 047CBCh | | | | | 047CBDh | | | | | | CAN0 Mailbox 11: Time Stamp | | XXXXh | | 047CBFh | | | | **Table 4.44** SFR List (44) | Address Register | Symbol | Reset Value | |---------------------------------------------|-------------|-----------------------------------------| | 047CC0h CAN0 Mailbox 12: Message Identifier | C0MB12 | XXXX XXXXh | | 047CC1h | | | | 047CC2h | | | | 047CC3h | | | | 047CC4h | <del></del> | | | 047CC5h CAN0 Mailbox 12: Data Length | <del></del> | XXh | | 047CC6h CAN0 Mailbox 12: Data Field | | XXXX XXXX | | 047CC7h | | XXXX XXXXh | | 047CC8h | | | | 047CC9h | | | | 047CCAh | | | | 047CCBh | | | | 047CCCh | | | | 047CCDh | | | | 047CCEh CAN0 Mailbox 12: Time Stamp | | XXXXh | | 047CCFh | | 700011 | | 047CD0h CAN0 Mailbox 13: Message Identifier | C0MB13 | XXXX XXXXh | | 047CD1h | CONIDIO | 70000700011 | | 047CD2h | | | | 047CD3h | | | | 047CD4h | | | | 047CD5h CAN0 Mailbox 13: Data Length | | XXh | | 047CD6h CAN0 Mailbox 13: Data Field | | XXXX XXXX | | 047CD7h | | XXXX XXXXh | | 047CD8h | | 70000000 | | 047CD9h | | | | 047CDAh | | | | 047CDBh | | | | 047CDCh | | | | 047CDDh | | | | 047CDEh CAN0 Mailbox 13: Time Stamp | | XXXXh | | 047CDFh | | 700001 | | 047CE0h CAN0 Mailbox 14: Message Identifier | C0MB14 | XXXX XXXXh | | 047CE1h | COMBIT | 70000700011 | | 047CE2h | | | | 047CE3h | | | | 047CE4h | | | | 047CE5h CAN0 Mailbox 14: Data Length | | XXh | | 047CE6h CAN0 Mailbox 14: Data Field | | XXXX XXXX | | 047CE7h | | XXXX XXXXh | | 047CE8h | | , , , , , , , , , , , , , , , , , , , , | | 047CE9h | | | | 047CE9h | | | | 047CEBh | | | | 047CECh | | | | 047CECh | | | | 047CEEh CAN0 Mailbox 14: Time Stamp | | XXXXh | | • | | ^^^ | | 047CEFh X: Undefined | | | **Table 4.45** SFR List (45) | | 01 17 E13t (+0) | | | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------| | Address | Register | Symbol | Reset Value | | | CAN0 Mailbox 15: Message Identifier | C0MB15 | XXXX XXXXh | | 047CF1h | | | | | 047CF2h | | | | | 047CF3h | | | | | 047CF4h | | | | | | CAN0 Mailbox 15: Data Length | | XXh | | 047CF6h | CAN0 Mailbox 15: Data Field | | XXXX XXXX | | 047CF7h | | | XXXX XXXXh | | 047CF8h | | | | | 047CF9h | | | | | 047CFAh | | | | | 047CFBh | | | | | 047CFCh | | | | | 047CFDh | | | | | 047CFEh | CAN0 Mailbox 15: Time Stamp | | XXXXh | | 047CFFh | | | | | 047D00h | CAN0 Mailbox 16: Message Identifier | C0MB16 | XXXX XXXXh | | 047D01h | 1 | | | | 047D02h | 1 | | | | 047D03h | | | | | 047D04h | | | | | 047D05h | CAN0 Mailbox 16: Data Length | | XXh | | 047D06h | CAN0 Mailbox 16: Data Field | | XXXX XXXX | | 047D07h | | | XXXX XXXXh | | 047D08h | | | | | 047D09h | | | | | 047D0Ah | | | | | 047D0Bh | | | | | 047D0Ch | | | | | 047D0Dh | | | | | | CAN0 Mailbox 16: Time Stamp | | XXXXh | | 047D0Fh | II · · · · · · · · · · · · · · · · · · | | | | | CAN0 Mailbox 17: Message Identifier | C0MB17 | XXXX XXXXh | | 047D11h | | | | | 047D12h | | | | | 047D13h | | | | | 047D14h | | | | | | CAN0 Mailbox 17: Data Length | | XXh | | | CAN0 Mailbox 17: Data Field | | XXXX XXXX | | 047D17h | | | XXXX XXXXh | | 047D18h | | | | | 047D19h | | | | | 047D1Ah | | | | | 047D1An | | | | | 047D1Ch | | | | | 047D1Ch | | | | | | CAN0 Mailbox 17: Time Stamp | | XXXXh | | 047D1EII | The state of s | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | Y: Undefine | | | | **Table 4.46** SFR List (46) | Address Register | Symbol | Reset Value | |-------------------------------------------------|--------|-------------| | 047D20h CAN0 Mailbox 18: Message Identifier | C0MB18 | XXXX XXXXh | | 047D21h | | | | 047D22h | | | | 047D23h | | | | 047D24h | | | | 047D25h CAN0 Mailbox 18: Data Length | | XXh | | 047D26h CAN0 Mailbox 18: Data Field | | XXXX XXXX | | 047D27h | | XXXX XXXXh | | 047D28h | | | | 047D29h | | | | 047D2Ah | | | | 047D2Bh | | | | 047D2Ch | | | | 047D2Dh | | | | 047D2Eh CAN0 Mailbox 18: Time Stamp | | XXXXh | | 047D2Fh | | /////II | | 047D30h CAN0 Mailbox 19: Message Identifier | C0MB19 | XXXX XXXXh | | 047D30H CANO Malibox 19. Message identifier | Compre | | | 047D31H<br>047D32h | | | | 047D32H | | | | 047D33ff | | | | 047D35h CAN0 Mailbox 19: Data Length | | XXh | | 047D35H CAN0 Mailbox 19: Data Length | | XXXX XXXX | | 047D35h1 CANO Malibox 19. Data Fleid<br>047D37h | | XXXX XXXXh | | 047D38h | | | | 047D36H<br>047D39h | | | | 047D39ft<br>047D3Ah | | | | | | | | 047D3Bh | | | | 047D3Ch | | | | 047D3Dh | | 20004 | | 047D3Eh CAN0 Mailbox 19: Time Stamp | | XXXXh | | 047D3Fh | | 200012000 | | 047D40h CAN0 Mailbox 20: Message Identifier | C0MB20 | XXXX XXXXh | | 047D41h | | | | 047D42h | | | | 047D43h | | | | 047D44h | | 200 | | 047D45h CAN0 Mailbox 20: Data Length | | XXh | | 047D46h CAN0 Mailbox 20: Data Field | | XXXX XXXX | | 047D47h | | XXXX XXXXh | | 047D48h | | | | 047D49h | | | | 047D4Ah | | | | 047D4Bh | | | | 047D4Ch | | | | 047D4Dh | | | | 047D4Eh CAN0 Mailbox 20: Time Stamp | | XXXXh | | 047D4Fh | | | **Table 4.47** SFR List (47) | Address Register | Symbol | Reset Value | |---------------------------------------------|----------|-------------| | 047D50h CAN0 Mailbox 21: Message Identifier | C0MB21 | XXXX XXXXh | | 047D51h | | | | 047D52h | | | | 047D53h | | | | 047D54h | | | | 047D55h CAN0 Mailbox 21: Data Length | | XXh | | 047D56h CAN0 Mailbox 21: Data Field | | XXXX XXXX | | 047D57h | | XXXX XXXXh | | 047D58h | | | | 047D59h | | | | 047D5Ah | | | | 047D5Bh | | | | 047D5Ch | | | | 047D5Dh | | | | 047D5Eh CAN0 Mailbox 21: Time Stamp | | XXXXh | | 047D5Fh | | AAAAII | | 047D60h CAN0 Mailbox 22: Message Identifier | C0MB22 | XXXX XXXXh | | 047D60H CANO Wallbox 22: Wessage Identifier | COIVIDZZ | ^^^ | | 047D61H<br>047D62h | | | | 047D63h | | | | 047D63H | | | | 047D65h CAN0 Mailbox 22: Data Length | | XXh | | 047D66h CAN0 Mailbox 22: Data Eerigiii | | XXXX XXXX | | 047D60H CANO Walibox 22: Data Field | | XXXX XXXXh | | 047D68h | | 7000 700011 | | 047D69h | | | | 047D69H<br>047D6Ah | | | | 047D6Bh | | | | 047D6Ch | | | | | | | | 047D6Eh CANO Mailhau 22, Tirra Stano | | VVVVL | | 047D6Eh CAN0 Mailbox 22: Time Stamp | | XXXXh | | 047D6Fh | COMPOS | 2000/2000/ | | 047D70h CAN0 Mailbox 23: Message Identifier | C0MB23 | XXXX XXXXh | | 047D71h | | | | 047D72h | | | | 047D73h | | | | 047D74h | | 200 | | 047D75h CAN0 Mailbox 23: Data Length | | XXh | | 047D76h CAN0 Mailbox 23: Data Field | | XXXX XXXX | | 047D77h | | XXXX XXXXh | | 047D78h | | | | 047D79h | | | | 047D7Ah | | | | 047D7Bh | | | | 047D7Ch | | | | 047D7Dh | | | | 047D7Eh CAN0 Mailbox 23: Time Stamp | | XXXXh | | 047D7Fh | | | **Table 4.48** SFR List (48) | | Of It Elst (40) | | | |--------------------|-------------------------------------|----------|-------------| | Address | Register | Symbol | Reset Value | | | CAN0 Mailbox 24: Message Identifier | C0MB24 | XXXX XXXXh | | 047D81h | | | | | 047D82h | | | | | 047D83h | | | | | 047D84h | | | | | | CAN0 Mailbox 24: Data Length | | XXh | | 047D86h | CAN0 Mailbox 24: Data Field | | XXXX XXXX | | 047D87h | | | XXXX XXXXh | | 047D88h | | | | | 047D89h | | | | | 047D8Ah | | | | | 047D8Bh | | | | | 047D8Ch | | | | | 047D8Dh | | | | | 047D8Eh | CAN0 Mailbox 24: Time Stamp | | XXXXh | | 047D8Fh | 1 | | | | 047D90h | CAN0 Mailbox 25: Message Identifier | C0MB25 | XXXX XXXXh | | 047D91h | 1 | | | | 047D92h | 1 | | | | 047D93h | 1 | | | | 047D94h | | | | | 047D95h | CAN0 Mailbox 25: Data Length | | XXh | | 047D96h | CAN0 Mailbox 25: Data Field | | XXXX XXXX | | 047D97h | | | XXXX XXXXh | | 047D98h | | | | | 047D99h | | | | | 047D9Ah | | | | | 047D9Bh | | | | | 047D9Ch | | | | | 047D9Dh | | | | | | CAN0 Mailbox 25: Time Stamp | | XXXXh | | 047D9Fh | <u> </u> | | | | | CAN0 Mailbox 26: Message Identifier | C0MB26 | XXXX XXXXh | | 047DA1h | | | | | 047DA2h | | | | | 047DA3h | $\pm$ | | | | 047DA4h | | | | | | CAN0 Mailbox 26: Data Length | | XXh | | | CAN0 Mailbox 26: Data Field | <u>-</u> | XXXX XXXX | | 047DA7h | | | XXXX XXXXh | | 047DA8h | | | | | 047DA9h | | | | | 047DAAh | | | | | 047DAAH<br>047DABh | | | | | 047DABh | | | | | 047DACH | | | | | | CAN0 Mailbox 26: Time Stamp | | XXXXh | | 047DAEH<br>047DAFh | <u>-</u> | | ^^^ | | V. Undefine | | | | **Table 4.49** SFR List (49) | Address Register | Symbol | Reset Value | |---------------------------------------------|----------|-----------------------------------------| | 047DB0h CAN0 Mailbox 27: Message Identifier | C0MB27 | XXXX XXXXh | | 047DB1h | | | | 047DB2h | | | | 047DB3h | | | | 047DB4h | | | | 047DB5h CAN0 Mailbox 27: Data Length | | XXh | | 047DB6h CAN0 Mailbox 27: Data Field | | XXXX XXXX | | 047DB7h | | XXXX XXXXh | | 047DB8h | | | | 047DB9h | | | | 047DBAh | | | | 047DBBh | | | | 047DBCh | | | | 047DBDh | | | | 047DBEh CAN0 Mailbox 27: Time Stamp | | XXXXh | | 047DBFh | | | | 047DC0h CAN0 Mailbox 28: Message Identifier | C0MB28 | XXXX XXXXh | | 047DC1h | 23.11.22 | , , , , , , , , , , , , , , , , , , , , | | 047DC2h | | | | 047DC3h | | | | 047DC4h | | | | 047DC5h CAN0 Mailbox 28: Data Length | | XXh | | 047DC6h CAN0 Mailbox 28: Data Field | | XXXX XXXX | | 047DC7h | | XXXX XXXXh | | 047DC8h | | | | 047DC9h | | | | 047DCAh | | | | 047DCBh | | | | 047DCCh | | | | 047DCDh | | | | 047DCEh CAN0 Mailbox 28: Time Stamp | | XXXXh | | 047DCFh | | 700011 | | 047DD0h CAN0 Mailbox 29: Message Identifier | C0MB29 | XXXX XXXXh | | 047DD1h | 23111220 | 70007700011 | | 047DD2h | | | | 047DD3h | | | | 047DD4h | | | | 047DD5h CAN0 Mailbox 29: Data Length | | XXh | | 047DD6h CAN0 Mailbox 29: Data Field | | XXXX XXXX | | 047DD7h | | XXXX XXXXh | | 047DD8h | | | | 047DD9h | | | | 047DDAh | | | | 047DDBh | | | | 047DDCh | | | | 047DDDh | | | | 047DDEh CAN0 Mailbox 29: Time Stamp | | XXXXh | | 047DDFh CANO Mailbox 29: Time Stamp | | ^^^ | | Y: Undefined | | | **Table 4.50** SFR List (50) | | Of It Elst (00) | | | |-------------|-------------------------------------|--------|-------------| | Address | Register | Symbol | Reset Value | | | CAN0 Mailbox 30: Message Identifier | C0MB30 | XXXX XXXXh | | 047DE1h | | | | | 047DE2h | | | | | 047DE3h | | | | | 047DE4h | | | | | 047DE5h | CAN0 Mailbox 30: Data Length | | XXh | | 047DE6h | CAN0 Mailbox 30: Data Field | | XXXX XXXX | | 047DE7h | | | XXXX XXXXh | | 047DE8h | | | | | 047DE9h | | | | | 047DEAh | | | | | 047DEBh | | | | | 047DECh | | | | | 047DEDh | | | | | | CAN0 Mailbox 30: Time Stamp | | XXXXh | | 047DEFh | <u>.</u> | | | | | CAN0 Mailbox 31: Message Identifier | C0MB31 | XXXX XXXXh | | 047DF1h | | COMBOT | 7000(700011 | | 047DF1h | | | | | 047DF3h | | | | | 047DF4h | | | | | | CAN0 Mailbox 31: Data Length | | XXh | | | CANO Mailbox 31: Data Eerigiii | | XXXX XXXX | | 047DF7h | | | XXXX XXXXh | | 047DF7fi | | | 70000700001 | | 047DF8h | | | | | 047DF9h | | | | | | | | | | 047DFBh | | | | | 047DFCh | | | | | 047DFDh | | | 20004 | | | CAN0 Mailbox 31: Time Stamp | | XXXXh | | 047DFFh | | | | | | CAN0 Mask Register 0 | C0MKR0 | XXXX XXXXh | | 047E01h | | | | | 047E02h | | | | | 047E03h | | | | | | CAN0 Mask Register 1 | C0MKR1 | XXXX XXXXh | | 047E05h | | | | | 047E06h | | | | | 047E07h | | | | | | CAN0 Mask Register 2 | C0MKR2 | XXXX XXXXh | | 047E09h | | | | | 047E0Ah | | | | | 047E0Bh | | | | | 047E0Ch | CAN0 Mask Register 3 | C0MKR3 | XXXX XXXXh | | 047E0Dh | 1 | | | | 047E0Eh | | | | | 047E0Fh | | | | | Y: Undefine | | + | | **Table 4.51** SFR List (51) | Address | Pagister Pagister | Cumbal | Doost Value | |-------------|-----------------------------------------|----------|-------------| | Address | Register | Symbol | Reset Value | | 1 | CAN0 Mask Register 4 | C0MKR4 | XXXX XXXXh | | 047E11h | | | | | 047E12h | | | | | 047E13h | | | | | | CAN0 Mask Register 5 | C0MKR5 | XXXX XXXXh | | 047E15h | | | | | 047E16h | | | | | 047E17h | | | | | | CAN0 Mask Register 6 | C0MKR6 | XXXX XXXXh | | 047E19h | | | | | 047E1Ah | | | | | 047E1Bh | | | | | 047E1Ch | CAN0 Mask Register 7 | C0MKR7 | XXXX XXXXh | | 047E1Dh | | | | | 047E1Eh | | | | | 047E1Fh | | | | | 047E20h | CAN0 FIFO Receive ID Compare Register 0 | C0FIDCR0 | XXXX XXXXh | | 047E21h | | | | | 047E22h | | | | | 047E23h | | | | | 047E24h | CAN0 FIFO Receive ID Compare Register 1 | C0FIDCR1 | XXXX XXXXh | | 047E25h | | | | | 047E26h | | | | | 047E27h | | | | | | CAN0 Mask Invalid Register | C0MKIVLR | XXXX XXXXh | | 047E29h | | | | | 047E2Ah | | | | | 047E2Bh | | | | | | CAN0 Mailbox Interrupt Enable Register | COMIER | XXXX XXXXh | | 047E2Dh | <u> </u> | | | | 047E2Eh | | | | | 047E2Fh | | | | | 047E30h | | | | | 047E31h | | | | | 047E32h | | | | | 047E33h | | | | | 047E34h | | | | | 047E35h | | | | | 047E36h | | | | | 047E37h | | | | | 047E38h | | | | | 047E39h | | | | | 047E3Ah | | | | | 047E3Bh | | | | | 047E3Ch | | | | | 047E3Dh | | | | | 047E3Eh | | | | | 047E3E11 | | | | | 047E3FII | | | | | 047E4011 to | | | | | X: Undefine | | | | **Table 4.52** SFR List (52) | | | <del></del> | | |---------|----------------------------------|-------------|-------------| | Address | Register | Symbol | Reset Value | | | CAN0 Message Control Register 0 | C0MCTL0 | 00h | | | CAN0 Message Control Register 1 | C0MCTL1 | 00h | | | CAN0 Message Control Register 2 | C0MCTL2 | 00h | | | CAN0 Message Control Register 3 | C0MCTL3 | 00h | | | CAN0 Message Control Register 4 | C0MCTL4 | 00h | | | CAN0 Message Control Register 5 | C0MCTL5 | 00h | | | CAN0 Message Control Register 6 | C0MCTL6 | 00h | | | CAN0 Message Control Register 7 | C0MCTL7 | 00h | | | CAN0 Message Control Register 8 | C0MCTL8 | 00h | | | CAN0 Message Control Register 9 | C0MCTL9 | 00h | | | CAN0 Message Control Register 10 | C0MCTL10 | 00h | | 047F2Bh | CAN0 Message Control Register 11 | C0MCTL11 | 00h | | 047F2Ch | CAN0 Message Control Register 12 | C0MCTL12 | 00h | | 047F2Dh | CAN0 Message Control Register 13 | C0MCTL13 | 00h | | 047F2Eh | CAN0 Message Control Register 14 | C0MCTL14 | 00h | | 047F2Fh | CAN0 Message Control Register 15 | C0MCTL15 | 00h | | | CAN0 Message Control Register 16 | C0MCTL16 | 00h | | 047F31h | CAN0 Message Control Register 17 | C0MCTL17 | 00h | | 047F32h | CAN0 Message Control Register 18 | C0MCTL18 | 00h | | 047F33h | CAN0 Message Control Register 19 | C0MCTL19 | 00h | | 047F34h | CAN0 Message Control Register 20 | C0MCTL20 | 00h | | 047F35h | CAN0 Message Control Register 21 | C0MCTL21 | 00h | | 047F36h | CAN0 Message Control Register 22 | C0MCTL22 | 00h | | 047F37h | CAN0 Message Control Register 23 | C0MCTL23 | 00h | | 047F38h | CAN0 Message Control Register 24 | C0MCTL24 | 00h | | 047F39h | CAN0 Message Control Register 25 | C0MCTL25 | 00h | | 047F3Ah | CAN0 Message Control Register 26 | C0MCTL26 | 00h | | 047F3Bh | CAN0 Message Control Register 27 | C0MCTL27 | 00h | | 047F3Ch | CAN0 Message Control Register 28 | C0MCTL28 | 00h | | 047F3Dh | CAN0 Message Control Register 29 | C0MCTL29 | 00h | | 047F3Eh | CAN0 Message Control Register 30 | C0MCTL30 | 00h | | 047F3Fh | CAN0 Message Control Register 31 | C0MCTL31 | 00h | **Table 4.53** SFR List (53) | 047F41h | N0 Control Register | C0CTLR | 0000 0101b | |------------|-------------------------------------------|---------|------------| | | | | | | 0475406 04 | | | 0000 0000b | | | N0 Status Register | C0STR | 0000 0101b | | 047F43h | | | 0000 0000b | | 047F44h CA | N0 Bit Configuration Register | C0BCR | 00 0000h | | 047F45h | | | | | 047F46h | | | | | | N0 Clock Select Register | C0CLKR | 000X 0000b | | | N0 Receive FIFO Control Register | C0RFCR | 1000 0000b | | | N0 Receive FIFO Pointer Control Register | C0RFPCR | XXh | | | N0 Transmit FIFO Control Register | C0TFCR | 1000 0000b | | | N0 Transmit FIFO Pointer Control Register | C0TFPCR | XXh | | | N0 Error Interrupt Enable Register | C0EIER | 00h | | | N0 Error Interrupt Factor Judge Register | C0EIFR | 00h | | | N0 Receive Error Count Register | C0RECR | 00h | | | N0 Transmit Error Count Register | C0TECR | 00h | | | N0 Error Code Store Register | C0ECSR | 00h | | | N0 Channel Search Support Register | C0CSSR | XXh | | | N0 Mailbox Search Status Register | C0MSSR | 1000 0000b | | | N0 Mailbox Search Mode Register | C0MSMR | 0000 0000b | | | N0 Time Stamp Register | C0TSR | 0000h | | 047F55h | | | | | | N0 Acceptance Filter Support Register | C0AFSR | XXXXh | | 047F57h | | | | | 047F58h CA | N0 Test Control Register | C0TCR | 00h | | 047F59h | | | | | 047F5Ah | | | | | 047F5Bh | | | | | 047F5Ch | | | | | 047F5Dh | | | | | 047F5Eh | | | | | 047F5Fh | | | | | 047F60h to | | | | | 047FFFh | | | | | 048000h to | | | | | 04FFFFh | | | | X: Undefined ## 5. Resets There are three types of operations for resetting the MCU: hardware reset, software reset, and watchdog timer reset. ## 5.1 Hardware Reset A hardware reset is generated when a low signal is applied to the $\overline{\text{RESET}}$ pin under the recommended operating conditions of the supply voltage. When the $\overline{\text{RESET}}$ pin is driven low, all pins, and oscillators are reset (refer to Table 5.1 for details), and the main clock starts oscillating. The CPU and SFRs are reset by a low-to-high transition on the $\overline{\text{RESET}}$ pin. Then, the CPU starts executing the program from the address indicated by the reset vector. Internal RAM is not affected by a hardware reset. However, if a hardware reset occurs during a write operation to the internal RAM, the value is undefined. Figure 5.1 shows an example of the reset circuit. Figure 5.2 shows the reset sequence. Table 5.1 lists pin states while the RESET pin is held low. Figure 5.3 shows CPU register states after a reset. Refer to 4. "Special Function Registers (SFRs)" for details on the states of SFRs after a reset. - A. Reset when the supply voltage is stable - (1) Drive the $\overline{RESET}$ pin low. - (2) Input at least 20 clock cycles to the XIN pin. - (3) Drive the RESET pin high. - B. Reset when turning on the power - (1) Drive the RESET pin low. - (2) Raise the supply voltage to the recommended operating voltage. - (3) Wait td(P-R) ms until the internal voltage is stabilized. - (4) Input at least 20 clock cycles to the XIN pin. - (5) Drive the $\overline{RESET}$ pin high. Figure 5.1 Reset Circuitry Figure 5.2 Reset Sequence Table 5.1 Pin States while RESET Pin is Held Low (1) | Pin Name | Pin States | |----------|-----------------------------| | P0 to P9 | Input port (high-impedance) | #### Note: 1. Whether a pull-up resistor is enabled or not is undefined until the internal voltage has stabilized. Figure 5.3 CPU Registers after Reset ## 5.2 Software Reset The CPU, SFRs, and pins are reset when the PM03 bit in the PM0 register is set to 1 (the MCU is reset). Then, the CPU executes the program from the address indicated by the reset vector. Figure 5.4 shows the PM0 register. Set the PM03 bit to 1 while the PLL clock is selected as the CPU clock source and the main clock oscillation is completely stable. Figure 5.4 PM0 Register # 5.3 Watchdog Timer Reset The CPU, SFRs, and pins are reset when the watchdog timer underflows while the CM06 bit in the CM0 register is 1 (reset when watchdog timer underflows). Then, the CPU executes the program from the address indicated by the reset vector. ## 5.4 Reset Vector The reset vector in the R32C/100 Series is configured as shown in Figure 5.5. The start address of a program consists of the upper 30 bits of the reset vector and 00b as lower 2 bits. The lower 2 bits of the reset vector are bits to select the external bus width in microprocessor mode. Therefore, the start address of a program requires 4-byte alignment so that the lower 2 bits are 00b. In single-chip mode, set the external bus width select bits to 00b. Figure 5.5 Reset Vector Configuration # 6. Power Management # 6.1 Voltage Regulators for Internal Logic The supply voltage for internal logic is generated by reducing the input voltage from the VCC pin with the voltage regulators. Figure 6.1 shows a block diagram of the voltage regulators for internal logic, and Figure 6.2 shows the VRCR register. Figure 6.1 Block Diagram of Voltage Regulators for Internal Logic Figure 6.2 VRCR Register # 6.1.1 Decoupling Capacitor An external decoupling capacitor is required to stabilize internal voltage. The capacitor should be beneficially effective at higher frequencies and maintain a more stable capacitance irrespective of temperature change. In general, ceramic capacitors are recommended. The capacitance varies by conditions such as operating temperature, DC bias, and aging. To select an appropriate capacitor, these conditions should be considered. Also, refer to the recommended capacitor specifications listed in Table 6.1. The traces between the capacitor and the VDC1/VDC0 pins should be as short and wide as physically possible. **Table 6.1** Recommended Capacitor Specifications | Temperature Characteristics | | | | Nominal | | | |-----------------------------|-----|----------------------------------------|---------------------------|----------------------|---------------------|------------------------------| | Applicable standard | | Operating<br>temperature<br>range (°C) | Capacitance<br>change (%) | Rated Voltage<br>(V) | Capacitance<br>(µF) | Capacitance<br>Tolerance (%) | | В | JIS | -25 to 85 | ±10 | 6.3 or higher | 4.7 | ±20 or better | | R | JIS | -55 to 125 | ±15 | 6.3 or higher | 4.7 | ±20 or better | | X5R | EIA | -55 to 85 | ±15 | 6.3 or higher | 4.7 | ±20 or better | | X7R | EIA | -55 to 125 | ±15 | 6.3 or higher | 4.7 | ±20 or better | | X8R | EIA | -55 to 150 | ±15 | 6.3 or higher | 4.7 | ±20 or better | | X6S | EIA | -55 to 105 | ±22 | 6.3 or higher | 4.7 | ±20 or better | | X7S | EIA | -55 to 125 | ±22 | 6.3 or higher | 4.7 | ±20 or better | # 6.2 Low Voltage Detector The low voltage detector monitors the supply voltage input to the VCC pin. This circuit is used to monitor the power supply upstream of the voltage regulators for internal logic and provide advanced warning that the power is about to fail. By providing a few milliseconds of advanced warning, the CPU can save any critical parameters to the flash memory and safely shut down. Figure 6.3 shows a block diagram of the low voltage detector, and Figures 6.4 and 6.5 show registers associated with the circuit. Figure 6.3 Low Voltage Detector Block Diagram - 1. Set the PRC31 bit in the PRCR3 register to 1 (write enabled) before rewriting this register. - 2. Before setting this bit to 1, set the VDEN bit to 1 first, and wait until the circuit is stabilized. - 3. This bit is enabled when the VDEN bit is set to 1. - 4. This bit can be set to 0 by a program (Writing 1 to this bit has no effect). Figure 6.4 LVDC Register #### Notes: - 1. Set the PRC31 bit in the PRCR3 register to 1 (write enabled) before rewriting this register. Rewrite this register when the VDEN bit in the LVDC register is 0 (low voltage detector disabled). - 2. Refer to the following table for detected voltages Vdet(F) and Vdet(R). | Reference Voltage | Low-detection Voltage<br>Vdet(F) | Rise-detection Voltage<br>Vdet(R) | |-------------------|----------------------------------|-----------------------------------| | 4.65 V | 4.55 V | 4.77 V | | 4.50 V | 4.40 V | 4.62 V | | 4.35 V | 4.24 V | 4.46 V | | 4.20 V | 4.09 V | 4.31 V | | 4.05 V | 3.95 V | 4.17 V | | 3.90 V | 3.80 V | 4.02 V | | 3.75 V | 3.65 V | 3.87 V | | 3.60 V | 3.50 V | 3.72 V | | 3.45 V | 3.35 V | 3.57 V | | 3.30 V | 3.20 V | 3.42 V | Figure 6.5 DVCR Register # 6.2.1 Operational State of Low Voltage Detector The low voltage detector starts operating stably after td(E-A) when the VDEN bit in the LVDC register is set to 1 (low voltage detector enabled). When the input voltage to the VCC pin drops below Vdet(F), the VMF bit becomes 0 (VCC < Vdet) and the LVDF bit becomes 1 (low voltage detected (Vdet passed)). At this point an interrupt request is generated when the LVDIEN bit is 1 (low voltage detection interrupt enabled). Set the LVDF bit to 0 (low voltage undetected) by a program. When the voltage rises above Vdet(R) again, the VMF bit becomes to 1 (VCC $\geq$ Vdet) and the LVDF bit becomes 1. At this point an interrupt request is generated when the LVDIEN bit is 1. Figure 6.6 shows the operation of the low voltage detector. Figure 6.6 Low Voltage Detector Operation ## 6.2.2 Low Voltage Detection Interrupt A low voltage detection interrupt request is generated when the input voltage at the VCC pin rises above the Vdet(R) level, or falls below the Vdet(F) level while the LVDIEN bit in the LVDC register is 1 (low voltage detection interrupt enabled). This interrupt shares the interrupt vector with the watchdog timer interrupt and oscillator stop detection interrupt. When using the low voltage detection interrupt either or both with the other interrupts at the same time, read the LVDF bit in the LVDC register in the interrupt handler and confirm that the low voltage detection interrupt has been occurred. The LVDF bit becomes 1 when the input voltage at the VCC pin passes the Vdet(R) level or Vdet(F) level. When the LVDF bit changes from 0 to 1, a low voltage detection interrupt request is generated. Set this bit to 0 (low voltage undetected) by a program. # 6.2.3 Application Example of the Low Voltage Detector Figure 6.7 shows an example of the low voltage detection interrupt. The supply voltage for internal logic is generated by reducing the input voltage from the VCC pin with the voltage regulators. When the input voltage begins to fall, the internal voltage remains steady. However, as the VCC supply voltage continues to fall, the supply voltage for the internal logic also begins to fall, which may affect MCU operation. Consequently, the system can be safely shut down between when the VCC supply voltage begins to fall and when the supply voltage for internal logic begins to fall. The low voltage detection interrupt can be applied to detect the falling input voltage. Figure 6.7 Example of the Low Voltage Detection Interrupt # 7. Clock Generator # 7.1 Clock Generator Types The clock generator consists of four circuits: - · Main clock oscillator - · Sub clock oscillator - PLL frequency synthesizer - On-chip oscillator (OCO) Table 7.1 lists the specifications of the clock generator. Figure 7.1 shows a block diagram of the clock generator, and Figures 7.2 to 7.10 show registers associated with clock control. Table 7.1 Clock Generator Specifications | Item | Main Clock<br>Oscillator | Sub Clock Oscillator | PLL Frequency<br>Synthesizer | On-chip Oscillator | |------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------| | Used as | PLL reference<br>clock source Peripheral clock<br>source | CPU clock source Clock source for timers A and B | CPU clock source Peripheral clock source | CPU clock source Clock source for timers A and B | | Clock frequency | 4 to 8 MHz | 32.768 kHz | f <sub>SO(PLL)</sub> or f <sub>(PLL)</sub> | Approx. 125 kHz | | Connectable oscillators or additional circuits | Ceramic resonator<br>Crystal oscillator | Crystal oscillator | _ | _ | | Pins for oscillators or additional circuits | XIN, XOUT | XCIN, XCOUT | _ | _ | | Oscillator stop/<br>restart function | Available | Available | Available | Available | | Oscillator state after a reset | Running | Stopped | Running | Stopped | | Note | Externally generated clock can be input | Externally generated clock can be input | When the main clock<br>oscillator stops<br>running, the PLL<br>frequency<br>synthesizer<br>oscillates at its own<br>frequency of f <sub>SO(PLL)</sub> | oscillator starts<br>running by setting<br>the CSPM bit in the<br>OFS area to 0 after a<br>reset | Figure 7.1 Clock Generation Circuitry #### Notes: - 1. Set the PRR register to AAh (write enabled) before rewriting this register. - 2. The divide ratios of the base clock and peripheral bus clock should not be changed simultaneously. Doing so may cause the peripheral bus clock frequency to go over the maximum operating frequency. - 3. The divide ratio of the CPU clock should be equal to or lower than that of peripheral bus clock. - 4. Set this bit only once after a reset and do not change the setting afterwards. Rewrite the PBC register before rewriting this bit. - 5. To set this bit to 1, a 32-bit write access to addresses 0004h to 0007h should be performed. - 6. To use these low speed clocks, select one of them by setting bits CM31 and CM30 in the CM3 register and then set the BCS bit to 1. Figure 7.2 CCR Register #### Notes: - 1. Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. - 2. When the PM21 bit in the PM2 register is 1 (clock change disabled), bits CM02 and CM05 cannot be changed by a write access. - 3. fC32 and f2n (whose clock source is the main clock) do not stop. - 4. When entering stop mode, the CM03 bit becomes 1. - 5. To set the CM04 bit to 1, set bits PD8\_7 and PD8\_6 in the PD8 register to 0 (input), and the PU25 bit in the PUR2 register to 0 (pull-up resistor disabled). - 6. This bit stops the main clock when entering low power mode. It cannot detect whether or not the main clock oscillator stops. When this bit is set to 1, the clock applied to the XOUT pin becomes high. Since the on-chip feedback resistor remains connected, the XIN pin is connected to the XOUT pin via the feedback resistor. - Set this bit before activating the watchdog timer. When rewriting this bit while the watchdog timer is running, set it immediately after writing to the WDTS register. - 8. Once this bit is set to 1, it cannot be set to 0 by a program. Figure 7.3 CM0 Register - 1. Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. - 2. When the BCS bit in the CCR register is 0 (PLL clock selected as base clock source), the PLL frequency synthesizer does not stop oscillating even if the CM10 bit is set to 1. - 3. When the PM21 bit in the PM2 register is 1 (clock change disabled), the CM10 bit cannot be changed by a write access - 4. This bit becomes 1 when the main clock is stopped. When setting to 0, rewrite it after the main clock oscillation is fully stabilized. Figure 7.4 CM1 Register - - 1. Set the PRC0 bit in the PRCR register to 1 (write enabled) before rewriting this register. - Set this bit to 0 when f256 is selected as the base clock source in low speed mode. - 3. When the PM21 bit in the PM2 register is 1 (clock change disabled), the CM20 bit cannot be changed by a write access. - 4. When a main clock oscillator stop is detected, this bit becomes 1. It can be set to 0 by a program, however not to 1. When it is set to 0 while the main clock oscillator is stopped, it does not become 1 until the next main clock oscillator stop is detected. - 5. After an oscillator stop detection interrupt occurs, read this bit several times to determine the main clock Figure 7.5 **CM2 Register** Figure 7.6 CM3 Register Figure 7.7 TCSPR Register Figure 7.8 CPSRF Register #### Notes: - 1. Set the PRC1 bit in the PRCR register to 1 (write enabled) before rewriting this register. - 2. Once this bit is set to 1, it cannot be set to 0 by a program. CM02 bit in the CM0 register (the peripheral clock source state in wait mode) CM05 bit in the CM0 register (main clock oscillator enabled/disabled) CM10 bit in the CM1 register (PLL oscillator enabled/disabled) CM20 bit in the CM2 register (oscillator stop detection enabled/disabled) - 4. This bit should be set before the watchdog timer activates. - When the PM22 bit is set to 1, the state changes as follows: - -On-chip oscillator clock starts running - -On-chip oscillator clock functions as the count source of the watchdog timer - -The watchdog timer is not stopped - 5. When the PM24 bit is 0, the forced cutoff of the three-phase motor control timers is also disabled. - 6. Stop all the peripherals that use f2n before rewriting this bit. Figure 7.9 PM2 Register Figure 7.10 PM3 Register specified in the electrical characteristics The following sections illustrate clocks generated in clock generators. ## 7.1.1 Main Clock The main clock is generated by the main clock oscillator. This clock can be a clock source for the PLL reference clock or peripheral clocks. It also functions as an operating clock for the CAN module. The main clock oscillator is configured with two pins, XIN and XOUT, connected by an oscillator or resonator. The circuit has an on-chip feedback resistor which is separated from the oscillator in stop mode to save power consumption. An external clock can be applied to the XIN pin in this circuit. Figure 7.11 shows an example of a main clock circuit connection. Circuit constants vary depending on the oscillator. Circuit constants should be set as per the oscillator manufacturer's recommendations. After a reset, the main clock oscillator is still independently active and disconnected from the PLL frequency synthesizer. A PLL frequency synthesizer self-oscillating clock divided by 12 is provided to the CPU. Setting the CM05 bit in the CM0 register to 1 (main clock oscillator disabled) enables power-saving. In this case, the clock applied to the XOUT pin becomes high. The XIN pin connected to the XOUT pin by an embedded feedback resistor is also driven high. Do not set the CM05 bit to 1 when an external clock is applied to the XIN pin. All clocks, including the main clock, stop in stop mode. Refer to 7.7 "Power Control" for details. Figure 7.11 Main Clock Circuit Connection # 7.1.2 Sub Clock (fC) The sub clock is generated by the sub clock oscillator. This clock can be a clock source for the CPU clock and a count source for timers A and B. It can be output from the CLKOUT pin. The sub clock oscillator is configured with pins XCIN and XCOUT connected by a crystal oscillator. The circuit has a on-chip feedback resistor which is separated from the oscillator in stop mode to save power consumption. An external clock can be applied to the XCIN pin. Figure 7.12 shows an example of a sub clock circuit connection. Circuit constants vary depending on the oscillator. Circuit constants should be set as per the oscillator manufacturer's recommendations. After a reset, the sub clock is stopped and the feedback resistor is separated from the oscillator. In order to start the sub clock oscillation, first set bits PD8\_6 and PD8\_7 in the PD8 register to 0 (input mode), and the PU25 bit in the PUR2 register to 0 (pull-up resistor disabled). Then, set the CM04 bit in the CM0 register to 1 (XCIN-XCOUT oscillator). To input an external clock to the XCIN pin, set bits PD8\_7 and PU25 to 0 and then the CM04 bit to 1. The clock applied to the XCIN pin becomes a clock source for the sub clock. When the CM3 register is set to 00h (fC) and the BCS bit in the CCR register is set to 1 (fC, fOCO4, or f256) after the sub clock oscillation has stabilized, the sub clock becomes the base clock of the CPU clock and the peripheral bus clock. All clocks, including the sub clock, stop in stop mode. Refer to 7.7 "Power Control" for details. Figure 7.12 Sub Clock Circuit Connection #### 7.1.3 PLL Clock The PLL clock is generated by the PLL frequency synthesizer based on the main clock. This clock can be a clock source for any clock including the CPU clock and the peripheral clock. Figure 7.13 shows a block diagram of the PLL frequency synthesizer. Figures 7.14 and 7.15 show registers PLC0 and PLC1, respectively. Figure 7.16 shows the PLS register. Figure 7.13 PLL Frequency Synthesizer Block Diagram Figure 7.14 PLC0 Register Figure 7.15 PLC1 Register Figure 7.16 PLS Register In the PLL frequency synthesizer, the pulse-swallow operation is implemented. The divide ratio m is simply expressed by $n \times p$ . However, with the swallow counter, the divide ratio p is 6 in a out of n, or 5 in other cases, the actual m is therefore given by the formula below: $$m = n \times p$$ $$= n \times \left(\frac{a}{n} \cdot 6 + \frac{n-a}{n} \cdot 5\right)$$ $$= 5n + a$$ The setting range of *a* is $0 \le a < 5$ , $0 \le a \le n$ . As r is the divide ratio of the reference counter, the PLL clock has a m/r times the main clock (XIN) frequency. PLL clock frequency $$f(PLL) = \frac{m}{r} \cdot \text{main clock frequency}$$ = $\frac{5n+a}{r} \cdot \text{main clock frequency}$ After a reset, the reference counter is divided by 16, and the PLL frequency synthesizer is multiplied by 10. Since the main clock as a reference clock is disconnected, the PLL frequency synthesizer may self-oscillate at its own frequency of f<sub>SO(PLL)</sub>. Each register should be set to meet the following conditions: - -The reference clock, which is the main clock divided by r, should be between 2 to 4 MHz. - -The divide ratio *m* is $25 \le m \le 100$ . For the setting of registers PLC1 and PLC0, Table 7.2 should be applied. While the main clock oscillation is stable, a wait time of $t_{LOCK(PLL)}$ is necessary between rewriting registers PLC1 and PLC0, and the PLL clock becoming stable. Table 7.2 PLC1 and PLC0 Register Settings (1) | Main Clock | r | Reference<br>Clock | n | а | m | PLC1<br>Register<br>Setting | PLC0<br>Register<br>Setting | m/r | PLL Clock | |------------|---|--------------------|----|---|----|-----------------------------|-----------------------------|---------|-----------| | 4 MHz | 2 | 2 MHz | 9 | 3 | 48 | 01h | 68h | 24 | 96 MHz | | 6 MHz | 2 | 3 MHz | 6 | 2 | 32 | 01h | 45h | 16 | 96 MHz | | 8 MHz | 3 | 2.6667 MHz | 7 | 1 | 36 | 02h | 26h | 12 | 96 MHz | | 4 MHz | 1 | 4 MHz | 6 | 0 | 30 | 00h | 05h | 30 | 120 MHz | | 5 MHz | 2 | 2.5 MHz | 9 | 3 | 48 | 01h | 68h | 24 | 120 MHz | | 6 MHz | 2 | 3 MHz | 8 | 0 | 40 | 01h | 07h | 20 | 120 MHz | | 8 MHz | 2 | 4 MHz | 6 | 0 | 30 | 01h | 05h | 15 | 120 MHz | | 4 MHz | 1 | 4 MHz | 6 | 2 | 32 | 00h | 45h | 32 | 128 MHz | | 6 MHz | 3 | 2 MHz | 12 | 4 | 64 | 02h | 8Bh | 21.3333 | 128 MHz | | 8 MHz | 2 | 4 MHz | 6 | 2 | 32 | 01h | 45h | 16 | 128 MHz | Note: 1. Registers PLC1 and PLC0 should be set according to the list above. ## 7.1.4 On-chip Oscillator Clock The on-chip oscillator clock is generated by the on-chip oscillator (OCO). This clock can be a clock source for the CPU clock and a count source for timers A and B. This clock has a frequency of approximately 125 kHz. The on-chip oscillator clock divided by 4 can be used as the base clock for the CPU clock and peripheral bus clock. When the CSPM bit in the OFS area is 1, the on-chip oscillator clock is stopped after a reset. It starts running if the CM31 bit in the CM3 register or the PM22 bit in the PM2 register is set to 1. It is not necessary to wait for stabilization because the on-chip oscillator instantly starts oscillating. ### 7.2 Oscillator Stop Detection This function detects the main clock is stopped when its oscillator stops running due to an external factor. When the CM20 bit in the CM2 register is 1 (enable oscillator stop detection), an oscillator stop detection interrupt request is generated as soon as the main clock stops. Simultaneously, the PLL frequency synthesizer starts to self-oscillate at its own frequency. If the PLL frequency synthesizer is the clock source for CPU clock and peripheral clock, these clocks continue running. When an oscillator stop is detected, the following bits in the CM2 register become 1: - The CM22 bit: main clock oscillator stop detected - The CM23 bit: main clock oscillator stopped ## 7.2.1 How to Use Oscillator Stop Detection The oscillator stop detection interrupt shares vectors with the watchdog timer interrupt and the low voltage detection interrupt. When using these interrupts simultaneously, read the CM22 bit with an interrupt handler to determine if an oscillator stop detection interrupt request has been generated. When the main clock oscillator resumes running after an oscillator stop is detected, the PLL clock frequency may temporarily exceed the preset value before the PLL frequency synthesizer oscillation stabilizes. As soon as an oscillator stop is detected, the main clock oscillator should be stopped from resuming (set the CM05 bit in the CM0 register to 1) or the divide ratios of the base clock and peripheral clock source should be increased by a program. They can be set using bits BCD1 and BCD0 in the CCR register and bits PM36 and PM35 in the PM3 register. In low speed mode, when the main clock oscillator stops running, an oscillator stop detection interrupt request is generated if the CM20 bit is set to 1 (enable oscillator stop detection). The CPU clock remains running with a low speed clock source. Note that if the base clock is f256, which is the main clock divided by 256, oscillator stop detection cannot be used. The oscillator stop detection is provided to handle main clock stop caused by external factors. To stop the main clock oscillator by a program, i.e., to enter stop mode or to set the CM05 bit to 1 (main clock oscillator disabled), the CM20 bit in the CM2 register should be set to 0 (disable oscillator stop detection). To enter wait mode, this bit should be also set to 0. The oscillator stop detection functions depending on the voltage of a capacitor which is being changed. In more concrete terms, this function detects that the oscillator is stopped when the main clock goes lower than approximately 500 kHz. Note that if the CM22 bit is set to 0 by a program in an interrupt handler while the frequency is around 500 kHz, a stack overflow may occur due to multiple interrupt requests. #### 7.3 Base Clock The base clock is a reference clock for the CPU clock and peripheral bus clock. The base clock after a reset is the PLL clock divided by 6. The base clock source is selected between the PLL clock and the low speed clocks which contain the sub clock (fC), on-chip oscillator clock divided by 4 (fOCO4), and main clock divided by 256 (f256). If the PLL clock is selected, it is divided by 2, 3, 4, or 6 to become the base clock. If a low speed clock is selected, the clock itself can be the base clock. The base clock source is set using the BCS bit in the CCR register and the divide ratio for the PLL clock is set using bits BCD1 and BCD0. Bits CM31 and CM30 in the CM3 register select a low speed clock. ### 7.4 CPU Clock and Peripheral Bus Clock The CPU operating clock is referred to as the CPU clock. The CPU clock after a reset is the base clock divided by 2. The CPU clock source is the base clock, and its divide ratio is selected by setting bits CCD1 and CCD0 in the CCR register. The base clock divided by 2 to 4 becomes the peripheral bus clock. Its divide ratio is selected by setting bits PCD1 and PCD0 in the CCR register. The peripheral bus clock also functions as a count source for the watchdog timer and operating clock for the serial bus interface and the CAN module. To prevent the CPU clock, whose clock source is the PLL clock, from stopping when the CPU becomes out of control, set the following while the CM05 bit in the CM0 register is 0 (main clock oscillator enabled) and the BCS bit in the CCR register is 0 (PLL clock selected as base clock source): - (1) Set the PRC1 bit in the PRCR register to 1 (write enabled to the PM2 register). - (2) Set the PM21 bit in the PM2 register to 1 (clock change disabled). ### 7.5 Peripheral Clock The peripheral clock is an operating clock or a count source for the peripherals excluding the watchdog timer, the serial bus interface, and the CAN module. The source of this clock is generated by a clock, which has the same frequency as the PLL clock, divided by 2, 4, 6, or 8 according to the settings of bits PM36 and PM35 in the PM3 register. The peripheral clock is classified into three types of clock as follows: ### (1) f1, f8, f32, f2n f1, f8, and f32 are the peripheral clock sources divided by 1, 8, and 32, respectively. The clock source for f2n is selected between the peripheral clock source and the main clock by setting the PM26 bit in the PM2 register. The f2n divide ratio can be set using bits CNT3 to CNT0 in the TCSPR register (n = 1 to 15, not divided when n = 0). f1, f8, f32, and f2n, whose clock source is the peripheral clock source, stop in low power mode or when the CM02 bit is set to 1 (peripheral clock source stopped in wait mode) to enter wait mode. f1, f8, and f2n are used as a count source for timers A and B or an operating clock for the serial interface and the LIN module. f1 is used as an operating clock for the intelligent I/O as well. The f32 is used as an operating clock for the LIN module as well. f8 and f32 can be output from the CLKOUT pin. Refer to 7.6 "Clock Output Function" for details. #### (2) fAD fAD, which has the same frequency as peripheral clock source, is an operating clock for the A/D converter. This clock stops in low power mode or when the CM02 bit is set to 1 (peripheral clock source stopped in wait mode) to enter wait mode. #### (3) fC32 fC32, which is a sub clock divided by 32, or on-chip oscillator clock divided by 128, is used as the count source for timers A and B. This clock is available when the sub clock or on-chip oscillator clock is active. # 7.6 Clock Output Function Low speed clocks, f8, and f32 can be output from the CLKOUT pin. Table 7.3 lists the CLKOUT pin functions. Table 7.3 CLKOUT Pin Functions | CM0 Re | gister (1) | CLKOUT Pin Function | | |--------|------------|--------------------------|--| | CM01 | CM00 | CERCOTT IIIT directori | | | 0 | 0 | I/O port P5_3 | | | 0 | 1 | Output a low speed clock | | | 1 | 0 | Output f8 | | | 1 | 1 | Output f32 | | ### Note: 1. Set the PRC0 bit in the PRCR register 1 (write enabled) before rewriting this register. #### 7.7 Power Control Power control has three modes: wait mode, stop mode, and normal operating mode. The name "normal operating mode" is used restrictively in this chapter, and it indicates all other modes except wait mode and stop mode. Figure 7.17 shows a block diagram of the state transition in normal operating mode, stop mode, and wait mode. Figure 7.17 State Transition in Stop Mode and Wait Mode ## 7.7.1 Normal Operating Mode Normal operating mode is classified into the five modes shown below. In normal operating mode, the CPU clock and peripheral clock are provided to operate the CPU and peripherals. Power consumption is controlled by the CPU clock frequency. The higher the CPU clock frequency is, the more processing power increases. The lower the CPU clock frequency is, the less power consumption is required. Power consumption can be reduced by stopping oscillators that are not being used. #### (1) PLL Mode (high speed mode) In this mode, the PLL clock is selected as the base clock source, and the main clock is provided as the reference clock source for the PLL frequency synthesizer. High speed mode enables the CPU to operate at the maximum operating frequency. The PLL clock divided by 2 becomes the base clock. The base clock frequency should be identical to that of the CPU clock. fAD, f1, f8, f32, and f2n can be used as the peripheral clocks. When the sub clock or the on-chip oscillator clock is provided, fC32 can be used as the count source for timers A and B. #### (2) PLL Mode (medium speed mode) This mode indicates all modes in PLL mode except high speed mode. The PLL clock divided by 2, 3, 4, or 6 becomes the base clock and the base clock divided by 1 to 4 becomes the CPU clock. fAD, f1, f8, f32, and f2n can be used as the peripheral clocks. When the sub clock or the on-chip oscillator clock is provided, fC32 can be used as the count source for timers A and B. #### (3) Low Speed Mode In this mode, a low speed clock is used as the base clock source. The low speed clock becomes the base clock and the base clock divided by 1 to 4 becomes the CPU clock. fAD, f1, f8, f32, and f2n can be used as the peripheral clocks. When the sub clock or the on-chip oscillator clock is provided, fC32 can be used as the count source for timers A and B. ## (4) Low Power Mode This is a state where the main clock oscillator and the PLL frequency synthesizer are stopped after switching to low speed mode. The sub clock or the on-chip oscillator clock divided by 4 becomes the base clock and the base clock divided by 1 to 4 becomes the CPU clock. fC32, which is the only peripheral clock available, can be used as the count source for timers A and B. By setting the MRS bit in the VRCR register to 1 (main regulator stopped), this mode consumes even less power than the modes above. #### (5) PLL Self-oscillation Mode In this mode, the PLL clock is selected as the base clock source, and the main clock is not provided as the reference clock source for the PLL frequency synthesizer. The PLL frequency synthesizer self-oscillates at its own frequency. The PLL clock divided by 2, 3, 4, or 6 becomes the base clock and the base clock divided by 1 to 4 becomes the CPU clock. fAD, f1, f8, f32, and f2n can be used as the peripheral clocks. When the sub clock or the on-chip oscillator clock is provided, fC32 can be used as the count source for timers A and B. The state transition within normal operating mode can be very complicated; therefore only the block diagrams of typical state transitions are shown. Figures 7.18 to 7.20 show block diagrams of the respective state transitions: state when the sub clock is used, state when the main clock divided by 256 is used, and state when the on-chip oscillator clock is used. As for the state transitions other than the above, setting of each register and the usage notes below can be used as references. - PLL can be switched from PLL oscillating to self-oscillating by setting the SEO bit in the PLC1 register to 1. Set the SEO bit to 1 (self-oscillating) before setting the CM05 bit in the CM0 register to 0 (main clock oscillator disabled) to stop the main clock. - The divide ratio of the clock should be increased and the frequency should be decreased by using bits BCD1 to BCD0 in the CCR register or bits PM36 to PM35 in the PM3 register before setting the SEO bit to 0 (PLL oscillating) in order to switch back PLL self-oscillation mode to PLL mode. Set back the settings of bits BCD1 to BCD0 and bits PM36 to PM35 once PLL oscillation is stabilized after setting the SEO bit to 0. - Before switching the CPU clock to another clock, that clock should be stabilized. In particular, the sub clock oscillator may require more time to stabilize <sup>(1)</sup>. Therefore, certain waiting time to switch should be taken by a program immediately after turning the MCU on or exiting stop mode. #### Note: 1. Contact the oscillator manufacturer for details on oscillator stabilization time. Figure 7.18 State Transition When Using the Sub Clock Figure 7.19 State Transition When Using the Main Clock Divided by 256 Figure 7.20 State Transition When Using the On-chip Oscillator Clock #### 7.7.2 Wait Mode The base clock stops in wait mode so that clocks generated by the base clock, the CPU clock and peripheral bus clock, stop running as well. Thus the CPU and watchdog timer, operated by these two clocks, also stop. However, the watchdog timer continues operating when the PM22 bit in the PM2 register is 1 (on-chip oscillator selected as count source for the watchdog timer). Since the main clock, sub clock, PLL clock, and on-chip oscillator clock continue running, the peripherals using these clocks also continue operating. ## 7.7.2.1 Peripheral Clock Source Stop Function When the CM02 bit in the CM0 register is 1 (peripheral clock source stopped in wait mode), power consumption is reduced since peripheral clocks f1, f8, f32, f2n (when the clock source is the peripheral clock source), and fAD stop running in wait mode. fC32 and f2n (when the clock source is the main clock) do not stop running. ### 7.7.2.2 Entering Wait Mode To enter wait mode, the following procedures should be completed before the WAIT instruction is executed. · Initial setting Set the wake-up interrupt priority level (bits RLVL2 to RLVL0 in registers RIPL1 and RIPL2) to 7. Then set each interrupt request level. - · Steps before entering wait mode - (1) Set the I flag to 0. - (2) Set the interrupt request level for each interrupt source (interrupt number from 1 to 127) to 0, if its interrupt request level is not 0. - (3) Perform a dummy read of any of the interrupt control registers. - (4) Set the processor interrupt priority level (IPL) in the flag register to 0. - (5) Enable interrupts temporarily by executing the following instructions: FSET I NOP NOP FCLR I - (6) Set the interrupt request level for the interrupt to exit wait mode. - Do not rewrite the interrupt control register after this step. - (7) Set the IPL in the flag register. - (8) Set the interrupt priority level for resuming to the same level as the IPL. Interrupt request level for the interrupt to exit wait mode > IPL = Interrupt priority level for resuming - (9) Set the CM20 bit in the CM2 register to 0 (disable oscillator stop detection) when the oscillator stop detection is used. - (10)Enter either low speed mode or low power mode. - (11)Set the I flag to 1. - (12)Execute the WAIT instruction. - After exiting wait mode Set the wake-up interrupt priority level to 7 immediately after exiting wait mode. #### 7.7.2.3 Pin State in Wait Mode Table 7.4 lists the pin state in wait mode. Table 7.4 Pin State in Wait Mode | Pin | | State in Wait Mode | | |--------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Ports | | The state immediately before entering wait mode is held | | | CLKOUT | When a low speed clock is selected | The clock is output | | | | When f8 or f32 is selected | The clock is output when the CM02 bit in the CM0 register is 0 (no peripheral clock source stopped in wait mode). The state immediately before entering wait mode is held when the CM02 bit is 1 (peripheral clock source stopped in wait mode) | | ### 7.7.2.4 Exiting Wait Mode The MCU exits wait mode by a hardware reset, an NMI, or a peripheral interrupt assigned to software interrupt number from 0 to 63. To exit wait mode using either a hardware reset or NMI, without using peripheral interrupts, set bits ILVL2 to ILVL0 for the peripheral interrupts to 000b (interrupt disabled) before executing the WAIT instruction. The CM02 bit setting in the CM0 register affects the peripheral interrupts. When the CM02 bit is 0 (peripheral clock source not stopped in wait mode), peripheral interrupts for software interrupt numbers from 0 to 63 can be used to exit wait mode. When this bit is 1 (peripheral clock source stopped in wait mode), peripherals operated using clocks (f1, f8, f32, f2n whose clock source is the peripheral clock source, and fAD) generated by the peripheral clock source stop operating. Therefore, the peripheral interrupts cannot be used to exit wait mode. However, peripherals operated using clocks which are independent from the peripheral clock source (fC32, external clock, and f2n whose clock source is the main clock) do not stop operating. Thus, interrupts generated by these peripherals and assigned to software interrupt numbers from 0 to 63 can be used to exit wait mode. The CPU clock used when exiting wait mode by a peripheral interrupt or an NMI is the same clock used when the WAIT instruction is executed. Table 7.5 lists interrupts used to exit wait mode and usage conditions. Table 7.5 Interrupts for Exiting Wait Mode and Usage Conditions | Interrupt | When the CM02 Bit is 0 | When the CM02 Bit is 1 | |-------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | NMI | Available | Available | | External interrupt | Available | Available | | Low voltage detection interrupt | Available | Available | | Watchdog timer interrupt | Should not be used | Should not be used | | Timer A interrupt Timer B interrupt | Available in any mode | Available in event counter mode, or when the count source is fC32 or f2n (when the main clock is selected as the clock source) | | Serial interface interrupt (1) | Available when an internal or external clock is used | Available when the external clock or f2n (when the main clock is selected as the clock source) is used | | A/D conversion interrupt | Available in single mode or single-<br>sweep mode | Should not be used | | Intelligent I/O interrupt | Available | Should not be used | | LIN Low detection interrupt | Available | Available | | CAN wake-up interrupt | Available | Available | ### Note: 1. UART3 and UART4 are excluded. ### 7.7.3 Stop Mode In stop mode, all of the clocks, except for those that are protected, stop running. That is, the CPU and peripherals, operated by the CPU clock and peripheral clock, also stop. This mode saves the most power. ## 7.7.3.1 Entering Stop Mode To enter stop mode, the following procedures should be done before the STOP instruction is executed. Initial setting Set the wake-up interrupt priority level (bits RLVL2 to RLVL0 in registers RIPL1 and RIPL2) to 7. Then set each interrupt request level. - Steps before entering stop mode - (1) Set the I flag to 0. - (2) Set the interrupt request level for each interrupt source (interrupt number from 1 to 127) to 0, if the interrupt request level is not 0. - (3) Perform a dummy read of any of the interrupt control registers. - (4) Set the processor interrupt priority level (IPL) in the flag register to 0. - (5) Enable interrupts temporarily by executing the following instructions: FSET I NOP NOP FCLR I - (6) Set the interrupt request level for the interrupt to exit stop mode. - Do not rewrite the interrupt control register after this step. - (7) Set the IPL in the flag register. - (8) Set the interrupt priority level for resuming to the same level as the IPL. Interrupt request level for the interrupt to exit stop mode > IPL = Interrupt priority level for resuming - (9) Set the CM20 bit in the CM2 register to 0 (oscillator stop detection disabled) when the oscillator stop detection is used. - (10)Change the base clock to either the main clock divided by 256 (f256) or the on-chip oscillator clock divided by 4 (fOCO4). - (11)Set the I flag to 1. - (12)Execute the STOP instruction. - After exiting stop mode Set the wake-up interrupt priority level to 7 immediately after exiting stop mode. ## 7.7.3.2 Pin State in Stop Mode Table 7.6 lists the pin state in stop mode. Table 7.6 Pin State in Stop Mode | Pin | | State in Stop Mode | | |-------------------------------------------|----------------------------|---------------------------------------------------------|--| | Ports | | The state immediately before entering stop mode is held | | | CLKOUT When a low speed clock is selected | | High | | | | When f8 or f32 is selected | The state immediately before entering stop mode is held | | | XIN | | High-impedance | | | XOUT | | High | | | XCIN, XCOUT | | High-impedance | | ## 7.7.3.3 Exiting Stop Mode The MCU exits stop mode by a hardware reset, NMI, low voltage detection interrupt, or a peripheral interrupt assigned to software interrupt number from 0 to 63. To exit stop mode using either a hardware reset or NMI, without using peripheral interrupts, set bits ILVL2 to ILVL0 for the peripheral interrupts to 000b (interrupt disabled) before executing the STOP instruction. The CPU clock used when exiting stop mode by a peripheral interrupt or NMI is the same clock used when the STOP instruction is executed. Table 7.7 lists interrupts used to exit stop mode and usage conditions. Table 7.7 Interrupts for Exiting Stop Mode and Usage Conditions | Interrupt | Usage Condition | | |---------------------------------|-------------------------------------------------------------------------|--| | NMI | | | | Low voltage detection interrupt | | | | External interrupt | | | | Timer A interrupt | Available when a timer counts an external pulse with a frequency of 100 | | | Timer B interrupt | Hz or less in event counter mode | | | Serial interface interrupt (1) | Available when an external clock is used | | | LIN Low detection interrupt | | | | CAN wake-up interrupt | | | #### Note: 1. UART3 and UART4 are excluded. ## 7.8 System Clock Protection The system clock protection disables clock change when the PLL clock is selected as the base clock source. This prevents the CPU clock from stopping due to a runaway program. When the PM21 bit in the PM2 register is set to 1 (clock change disabled), the following bits cannot be written to: - Bits CM02 and CM05 in the CM0 register - The CM10 bit in the CM1 register - The CM20 bit in the CM2 register - The PM27 bit in the PM2 register To use the system clock protection, set the CM05 bit in the CM0 register to 0 (main clock oscillator enabled) and the BCS bit in the CCR register to 0 (PLL clock selected as base clock source) before the following procedure is done: - (1) Set the PRC1 bit in the PRCR register to 1 (write to the 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 the PM2 register disabled). #### 7.9 Notes on Clock Generator #### 7.9.1 Sub Clock ## 7.9.1.1 Oscillator Constant Matching The constant matching of the sub clock oscillator should be evaluated in both cases when the drive strength is high and low. Contact the oscillator manufacturer for details on the oscillation circuit constant matching. #### 7.9.2 Power Control Do not switch the base clock source until the oscillation of the clock to be used has stabilized. However, this does not apply to the on-chip oscillator since it starts running immediately after the CM31 bit in the CM3 register is set to 1. To switch the base clock source from the PLL clock to a low speed clock, use the MOV.L or OR.L instruction to set the BCS bit in the CCR register to 1. - Program example in assembly language OR.L #80h, 0004h - Program example in C language asm("OR.L #80h, 0004h"); ### 7.9.2.1 Stop Mode • To exit stop mode using a reset, apply a low signal to the RESET pin until the main clock oscillation stabilizes. ### 7.9.2.2 Suggestions for Power Saving The following are suggestions to reduce power consumption when programming or designing systems. - I/O pins: - If inputs are floating, both transistors may be conducting. Set unassigned pins to input mode and connect each of them to VSS via a resistor, or set them to output mode and leave them open. - A/D converter: - When not performing the A/D conversion, set the VCUT bit in the AD0CON1 register to 0 (VREF disconnected). To perform the A/D conversion, set the VCUT bit to 1 (VREF connected) and wait at least 1 µs before starting conversion. - Peripheral clock stop: - When entering wait mode, power consumption can be reduced by setting the CM02 bit in the CM0 register to 1 to stop the peripheral clock source. However, this setting does not stop the fC32. R32C/161 Group 8. Bus ## 8. Bus This MCU has a fast bus (CPU bus) and a slow bus (peripheral bus). Figure 8.1 shows a block diagram of the bus. Figure 8.1 Bus Block Diagram ## 8.1 Bus Setting The bus setting is controlled by the PBC register. Table 8.1 lists the bus setting and its source. Table 8.1 Bus Setting and Source | Bus Setting | Source | | | |-------------------------|--------------|--|--| | Internal SFR bus timing | PBC register | | | R32C/161 Group 8. Bus ## 8.2 Peripheral Bus Timing Setting The 16-/32-bit wide peripheral bus operates at a frequency up to 32 MHz (the theoretical value and the maximum frequency of each product group are as defined by f(BCLK) in 28. "Electrical Characteristics"). The timing adjustment and bus-width conversion with the faster, 64-bit wide CPU bus are controlled in the bus interface unit (BIU). Figure 8.2 shows the PBC register which determines the peripheral bus timing. Figure 8.2 PBC Register ### 9. Protection This function protects important registers from being easily overwritten when a program goes out of control. Registers used to protect other registers from being rewritten are as follows: PRCR, PRCR2 to PRCR4, and PRR. ## 9.1 Protect Register (PRCR Register) Figure 9.1 shows the PRCR register. Registers protected by bits in the PRCR register are listed in Table 9.1. Table 9.1 Registers Protected by the PRCR Register | Bit | Protected Registers | |------|-----------------------------------------| | PRC0 | CM0, CM1, CM2, and PM3 | | PRC1 | PM0, PM2, INVC0, INVC1, and IOBC | | PRC2 | PLC0, PLC1, PD9, and P9_iS (i = 3 to 7) | The PRC2 bit becomes 0 (write disabled) when a write operation is performed in a given address after this bit is set to 1 (write enabled). Set the PRC2 bit to 1 just before rewriting registers PD9, P9\_iS, PLC0, and PLC1 (i = 3 to 7). No interrupt handling or DMA transfers should be inserted between these two instructions. Bits PRC0 and PRC1 do not become 0 even if data is written to a given address. These bits should be set to 0 by a program. Figure 9.1 PRCR Register ## 9.2 Protect Register 2 (PRCR2 Register) Figure 9.2 shows the PRCR2 register which protects the CM3 register only. Figure 9.2 PRCR2 Register # 9.3 Protect Register 3 (PRCR3 Register) Figure 9.3 shows the PRCR3 register. Registers protected by the bits in the PRCR3 register are listed in Table 9.2. Table 9.2 Registers Protected by the PRCR3 Register (i = 0 to 7) | Bit | Protected Registers | | |-------|----------------------------------------|--| | PRC30 | PD3, P3_iS, PD7, P7_iS, PD8, and P8_iS | | | PRC31 | VRCR, LVDC, and DVCR | | Figure 9.3 PRCR3 Register # 9.4 Protect Register 4 (PRCR4 Register) Figure 9.4 shows the PRCR4 register. Registers protected by the bits in the PRCR4 register are listed in Table 9.3. Table 9.3 Registers Protected by the PRCR4 Register | Bit | Protected Registers | | |-------|---------------------|--| | PRC40 | WDTS | | | PRC41 | E2FM | | Figure 9.4 PRCR4 Register ## 9.5 Protect Release Register (PRR Register) Figure 9.5 shows the PRR register. Registers protected by the PRR register are as follows: CCR, FMCR, PBC, and FEBC. To write to the registers above, the PRR register should be set to AAh (write enabled). Otherwise, the PRR register should be set to any value other than AAh to protect the above registers from unexpected write accesses. Figure 9.5 PRR Register # 10. Interrupts ## 10.1 Interrupt Types Figure 10.1 shows the types of interrupts. Figure 10.1 Interrupts Interrupts are also classified into maskable/non-maskable. ### (1) Maskable Interrupts Maskable interrupts <u>can be disabled</u> by the interrupt enable flag (I flag). The priority can be configured by assigning an interrupt request level. ## (2) Non-maskable Interrupts Maskable interrupts <u>cannot be disabled</u> by the interrupt enable flag (I flag). The interrupt priority cannot be configured. ### 10.2 Software Interrupts Software interrupts are non-maskable. A software interrupt occurs by executing an instruction. There are five types of software interrupts shown below. #### (1) Undefined Instruction Interrupt This interrupt occurs when the UND instruction is executed. #### (2) Overflow Interrupt This interrupt occurs when the INTO instruction is executed while the O flag is 1. The following instructions may change the O flag to 1, depending on the operation result: ABS, ADC, ADCF, ADD, ADDF, ADSF, CMP, CMPF, CNVIF, DIV, DIVF, DIVU, DIVX, EDIV, EDIVU, EDIVX, MUL, MULF, MULU, MULX, NEG, RMPA, ROUND, SBB, SCMPU, SHA, SUB, SUBF, SUNTIL, and SWHILE ### (3) BRK Instruction Interrupt This interrupt occurs when the BRK instruction is executed. ### (4) BRK2 Instruction Interrupt This interrupt occurs when the BRK2 instruction is executed. This interrupt is only meant for use as a development support tool and users are not allowed to use it. #### (5) INT Instruction Interrupt This interrupt occurs when the INT instruction is executed with a selected software interrupt number from 0 to 255. Software interrupt numbers 0 to 127 are designated for peripheral interrupts. That is, the INT instruction with a software interrupt number from 0 to 127 has the same interrupt handler as that for peripheral interrupts. The stack pointer (SP) used for this interrupt differs depending on the software interrupt numbers. For software interrupt numbers 0 to 127, when an interrupt request is accepted, the U flag is saved and set to 0 to select the interrupt stack pointer (ISP) during the interrupt sequence. The saved data of the U flag is restored upon returning from the interrupt handler. For software interrupt numbers 128 to 255, the stack pointer does not change during the interrupt sequence. ### 10.3 Hardware Interrupts There are two kinds of hardware interrupts: special interrupts and peripheral interrupts. In peripheral interrupts, only one interrupt with the highest priority can be specified as a fast interrupt. ## 10.3.1 Special Interrupts Special interrupts are non-maskable. There are five special interrupts shown below. #### (1) NMI (Non Maskable Interrupt) This interrupt occurs when an input signal at the $\overline{\text{NMI}}$ pin switches from high to low. Refer to 10.11 "NMI" for details. #### (2) Watchdog Timer Interrupt The watchdog timer generates this interrupt. Refer to 11. "Watchdog Timer" for details. ### (3) Oscillator Stop Detection Interrupt This interrupt occurs when the MCU detects a main clock oscillator stop. Refer to 7.2 "Oscillator Stop Detection" for details. ### (4) Low Voltage Detection Interrupt This interrupt occurs when a low voltage input to VCC is detected by the voltage detector. Refer to 6.2 "Low Voltage Detector" for details. #### (5) Single-step Interrupt This interrupt is only meant for use as a development support tool and users are not allowed to use it. ### 10.3.2 Peripheral Interrupts Peripheral interrupts occur when an interrupt request from a peripheral in the MCU is accepted. They share the interrupt vector with software interrupt numbers 0 to 127 for the INT instruction. Peripheral interrupts are maskable. Refer to Tables 10.2 to 10.5 for details on the interrupt sources. Refer to the relevant descriptions for details on each function. ### 10.4 Fast Interrupt A fast interrupt enables the CPU to accelerate interrupt response. In peripheral interrupts, only one interrupt with the highest priority can be specified as the fast interrupt. Use the following procedure to enable a fast interrupt: - (1) Set the both FSIT bit in registers RIPL1 and RIPL2 to 1 (interrupt request level 7 available for fast interrupt). - (2) Set the both DMAII bit in registers RIPL1 and RIPL2 to 0 (interrupt request level 7 available for interrupts). - (3) Set the start address of the fast interrupt handler to the VCT register. Under the conditions above, bits ILVL2 to ILVL0 in the interrupt control register should be set to 111b (level 7) to enable the fast interrupt. No other interrupts should be set to interrupt request level 7. When the fast interrupt is accepted, the flag register (FLG) and program counter (PC) are saved to the save flag register (SVF) and save PC register (SVP), respectively. The program is executed from the address indicated by the VCT register. To return from the fast interrupt handler, the FREIT instruction should be executed. The values saved into registers SVF and SVP are restored to the FLG register and PC, respectively. ### 10.5 Interrupt Vectors Each interrupt vector has a 4-byte memory space, in which the start address of the associated interrupt handler is stored. When an interrupt request is accepted, a jump to the address set in the interrupt vector takes place. Figure 10.2 shows an interrupt vector. Figure 10.2 Interrupt Vector ## 10.5.1 Fixed Vector Table The fixed vector table is allocated in addresses FFFFFDCh to FFFFFFFh. Table 10.1 lists the fixed vector table. Table 10.1 Fixed Vector Table | Interrupt Source | Vector Addresses<br>(Address (L) to Address (H)) | Remarks | Reference | |----------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------| | Undefined instruction | FFFFFDCh to FFFFFDFh | Interrupt by the UND instruction | R32C/100 Series Software<br>Manual | | Overflow | FFFFFE0h to FFFFFE3h | Interrupt by the INTO instruction | | | BRK instruction | FFFFFFE4h to FFFFFE7h | If address FFFFFE7h is FFh, a jump to the interrupt vector of software interrupt number 0 in the relocatable vector table takes place | | | _ | FFFFFE8h to FFFFFEBh | Reserved | | | _ | FFFFFECh to FFFFFEFh | Reserved | | | Watchdog timer Oscillator stop detection Low voltage detection | FFFFFFF0h to FFFFFFF3h | These addresses are shared<br>by the watchdog timer<br>interrupt, oscillator stop<br>detection interrupt, and low<br>voltage detection interrupt | <ul><li>11. "Watchdog Timer"</li><li>7. "Clock Generator"</li><li>6.2 "Low Voltage Detector"</li></ul> | | _ | FFFFFFF4h to FFFFFF7h | Reserved | | | NMI | FFFFFFF8h to FFFFFFBh | External interrupt by the NMI pin | | | Reset | FFFFFFFCh to FFFFFFFh | | 5. "Resets" | ## 10.5.2 Relocatable Vector Table The relocatable vector table occupies a 1024-byte memory space from the start address set in the INTB register. Tables 10.2 to 10.5 list the relocatable vector table entries. An address in a multiple of 4 should be set in the INTB register for a faster interrupt sequence. Table 10.2 Relocatable Vector Table (1/4) | | | 0.6 | + | |------------------------------|---------------------------------------|-----------|------------------| | late would Course | Vector Table Relative Addresses | Software | Deference | | Interrupt Source | (Address (L) to Address (H)) (1) | Interrupt | Reference | | DDK is atmostic to (2) | +0 to +3 (0000h to 0003h) | Number | R32C/100 Series | | BRK instruction (2) | +0 (0 +3 (000011 to 000311) | 0 | Software Manual | | Reserved | +4 to +7 (0004h to 0007h) | 1 | Joitwale Mailual | | Reserved | +8 to +11 (0008h to 0008h) | 2 | 17. "Serial | | | +12 to +15 (000Ch to 000Fh) | 3 | Interface" | | Reserved | · · · · · · · · · · · · · · · · · · · | | (Reserved) | | Reserved | +16 to +19 (0010h to 0013h) | 4 | - (1 veset ved) | | Reserved | +20 to +23 (0014h to 0017h) | 5 | | | Reserved | +24 to +27 (0018h to 001Bh) | 6 | | | Reserved | +28 to +31 (001Ch to 001Fh) | 7 | | | DMA0 transfer complete | +32 to +35 (0020h to 0023h) | 8 | 12. "DMAC" | | DMA1 transfer complete | +36 to +39 (0024h to 0027h) | 9 | | | DMA2 transfer complete | +40 to +43 (0028h to 002Bh) | 10 | | | DMA3 transfer complete | +44 to +47 (002Ch to 002Fh) | 11 | | | Timer A0 | +48 to +51 (0030h to 0033h) | 12 | 15.1 "Timer A" | | Timer A1 | +52 to +55 (0034h to 0037h) | 13 | | | Timer A2 | +56 to +59 (0038h to 003Bh) | 14 | | | Timer A3 | +60 to +63 (003Ch to 003Fh) | 15 | | | Timer A4 | +64 to +67 (0040h to 0043h) | 16 | | | UART0 transmission, NACK (3) | +68 to +71 (0044h to 0047h) | 17 | 17. "Serial | | UART0 reception, ACK (3) | +72 to +75 (0048h to 004Bh) | 18 | Interface" | | UART1 transmission, NACK (3) | +76 to +79 (004Ch to 004Fh) | 19 | | | UART1 reception, ACK (3) | +80 to +83 (0050h to 0053h) | 20 | | | Timer B0 | +84 to +87 (0054h to 0057h) | 21 | 15.2 "Timer B" | | Timer B1 | +88 to +91 (0058h to 005Bh) | 22 | | | Timer B2 | +92 to +95 (005Ch to 005Fh) | 23 | | | Timer B3 | +96 to +99 (0060h to 0063h) | 24 | | | Timer B4 | +100 to +103 (0064h to 0067h) | 25 | | | INT5 | +104 to +107 (0068h to 006Bh) | 26 | 10.10 "External | | INT4 | +108 to +111 (006Ch to 006Fh) | 27 | Interrupt" | | INT3 | +112 to +115 (0070h to 0073h) | 28 | | | INT2 | +116 to +119 (0074h to 0077h) | 29 | | | INT1 | +120 to +123 (0078h to 007Bh) | 30 | | | INT0 | +124 to +127 (007Ch to 007Fh) | 31 | 1 | | Timer B5 | +128 to +131 (0080h to 0083h) | 32 | 15.2 "Timer B" | | | 1 | l | 1 | - 1. Each entry is relative to the base address in the INTB register. - 2. Interrupts from this source cannot be disabled by the I flag. - 3. In I<sup>2</sup>C mode, interrupts are generated by NACK, ACK, or detection of a start condition/stop condition. Table 10.3 Relocatable Vector Table (2/4) | | Vector Table Relative Addresses | Software | | |-----------------------------------|----------------------------------|-----------|------------------------| | Interrupt Source | | Interrupt | Reference | | · | (Address (L) to Address (H)) (1) | Number | | | UART2 transmission, NACK (2) | +132 to +135 (0084h to 0087h) | 33 | 17. "Serial | | UART2 reception, ACK (2) | +136 to +139 (0088h to 008Bh) | 34 | Interface" | | Reserved | +140 to +143 (008Ch to 008Fh) | 35 | | | Reserved | +144 to +147 (0090h to 0093h) | 36 | | | Reserved | +148 to +151 (0094h to 0097h) | 37 | | | Reserved | +152 to +155 (0098h to 009Bh) | 38 | | | Start condition detection or stop | +156 to +159 (009Ch to 009Fh) | 39 | | | condition detection (UART2) (2) | | | | | Start condition detection or stop | +160 to +163 (00A0h to 00A3h) | 40 | | | condition detection (UART0) (2) | | | | | Start condition detection or stop | +164 to +167 (00A4h to 00A7h) | 41 | | | condition detection (UART1) (2) | | | | | A/D0 | +168 to +171 (00A8h to 00ABh) | 42 | 18. "A/D Converter" | | Reserved | +172 to +175 (00ACh to 00AFh) | 43 | | | Intelligent I/O interrupt 0 | +176 to +179 (00B0h to 00B3h) | 44 | 10.12 "Intelligent I/O | | Intelligent I/O interrupt 1 | +180 to +183 (00B4h to 00B7h) | 45 | Interrupt", | | Intelligent I/O interrupt 2 | +184 to +187 (00B8h to 00BBh) | 46 | 21. "Intelligent I/O" | | Intelligent I/O interrupt 3 | +188 to +191 (00BCh to 00BFh) | 47 | | | Intelligent I/O interrupt 4 | +192 to +195 (00C0h to 00C3h) | 48 | | | Intelligent I/O interrupt 5 | +196 to +199 (00C4h to 00C7h) | 49 | | | Intelligent I/O interrupt 6 | +200 to +203 (00C8h to 00CBh) | 50 | | | Intelligent I/O interrupt 7 | +204 to +207 (00CCh to 00CFh) | 51 | | | Intelligent I/O interrupt 8 | +208 to +211 (00D0h to 00D3h) | 52 | | | Intelligent I/O interrupt 9 | +212 to +215 (00D4h to 00D7h) | 53 | | | Intelligent I/O interrupt 10 | +216 to +219 (00D8h to 00DBh) | 54 | | | Intelligent I/O interrupt 11 | +220 to +223 (00DCh to 00DFh) | 55 | | | Reserved | +224 to +227 (00E0h to 00E3h) | 56 | | | Reserved | +228 to +231 (00E4h to 00E7h) | 57 | | | CAN0 wakeup | +232 to +235 (00E8h to 00EBh) | 58 | 24. "CAN Module" | | CAN1 wakeup | +236 to +239 (00ECh to 00EFh) | 59 | | | Reserved | +240 to +243 (00F0h to 00F3h) | 60 | | | Reserved | +244 to +247 (00F4h to 00F7h) | 61 | | | LIN Low detection | +248 to +251 (00F8h to 00FBh) | 62 | 23. "LIN Module" | | Reserved | +252 to +255 (00FCh to 00FFh) | 63 | | - 1. Each entry is relative to the base address in the INTB register. - 2. In I<sup>2</sup>C mode, interrupts are generated by NACK, ACK, or detection of a start condition/stop condition. Table 10.4 Relocatable Vector Table (3/4) (1) | Interrupt Source | Vector Table Relative Addresses (Address (L) to Address (H)) (2) | Software | | |--------------------------|------------------------------------------------------------------|-----------|------------------| | | | Interrupt | Reference | | | | Number | | | Serial bus interface 0 | +256 to +259 (0100h to 0103h) | 64 | 22. "Serial Bus | | Reserved | +260 to +263 (0104h to 0107h) | 65 | Interface" | | Reserved | +264 to +267 (0108h to 010Bh) | 66 | | | Reserved | +268 to +271 (010Ch to 010Fh) | 67 | 1 | | Reserved | +272 to +275 (0110h to 0113h) | 68 | | | Reserved | +276 to +279 (0114h to 0117h) | 69 | | | Reserved | +280 to +283 (0118h to 011Bh) | 70 | | | Reserved | +284 to +287 (011Ch to 011Fh) | 71 | | | Reserved | +288 to +291 (0120h to 0123h) | 72 | | | Reserved | +292 to +295 (0124h to 0127h) | 73 | - | | Reserved | +296 to +299 (0128h to 012Bh) | 74 | - | | Reserved | +300 to +303 (012Ch to 012Fh) | 75 | 1 | | Reserved | +304 to +307 (0130h to 0133h) | 76 | | | Reserved | +308 to +311 (0134h to 0137h) | 77 | - | | Reserved | +312 to +315 (0138h to 013Bh) | 78 | 1 | | Reserved | +316 to +319 (013Ch to 013Fh) | 79 | 1 | | CAN0 transmit FIFO | +320 to +323 (0140h to 0143h) | 80 | 24. "CAN Module" | | CAN0 receive FIFO | +324 to +327 (0144h to 0147h) | 81 | 1 | | CAN1 transmit FIFO | +328 to +331 (0148h to 014Bh) | 82 | | | CAN1 receive FIFO | +332 to +335 (014Ch to 014Fh) | 83 | 1 | | Reserved | +336 to +339 (0150h to 0153h) | 84 | 1 | | Reserved | +340 to +343 (0154h to 0157h) | 85 | - | | Reserved | +344 to +347 (0158h to 015Bh) | 86 | 1 | | Reserved | +348 to +351 (015Ch to 015Fh) | 87 | 1 | | E <sup>2</sup> dataFlash | +352 to +355 (0160h to 0163h) | 88 | 27. "E2PROM | | | | | Emulation Data | | | | | Flash" | | Reserved | +356 to +359 (0164h to 0167h) | 89 | | | Reserved | +360 to +363 (0168h to 016Bh) | 90 | | | Reserved | +364 to +367 (016Ch to 016Fh) | 91 | | | Reserved | +368 to +371 (0170h to 0173h) | 92 | | | Reserved | +372 to +375 (0174h to 0177h) | 93 | | | Reserved | +376 to +379 (0178h to 017Bh) | 94 | 1 | | Reserved | +380 to +383 (017Ch to 017Fh) | 95 | 1 | - 1. Entries in this table cannot be used to exit wait mode or stop mode. - 2. Each entry is relative to the base address in the INTB register. Table 10.5 Relocatable Vector Table (4/4) (1) | Interrupt Source | Vector Table Relative Addresses (Address (L) to Address (H)) (2) | Software | | |---------------------|------------------------------------------------------------------|-----------|-------------------------------| | | | Interrupt | Reference | | | | Number | | | CAN0 transmission | +384 to +387 (0180h to 0183h) | 96 | 24. "CAN Module" | | CAN0 reception | +388 to +391 (0184h to 0187h) | 97 | | | CAN0 error | +392 to +395 (0188h to 018Bh) | 98 | | | CAN1 transmission | +396 to +399 (018Ch to 018Fh) | 99 | | | CAN1 reception | +400 to +403 (0190h to 0193h) | 100 | | | CAN1 error | +404 to +407 (0194h to 0197h) | 101 | | | Reserved | +408 to +411 (0198h to 019Bh) | 102 | | | Reserved | +412 to +415 (019Ch to 019Fh) | 103 | | | Reserved | +416 to +419 (01A0h to 01A3h) | 104 | | | Reserved | +420 to +423 (01A4h to 01A7h) | 105 | | | Reserved | +424 to +427 (01A8h to 01ABh) | 106 | | | Reserved | +428 to +431 (01ACh to 01AFh) | 107 | - | | Reserved | +432 to +435 (01B0h to 01B3h) | 108 | | | Reserved | +436 to +439 (01B4h to 01B7h) | 109 | 1 | | Reserved | +440 to +443 (01B8h to 01BBh) | 110 | 1 | | Reserved | +444 to +447 (01BCh to 01BFh) | 111 | 1 | | Reserved | +448 to +451 (01C0h to 01C3h) | 112 | 1 | | Reserved | +452 to +455 (01C4h to 01C7h) | 113 | 1 | | Reserved | +456 to +459 (01C8h to 01CBh) | 114 | | | Reserved | +460 to +463 (01CCh to 01CFh) | 115 | | | LIN0 | +464 to +467 (01D0h to 01D3h) | 116 | 23. "LIN Module" | | Reserved | +468 to +471 (01D4h to 01D7h) | 117 | | | Reserved | +472 to +475 (01D8h to 01DBh) | 118 | | | Reserved | +476 to +479 (01DCh to 01DFh) | 119 | | | Reserved | +480 to +483 (01E0h to 01E3h) | 120 | | | Reserved | +484 to +487 (01E4h to 01E7h) | 121 | 1 | | Reserved | +488 to +491 (01E8h to 01EBh) | 122 | | | Reserved | +492 to +495 (01ECh to 01EFh) | 123 | | | UART3 transmission | +496 to +499 (01F0h to 01F3h) | 124 | 17. "Serial Interface" | | UART3 reception | +500 to +503 (01F4h to 01F7h) | 125 | 1 | | UART4 transmission | +504 to +507 (01F8h to 01FBh) | 126 | 1 | | UART4 reception | +508 to +511 (01FCh to 01FFh) | 127 | 1 | | INT instruction (3) | +0 to +3 (0000h to 0003h) to<br>+1020 to +1023 (03FCh to 03FFh) | 0 to 255 | 10.2 "Software<br>Interrupts" | - 1. Entries in this table cannot be used to exit wait mode or stop mode. - 2. Each entry is relative to the base address in the INTB register. - 3. Interrupts from this source cannot be disabled by the I flag. ## 10.6 Interrupt Request Acceptance Software interrupts and special interrupts are accepted whenever their interrupt request is generated. Peripheral interrupts, however, are only accepted if the conditions below are met: - I flag is 1 - IR bit is 1 - Bits ILVL2 to ILVL0 > IPL The I flag, IPL, IR bit, and bits ILVL2 to ILVL0 do not affect each other. The I flag and IPL are in the FLG register. The IR bit and bits ILVL2 to ILVL0 are in the interrupt control register. The following section describes these flag and bits. ## 10.6.1 I Flag and IPL The I flag (interrupt enable flag) enables or disables maskable interrupts. When the I flag is set to 1 (enabled), all maskable interrupts are enabled; when it is set to 0 (disabled), they are disabled. The I flag becomes 0 after a reset. The IPL (processor interrupt priority level) consists of 3 bits and indicates eight interrupt priority levels from 0 to 7. An interrupt becomes acceptable when its interrupt request level is higher than the specified IPL (bits ILVL2 to ILVL0 > IPL). Table 10.6 lists interrupt request levels classified by the IPL. Table 10.6 Acceptable Interrupt Request Levels and IPL | IPL | | | Acceptable Interrupt Request Levels | | |------|------|------|--------------------------------------|--| | IPL2 | IPL1 | IPL0 | Acceptable interrupt Nequest Levels | | | 1 | 1 | 1 | All maskable interrupts are disabled | | | 1 | 1 | 0 | Level 7 only | | | 1 | 0 | 1 | Level 6 and above | | | 1 | 0 | 0 | Level 5 and above | | | 0 | 1 | 1 | Level 4 and above | | | 0 | 1 | 0 | Level 3 and above | | | 0 | 0 | 1 | Level 2 and above | | | 0 | 0 | 0 | Level 1 and above | | # 10.6.2 Interrupt Control Registers Each peripheral interrupt is controlled by an interrupt control register. Figures 10.3 and 10.4 show the interrupt control registers. Figure 10.3 Interrupt Control Register (1/2) Figure 10.4 Interrupt Control Register (2/2) ### Bits ILVL2 to ILVL0 The interrupt request level is selected by setting bits ILVL2 to ILVL0. The higher the level is, the higher interrupt priority is. When an interrupt request is generated, its request level is compared to the IPL. The interrupt is accepted only when the interrupt request level is higher than the IPL. When bits ILVL2 to ILVL0 are set to 000b, the interrupt is disabled. ### IR bit The IR bit becomes 1 (interrupt requested) when an interrupt request is generated; this bit setting is retained until the interrupt request is accepted. When the request is accepted and a jump to the corresponding interrupt vector takes place, the IR bit becomes 0 (no interrupt requested). The IR bit can be set to 0 by a program. This bit should not be set to 1. When rewriting the interrupt control register, no corresponding interrupt request should be generated. If there is a possibility that an interrupt request may be generated, disable all maskable interrupts before rewriting the register. When enabling an interrupt immediately after changing the interrupt control register, insert NOPs between two instructions or perform a dummy read of the interrupt control register so that the interrupt enable flag (I flag) cannot become 1 (interrupt enabled) before writing to the interrupt control register is completed. If an interrupt request is generated for the register being rewritten, the IR bit may not become 1 depending on the instruction being used. If it matters, use one of the following instructions to rewrite the register: - AND - OR - BCLR - BSET If the AND or BCLR instruction is used to set the IR bit to 0, the IR bit may not become 0 as these instructions cause the interrupt request to be retained during the rewrite. To prevent this from happening, rewrite the register using the MOV instruction. To set just the IR bit to 0, first temporarily store the read value to memory or a CPU internal register, then execute either the AND or BCLR instruction in the stored area. After that, write the value back to the register using the MOV instruction. # 10.6.3 Wake-up IPL Setting Register Set the wake-up IPL setting registers (registers RIPL1 and RIPL2) when using an interrupt to exit wait or stop mode, or using the fast interrupt. Refer to 7.7.2 "Wait Mode", 7.7.3 "Stop Mode", or 10.4 "Fast Interrupt" for details. Figure 10.5 shows registers RIPL1 and RIPL2. ### Notes: - 1. Registers RIPL1 and RIPL2 should be set with the same values. - 2. The MCU exits wait mode or stop mode when the request level of the requested interrupt is higher than the level selected using bits RLVL2 to RLVL0. Set these bits to the same value as the IPL in the FLG register. - 3. When the FSIT bit is 1, an interrupt with interrupt request level 7 becomes the fast interrupt. In this case, set the interrupt request level to level 7 with only one interrupt. - 4. Set either the FSIT or DMAII bit to 1. The fast interrupt and DMAC II cannot be used simultaneously. - 5. Set bits ILVL2 to ILVL0 in the interrupt control register after the DMAII bit is set. DMA II transfer is not affected by the I flag or IPL. Figure 10.5 Registers RIPL1 and RIPL2 ### 10.6.4 Interrupt Sequence An interrupt sequence is performed from when an interrupt request has been accepted until the interrupt handler starts. When an interrupt request is generated while an instruction is being executed, the requested interrupt is evaluated in the priority resolver after the current instruction is completed, and the interrupt sequence starts from the next cycle. However, for instructions RMPA, SCMPU, SIN, SMOVB, SMOVF, SMOVU, SOUT, SSTR, SUNTIL, and SWHILE, when an interrupt request is generated while an instruction is being executed, the current instruction is suspended, and the interrupt sequence starts. The interrupt sequence is as follows: - (1) The CPU acknowledges the interrupt request to obtain the interrupt information (the interrupt number, and the interrupt request level) from the interrupt controller. Then the corresponding IR bit becomes 0 (no interrupt requested). - (2) The state of the FLG register before the interrupt sequence is stored to a temporary register in the CPU. The temporary register is inaccessible to users. - (3) The following bits in the FLG register become 0: - The I flag (interrupt enable flag): interrupt disabled - The D flag (debug flag): single-step interrupt disabled - The U flag (stack pointer select flag): ISP selected - (4) The content of the temporary register in the CPU is saved to the stack, or to the SVF register in case of the fast interrupt. - (5) The content of the PC is saved to the stack, or to the SVP register in case of the fast interrupt. - (6) The interrupt request level for the accepted interrupt is set in the IPL (processor interrupt priority level). - (7) The corresponding interrupt vector is read from the interrupt vector table. - (8) This interrupt vector is stored into the PC. After the interrupt sequence is completed, an instruction is executed from the start address of the interrupt handler. # 10.6.5 Interrupt Response Time The interrupt response time, as shown in Figure 10.6, consists of two non-overlapping time segments: (a) the period from when an interrupt request is generated until the instruction being executed is completed; and (b) the period required for the interrupt sequence. Figure 10.6 Interrupt Response Time Period (a) varies depending on the instruction being executed. Instructions, such as LDCTX and STCTX in which registers are sequentially saved into or restored from the stack, require the longest time. For example, the STCTX instruction requires at least 30 cycles for 10 registers to be saved. It requires more time if the WAIT instruction is in the stack. Period (b) is listed in Table 10.7. Table 10.7 Interrupt Sequence Execution Time (1) | Interrupt | Execution Time in Terms of CPU Clock | |--------------------------------------------|--------------------------------------| | Peripherals | 13 + α cycles <sup>(2)</sup> | | INT instruction | 11 cycles | | NMI | 10 cycles | | Watchdog timer | | | Oscillator stop detection | 11 cycles | | Low voltage detection | | | Undefined instruction | 12 cycles | | Overflow | 12 cycles | | BRK instruction (relocatable vector table) | 16 cycles | | BRK instruction (fixed vector table) | 19 cycles | | BRK2 instruction | 19 cycles | | Fast interrupt | 11 cycles | ### Notes: - 1. These are the values when the interrupt vectors are aligned to the addresses in multiples of 4 in the internal ROM. However, the condition does not apply to the fast interrupt. - 2. $\alpha$ is the number of waits to access SFRs minus 2. # 10.6.6 IPL after Accepting an Interrupt Request When a peripheral interrupt request is accepted, the interrupt request level is set in the IPL (processor interrupt priority level). Software interrupts and special interrupts have no interrupt request level. When these interrupt requests are accepted, the value listed in Table 10.8 is set in the IPL as the interrupt request level. Table 10.8 Interrupts without Interrupt Request Level and IPL | Interrupt Sources without Interrupt Request Level | IPL Value to be Set | |-----------------------------------------------------------------------|---------------------| | NMI, watchdog timer, oscillator stop detection, low voltage detection | 7 | | Reset | 0 | | Software | Unchanged | # 10.6.7 Register Saving In the interrupt sequence, the FLG register and PC values are saved to the stack, in that order. Figure 10.7 shows the stack status before and after an interrupt request is accepted. In the fast interrupt sequence, the FLG register and PC values are saved to registers SVF and SVP, respectively. If there are any other registers to be saved to the stack, save them at the beginning of the interrupt handler. A single PUSHM instruction saves all registers except the frame base register (FB) and stack pointer (SP). Figure 10.7 Stack Status Before and After an Interrupt Request is Accepted # 10.7 Register Restoring from Interrupt Handler When the REIT instruction is executed at the end of the interrupt handler, the FLG register and PC values, which are saved in the stack, are restored, and the program resumes the operation that was interrupted. In the fast interrupt, execute the FREIT instruction to restore them from the save registers, instead. To restore the register values which are saved by software in the interrupt handler, use an instruction such as POPM before the REIT or FREIT instruction. If the register bank is switched in the interrupt handler, the bank is automatically switched back to the original register bank by the REIT or FREIT instruction. ## 10.8 Interrupt Priority If two or more interrupt requests are detected at an interrupt request sampling point, the interrupt request with higher priority is accepted. For maskable interrupts (peripheral interrupts), the interrupt request level select bits (bits ILVL2 to ILVL0) select a request level. If two or more interrupt requests have the same request level, the interrupt with higher priority, predetermined by hardware, is accepted. The priorities of the reset and special interrupts, such as the watchdog timer interrupt, are determined by the hardware. Note that the reset has the highest priority. The following is the priority order determined by the hardware: $Watchdog\ timer$ $Reset > Oscillator\ stop\ detection > NMI > Peripherals$ $Low\ voltage\ detection$ Software interrupts are not governed by priority. A jump to the interrupt handler takes place whenever the relevant instruction is executed. ## 10.9 Priority Resolver The priority resolver selects an interrupt that has the highest priority among requested interrupts detected at the same sampling point. Figure 10.8 shows the priority resolver. Figure 10.8 Priority Resolver ### 10.10 External Interrupt An external interrupt occurs by an external input applied to the INTi pin (i = 0 to 5). Set the LVS bit in the INTiIC register to select whether an interrupt is triggered by the effective edge(s) (edge sensitive), or by the effective level (level sensitive) of the input signal. The polarity of the input signal is selected by setting the POL bit in the same register. When using edge-triggered interrupts, setting the IFSR0i bit in the IFSR0 register to 1 (both edges) causes interrupt requests to be generated on both rising and falling edges of the external input. Set the POL bit in the corresponding register to 0 (falling edge) to set the IFSR0i bit to 1. When using level-triggered interrupts, set the IFSR0i bit to 0 (one edge). When an effective level, which is selected by the POL bit, is detected on the $\overline{\text{INTi}}$ pin, the IR bit in the INTiIC register becomes 1. The IR bit remains unchanged until the INTi interrupt is accepted, or set to 0 by a program, even if the signal level at the $\overline{\text{INTi}}$ pin changes. Figure 10.9 shows the IFSR0 register. Figure 10.9 IFSR0 Register The external interrupt signal has a digital filtering function for noise reduction. This function enables the interrupt controller to sample input signals with a selected clock and to pass pulses only which match the level three times sequentially. Figures 10.10 and 10.11 show registers INTF0 and INTF1. Figure 10.10 INTF0 Register Figure 10.11 INTF1 Register # 10.11 NMI The NMI (non maskable interrupt) occurs when an input signal at the $\overline{\text{NMI}}$ pin switches from high to low. This non maskable interrupt is disabled after a reset. To enable this interrupt, set the PM24 bit in the PM2 register to 1 after setting the interrupt stack pointer (ISP) at the beginning of the program. The $\overline{\text{NMI}}$ pin shares a pin with port P8\_5, which enables the P8\_5 bit in the P8 register to indicate the input level at the $\overline{\text{NMI}}$ pin. Note: 1. When not using the NMI, do not change the reset value of the PM24 bit in the PM2 register. # 10.12 Intelligent I/O Interrupt The intelligent I/O interrupt is assigned to software interrupt numbers 44 to 55. Figure 10.12 shows a block diagram of the intelligent I/O interrupt. Figures 10.13 and 10.14 show registers IIOiIR and IIOiIE, respectively (i = 0 to 11). To use the intelligent I/O interrupt, set the IRLT bit in the IIOiIE register to 1 (interrupt requests used for interrupt). The intelligent I/O interrupt has multiple request sources. When an interrupt request is generated with an intelligent I/O function, the corresponding bit in the IIOiIR register becomes 1 (interrupt requested). If the corresponding bit in the IIOiIE register is 1 (interrupt enabled), the IR bit in the corresponding IIOiIC register changes to 1 (interrupt requested). After the IR bit setting changes from 0 to 1, it remains unchanged if a bit in the IIOiIR register becomes 1 by another interrupt request source and the corresponding bit in the IIOiIE register is 1. Bits in the IIOiIR register do not become 0 even if an interrupt is accepted. They should be set to 0 by either the AND or BCLR instruction. Note that every generated interrupt request is ignored until these bits are set to 0. To use the intelligent I/O interrupt as a DMAC II trigger, set the IRLT bit in the IIOiIE register to 0 (interrupt requests used for DMA or DMA II) and the bit used for the interrupt source to 1 (interrupt enabled) in the IIOiIE register. Figure 10.12 Intelligent I/O Interrupt Block Diagram (i = 0 to 11) ### Notes: - 1. When the register has any function-assigned bit, the reset value is X (undefined); otherwise, the reset value is 0. - 2. Refer to the table below for bit symbols. - 3. When this bit is function-assigned, it can only be set to 0. It should not be set to 1. To set it to 0, either the AND or BCLR instruction should be used; when the bit is not function-assigned (reserved), it should be set to 0. ### Bit Symbols for the Intelligent I/O Interrupt Request Register | Symbol | Address | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------|---------|-------|-------|-------|-------|-------|-------|-------------|-------| | IIO0IR | 00A0h | _ | 1 | - | _ | | | TM02R/PO02R | _ | | IIO1IR | 00A1h | _ | _ | _ | _ | | _ | TM00R/PO00R | _ | | IIO2IR | 00A2h | _ | _ | _ | _ | _ | _ | _ | _ | | IIO3IR | 00A3h | _ | _ | _ | _ | _ | _ | TM03R/PO03R | _ | | IIO4IR | 00A4h | _ | _ | _ | _ | _ | _ | TM04R/PO04R | _ | | IIO5IR | 00A5h | _ | _ | _ | _ | _ | _ | TM05R/PO05R | _ | | IIO6IR | 00A6h | _ | _ | _ | _ | _ | _ | TM06R/PO06R | _ | | IIO7IR | 00A7h | _ | _ | _ | BT0R | _ | _ | TM07R/PO07R | _ | | IIO8IR | 00A8h | _ | _ | _ | _ | _ | _ | _ | _ | | IIO9IR | 00A9h | _ | _ | _ | _ | _ | _ | _ | _ | | IIO10IR | 00AAh | _ | _ | _ | _ | _ | _ | _ | _ | | IIO11IR | 00ABh | _ | _ | _ | _ | _ | _ | TM01R/PO01R | _ | BT0R: Intelligent I/O group 0 base timer interrupt request TM0yR: Intelligent I/O group 0 time measurement channel y interrupt request (y = 0 to 7) PO0yR: Intelligent I/O group 0 waveform generation channel y interrupt request (y = 0 to 7) Figure 10.13 Registers IIO0IR to IIO11IR #### Notes: - 1. Refer to the table below for bit symbols. - 2. To use interrupt requests for interrupt, the IRLT bit should be set to 1, then bits 1 and 4 should be set to 1. ### Bit Symbols for the Intelligent I/O Interrupt Enable Register | Symbol | Address | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------|---------|-------|-------|-------|-------|-------|-------|-------------|-------| | IIO0IE | 00B0h | | | | _ | _ | _ | TM02E/PO02E | IRLT | | IIO1IE | 00B1h | | _ | _ | _ | _ | _ | TM00E/PO00E | IRLT | | IIO2IE | 00B2h | | 1 | - | _ | _ | | _ | IRLT | | IIO3IE | 00B3h | | 1 | 1 | _ | | | TM03E/PO03E | IRLT | | IIO4IE | 00B4h | | | | _ | _ | _ | TM04E/PO04E | IRLT | | IIO5IE | 00B5h | | _ | _ | _ | _ | _ | TM05E/PO05E | IRLT | | IIO6IE | 00B6h | | 1 | _ | _ | _ | _ | TM06E/PO06E | IRLT | | IIO7IE | 00B7h | | 1 | 1 | BT0E | | | TM07E/PO07E | IRLT | | IIO8IE | 00B8h | | | | _ | _ | _ | _ | IRLT | | IIO9IE | 00B9h | | _ | _ | _ | _ | _ | _ | IRLT | | IIO10IE | 00BAh | _ | | _ | _ | _ | _ | _ | IRLT | | IIO11IE | 00BBh | _ | | | _ | _ | _ | TM01E/PO01E | IRLT | BT0E: Intelligent I/O group 0 base timer interrupt enabled TM0yE: Intelligent I/O group 0 time measurement channel y interrupt enabled (y = 0 to 7) PO0yE: Intelligent I/O group 0 waveform generation channel y interrupt enabled (y = 0 to 7) Figure 10.14 Registers IIO0IE to IIO11IE ## 10.13 Notes on Interrupts ## 10.13.1 ISP Setting The interrupt stack pointer (ISP) is initialized to 00000000h after a reset. Set a value to the ISP before an interrupt is accepted, otherwise the program may go out of control. A multiple of 4 should be set to the ISP, which enables faster interrupt sequence due to less memory access. When using NMI, in particular, since this interrupt cannot be disabled, set the PM24 bit in the PM2 register to 1 (NMI enabled) after setting the ISP at the beginning of the program. ### 10.13.2 NMI - NMI cannot be disabled once the PM24 bit in the PM2 register is set to 1 (NMI enabled). This bit setting should be done only when using NMI. - When the PM24 bit in the PM2 register is 1 (NMI enabled), the P8\_5 bit in the P8 register is enabled just for monitoring the NMI pin state. It is not enabled as a general port. # 10.13.3 External Interrupts - The input signal to the INTi pin requires the pulse width specified in the electrical characteristics (i = 0 to 5). If the pulse width is narrower than the specification, an external interrupt may not be accepted. - When the effective level or edge of the INTi pin (i = 0 to 5) is changed by the following bits: bits POL, LVS in the INTiIC register, the IFSR0i bit (i = 0 to 5) in the IFSR0 register, the corresponding IR bit may become 1 (interrupt requested). When setting the above mentioned bits, preset bits ILVL2 to ILVL0 in the INTiIC register to 000b (interrupt disabled). After setting the above mentioned bits, set the corresponding IR bit to 0 (no interrupt requested), then rewrite bits ILVL2 to ILVL0. # 11. Watchdog Timer The watchdog timer is used to detect program runaway. The 15-bit watchdog counter decrements with the cycle which is the peripheral bus clock frequency or on-chip oscillator clock frequency divided by the prescaler. Select either an interrupt request or a reset with the CM06 bit in the CM0 register for when the watchdog timer underflows. Once the CM06 bit is set to 1 (reset), it cannot be changed to 0 (watchdog timer interrupt) by a program. It can be set to 0 only by a reset. The watchdog timer has two prescalers. One is the on-chip oscillator clock divided by 1, 2, 4 or 8; the other is the peripheral bus clock divided by 16 or 128. To select the divide ratio for the former, set bits WDK3 and WDK2 in the WDK register. To select the divide ratio for the latter, set the WDC7 bit in the WDC register. The count source for the watchdog timer is set by the PM22 bit in the PM2 register. When the peripheral bus clock is selected as the count source, the watchdog timer is stopped in wait mode, stop mode, or when the HOLD signal is driven low. It resumes counting from the value held when exiting the mode or state. When the on-chip oscillator clock is selected, the watchdog timer does not stop. The general formula to calculate a watchdog timer period is: For example, when the peripheral bus clock is selected as the count source and it is 1/2 of 48 MHz CPU clock and the prescaler has a divide-by-16 operation, the watchdog timer period is approximately 21.8 ms. Depending on the timing of when a value is written to the WDTS register, a marginal error of one prescaler output cycle (maximum) may occur in the watchdog timer period. The watchdog timer is initialized when a write operation to the WDTS register is performed or when a watchdog timer interrupt request is generated. The prescaler is initialized only when the MCU is reset. After a reset, the watchdog timer starts counting automatically if the OFS area of the flash memory are preset. When the WDTON bit in the OFS area is 1, both the watchdog timer and the prescaler are stopped. They start counting when a write operation to the WDTS register is performed. When the WDTON bit is 0, both the watchdog timer and the prescaler automatically start counting after a reset. Figure 11.1 shows a block diagram of the watchdog timer. Figures 11.2 to 11.5 show registers associated with the watchdog timer. Figure 11.1 Watchdog Timer Block Diagram Figure 11.2 WDC Register - 1. This register cannot be rewritten when the WDTON bit in the OFS area is 0 (the watchdog timer starts counting automatically after a reset). When the WDTON bit is 1 (the watchdog timer stops after a reset), this register can be rewritten only once after a reset. When the count source protect mode is enabled, this register should be set at the very beginning of the program. - 2. Set these bits before activating the watchdog timer. Figure 11.3 WDK Register Figure 11.4 WDTS Register #### Notes: - 1. Rewrite this area by the flash programmer. It cannot be rewritten by a program. - 2. To enable the count source protect mode, set bits WDTON and CSPM to 0. Once the watchdog timer starts, the PM22 bit in the PM2 register cannot be rewritten. - 3. These bit settings are disabled when the WDTON bit is 1. The values set to these bits are reflected to registers WDK and PM2 when the WDTON bit is 0. Figure 11.5 OFS Area ## **12. DMAC** Direct memory access (DMA) is a system that can control data transfer without using a CPU instruction. The R32C/100 Series' four channel DMA controller (DMAC) transmits 8-bit (byte), 16-bit (word), or 32-bit (long word) data in cycle-steal mode from a source address to a destination address each time a transfer request is generated. The DMAC, which shares a data bus with the CPU, has a higher bus access priority than the CPU. This allows the DMAC to perform fast data transfer when a transfer request is generated. Figure 12.1 shows a map of the CPU-internal registers associated with DMAC. Table 12.1 lists DMAC specifications. Figures 12.2 to 12.10 show registers associated with DMAC. Since the registers shown in Figure 12.1 are allocated in the CPU, the LDC or STC instruction should be used to write to the registers. Figure 12.1 CPU-internal Registers for DMAC Table 12.1 DMAC Specifications (i = 0 to 3) | It | em | Specification | |--------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Channels | | 4 | | Bus request mod | е | Cycle-steal mode | | Transfer memory | spaces | From a given address in a 64-Mbyte space (00000000h to 01FFFFFFh and FE000000h to FFFFFFFFh) to another given address in the same space | | Maximum transfe | • | 64-Mbytes (when 32-bit data is transferred), 32-Mbytes (when 16-bit data is transferred), 16-Mbytes (when 8-bit data is transferred) | | DMA request sources (1) | | Falling edge or both edges of signals applied to pins INT0 to INT3 Interrupt requests from timers A0 to A4 Interrupt requests from timers B0 to B5 Transmit/receive interrupt requests from UART0 to UART4 A/D conversion interrupt requests Intelligent I/O interrupt requests Serial bus interface interrupt requests Software trigger | | Channel priority | | DMA0 > DMA1 > DMA2 > DMA3 (DMA0 has the highest priority) | | Transfer sizes | | 8 bits, 16 bits, or 32 bits | | Addressing mode | es | Incrementing addressing or non-incrementing addressing | | Transfer modes | Single transfer | Transfer is completed when the DCTi register becomes 00000000h | | | Repeat transfer | When the DCTi register becomes 00000000h, the value of the DCRi register is reloaded into the DCTi register to continue the DMA transfer | | DMA transfer cor<br>request generation | • | When the DCTi register changes from 00000001h to 00000000h | | DMA transfer Single transfer start-up Repeat transfer | | When a DMA transfer request is generated after the DCTi register is set to a value other than 00000000h and bits MDi1 and MDi0 in the DMDi register are set to 01b (single transfer) | | | | When a DMA transfer request is generated after the DCTi register is set to a value other than 00000000h and bits MDi1 and MDi0 are set to 11b (repeat transfer) | | DMA transfer | Single transfer | When bits MDi1 and MDi0 are set to 00b (DMA transfer disabled) | | stop | Repeat transfer | When bits MDi1 and MDi0 are set to 00b (DMA transfer disabled) | | Reload timing to DDAi register | | When the DCTi register changes from 00000001h to 00000000h in repeat transfer mode | | Minimum DMA tra | ansfer cycles | 3 | ## Note: 1. DMA transfer does not affect any interrupts. The DMA transfer request is available by two different sources: software and hardware. More concretely, they are a write access to the DSR bit in the DMiSL2 register and an interrupt request output from a function specified in bits DSEL4 to DSEL0 in the DMiSL register, and in bits DSEL24 to DSEL20 in the DMiSL2 register (i = 0 to 3). Unlike interrupt requests, the DMA transfer request is not affected by the I flag or the interrupt control register. Therefore this request can be accepted even when interrupts are disabled. Since the DMA transfer does not affect any interrupts, either, the IR bit in the interrupt control register is not changed by the DMA transfer. Figure 12.2 Registers DM0SL to DM3SL Figure 12.3 Registers DM0SL2 to DM3SL2 Table 12.2 DMiSL Register Functions (i = 0 to 3) | Setting Value | | DMA Request Source | | | | | |----------------|----------------------------------------------------------------------------------|-----------------------------|--------------------------|--------------------------|--|--| | b4 b3 b2 b1 b0 | DMA0 | DMA1 | DMA2 | DMA3 | | | | 0 0 0 0 0 | Select from DMiSL2 regi | Select from DMiSL2 register | | | | | | 0 0 0 0 1 | Falling edge of INTO (1) | Falling edge of INT1 (1) | Falling edge of INT2 (1) | Falling edge of INT3 (1) | | | | 0 0 0 1 0 | Both edges of INTO (1) | Both edges of INT1 (1) | Both edges of INT2 (1) | Both edges of INT3 (1) | | | | 0 0 0 1 1 | Timer A0 interrupt reque | st | | | | | | 0 0 1 0 0 | Timer A1 interrupt reque | st | | | | | | 0 0 1 0 1 | Timer A2 interrupt reque | st | | | | | | 0 0 1 1 0 | Timer A3 interrupt reque | st | | | | | | 0 0 1 1 1 | Timer A4 interrupt reque | st | | | | | | 0 1 0 0 0 | Timer B0 interrupt reque | st | | | | | | 0 1 0 0 1 | Timer B1 interrupt reque | st | | | | | | 0 1 0 1 0 | Timer B2 interrupt reque | st | | | | | | 0 1 0 1 1 | Timer B3 interrupt reque | st | | | | | | 0 1 1 0 0 | Timer B4 interrupt reque | st | | | | | | 0 1 1 0 1 | Timer B5 interrupt reque | st | | | | | | 0 1 1 1 0 | UART0 transmit interrup | t request | | | | | | 0 1 1 1 1 | UART0 receive interrupt | request or ACK interrupt | request (2) | | | | | 1 0 0 0 0 | UART1 transmit interrup | t request | <u> </u> | | | | | 1 0 0 0 1 | UART1 receive interrupt | request or ACK interrupt | request (2) | | | | | 1 0 0 1 0 | UART2 transmit interrup | | <u> </u> | | | | | 1 0 0 1 1 | UART2 receive interrupt | | request (2) | | | | | 1 0 1 0 0 | Reserved | - 4 | | | | | | 1 0 1 0 1 | Reserved | | | | | | | 1 0 1 1 0 | Reserved | | | | | | | 1 0 1 1 1 | Reserved | | | | | | | 1 1 0 0 0 | A/D0 interrupt request | | | | | | | | Intelligent I/O | Intelligent I/O | Intelligent I/O | Intelligent I/O | | | | 1 1 0 0 1 | interrupt 0 request | interrupt 7 request | interrupt 2 request | interrupt 9 request | | | | 1 1 0 1 0 | Intelligent I/O | Intelligent I/O | Intelligent I/O | Intelligent I/O | | | | 1 1 0 1 0 | interrupt 1 request | interrupt 8 request | interrupt 3 request | interrupt 10 request | | | | 1 1 0 1 1 | Intelligent I/O | Intelligent I/O | Intelligent I/O | Intelligent I/O | | | | | interrupt 2 request | interrupt 9 request | interrupt 4 request | interrupt 11 request | | | | 1 1 1 0 0 | Intelligent I/O | Intelligent I/O | Intelligent I/O | Intelligent I/O | | | | | interrupt 3 request | interrupt 10 request | interrupt 5 request | interrupt 0 request | | | | 1 1 1 0 1 | Intelligent I/O | Intelligent I/O | Intelligent I/O | Intelligent I/O | | | | ' ' ' ' | interrupt 4 request interrupt 11 request interrupt 6 request interrupt 1 request | | | | | | | 1 1 1 1 0 | Intelligent I/O Intelligent I/O Intelligent I/O Intelligent I/O | | | | | | | | interrupt 5 request | interrupt 0 request | interrupt 7 request | interrupt 2 request | | | | 1 1 1 1 1 | Intelligent I/O | Intelligent I/O | Intelligent I/O | Intelligent I/O | | | | | interrupt 6 request | interrupt 1 request | interrupt 8 request | interrupt 3 request | | | ### Notes: - 1. The falling edge and both edges of signals applied to the INTi pin become the DMA request sources (i = 0 to 3). These request sources are not affected by external interrupts (the IFSR0 register and bits POL and LVS in the INTilC register), and vice versa. - 2. Registers UiSMR and UiSMR2 are used to switch between the UARTi receive interrupt and ACK interrupt (i = 0 to 2). Table 12.3 DMiSL2 Register Functions (i = 0 to 3) | Description | Setting Value | | DMA Requ | est Source | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------|---------------------------------|------------|------|--| | 0 | b4 b3 b2 b1 b0 | DMA0 | DMA1 | DMA2 | DMA3 | | | 0 0 0 1 1 Reserved 0 0 1 1 Reserved 0 0 1 0 1 1 Reserved 0 0 1 1 0 Reserved 0 1 1 1 Reserved 0 1 1 1 Reserved 0 1 0 0 Reserved 0 1 0 0 Reserved 0 1 0 0 1 Reserved 0 1 0 0 Reserved 0 1 1 0 0 Reserved 0 1 1 0 0 Reserved 0 1 1 1 1 Reserved 1 0 0 0 Reserved 1 0 1 1 Reserved 1 0 1 <td< td=""><td>0 0 0 0 0</td><td>Software trigger</td><td></td><td>•</td><td></td></td<> | 0 0 0 0 0 | Software trigger | | • | | | | 0 | 0 0 0 0 1 | Reserved | | | | | | 0 | 0 0 0 1 0 | Reserved | | | | | | 0 0 1 1 0 Reserved 0 0 1 1 1 Reserved 0 0 1 1 1 Reserved 0 1 0 1 Reserved 0 1 0 1 Reserved 0 1 1 0 Reserved 0 1 1 0 Reserved 0 1 1 1 0 Reserved 0 1 1 1 0 Reserved 0 1 1 1 1 Reserved 1 0 0 0 Reserved 1 0 0 1 Reserved 1 0 0 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved | 0 0 0 1 1 | Reserved | | | | | | 0 0 1 1 0 Reserved 0 0 1 1 1 Reserved 0 1 0 0 Reserved 0 1 0 1 Reserved 0 1 0 1 1 Reserved 0 1 1 0 Reserved 0 1 1 1 0 Reserved 0 1 1 1 0 Reserved 1 0 0 0 Reserved 1 0 0 0 Reserved 1 0 0 0 Reserved 1 0 0 1 Reserved 1 0 0 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 1 0 1 UART3 transmit interrupt request | 0 0 1 0 0 | Serial bus interface 0 inf | errupt request | | | | | 0 | 0 0 1 0 1 | Reserved | | | | | | 0 1 0 0 Reserved 0 1 0 1 Reserved 0 1 0 1 1 Reserved 0 1 1 0 Reserved 0 1 1 0 Reserved 0 1 1 1 1 Reserved 0 1 1 1 1 Reserved 1 0 0 0 Reserved 1 0 0 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 1 0 0 UART3 transmit interrupt request 1 1 0 1 UART4 receive interrupt request | 0 0 1 1 0 | Reserved | | | | | | 0 1 0 0 1 Reserved 0 1 0 1 0 Reserved 0 1 0 1 1 Reserved 0 1 1 0 0 Reserved 0 1 1 0 0 Reserved 0 1 1 0 0 Reserved 0 1 1 0 1 Reserved 0 1 1 1 0 Reserved 0 1 1 1 1 Reserved 0 1 1 1 1 Reserved 0 1 1 1 1 Reserved 1 0 0 0 0 Reserved 1 0 0 0 1 Reserved 1 0 0 0 1 Reserved 1 0 0 1 1 Reserved 1 0 0 1 1 Reserved 1 0 0 1 1 Reserved 1 0 1 0 Reserved 1 0 1 0 Reserved 1 0 1 0 Reserved 1 0 1 0 1 Reserved 1 0 1 0 0 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 1 0 1 1 Reserved 1 1 1 0 Reserved 1 1 1 1 Reserved 1 1 1 1 Reserved 1 1 1 1 Reserved 1 1 1 1 1 Reserved 1 1 1 1 1 Reserved 1 | 0 0 1 1 1 | Reserved | | | | | | 0 1 0 1 0 1 0 Reserved 0 1 0 1 1 Reserved 0 1 1 0 0 Reserved 0 1 1 0 0 Reserved 0 1 1 0 0 Reserved 0 1 1 1 0 Reserved 0 1 1 1 1 Reserved 0 1 1 1 1 Reserved 1 0 0 0 0 Reserved 1 0 0 0 1 Reserved 1 0 0 0 1 Reserved 1 0 0 1 1 Reserved 1 0 0 1 1 Reserved 1 0 0 1 Reserved 1 0 0 1 Reserved 1 0 0 1 Reserved 1 0 0 1 Reserved 1 Reserved 1 0 Reserved 1 1 Reserved 1 1 Reserved | 0 1 0 0 0 | Reserved | | | | | | 0 1 0 1 1 Reserved 0 1 1 0 1 Reserved 0 1 1 1 0 Reserved 0 1 1 1 1 Reserved 1 0 0 0 Reserved 1 0 0 1 Reserved 1 0 0 1 Reserved 1 0 0 1 Reserved 1 0 1 0 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 1 0 0 UART3 transmit interrupt request 1 1 0 1 UART4 transmit interrupt request 1 1 0 1 UART4 receive interrupt request 1 1 1 0 <td></td> <td></td> <td></td> <td></td> <td></td> | | | | | | | | 0 1 1 0 0 Reserved 0 1 1 1 0 1 Reserved 0 1 1 1 1 0 Reserved 0 1 1 1 1 1 Reserved 1 0 0 0 0 Reserved 1 0 0 0 1 Reserved 1 0 0 1 1 Reserved 1 0 0 1 1 Reserved 1 0 0 1 1 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 1 0 1 1 1 Reserved 1 1 0 1 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 1 0 1 Reserved 1 1 1 0 1 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved 1 1 1 0 Reserved 1 1 1 0 Reserved | 0 1 0 1 0 | Reserved | | | | | | 0 1 1 0 1 Reserved 0 1 1 1 1 0 Reserved 0 1 1 1 1 1 Reserved 1 0 0 0 0 Reserved Reserved 1 0 0 1 1 Reserved Reserved 1 0 0 1 1 Reserved Reserved 1 0 1 0 Reserved Reserved 1 0 1 1 Reserved Reserved 1 0 1 1 Reserved Reserved 1 0 1 1 Reserved Reserved 1 0 1 1 Reserved Reserved 1 0 1 1 Reserved Reserved 1 1 0 0 UART3 transmit interrupt request UART3 receive interrupt request 1 1 0 1 UART4 transmit interrupt request UART4 transmit interrupt request 1 1 1 0 1 Reserved Reserved 1 1 1 0 Reserved Reserved | 0 1 0 1 1 | Reserved | | | | | | 0 1 1 1 1 0 Reserved 0 1 1 1 1 1 Reserved 1 0 0 0 0 1 Reserved 1 0 0 1 0 Reserved 1 0 0 1 1 Reserved 1 0 1 0 0 Reserved Reserved 1 0 1 0 1 Reserved Reserved 1 0 1 1 0 Reserved Reserved 1 0 1 1 Reserved Reserved 1 0 1 1 Reserved Reserved 1 1 0 0 1 Reserved Reserved 1 1 0 0 1 Reserved Reserved 1 1 0 0 1 Reserved Reserved 1 1 0 1 Reserved Reserved 1 1 0 1 Reserved Reserved 1 1 1 0 Reserved Reserved 1 1 1 0 Reserved Reserved 1 1 1 0 Reserved Reserved 1 1 1 1 0 Reserved Reserved | 0 1 1 0 0 | Reserved | | | | | | 0 1 1 1 1 1 Reserved 1 0 0 0 0 Reserved 1 0 0 1 Reserved 1 0 0 1 0 Reserved 1 0 1 0 Reserved 1 0 1 0 Reserved 1 0 1 0 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 0 1 1 Reserved 1 1 0 1 1 Reserved 1 1 0 0 1 UART3 transmit interrupt request 1 1 0 1 UART4 transmit interrupt request 1 1 0 1 Reserved 1 1 Reserved 1 1 Reserved | 0 1 1 0 1 | Reserved | | | | | | 1 0 0 0 0 1 Reserved 1 0 0 1 0 Reserved 1 0 0 1 1 Reserved 1 0 0 1 1 Reserved 1 0 1 0 0 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 1 0 1 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 1 0 1 Reserved 1 1 1 0 Reserved 1 1 1 0 Reserved | 0 1 1 1 0 | Reserved | | | | | | 1 0 0 1 Reserved 1 0 0 1 1 Reserved 1 0 0 1 1 Reserved 1 0 1 0 Reserved 1 0 1 0 1 Reserved 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 1 0 1 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 1 Reserved 1 1 1 0 1 Reserved 1 1 1 0 1 Reserved | 0 1 1 1 1 | Reserved | | | | | | 1 0 0 1 0 Reserved 1 0 0 1 1 Reserved 1 0 1 0 0 Reserved 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 1 0 0 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 1 Reserved 1 1 1 0 Reserved 1 1 1 0 Reserved 1 1 1 0 Reserved | 1 0 0 0 0 | Reserved | | | | | | 1 0 0 1 1 Reserved 1 0 1 0 0 Reserved 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 0 1 1 1 Reserved 1 1 0 0 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 1 Reserved 1 1 1 0 Reserved 1 1 1 0 Reserved | 1 0 0 0 1 | Reserved | | | | | | 1 0 1 0 0 Reserved 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 1 0 1 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 1 Reserved 1 1 1 0 0 Reserved 1 1 1 0 1 Reserved | 1 0 0 1 0 | Reserved | | | | | | 1 0 1 0 1 Reserved 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 1 1 Reserved 1 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 0 0 1 1 | Reserved | | | | | | 1 0 1 1 0 Reserved 1 0 1 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 1 1 Reserved 1 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 0 1 0 0 | Reserved | | | | | | 1 0 1 1 1 Reserved 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 0 1 0 1 | Reserved | | | | | | 1 1 0 0 0 UART3 transmit interrupt request 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 0 1 1 0 | Reserved | | | | | | 1 1 0 0 1 UART3 receive interrupt request 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 0 1 1 1 | Reserved | | | | | | 1 1 0 1 0 UART4 transmit interrupt request 1 1 0 1 1 UART4 receive interrupt request 1 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 1 0 0 0 | UART3 transmit interrup | t request | | | | | 1 1 0 1 1 UART4 receive interrupt request 1 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 1 0 0 1 | I | UART3 receive interrupt request | | | | | 1 1 1 0 0 Reserved 1 1 1 0 1 Reserved 1 1 1 0 Reserved | 1 1 0 1 0 | UART4 transmit interrupt request | | | | | | 1 1 1 0 1 Reserved<br>1 1 1 0 Reserved | 1 1 0 1 1 | UART4 receive interrupt | JART4 receive interrupt request | | | | | 1 1 1 1 0 Reserved | 1 1 1 0 0 | Reserved | | | | | | | 1 1 1 0 1 | Reserved | | | | | | 1 1 1 1 Reserved | 1 1 1 1 0 | Reserved | | | | | | | 1 1 1 1 1 | Reserved | | | | | Figure 12.4 Registers DMD0 to DMD3 Figure 12.5 Registers DCT0 to DCT3 Figure 12.6 Registers DCR0 to DCR3 Figure 12.7 Registers DSA0 to DSA3 Figure 12.8 Registers DSR0 to DSR3 Figure 12.9 Registers DDA0 to DDA3 Figure 12.10 Registers DDR0 to DDR3 # 12.1 Transfer Cycle The transfer cycle is composed of bus cycles to read data from (source read) or to write data to (destination write) memory or an SFR. The read and write bus cycles vary with the setting of registers DSAi and DDAi, the width and timing of the data bus connected to the relevant device (i = 0 to 3). ## 12.1.1 Effect of Transfer Address and Data Bus Width Table 12.4 lists the incremental bus cycles caused by transfer address alignment or data bus width. Table 12.4 Incremental Bus Cycles Caused by Transfer Address and Data Bus Width | Transfer Data | Data Bus | Transfer Bus Cycles to be | | Bus Cycles Generated | |-----------------|--------------|---------------------------|-------------|-----------------------------------| | Unit | Width | Address | Incremented | Dus Cycles Generated | | 8-bit transfer | 8 to 64 bits | n | 0 | [n] | | | 8 bits | n | +1 | [n] - [n + 1] | | | 16 bits | 2n | 0 | [2n] | | | TO DIES | 2n + 1 | +1 | [2n + 1] - [2n + 2] | | | | 4n | 0 | [4n] | | | 32 bits | 4n + 1 | 0 | [4n + 1] | | | 32 Dits | 4n + 2 | 0 | [4n + 2] | | | | 4n + 3 | +1 | [4n + 3] - [4n + 4] | | 16-bit transfer | | 8n | 0 | [8n] | | | | 8n + 1 | 0 | [8n + 1] | | | | 8n + 2 | 0 | [8n + 2] | | | 64 bits | 8n + 3 | 0 | [8n + 3] | | | 04 มีเร | 8n + 4 | 0 | [8n + 4] | | | | 8n + 5 | 0 | [8n + 5] | | | | 8n + 6 | 0 | [8n + 6] | | | | 8n + 7 | +1 | [8n + 7] - [8n + 8] | | | 8 bits | n | +3 | [n] - [n + 1] - [n + 2] - [n + 3] | | | | 4n | +1 | [4n] - [4n + 2] | | | 16 hita | 4n + 1 | +2 | [4n + 1] - [4n + 2] - [4n + 4] | | | 16 bits | 4n + 2 | +1 | [4n + 2] - [4n + 4] | | | | 4n + 3 | +2 | [4n + 3] - [4n + 4] - [4n + 6] | | | | 4n | 0 | [4n] | | | 32 bits | 4n + 1 | +1 | [4n + 1] - [4n + 4] | | | 32 DIIS | 4n + 2 | +1 | [4n + 2] - [4n + 4] | | 32-bit transfer | | 4n + 3 | +1 | [4n + 3] - [4n + 4] | | | | 8n | 0 | [8n] | | | | 8n + 1 | 0 | [8n + 1] | | | | 8n + 2 | 0 | [8n + 2] | | | 64 5:45 | 8n + 3 | 0 | [8n + 3] | | | 64 bits | 8n + 4 | 0 | [8n + 4] | | | | 8n + 5 | +1 | [8n + 5] - [8n + 8] | | | | 8n + 6 | +1 | [8n + 6] - [8n + 8] | | | | 8n + 7 | +1 | [8n + 7] - [8n + 8] | ## 12.1.2 Effect of Bus Timing In the R32C/100 Series, a separate bus is connected to each device. The bus width and bus timing vary with each device. Table 12.5 lists the bus width and access cycles for each device. Table 12.5 Bus Width and Bus Cycles | Device | Addresses (1) | Bus Width | Access Cycles (2) | Reference Clock | |--------------|------------------------|-----------|-----------------------|----------------------| | Flash memory | FFE00000h to FFFFFFFh | 64-bit | 2 or 3 <sup>(3)</sup> | CPU clock | | Data flash | 00060000h to 00061FFFh | 64-bit | 5 | CPU clock | | RAM | 00000400h to 0003FFFFh | 64-bit | 1 or 2 <sup>(4)</sup> | CPU clock | | SFR space | 00000000h to 0000001Fh | 16-bit | 3 (5) | Peripheral bus clock | | | 00000020h to 000003FFh | 16-bit | 2 (5) | Peripheral bus clock | | SFR2 space | 00040000h to 00041FFFh | 16-bit | 2 (5) | Peripheral bus clock | | | 00042000h to 00043FFFh | 32-bit | 2 (5) | Peripheral bus clock | | | 00044000h to 000440DFh | 16-bit | 2 (5, 6) | Peripheral bus clock | | | 000440E0h to 000443FFh | 16-bit | 3 (5, 6) | Peripheral bus clock | | | 00044400h to 00045FFFh | 16-bit | 2 (5, 6) | Peripheral bus clock | | | 00046000h to 000467FFh | 32-bit | 3 (5, 6) | Peripheral bus clock | | | 00046800h to 00047FFFh | 32-bit | 2 (5, 6) | Peripheral bus clock | | | 00048000h to 0004FFFFh | 64-bit | 2 | CPU clock | #### Notes: - 1. Reserved spaces are included. - 2. Access cycles are based on each bus clock. - 3. An access to the same page as the previous time requires two cycles. Otherwise, three cycles are required. - 4. If write cycles are generated sequentially, each write cycle except the initial one has two access cycles. A read cycle just after a write cycle has also two access cycles. - 5. If SFRs are sequentially accessed, each access except the initial one has one additional base clock cycle. - 6. Up to one access cycle may be added depending on the phase of peripheral bus clock. Figure 12.11 shows an example of source-read bus cycles in a transfer cycle. In this figure, the number of source-read bus cycles is shown under different conditions, provided that the destination address is in an internal RAM with one bus cycle of destination-write. In a real operation, the transfer cycles change according to conditions for destination-write bus cycles as well as for source-read bus cycles. To calculate a transfer cycle, respective conditions should be applied to both destination-write bus cycle and source-read bus cycle. In (B) of Figure 12.11, for example, if two bus cycles are generated, bus cycles required for the destination-write is two as well as for the source-read bus cycle. Figure 12.11 Source-read Bus Cycles in a Transfer Cycle # 12.2 DMA Transfer Cycle The DMA transfer cycles are calculated as follows: Number of transfer cycles = Source-read bus cycles $\times$ j + Destination-write bus cycles $\times$ k + 1 where: j = access cycles for read k = access cycles for write (refer to Table 12.5) Each bus cycle, source-read, and destination-write requires one or more cycles. In addition, more cycles may be required depending on the transfer address. Refer to Table 12.4 for details on the required bus cycles. "+1" in the formula above means a cycle required to decrement the value of DCTi register (i = 0 to 3). The following are calculation examples: To transfer 32-bit data from address 400h in the RAM to address 800h in the RAM, Number of the transfer cycles = $$1 \times 1 + 1 \times 1 + 1$$ = 3 Thus, there are three cycles. To transfer 16-bit data from the AD00 register at address 380h to registers P1 and P0 at addresses 3C1h and 3C0h, respectively, when the peripheral bus clock frequency is half the CPU clock, Number of the transfer cycles = $$1 \times 2 \times 2 + 1 \times 2 \times 2 + 1$$ = 9 Thus, there are nine cycles. # 12.3 Channel Priority and DMA Transfer Timing When multiple DMA transfer requests are generated in the same sampling period, between the falling edge of the CPU clock and the next falling edge, these requests are simultaneously input into the DMAC. Channel priority in this case is: DMA0 > DMA1 > DMA2 > DMA3. Figure 12.12 shows an example of the DMA transfer by external source, specifically when DMA0 and DMA1 requests are simultaneously generated. The DMA0, whose request priority is higher than that of DMA1, is received first to start the transfer and then hands over the bus to the CPU after completing one DMA0 transfer. Once the CPU completes one bus access, the DMA1 transfer starts. The CPU takes the bus back from the DMA1 after one DMA1 transfer is completed. DMA transfer requests cannot be counted. Only a single transfer is performed even when an INTi interrupt occurs more than once before the bus is granted, as shown by DMA1 in Figure 12.12. Figure 12.12 DMA Transfer by External Source ### 12.4 Notes on DMAC # 12.4.1 DMAC-associated Register Settings • Set DMAC-associated registers while bits MDi1 and MDi0 in the DMDi register are 00b (DMA transfer disabled) (i = 0 to 3). Then, set bits MDi1 and MDi0 to 01b (single transfer) or 11b (repeat transfer) at the end of the setup procedure. This procedure also applies when rewriting bits UDAi, USAi, and BWi1 and BWi0 in the DMDi register. - When rewriting the DMAC-associated registers while DMA transfer is enabled, stop the peripherals that can be DMA triggers so that no DMA transfer request is generated, then set bits MDi1 and MDi0 in the DMDi register of the corresponding channel to 00b (DMA transfer disabled). - Once a DMA transfer request is accepted, DMA transfer cannot be disabled even if setting bits MDi1 and MDi0 in the DMDi register to 00b (DMA transfer disabled). Do not change the settings of any DMAC-associated registers other than bits MDi1 and MDi0 until the DMA transfer is completed. - After setting registers DMiSL and DMiSL2, wait at least six peripheral bus clocks to set bits MDi1 and MDi0 in the DMDi register to 01b (single transfer) or 11b (repeat transfer). ## 12.4.2 Reading DMAC-associated Registers Use the following read order to sequentially read registers DMiSL and DMiSL2: DM0SL, DM1SL, DM2SL, and DM3SL DM0SL2, DM1SL2, DM2SL2, and DM3SL2 R32C/161 Group 13. DMAC II ## 13. DMAC II DMAC II starts by an interrupt request from any peripheral and performs data transfer without a CPU instruction. Transfer sources are selectable from memory, immediate data, memory + memory, and immediate data + memory. Table 13.1 lists specifications of DMAC II. Table 13.1 DMAC II Specifications | Item | Specification | |--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DMAC II request sources | Interrupt requests from the peripherals of which bits ILVL2 to ILVL0 in the corresponding interrupt control register are set to 111b (level 7) | | Transfer types | <ul> <li>Data in memory is transferred to memory (memory-to-memory transfer)</li> <li>Immediate data is transferred to memory (immediate data transfer)</li> <li>Data in memory + data in memory are transferred to memory (calculation result transfer)</li> <li>Immediate data + data in memory are transferred to memory (calculation result transfer)</li> </ul> | | Transfer sizes | 8 bits or 16 bits | | Transfer memory spaces | From a given address in a 64-Mbyte space (00000000h to 01FFFFFh and FE000000h to FFFFFFFh) to another given address in the same space (1) | | Addressing modes | Individually selectable for each source address and destination address from the following two modes: • Non-incrementing addressing: Address is held constant throughout a data transfer/DMA II transaction • Incrementing addressing: Address increments by 1 (when 8-bit data is transferred) or 2 (when 16-bit data is transferred) after each data transfer | | Transfer modes | <ul> <li>Single transfer: Only one data transfer is performed by one transfer request</li> <li>Burst transfer: Data transfers are continuously performed for the number of times set in the transfer counter by one transfer request</li> <li>Multiple transfer: Multiple memory-to-memory transfers are performed from different source addresses to different destination addresses by one transfer request</li> </ul> | | Chain transfer | Data transfer is sequentially performed by switching among multiple DMAC II indexes (transfer information) | | DMA II transfer complete interrupt request | An interrupt request is generated when the transfer counter reaches 0000h | | | | #### Note: 1. When the transfer size is 16 bits and the destination address is FFFFFFFh, data is transferred to FFFFFFFh and 00000000h. This also applies when the source address is FFFFFFFh. # 13.1 DMAC II Settings To use DMAC II, set the following: - Registers RIPL1 and RIPL2 - DMAC II index - Interrupt control registers of the peripherals that trigger DMAC II - Relocatable vectors of the peripherals that trigger DMAC II - The IRLT bit in the IIOiIE register when using the intelligent I/O interrupt (i = 0 to 11). Refer to 10. "Interrupts" for details on the IIOiIE register. R32C/161 Group 13. DMAC II # 13.1.1 Registers RIPL1 and RIPL2 When the DMAII bit in registers RIPL1 and RIPL2 is set to 1 (DMA II transfer selected) and the FSIT bit is set to 0 (normal interrupt selected), DMAC II starts by an interrupt request from any peripheral whose bits ILVL2 to ILVL0 in the corresponding interrupt control register are set to 111b (level 7). Figure 13.1 shows registers RIPL1 and RIPL2. ### Notes: - 1. Registers RIPL1 and RIPL2 should be set with the same values. - 2. The MCU exits wait mode or stop mode when the request level of the requested interrupt is higher than the level selected using bits RLVL2 to RLVL0. Set these bits to the same value as the IPL in the FLG register. - 3. When the FSIT bit is 1, an interrupt with interrupt request level 7 becomes the fast interrupt. In this case, set the interrupt request level to level 7 with only one interrupt. - 4. Set either the FSIT or DMAII bit to 1. The fast interrupt and DMAC II cannot be used simultaneously. - 5. Set bits ILVL2 to ILVL0 in the interrupt control register after the DMAII bit is set. DMA II transfer is not affected by the I flag or IPL. Figure 13.1 Registers RIPL1 and RIPL2 ### 13.1.2 DMAC II Index The DMAC II index is a data table of 12 to 60 bytes. It stores parameters for transfer mode, transfer counter, source address (or immediate data), operation address as an address to be calculated, destination address, chain transfer base address, and jump address for the DMA II transfer complete interrupt handler. This DMAC II index should be allocated on the RAM. Figure 13.2 shows a configuration of the DMAC II index and Table 13.2 lists a configuration example of the DMAC II index. The DMAC II index should be allocated on the RAM. Required data should be set front-aligned. For example, when the calculation transfer is not used, the destination address should be set to BASE + 8 (refer to the "DMAC II Index Configuration" on the next page). Start address of the DMAC II index should be set in the interrupt vector space for the peripheral interrupt triggering DMAC II. Figure 13.2 DMAC II Index The following are the details on the DMAC II index. These parameters should be aligned in the order listed in Table 13.2 according to the transfer mode to be used. - Transfer mode (MOD) - Set a transfer mode in 2 bytes. Refer to Figure 13.3 for details on the setting of MOD. - Transfer counter (COUNT) - Set a number of transfers in 2 bytes. - Source address (SADR) - Set a source address or immediate data in 4 bytes. Note that the two upper bytes of immediate data are ignored. - Operation address (OADR) - Set an address in a to-be calculated memory in 4 bytes. This data setting is required only for the calculation transfer. - Destination address (DADR) - Set a destination address in 4 bytes. - Chain transfer base address (CADR) - Set the start address of the DMAC II index for the next transfer (BASE) in 4 bytes. This data setting is required only for the chain transfer. - Jump address for the DMA II transfer complete interrupt handler (IADR) Set the start address for the DMA II transfer complete interrupt handler in 4 bytes. This data setting is required only for the DMA II transfer complete interrupt. The symbols above are hereinafter used in place of their respective parameters. Table 13.2 DMAC II Index Configuration | Transfer | Memory-to-memory Transfer/ | | | Calculation Transfer | | | Multiple | | | |---------------------------------------------|----------------------------|----------|----------|----------------------|----------|----------|----------|----------|------------------------------------------------| | Data | Immediate Data Transfer | | | Calculation mansier | | | Transfer | | | | Chain transfer | Not used | Used | Not used | Used | Not used | Used | Not used | Used | Not available | | DMA II<br>transfer<br>complete<br>interrupt | Not used | Not used | Used | Used | Not used | Not used | Used | Used | Not<br>available | | | | | | | | | | | | | DMAC II<br>index | MOD | | COUNT | | SADR SADR1 | | | DADR | DADR | DADR | DADR | OADR | OADR | OADR | OADR | DADR1 | | | 12 bytes | CADR | IADR | CADR | DADR | DADR | DADR | DADR | | | | | 16 bytes | 16 bytes | IADR | 16 bytes | CADR | IADR | CADR | SADRi | | | | | | 20 bytes | | 20 bytes | 20 bytes | IADR | DADRi | | | | | | | | | | 24 bytes | i = 1 to 7<br>max. 60<br>bytes<br>(when i = 7) | Figure 13.3 MOD ## 13.1.3 Interrupt Control Register of the Peripherals Set bits ILVL2 to ILVL0 in the interrupt control register for the peripheral interrupt triggering DMAC II to 111b (level 7). # 13.1.4 Relocatable Vector Table of the Peripherals Set the start address of the DMAC II index in the interrupt vector space for the peripheral interrupt triggering DMAC II. To use the chain transfer, allocate the relocatable vector table on the RAM. # 13.1.5 IRLT Bit in the IIOiIE Register (i = 0 to 11) To use the intelligent I/O interrupt as a trigger for DMAC II, set the IRLT bit in the corresponding IIOiIE register to 0 (interrupt request for DMA or DMA II used). ## 13.2 DMAC II Operation Set the DMAII bit in registers RIPL1 and RIPL2 to 1 (interrupt request level 7 used for DMA II transfer) to perform a DMA II transfer. DMAC II starts by an interrupt request from any peripheral whose bits ILVL2 to ILVL0 in the corresponding interrupt control register are set to 111b (level 7). These peripheral interrupt requests are available only for DMA II transfer and cannot be used for the CPU. When an interrupt request is generated with interrupt request level 7, DMAC II starts irrespective of the state of the I flag or IPL. When a peripheral interrupt request triggering DMAC II and a higher-priority request such as the watchdog timer interrupt, low voltage detection interrupt, oscillator stop detection interrupt, or NMI are simultaneously generated, the higher-priority interrupt is accepted prior to the DMA II transfer, and the DMA II transfer starts after the higher-priority interrupt sequence. ## 13.3 Transfer Types DMAC II transfers three types of 8-bit or 16-bit data as follows: • Memory-to-memory transfer: Data is transferred from a given memory location in a 64-Mbyte space (addresses 00000000h to 01FFFFFh and FE000000h to FFFFFFFh) to another given memory location in the same space. • Immediate data transfer: Immediate data is transferred to a given memory location in a 64- Mbyte space. • Calculation transfer: Two data are added together and the result is transferred to a given memory location in a 64-Kbyte space. When 16-bit data is transferred to DADR at FFFFFFFh, it is transferred to 00000000h as well as FFFFFFFh. The same transfer is performed when SADR is FFFFFFFh. ## 13.3.1 Memory-to-memory Transfer Data transfer between any two memory locations can be: - A transfer from a fixed address to another fixed address - A transfer from a fixed address to an address range in memory - A transfer from an address range in memory to a fixed address - A transfer from an address range in memory to another address range in memory When increment addressing mode is selected, SADR and DADR increment by 1 in an 8-bit transfer and by 2 in a 16-bit transfer after a data transfer for the next transfer. When SADR or DADR exceeds FFFFFFFh by the incrementation, it returns to 00000000h. Likewise, when SADR or DADR exceeds 01FFFFFFh, it becomes 02000000h, but an actual transfer is performed for FE000000h. ### 13.3.2 Immediate Data Transfer DMAC II transfers immediate data to a given memory location. Either incrementing or non-incrementing addressing mode can be selected for the destination address. Store the immediate data to be transferred into SADR. To transfer 8-bit immediate data, set the data to the lower 1 byte of SADR. The upper 3 bytes are ignored. To transfer 16-bit immediate data, set the data to the lower 2 bytes. The upper 2 bytes are ignored. ### 13.3.3 Calculation Result Transfer After two memory data or immediate data and memory data are added together, DMAC II transfers the calculated result to a given memory location. Set an address to be calculated or immediate data to SADR and set the other address to be calculated to OADR. Either incrementing or non-incrementing addressing mode can be selected for source and destination addresses when performing data in memory + data in memory calculation transfer. If the source addressing is in incrementing mode, the operation addressing is also in incrementing mode. When performing immediate data + data in memory calculation transfer, the addressing mode is selectable only for the destination address. ### 13.4 Transfer Modes DMAC II provides three types of basic transfer mode: single transfer, burst transfer, and multiple transfer. COUNT determines the number of transfers to be performed. Transfers are not performed when COUNT is 0000h. ## 13.4.1 Single Transfer Set the BRST bit in the MOD to 0. A single data transfer is performed by one transfer request. When incrementing addressing mode is selected for the source and/or destination address, the address or addresses increment after a data transfer for the next transfer. COUNT is decremented each time a data transfer is performed. When COUNT reaches 0000h, the DMA II transfer complete interrupt request is generated if the INTE bit in the MOD is 1 (DMA II transfer complete interrupt used). ### 13.4.2 Burst Transfer Set the BRST bit in the MOD to 1. DMAC II continuously transfers data for the number of times determined by COUNT with one transfer request. COUNT decrements each time a data transfer is performed. When COUNT reaches 0000h, the burst transfer is completed. The DMA II transfer complete interrupt request is generated if the INTE bit is 1 (DMA II transfer complete interrupt used). No interrupts are accepted during a burst transfer. ## 13.4.3 Multiple Transfer Set the MULT bit in the MOD to 1. Multiple memory-to-memory transfers are performed from different source addresses to different destination addresses using one transfer request. Set bits CNT2 to CNT0 in the MOD to select the number of transfers to be performed from 001b (once) to 111b (seven times). Do not set these bits to 000b. Allocate the required number of SDARs and DADRs alternately following MOD and COUNT. When the multiple transfer is selected, the following transfer functions are not available: calculation result transfer, burst transfer, chain transfer, and DMA II transfer complete interrupt. ## 13.5 Chain Transfer The chain transfer is available when the CHAIN bit in the MOD is 1. The chain transfer is performed as follows: (1) When a transfer request is generated, a data transfer is performed according to the DMAC II index specified by the corresponding interrupt vector. Either a single transfer (the BRST bit in the MOD is 0) or burst transfer (the BRST bit is 1) is performed according to the BRST bit setting. - (2) When COUNT reaches 0000h, the value in the interrupt vector in (1) above is overwritten with the value in CADR. Simultaneously, the DMA II transfer complete interrupt request is generated when the INTE bit in the MOD is 1. - (3) When the next DMA II transfer request is generated, the data transfer is performed according to the DMAC II index specified by the peripheral interrupt vector in (2) above. Figure 13.4 shows the relocatable vector and DMAC II index in a chain transfer. To use the chain transfer, the relocatable vector table should be allocated on the RAM. Figure 13.4 Relocatable Vector and DMAC II Index in a Chain Transfer ## 13.6 DMA II Transfer Complete Interrupt The DMA II transfer complete interrupt is available when the INTE bit in the MOD is 1. Set the start address of the DMA II transfer complete interrupt handler to IADR. The interrupt request is generated when COUNT reaches 0000h. The initial instruction of the interrupt handler is executed in the eighth cycle after a DMA II transfer is completed. ### 13.7 Execution Time The DMAC II execution cycle is calculated by the following equations: Mode other than multiple transfer: $t = 6 + (26 + a + b + c + d) \times m + (4 + e) \times n$ cycles When using multiple transfer: $t = 21 + (11 + b + c) \times k$ cycles - a: When IMM is 0 (transfer source is immediate data), a is 0; When IMM is 1 (transfer source is memory), a is -1 - b: When UPDS is 1 (source addressing is incrementing), b is 0; When UPDS is 0 (source addressing is non-incrementing), b is 1 - c: When UPDD is 1 (destination addressing is incrementing), c is 0;When UPDD is 0 (destination addressing is non-incrementing), c is 1 - d: When OPER is 0 (calculation transfer is not selected), d is 0; When OPER is 1 (calculation transfer is selected) and UPDS is 0 (source addressing is immediate data or non-incrementing), d is 7; When OPER is 1 (calculation transfer is selected) and UPDS is 1 (source addressing is incrementing), d is 8 - e: When CHAIN is 0 (chain transfer is not selected), e is 0; When CHAIN is 1 (chain transfer is selected), e is 4 - m: When BRST is 0 (single transfer), m is 1; When BRST is 1 (burst transfer), m is COUNT - n: When COUNT is 0001h, n is 0; if COUNT is 0002h or more, n is 1 - k: The number of transfers set using bits CNT2 to CNT0 The equations above are estimations. The number of cycles may vary depending on CPU state, bus wait state, and DMAC II index allocation. Figure 13.5 Transfer Cycles # 14. Programmable I/O Ports There are 64 programmable I/O ports designated from P0 to P9 (excluding P6\_0 to P6\_4, P6\_6, P7\_1 to P7\_3, P7\_7, P8\_0, P8\_1, and P9\_0 to P9\_2). Each port status, input or output, can be selected using the direction register except P8\_5 and P9\_1 which are input only. The P8\_5 bit in the P8 register indicates an NMI input level since the P8\_5 shares a pin with the NMI. Figure 14.1 shows a configuration of programmable I/O ports, and Figures 14.2 and Figure 14.3 show a configuration of each input-only port. Figure 14.1 Programmable I/O Port Configuration Figure 14.2 Input-only Port Configuration (1/2) Figure 14.3 Input-only Port Configuration (2/2) # 14.1 Port Pi Register (Pi register, i = 0 to 9) A write/read operation to the Pi register is required to communicate with external devices. This register consists of a port latch to hold output data and a circuit to read pin states. Bits in the Pi register correspond to respective ports. When a programmable I/O port is selected in the output function select register, the value in the port latch is read for output and the pin state is read for input. Figure 14.4 shows the Pi register. Figure 14.4 Registers P0 to P9 ## 15. Timers This MCU has eleven 16-bit timers which are divided into two groups according to their functions: five timer As and six timer Bs. Each timer functions individually. The count source of each timer provides the clock for timer operations such as counting and reloading. Figure 15.1 and Figure 15.2 show the configuration of timers A and B, respectively. Figure 15.1 Timer A Configuration Figure 15.2 Timer B Configuration ### 15.1 Timer A Figure 15.3 shows a block diagram of timer A and Figure 15.4 to Figure 15.10 show registers associated with timer A. Timer A supports the four modes shown below. Timers A0 to A4 in any mode other than the event counter mode have the same function. Select a mode by setting bits TMOD1 and TMOD0 in the TAiMR register (i = 0 to 4). - Timer mode: The timer counts an internal count source - Event counter mode: The timer counts an external pulse or overflow and underflow of other timers - One-shot timer mode: The timer outputs one valid pulse before the counter reaches 0000h - Pulse-width modulation mode: The timer successively outputs pulses of a given width Figure 15.3 Timer A Block Diagram fj: f1, f8, f2n, fC32 #### Notes: - 1. A 16-bit read/write access to this register should be performed. - 2. The timer counts an external input pulse or overflow and underflow of other timers. - 3. When the TAi register is set to 0000h, the timer counter does not start, and the TAi interrupt request is not generated. - 4. Use the MOV instruction to set the TAi register. - 5. When the TAi register is set to 0000h, the pulse-width modulator does not operate, the TAiOUT pin is held low, and the TAi interrupt request is not generated. The same restrictions apply in 8-bit pulse-width modulator mode if the upper byte in the TAi register is set to 00h. Figure 15.4 Registers TA0 to TA4 Figure 15.5 Registers TA0MR to TA4MR Figure 15.6 TABSR Register 2 - 2. This bit is enabled in event counter mode and when the MR2 bit in the TAiMR register is set to 0 (the UDF register setting is the source of increment/decrement switching) (i = 0 to 4). - 3. Set this bit to 0 when not using two-pulse signal processing. Figure 15.7 UDF Register Figure 15.8 ONSF Register Figure 15.9 TRGSR Register Figure 15.10 TCSPR Register ## 15.1.1 Timer Mode In timer mode, the timer counts an internally generated count source. Table 15.1 lists the specifications of timer mode. Figure 15.11 shows registers TA0MR to TA4MR in this mode. Table 15.1 Timer Mode Specifications (i = 0 to 4) | Item | Specification | |-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count sources | f1, f8, f2n, or fC32 | | Count operations | Decrement When the timer counter underflows, the reload register value is reloaded into the counter to continue counting | | Divide ratio | $\frac{1}{n+1}$ $n$ : TAi register setting value, 0000h to FFFFh | | Count start condition | The TAiS bit in the TABSR register is 1 (start counter) | | Count stop condition | The TAiS bit in the TABSR register is 0 (stop counter) | | Interrupt request generating timing | When the timer counter underflows | | TAilN pin function | Functions as a programmable I/O port or a gate input | | TAiOUT pin function | Functions as a programmable I/O port or a pulse output | | Read from timer | The TAi register indicates the counter value | | Write to timer | <ul> <li>While the timer counter is stopped or before the initial count source is input after starting to count, the value written to the TAi register is written to both the reload register and the counter</li> <li>While the timer counter is running, the value written to the TAi register is written to the reload register (it is transferred to the counter at the next reload timing)</li> </ul> | | Other functions | <ul> <li>Gate function Input signal to the TAilN pin can control the count start/stop</li> <li>Pulse output function The polarity of the TAiOUT pin is inverted each time the timer counter underflows. A low is output while the TAiS bit holds 0 (stop counter)</li> </ul> | Figure 15.11 Registers TA0MR to TA4MR in Timer Mode ## 15.1.2 Event Counter Mode In event counter mode, the timer counts an external signal or an overflow and underflow of other timers. Timers A2, A3, and A4 can count two-phase external signals. Table 15.2 lists the specifications in event count mode and Table 15.3 also lists the specifications when the timers use two-phase pulse signal processing. Figure 15.12 shows registers TA0MR to TA4MR in this mode. Table 15.2 Event Counter Mode Specifications (without two-phase pulse signal processing) (i = 0 to 4) | Item | Specification | |------------------------------|------------------------------------------------------------------------------------------| | Count sources | External signal applied to the TAilN pin (valid edge is selectable by a program) | | | One of the following: the overflow and/or underflow signal of timer B2, the | | | overflow and/or underflow signal of timer Aj ( $j = i - 1$ , or $j = 4$ if $i = 0$ ), or | | | the overflow and/or underflow signal of timer Ak ( $k = i + 1$ , or $k = 0$ if $i = 4$ ) | | Count operations | Increment/decrement can be switched by an external signal or program | | | When the timer counter underflows or overflows, the reload register value | | | is reloaded into the counter to continue counting. In a free-running count | | Divide natio | operation, the timer counter continues counting without reloading | | Divide ratio | • $\frac{1}{FFFFh-n+1}$ when incrementing | | | • $\frac{1}{n+1}$ when decrementing | | | n: TAi register setting value, 0000h to FFFFh | | Count start condition | The TAiS bit in the TABSR register is 1 (start counter) | | Count stop condition | The TAiS bit in the TABSR register is 0 (stop counter) | | Interrupt request generating | When the timer counter overflows or underflows | | timing | | | TAilN pin function | Functions as a programmable I/O port or a count source input | | TAiOUT pin function | Functions as a programmable I/O port, a pulse output, or an input for | | | switching between increment/decrement | | Read from timer | The TAi register indicates a counter value | | Write to timer | While the timer counter is stopped or before the initial count source is | | | input after starting to count, the value written to the TAi register is written | | | to both the reload register and the counter | | | • While the timer counter is running, the value written to the TAi register is | | | written to the reload register (it is transferred to the counter at the next | | Other functions | reload timing) • Free-running count function | | Other functions | The reload register value is not reloaded even if the timer counter | | | overflows or underflows | | | Pulse output function | | | The polarity of the TAiOUT pin is inverted whenever the timer counter | | | overflows or underflows. | | | A low is output while the TAiS bit holds 0 (stop counter) | | | , , , , , | Table 15.3 Event Counter Mode Specifications (with two-phase pulse signal processing on timers A2 to A4) (i = 2 to 4) | Item | Specification | | | |-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count sources | Two-phase pulse signal applied to pins TAilN and TAiOUT | | | | Count operations | <ul> <li>Increment/decrement can be switched by a two-phase pulse signal</li> <li>When the timer counter underflows or overflows, the reload register value is reloaded into the counter to continue counting. In a free-running count operation, the timer counter continues counting without reloading</li> </ul> | | | | Divide ratio | • $\frac{1}{FFFFh-n+1}$ when incrementing | | | | | • $\frac{1}{n+1}$ when decrementing $n$ : TAi register setting value, 0000h to FFFFh | | | | Count start condition | The TAiS bit in the TABSR register is 1 (start counter) | | | | Count stop condition | The TAiS bit in the TABSR register is 0 (stop counter) | | | | Interrupt request generating timing | When the timer counter overflows or underflows | | | | TAilN pin function | A two-phase pulse input | | | | TAiOUT pin function | A two-phase pulse input | | | | Read from timer | The TAi register indicates a counter value | | | | Write to timer | <ul> <li>While the timer counter is stopped or before the initial count source is input after starting to count, the value written to the TAi register is written to both the reload register and the counter</li> <li>While the timer counter is running, the value written to the TAi register is written to the reload register (it is transferred to the counter at the next reload timing)</li> </ul> | | | | Other functions (1) | Normal processing operation (timers A2 and A3) While the input signal applied to the TAjOUT pin is held high, the timer increments on the rising edge of the TAjIN pin and decrements on the falling edge (j = 2 or 3) TAjOUT TAjOUT | | | | | TAjIN IC IC DC DC DC DC: Increments DC: Dc | | | | | <ul> <li>Quadrupled processing operation (timers A3 and A4) When the input signal applied to the TAkOUT pin is held high on the rising edge of the TAkIN pin, the timer increments on both the rising and falling edges of pins TAkOUT and TAkIN (k = 3 or 4). </li> <li>When the signal is held high on the falling edge of the TAkIN pin, the timer decrements on both the rising and falling edges of pins TAkOUT and TAkIN</li> </ul> | | | | | TAKOUT TAKIN Increments Decrements | | | | | • Counter reset by Z-phase input (timer A3) The counter value is set to 0 by Z-phase input | | | Note: Only timer A3 is available for any of the other functions. Timer A2 is exclusively for normal processing operations and timer A4 is for the quadrupled processing operation. ### Notes: - 1. Set bits TAiTGH and TAiTGL in the ONSF or TRGSR register to select the count source in event counter - 2. This bit setting is enabled only when an external signal is counted. - 3. The timer decrements when the input signal to the TAiOUT pin is held low, and increments when the signal is held high. - 4. The TCK1 bit is enabled only in the TA3MR register. - 5. For two-phase pulse signal processing, set the TAjP bit in the UDF register to 1 (two-phase pulse signal processing enabled) and bits TAjTGH and TAjTGL to 00b (input to the TAjIN pin) (j = 2 to 4). Figure 15.12 Registers TA0MR to TA4MR in Event Counter Mode # 15.1.2.1 Counter Reset by Two-phase Pulse Signal Processing A Z-phase input signal resets the timer counter when a two-phase pulse signal is being processed. This function can be used under the following conditions: timer A3 event counter mode, two-phase pulse signal processing, free-running count operation, and quadrupled processing. The Z-phase signal is applied to the $\overline{\text{INT2}}$ pin. When the TAZIE bit in the ONSF register is set to 1 (Z-phase input enabled), the timer counter can be reset by Z-phase input. To reset the counter, set the TA3 register to 0000h beforehand. A Z-phase signal applied to the $\overline{\text{INT2}}$ pin is detected on an edge. The edge polarity is selected using the POL bit in the INT2IC register. The Z-phase signal should be input in order to have a pulse width of one or more count source cycles for timer A3. Figure 15.13 shows the two-phase pulse (phases A and B) and the Z-phase. The timer counter is reset at the initial count source input after Z-phase input is detected. Figure 15.14 shows the counter reset timing. When timer A3 overflows or underflows during a reset by the Z-phase input, two timer A3 interrupt requests are successively generated. To avoid this, the timer A3 interrupt request should not be used when using this function. Figure 15.13 Two-phase Pulse (phases A and B) and Z-phase Figure 15.14 Counter Reset Timing ## 15.1.3 One-shot Timer Mode In one-shot timer mode, the timer operates only once for each trigger. Table 15.4 lists specifications of one-shot timer mode. Once a trigger occurs, the timer starts and operates for a given period. Figure 15.15 shows registers TA0MR to TA4MR in this mode. Table 15.4 One-shot Timer Mode Specifications (i = 0 to 4) | Item | Specification | |-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count sources | f1, f8, f2n, or 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 into the counter to continue counting</li> </ul> | | Divide ratio | $\frac{1}{n}$ $n$ : TAi register setting value, 0000h to FFFFh (Note that the timer counter does not run if n = 0000h) | | Count start conditions | <ul> <li>The TAiS bit in the TABSR register is 1 (start counter) and any of following triggers occurs:</li> <li>An external trigger applied to the TAiIN pin</li> <li>One of the following: the overflow and/or underflow signal of timer B2, the overflow and/or underflow signal of timer Aj (j = i - 1, or j = 4 if i = 0), or the overflow and/or underflow signal of timer Ak (k = i + 1, or k = 0 if i = 4)</li> <li>The TAiOS bit in the ONSF register is 1 (start the timer)</li> </ul> | | Count stop conditions | <ul> <li>The timer counter reaches 0000h and the reload register value is reloaded</li> <li>The TAiS bit in the TABSR register is 0 (stop counter)</li> </ul> | | Interrupt request generating timing | When the timer counter reaches 0000h | | TAilN pin function | A programmable I/O port or a trigger input | | TAiOUT pin function | A programmable I/O port or a pulse output | | Read from timer | The TAi register indicates an undefined value | | Write to timer | <ul> <li>While the timer counter is stopped or before the initial count source is input after starting to count, the value written to the TAi register is written to both the reload register and the counter</li> <li>While the timer counter is running, the value written to the TAi register is written to the reload register (it is transferred to the counter at the next reload timing)</li> </ul> | | Other function | Pulse output function A low is output while the timer counter is stopped and a high is output while the timer counter is running | Figure 15.15 Registers TA0MR to TA4MR in One-shot Timer Mode ## 15.1.4 Pulse-width Modulation Mode In pulse-width modulation mode, the timer outputs pulses of given width successively. Table 15.5 lists specifications of pulse-width modulation mode. The timer counter functions as either a 16-bit or 8-bit pulse-width modulator. Figure 15.16 shows registers TA0MR to TA4MR in this mode. Figures 15.17 and 15.18 show operation examples of 16-bit and 8-bit pulse-width modulators. Table 15.5 Pulse-width Modulation Mode Specifications (i = 0 to 4) | Item | Specification | | | | |------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Count sources | f1, f8, f2n, or fC32 | | | | | Count operations | <ul> <li>Decrement (the timer counter functions as an 8-bit or a 16-bit pulse-width modulator)</li> <li>The reload register value is reloaded on the rising edge of a PWM pulse to continue counting</li> <li>The timer is not affected by a trigger that occurs while the counter is</li> </ul> | | | | | | running | | | | | 16-bit PWM | • High level width: $\frac{n}{fj}$ $n$ : TAi register setting value, 0000h to FFFEh | | | | | | f: Count source frequency | | | | | | • Cycles: fixed to $\frac{2^{16}-1}{fj}$ | | | | | 8-bit PWM | • High level width: $\frac{n \times (m+1)}{fj}$ | | | | | | • Cycles: $\frac{(2^8-1)\times(m+1)}{fj}$ | | | | | | <ul><li>n: Upper byte of the TAi register setting value, 00h to FEh</li><li>m: Lower byte of the TAi register setting value, 00h to FFh</li></ul> | | | | | Count start conditions | • The TAIS bit in the TABSR register is 1 (start counter) | | | | | | • The TAiS bit is 1 and an external trigger is applied to the TAilN pin | | | | | | • The TAiS bit is 1 and any of following triggers occurs: | | | | | | the overflow and/or underflow signal of timer B2, the overflow and/or | | | | | | underflow signal of timer Aj (j = i - 1, or j = 4 if i = 0), or the overflow and/<br>or underflow signal of timer Ak (k = i + 1, or k = 0 if i = 4) | | | | | Count stop condition | The TAIS bit in the TABSR register is 0 (stop counter) | | | | | Interrupt request generating | On the falling edge of the PWM pulse | | | | | timing | The same same same same same same same sam | | | | | TAilN pin function | A programmable I/O port or trigger input | | | | | TAiOUT pin function | A pulse output | | | | | Read from timer | The TAi register indicates an undefined value | | | | | Write to timer | While the timer counter is stopped or before the initial count source is | | | | | | input after starting to count, the value written to the TAi register is written | | | | | | to both the reload register and the counter | | | | | | <ul> <li>While the timer counter is running, the value written to the TAi register is<br/>written to the reload register (it is transferred to the counter at the next<br/>reload timing)</li> </ul> | | | | Figure 15.16 Registers TA0MR to TA4MR in Pulse-width Modulation Mode Figure 15.17 16-bit Pulse-width Modulator Operation Figure 15.18 8-bit Pulse-width Modulator Operation ### 15.2 Timer B Figure 15.19 shows a block diagram of timer B, and Figure 15.20 to Figure 15.23 show registers associated with timer B. Timer B supports the three modes shown below. Select a mode by setting bits TMOD1 and TMOD0 in the TBiMR register (i = 0 to 5). - Timer mode: The timer counts an internal count source. - Event counter mode: The timer counts an external pulse or an overflow and underflow of other timers. - Pulse period/pulse-width measure mode: The timer measures the pulse period or pulse width of an external signal. Figure 15.19 Timer B Block Diagram Figure 15.20 Registers TB0 to TB5 Figure 15.21 Registers TB0MR to TB5MR Figure 15.22 TABSR Register Figure 15.23 TBSR Register ## 15.2.1 Timer Mode In timer mode, the timer counts an internally generated count source. Table 15.6 lists specifications of timer mode. Figure 15.24 shows registers TB0MR to TB5MR in this mode. Table 15.6 Timer Mode Specifications (i = 0 to 5) | Item | Specification | |-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count sources | f1, f8, f2n, or fC32 | | Count operations | Decrement When the timer counter underflows, the reload register value is reloaded into the counter to continue counting | | Divide ratio | $\frac{1}{n+1}$ n: TBi register setting value, 0000h to FFFFh | | Count start condition | The TBiS bit in the TABSR or TBSR register is 1 (start counter) | | Count stop condition | The TBiS bit in the TABSR or TBSR register is 0 (stop counter) | | Interrupt request generating timing | When the timer counter underflows | | TBiIN pin function | Functions as a programmable I/O port | | Read from timer | The TBi register indicates a counter value | | Write to timer | <ul> <li>While the timer counter is stopped or before the initial count source is input after starting to count, the value written to the TBi register is written to both the reload register and the counter</li> <li>While the timer counter is running, the value written to the TBi register is written to the reload register (it is transferred to the counter at the next reload timing)</li> </ul> | Figure 15.24 Registers TB0MR to TB5MR in Timer Mode ## 15.2.2 Event Counter Mode In event counter mode, the timer counts an external signal or the overflow or underflow of other timers. Table 15.7 lists specifications of event counter mode. Figure 15.25 shows the TBiMR register in this mode (i = 0 to 5). Table 15.7 Event Counter Mode Specifications (i = 0 to 5) | Item | Specification | |------------------------------|---------------------------------------------------------------------------------------------| | Count sources | External signal applied to the TBiIN pin (valid edge is selectable among | | | the falling edge, the rising edge, or both) | | | • The overflow or underflow signal of TBj (j = i - 1; j = 2 if i = 0; or j = 5 if | | | i = 3) | | | Phase shift clock of the intelligent I/O group 0 | | Count operations | Decrement | | | When the timer counter underflows, the reload register value is reloaded | | | into the counter to continue counting | | Divide ratio | $\frac{1}{n+1}$ n: TBi register setting value, 0000h to FFFFh | | Count start condition | The TBiS bit in the TABSR or TBSR register is 1 (start counter) | | | , , , | | Count stop condition | The TBiS bit in the TABSR or TBSR register is 0 (stop counter) | | Interrupt request generation | When the timer counter underflows | | timing | | | TBiIN pin function | Functions as a programmable I/O port or count source input | | Read from timer | The TBi register indicates a counter value | | Write to timer | While the timer counter is stopped or before the initial count source is | | | input after starting to count, the value written to the TBi register is written | | | to both the reload register and the counter | | | • While the timer counter is running, the value written to the TBi register is | | | written to the reload register (it is transferred to the counter at the next reload timing) | | <u> </u> | | Figure 15.25 Registers TB0MR to TB5MR in Event Counter Mode 3. j = i - 1; j = 2 if i = 0; or j = 5 if i = 3. Figure 15.26 TBECKS Register ## 15.2.3 Pulse Period/Pulse-width Measure Mode In pulse period/pulse-width measure mode, the timer measures the pulse period or pulse width of an external signal. Table 15.8 lists specifications of the pulse period/pulse-width measure mode. Figure 15.27 shows registers TB0MR to TB5MR in this mode. Figures 15.28 and 15.29 show an operation example of pulse period measurement and pulse-width measurement, respectively. Table 15.8 Pulse Period/Pulse-width Measure Mode Specifications (i = 0 to 5) | Item | Specification | | |------------------------------|---------------------------------------------------------------------------------|--| | Count sources | f1, f8, f2n, or fC32 | | | Count operations | Increment | | | | • The counter value is transferred to the reload register on the valid edge of | | | | a pulse to be measured, then it is set to 0000h to resume counting | | | Count start condition | The TBiS bit in the TABSR or TBSR register is 1 (start counter) | | | Count stop condition | The TBiS bit in the TABSR or TBSR register is 0 (stop counter) | | | Interrupt request generating | On the valid edge of a pulse to be measured (1) | | | timing | When the timer counter overflows | | | | (when the MR3 bit in the TBiMR register becomes 1 (overflow)) (2) | | | TBiIN pin function | A pulse input to be measured | | | Read from timer | The TBi register indicates a reload register value (measurement results) (3) | | | Write to timer | The value written to the TBi register is written to neither the reload register | | | | nor the counter | | #### Notes: - 1. No interrupt request is generated when the pulse to be measured is applied on the initial valid edge after the timer counter starts. - 2. While the TBiS bit is 1 (start counter), after the MR3 bit becomes 1 (overflow) and at least one count source cycle has elapsed, a write operation to the TBiMR register sets the MR3 bit to 0 (no overflow). - 3. The TBi register indicates an undefined value until the pulse to be measured is applied on the second valid edge after the timer counter starts. #### Notes: 1. The measure modes selected by setting bits MR1 and MR0 are as follows: Pulse period measurement 1 (bits MR1 and MR0 = 00b): Measures between a falling edge and the next falling edge of a pulse Pulse period measurement 2 (bits MR1 and MR0 = 01b): Measures between a rising edge and the next rising edge of a pulse Pulse-width measurement (bits MR1 and MR0 = 10b): Measures between a falling edge and the next rising edge of a pulse and between the rising edge and the next falling edge of the pulse 2. The MR3 bit is undefined when the timer is reset. While the TBiS bit in the TABSR or TBSR register is 1 (start counter), after the MR3 bit becomes 1 and at least one count source cycle has elapsed, a write operation to the TBiMR register sets the MR3 bit to 0. The MR3 bit cannot be set to 1 by a program. Figure 15.27 Registers TB0MR to TB5MR in Pulse Period/Pulse-width Measure Mode Figure 15.28 Operation Example in Pulse Period Measurement Figure 15.29 Operation Example in Pulse-width Measurement ### 15.3 Notes on Timers ## 15.3.1 Timer A and Timer B All timers are stopped after a reset. To restart timers, configure parameters such as operating mode, count source, and counter value, then set the TAiS bit or TBjS bit in the TABSR or TBSR register to 1 (count starts) (i = 0 to 4; j = 0 to 5). The following registers and bits should be set while the TAiS bit or TBjS bit is 0 (count stops): - Registers TAiMR and TBiMR - UDF register - Bits TAZIE, TA0TGL, and TA0TGH in the ONSF register - TRGSR register ### 15.3.2 Timer A #### 15.3.2.1 Timer Mode • While the timer counter is running, the TAi register indicates a counter value at any given time. However, FFFFh is read while reloading is in progress. A set value is read if the TAi register is set while the timer counter is stopped. #### 15.3.2.2 Event Counter Mode While the timer counter is running, the TAi register indicates a counter value at any given time. However, FFFFh is read if the timer counter underflows or 0000h if overflows while reloading is in progress. A set value is read if the TAi register is set while the timer counter is stopped. ### 15.3.2.3 One-shot Timer Mode - If the TAiS bit in the TABSR register is set to 0 (count stops) while the timer counter is running, the following operations are performed: - The timer counter stops and the setting value of the TAi register is reloaded. - A low signal is output at the TAiOUT pin. - The IR bit in the TAilC register becomes 1 (interrupts requested) after one CPU clock cycle. - The one-shot timer is operated by an internal count source. When the trigger is an input to the TAilN pin, the signal is output with a maximum one count source clock delay after a trigger input to the TAilN pin. - The IR bit becomes 1 by any of the settings below. To use the timer Ai interrupt, set the IR bit to 0 after one of the settings below is done: - Select one-shot timer mode after a reset. - Switch operating modes from timer mode to one-shot timer mode. - Switch operating modes from event counter mode to one-shot timer mode. - If a retrigger occurs while counting, the timer counter decrements by one, reloads the setting value of the TAi register, and then continues counting. To generate a retrigger while counting, wait one or more count source cycles after the last trigger is generated. - When an external trigger input is selected to start counting in timer A one-shot mode, do not provide an external retrigger for 300 ns before the timer counter reaches 0000h. Otherwise, it may stop counting. ## 15.3.2.4 Pulse-width Modulation Mode • The IR bit becomes 1 by any of the settings below. To use the timer Ai interrupt, set the IR bit to 0 after one of the settings below is done (i = 0 to 4): - Select pulse-width modulation mode after a reset. - Switch operating modes from timer mode to pulse-width modulation mode. - Switch operating modes from event counter mode to pulse-width modulation mode. - If the TAiS bit in the TABSR register is set to 0 (count stops) while PWM pulse is output, the following operations are performed: - The timer counter stops. - The output level at the TAiOUT pin changes from high to low. The IR bit becomes 1. - When a low signal is output at the TAiOUT pin, it does not change. The IR bit does not change, either. ### 15.3.3 Timer B #### 15.3.3.1 Timer Mode and Event Counter Mode • While the timer counter is running, the TBj register indicates a counter value at any given time (j = 0 to 5). However, FFFFh is read while reloading is in progress. When a value is set to the TBj register while the timer counter is stopped, if the TBj register is read before the count starts, the set value is read. # 15.3.3.2 Pulse Period/Pulse-width Measure Mode - While the TBjS bit in the TABSR or TBSR register is 1 (start counter), after the MR3 bit becomes 1 (overflow) and at least one count source cycle has elapsed, a write operation to the TBjMR register sets the MR3 bit to 0 (no overflow). - Use the IR bit in the TBjIC register to detect overflow. The MR3 bit is used only to determine an interrupt request source within the interrupt handler. - The counter value is undefined when the timer counter starts. Therefore, the timer counter may overflow before a measured pulse is applied on the initial valid edge and cause a timer Bj interrupt request to be generated. - When the measured pulse is applied on the initial valid edge after the timer counter starts, an undefined value is transferred to the reload register. At this time, a timer Bj interrupt request is not generated. - The IR bit may become 1 (interrupt requested) by changing bits MR1 and MR0 in the TBjMR register after the timer counter starts. However, if the same value is rewritten to bits MR1 and MR0, the IR bit does not change. - Pulse width is continuously measured in pulse-width measure mode. Whether the measurement result is high-level width or not is determined by a program. - When an overflow occurs at the same time a pulse is applied on the valid edge, this pulse is not recognized since an interrupt request is generated only once. Do not let an overflow occur in pulse period measure mode. - In pulse-width measure mode, determine whether an interrupt source is a pulse applied on the valid edge or an overflow by reading the port level in the timer Bj interrupt handler. # 16. Three-phase Motor Control Timers A three-phase motor driving waveform can be output using timers A1, A2, A4, and B2. The three-phase motor control timers are enabled by setting the INV02 bit in the INVC0 register to 1. Timer B2 is used for carrier wave control, and timers A1, A2, and A4 for three-phase PWM output (U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ ) control. Table 16.1 lists the specifications of the three-phase motor control timers and Figure 16.1 shows its block diagram. Figures 16.2 to 16.6 show registers associated with this function. Table 16.1 Specifications for Three-phase Motor Control Timers | Item | Specification | | | |--------------------------|-----------------------------------------------------------------------------|--|--| | Three-phase PWM waveform | Six pins: U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ | | | | output pins | | | | | Forced cutoff (1) | A low input to the NMI pin | | | | Timers | Timers A4, A1, and A2 are used in one-shot timer mode: | | | | | Timer A4 is used for U- and $\overline{\text{U}}$ -phase waveform control | | | | | Timer A1 is used for V- and $\overline{\text{V}}$ -phase waveform control | | | | | Timer A2 is used for W- and $\overline{\text{W}}$ -phase waveform control | | | | | Timer B2 is used in timer mode | | | | | Carrier wave cycle control | | | | | Dead time timer (three 8-bit timers share a reload register): | | | | | Dead time control | | | | Output waveforms | Triangular wave modulation and sawtooth wave modulation | | | | | Output of a high or a low waveform for one cycle | | | | | Separately settable levels of high side and low side | | | | Carrier wave cycles | Triangular wave modulation: count source × (m + 1) × 2 | | | | | Sawtooth wave modulation: count source × (m + 1) | | | | | m: TB2 register setting value from 0000h to FFFFh | | | | | Count source: f1, f8, f2n, or fC32 | | | | Three-phase PWM output | · · · · · · · · · · · · · · · · · · · | | | | width | Sawtooth wave modulation: count source × n | | | | | n: Setting value of registers TA4, TA1, and TA2 (registers TA4, TA41, | | | | | TA1, TA11, TA2, and TA21 when the INV11 bit in the INVC1 register | | | | | is 1) from 0001h to FFFFh | | | | | Count source: f1, f8, f2n, or fC32 | | | | Dead time (width) | Count source × p or no dead time | | | | | p: DTT register setting value from 01h to FFh | | | | | Count source: f1 or f1 divided by 2 | | | | Active level | Selectable either active high or active low | | | | Simultaneous conduction | Function to detect simultaneous turn-on signal outputs, function to disable | | | | prevention | signal output when simultaneous turn-on signal outputs are detected | | | | Interrupt frequency | Selectable from one through 15 time-carrier wave cycle-to-cycle basis for | | | | | the timer B2 interrupt | | | # Note: Forced cutoff by a signal input to the NMI pin can be performed when the PM24 bit in the PM2 register is 1 (NMI enabled), the SDE bit in the IOBC register is 1 (shutdown enabled), the INV02 bit in the INVC0 register is 1 (three-phase motor control timers used), and the INV03 bit is 1 (three-phase motor control timer output enabled). Figure 16.1 Block Diagram for Three-phase Motor Control Timers #### Notes: - 1. Set this register after setting the PRC1 bit in the PRCR register to 1 (write enabled). Also, rewrite bits INV00 to INV02 and INV06 while timers A1, A2, A4, and B2 are stopped. - 2. This bit is enabled when the INV11 bit in the INVC1 register is 1 (three-phase mode 1). When the INV11 bit is 0 (three-phase mode 0), the ICTB2 counter increments by one each time timer B2 underflows irrespective of the INV00 and INV01 bit settings. - 3. Set the ICTB2 register before setting the INV01 bit to 1. Also, set the TA1S bit in the TABSR register to 1 before the initial timer B2 underflow occurs. - 4. When the INV00 bit is set to 1, the first interrupt occurs when timer B2 underflows n-1 times (n is the value set in the ICTB2 counter). Subsequent interrupts occur every n times timer B2 underflows. - 5. Set the INV02 bit to 1 to operate the dead time timer, U-, V-, and W-phase output control circuits, and the ICTB2 counter. - 6. After setting the INV02 bit to 1, pins should be configured first by the IOBC register then by the output function select register. - 7. When the INV02 bit is set to 1 and the INV03 bit is set to 0, pins U, Ū, V, ∇, W, and W, even when they are assigned to other peripheral functions, become high-impedance. - 8. The INV03 bit becomes 0 when the following occurs: - Reset - Signals of both the high and low sides are simultaneously switched to active when the INV04 bit is 1. - The INV03 bit is set to 0 by a program. - The NMI pin goes from high to low when the PM24 bit in the PM2 register is 1 (NMI enabled) and the SDE bit in the IOBC register is 1 (shutdown enabled). - 9. This bit cannot be set to 1 by a program. Set the INV04 bit to 0 to set this bit to 0. - 10. When the INV06 bit is 1, set the INV11 bit in the INVC1 register to 0 (three-phase mode 0) and the PWCON bit in the TB2SC register to 0 (timer B2 register reloaded when timer B2 underflows). Figure 16.2 INVC0 Register #### Notes: - 1. Set this register after setting the PRC1 bit in the PRCR register to 1 (write enabled). Also, rewrite this register while timers A1, A2, A4, and B2 are stopped. - 2. Set the INV11 bit to 0 when the INV06 bit in the INVC0 register is 1 (sawtooth wave modulation mode). - 3. Set the PWCON bit in the TB2SC register to 0 (timer B2 register reloaded if timer B2 underflows) when the INV11 bit is 0 - 4. This bit setting is enabled when the INV06 bit is 0 (triangular wave modulation mode) and the INV11 bit is 1. - 5. Set the INV16 bit to 1 when the following conditions are all met: - The INV15 bit is 0. - The Dij bit has a different value from the DiBj bit whenever the INV03 bit is 1 (enables the three-phase motor control timer output); the high- and low-side output signals always have inverse levels on periods other than dead time (i = U, V, or W; j = 0, 1). - Set the INV16 bit to 0 when the conditions above are not met. Figure 16.3 INVC1 Register Figure 16.4 IOBC Register Figure 16.5 Registers IDB0 and IDB1 Figure 16.6 ICTB2 Register # 16.1 Modulation Modes of Three-phase Motor Control Timers The three-phase motor control timers support two modulation modes: triangular wave modulation mode and sawtooth wave modulation mode. The triangular wave modulation mode has two modes: three-phase mode 0 and three-phase mode 1. Table 16.2 lists bit settings and characteristics of each mode. **Table 16.2 Modulation Modes** | Item | Triangular Wave Modulation Mode | | Sawtooth Wave<br>Modulation Mode | |-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | | Three-phase mode 0 | Three-phase mode 1 | (Three-phase mode 0) | | Bit settings | INV06 is 0, INV11 is 0,<br>PWCON is 0 | INV06 is 0, INV11 is 1 | INV06 is 1, INV11 is 0,<br>PWCON is 0 | | Waveform | Triangular wave | | Sawtooth wave | | Registers TA11, TA21, and TA41 | Not used | Used | Not used | | Timing to transfer data from registers IDB0 and IDB1 to the three-phase output shift register | Only once when a transfe<br>setting registers IDB0 and | Whenever a transfer trigger <sup>(1)</sup> occurs | | | Timing to trigger the dead time timer when the INV16 bit is 0 | On the falling edge of a one-shot pulse of timers A1, A2, and A4 | | When a transfer trigger occurs, or on the falling edge of a one-shot pulse of timers A1, A2, and A4 | | Bits INV00 and INV01 in the INVC0 register | Disabled. The ICTB2 counter increments each time timer B2 underflows, irrespective of the INV00 and INV01 bit settings | Enabled | Disabled. The ICTB2 counter increments each time timer B2 underflows, irrespective of the INV00 and INV01 bit settings | | INV13 bit | Disabled | Enabled | Disabled | # Note: <sup>1.</sup> The transfer trigger is a timer B2 underflow, a write operation to the INV07 bit, or a write operation to the TB2 register when the INV10 bit is 1. #### 16.2 Timer B2 Timer B2, which operates in timer mode, is used for carrier wave control in the three-phase motor control timers. Figures 16.7 and 16.8 show registers TB2 and TB2MR in this function, respectively. Figure 16.9 shows the TB2SC register which switches timing to change the carrier wave frequency in three-phase mode 1. Figure 16.7 TB2 Register When Using Three-phase Motor Control Timers Figure 16.8 TB2MR Register When Using Three-phase Motor Control Timers Figure 16.9 TB2SC Register ## 16.3 Timers A4, A1, and A2 Timers A4, A1, and A2 are used for three-phase PWM output (U, $\overline{U}$ , V, $\overline{V}$ , W, and $\overline{W}$ ) control when using the three-phase motor control timers. These timers should be operated in one-shot timer mode. Every time timer B2 underflows, a trigger is input to timers A4, A1, and A2 to generate a one-shot pulse. If the values of registers TA4, TA1, and TA2 are rewritten every time a timer B2 interrupt occurs, the duty cycle of the PWM waveform can be varied. In three-phase mode 1, the value of registers TAi and TAi-1 is alternately reloaded to the counter at each timer B2 interrupt, which halves the timer B2 interrupt frequency (i = 4, 1, 2). Figure 16.10 shows registers TA1, TA2, TA4, TA11, TA21, and TA41 in the three-phase motor control timers. Figure 16.11 shows registers TA1M, TA2M, TA4M, TA11M, TA21M, and TA41M in this function. Figure 16.12 shows registers TA1MR, TA2MR, and TA4MR in this function. Figures 16.13 and 16.14 show registers TRGSR and TABSR, respectively, in this function. Figure 16.10 Registers TA1, TA2, TA4, TA11, TA21, and TA41 6. When the INV11 bit in the INVC1 register is 0 (three-phase mode 0), the value of the TAi register is transferred to the reload register by a timer Ai start trigger. When the INV11 bit is 1 (three-phase mode 1), first the value of the TAi1 register is transferred to the reload register by a timer Ai start trigger. Then the value of the TAi register is transferred by the next timer Ai start trigger. After that, the values of these registers TAi1 and TAi are alternately transferred to the reload register. 7. These registers should not be written when timer B2 underflows. Figure 16.11 Registers TA1M, TA2M, TA4M, TA11M, TA21M, and TA41M Figure 16.12 Registers TA1MR, TA2MR, and TA4MR When Using Three-phase Motor Control Timers Figure 16.13 TRGSR Register in Three-phase Motor Control Timers Figure 16.14 TABSR Register ## 16.4 Simultaneous Conduction Prevention and Dead Time Timer The three-phase motor control timers offer two ways to avoid shoot-through, which occurs when high-side and low-side transistors are simultaneously turned on. One is "simultaneous turn-on signal output disable function". This function prevents high-side and low-side transistors from being inadvertently switched to active due to events like program errors. The other is by the use of dead time timers. A dead time timer delays the turn-on of one transistor in order to ensure that an adequate time (the dead time) passes after the other is turned off. To disable simultaneous turn-on output signals, the INV04 bit in the INVC0 register should be set to 1. If outputs for any pair of phases (U and $\overline{U}$ , V and $\overline{V}$ , or W and $\overline{W}$ ) are simultaneously switched to an active state, every three-phase motor control output pin becomes high-impedance. Figure 16.15 shows an example of output waveform when simultaneous turn-on signal output is disabled. To enable the dead time timer, the INV15 bit in the INVC1 register should be set to 0. The DTT register determines the dead time. Figure 16.16 shows the DTT register and Figure 16.17 shows an example of output waveform on using dead time timer. Figure 16.15 Output Waveform When Simultaneous Turn-on Signal Output is Disabled Figure 16.16 DTT Register Figure 16.17 Output Waveform When Using Dead Time Timer ## 16.5 Three-phase Motor Control Timer Operation Figures 16.18 and 16.19 show an operation example of triangular wave modulation and sawtooth wave modulation, respectively. Figure 16.18 Triangular Wave Modulation Operation Figure 16.19 Sawtooth Wave Modulation Operation # 16.6 Notes on Three-phase Motor Control Timers # 16.6.1 Shutdown • When a low signal is applied to the \(\overline{NMI}\) pin with the following bit settings, pins TA1OUT, TA2OUT, and TA4OUT become high-impedance: the PM24 bit in the PM2 register is 1 (NMI enabled), the SDE bit in the IOBC register is 1 (shutdown enabled), the INV02 bit in the INVC0 register is 1 (three-phase motor control timers used), and the INV03 bit is 1 (three-phase motor control timer output enabled). # 16.6.2 Register Setting • Do not write to the TAi1 register before and after timer B2 underflows (i = 1, 2, 4). Before writing to the TAi1 register, read the TB2 register to verify that sufficient time remains until timer B2 underflows. Then, immediately write to the TAi1 register so no interrupt handling is performed during this write procedure. If the TB2 register indicates little time remains until the underflow, write to the TAi1 register after timer B2 underflows. # 17. Serial Interface The serial interface consists of five channels: UART0 to UART4. Each channel has an exclusive timer to generate the transmit/receive clock and operates independently. Figures 17.1 and 17.2 show block diagrams of UART0 to UART2 and UART3 and UART4, respectively. UARTi supports the following modes: - Synchronous serial interface mode (for UART0 to UART4) - Asynchronous serial interface mode (UART mode) (for UART0 to UART4) - Special mode 1 (I<sup>2</sup>C mode) (for UART0 to UART2) - Special mode 2 (for UART0 to UART2) Figures 17.3 to 17.17 show registers associated with UARTi (i = 0 to 4). Refer to the tables listing each mode for registers and pin settings. Table 17.1 Comparison UART0 to UART4 Functions | Mode/Function | | UART0 to UART2 | UART3, UART4 | |----------------------------------------|------------------------------------|----------------|---------------| | Synchronous serial interface mode | | Available | Available | | Serial data logic inversion | | Available | Not available | | UART mode | | Available | Available | | | CTS/RTS function selection | Available | Available | | | TXD and RXD I/O polarity selection | Available | Not available | | Special mode 1 (I <sup>2</sup> C mode) | | Available | Not available | | Special mode 2 | | Available | Not available | Figure 17.1 UARTi Block Diagram (i = 0 to 2) Figure 17.2 UARTi Block Diagram (i = 3, 4) Figure 17.3 Registers U0MR to U2MR Figure 17.4 Registers U3MR and U4MR Figure 17.5 Registers U0C0 to U2C0 Figure 17.6 Registers U3C0 and U4C0 Figure 17.7 Registers U0C1 to U2C1 Figure 17.8 Registers U3C1 and U4C1 Figure 17.9 U34CON Register Figure 17.10 Registers U0SMR to U2SMR Figure 17.11 Registers U0SMR2 to U2SMR2 17. Serial Interface R32C/161 Group #### Notes: - 1. This bit is used in special mode 2. - 2. Set the CRD bit in the UiC0 register to 1 (CTS function disabled) to use the SS function. - 3. The ERR bit can only be set to 0. Writing 1 to this bit has no effect. - 4. Bits DL2 to DL0 in I<sup>2</sup>C mode generate a digital delay for the SDAi output. Set these bits to 000b in all modes other than I<sup>2</sup>C mode. - 5. When an external clock is selected, a delay of approximately 100 ns is added. Figure 17.12 Registers U0SMR3 to U2SMR3 Figure 17.13 Registers U0SMR4 to U2SMR4 Figure 17.14 Registers U0BRG to U4BRG Figure 17.15 Registers U0TB to U4TB #### Notes: - 1. The ABT bit can only be set to 0. - 2. Bits OER, FER, PER, and SUM become 0 when bits SMD2 to SMD0 in the UiMR register are set to 000b (serial interface disabled) or the RE bit in the UiC1 register is set to 0 (reception disabled). When bits OER, FER, and PER all become 0, the SUM bit also becomes 0. Bits FER and PER become 0 when the lower byte in the UiRB register is read. - When bits SMD2 to SMD0 are 001b (synchronous serial interface mode) or 010b (I<sup>2</sup>C mode), these error flags are disabled and read as an undefined value. Figure 17.16 Registers U0RB to U2RB 2. When bits SMD2 to SMD0 are 001b (synchronous serial interface mode) or 010b (I<sup>2</sup>C mode), these error Figure 17.17 Registers U3RB and U4RB byte in the UiRB register is read. flags are disabled and read as an undefined value. ## 17.1 Synchronous Serial Interface Mode The synchronous serial interface mode allows data transmission/reception synchronized with the transmit/receive clock. Table 17.2 lists specifications of synchronous serial interface mode. Table 17.2 Synchronous Serial Interface Mode Specifications | Item | Specification | | | | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Data format | 8-bit character length | | | | | Transmit/receive clock | • The CKDIR bit in the UiMR register is 0 (internal clock) (i = 0 to 4): | | | | | | $\frac{fx}{2(m+1)}$ $fx = f1$ , f8, f2n; $m$ : UiBRG register setting value, 00h to FFh | | | | | | The CKDIR bit is 1 (external clock): input to the CLKi pin | | | | | Transmit/receive control | CTS function enabled, RTS function enabled, or CTS/RTS function disabled | | | | | Transmit start conditions | The conditions for starting data transmission are as follows <sup>(1)</sup> : • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data held in the UiTB register) • Input level at the CTSi pin is low when the CTS function is selected | | | | | Receive start conditions | The conditions for starting data reception are as follows (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 held in the UiTB register) • Input level at the CTSi pin is low when the CTS function is selected | | | | | Interrupt request generating timing | In transmit interrupt, one of the following conditions can be selected by setting the UiIRS bit in registers U0C1 to U2C1 and U34CON: • The UiIRS bit is 0 (transmit buffer is empty): when data is transferred from the UiTB register to the UARTi transmit register (when the transmission has started) • The UiIRS bit is 1 (transmission is completed): when data transmission from the UARTi transmit register is completed In receive interrupt, • When data is transferred from the UARTi receive register to the UiRB register (when the reception is completed) | | | | | Error detection | Overrun error <sup>(2)</sup> This error occurs when the seventh bit of the next data is received before the UiRB register is read | | | | | Other functions | CLK polarity Rising or falling edge of the transmit/receive clock for output and input of transmit/receive data Bit order selection LSB first or MSB first Continuous receive mode Data reception is enabled by a read access to the UiRB register Serial data logic inversion (UART0 to UART2) This function logically inverses transmit/receive data | | | | ### Notes: - 1. When selecting an external clock, the following preconditions should be met: - The CLKi pin is held high when the CKPOL bit in the UiC0 register is set to 0 (transmit data output on the falling edge of the transmit/receive clock and receive data input on the rising edge). - The CLKi pin is held low when the CKPOL bit is set to 1 (transmit data output on the rising edge of the transmit/receive clock and receive data input on the falling edge). - 2. The UiRB register is undefined when an overrun error occurs. The IR bit in the SiRIC register does not change to 1 (interrupt requested). Tables 17.3 and 17.4 list register settings. When UARTi operating mode is selected, a high is output at the TXDi pin until transmission starts (the TXDi pin is high-impedance when the N-channel open drain output is selected) (i = 0 to 4). Figures 17.18 and 17.19 show examples of transmit and receive operations in synchronous serial interface mode, respectively. Table 17.3 Register Settings in Synchronous Serial Interface Mode (for UART0 to UART2) | Register | Bits | Function | | |----------|---------------|--------------------------------------------------------|--| | UiMR | 7 to 4 | Set the bits to 0000b | | | | CKDIR | Select either an internal clock or external clock | | | | SMD2 to SMD0 | Set the bits to 001b | | | UiC0 | UFORM | Select either LSB first or MSB first | | | | CKPOL | Select a transmit/receive clock polarity | | | | NCH | Select an output mode of the TXDi pin | | | | CRD | Select CTS function enabled or disabled | | | | TXEPT | Transmit register empty flag | | | | 2 | Set the bit to 0 | | | | CLK1 and CLK0 | Select a count source for the UiBRG register | | | UiC1 | 7 | Set the bit to 0 | | | | UiLCH | Set the bit to 1 to use logic inversion | | | | UiRRM | Set the bit to 1 to use continuous receive mode | | | | UilRS | Select a source for the UARTi transmit interrupt | | | | RI | Receive complete flag | | | | RE | Set the bit to 1 to enable data reception | | | | TI | Transmit buffer empty flag | | | | TE | Set the bit to 1 to enable data transmission/reception | | | UiSMR | 7 to 0 | Set the bits to 00h | | | UiSMR2 | 7 to 0 | Set the bits to 00h | | | UiSMR3 | 7 to 4 | Set the bits to 0000b | | | | NODC | Select a clock output mode | | | | 2 to 0 | Set the bits to 000b | | | UiSMR4 | 7 to 0 | Set the bits to 00h | | | UiBRG | 7 to 0 | Set the bit rate | | | UiTB | 7 to 0 | Set the data to be transmitted | | | UiRB | OER | Overrun error flag | | | | 7 to 0 | Received data is read | | i = 0 to 2 Table 17.4 Register Settings in Synchronous Serial Interface Mode (for UART3 and UART4) | Register | Bits | Function | | |-----------------------------|---------------|--------------------------------------------------------|--| | UiMR | 7 to 4 | Set the bits to 0000b | | | | CKDIR | Select an internal clock or external clock | | | | SMD2 to SMD0 | Set the bits to 001b | | | UiC0 | UFORM | Select either LSB first or MSB first | | | | CKPOL | Select a transmit/receive clock polarity | | | | 5 | Set the bit to 0 | | | | CRD | Select CTS function enabled or disabled | | | | TXEPT | Transmit register empty flag | | | | 2 | Set the bit to 0 | | | | CLK1 and CLK0 | Select a count source for the UiBRG register | | | UiC1 | RI | Receive complete flag | | | | RE | Set the bit to 1 to enable data reception | | | | TI | Transmit buffer empty flag | | | | TE | Set the bit to 1 to enable data transmission/reception | | | U34CON | UiRRM | Set the bit to 1 to use continuous receive mode | | | | UilRS | Select an interrupt source for UARTi transmit | | | IFS0 | IFS04 | Select input pins for CLK4, RXD4, and CTS4 | | | UiBRG | 7 to 0 | Set the bit rate | | | UiTB | 7 to 0 | Set the data to be transmitted | | | UiRB OER Overrun error flag | | Overrun error flag | | | | 7 to 0 | Received data can be read | | i = 3, 4 Figure 17.18 Transmit Operation in Synchronous Serial Interface Mode Figure 17.19 Receive Operation in Synchronous Serial Interface Mode ### 17.1.1 Reset Procedure on Transmit/Receive Error When a transmit/receive error occurs in synchronous serial interface mode, follow the procedures below to perform a reset: - A. Reset procedure for the UiRB register (i = 0 to 4) - (1) Set the RE bit in the UiC1 register 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 to 001b (synchronous serial interface mode). - (4) Set the RE bit in the UiC1 register to 1 (reception enabled). - B. Reset procedure for the UiTB register - (1) Set bits SMD2 to SMD0 in the UiMR register to 000b (serial interface disabled). - (2) Set bits SMD2 to SMD0 to 001b (synchronous serial interface mode). - (3) Irrespective of its status, set the TE bit in the UiC1 register to 1 (transmission enabled). ### 17.1.2 CLK Polarity As shown in Figure 17.20, the polarity of the transmit/receive clock is selected using the CKPOL bit in the UiC0 register (i = 0 to 4). Figure 17.20 Transmit/Receive Clock Polarity (i = 0 to 4) ### 17.1.3 LSB First and MSB First Selection As shown in Figure 17.21, the bit order is selected by setting the UFORM bit in the UiC0 register (i = 0 to 4). Figure 17.21 Bit Order (i = 0 to 4) #### 17.1.4 Continuous Receive Mode In continuous receive mode, data reception is automatically enabled by a read access to the receive buffer register without writing dummy data to the transmit buffer register. To start data reception, however, dummy data is required to read the receive buffer register. When the UiRRM bit in registers U0C1 to U2C1 and the U34CON register is set to 1 (continuous receive mode enabled), the TI bit in the UiC1 register becomes 0 (data held in the UiTB register) by a read access to the UiRB register (i = 0 to 4). In this UiRRM bit setting, no dummy data should be written to the UiTB register. ## 17.1.5 Serial Data Logic Inversion When the UiLCH bit in the UiC1 register is 1 (data is logic inverted), the logical value written in the UiTB register is inverted before being transmitted (i = 0 to 2). The UiRB register is read as logic-inverted receive data. Figure 17.22 shows the logic inversion of serial data. Figure 17.22 Serial Data Logic Inversion (i = 0 to 2) #### 17.1.6 CTS/RTS Function CTS function controls data transmission using the $\overline{\text{CTSi}}/\overline{\text{RTSi}}$ pin (i = 0 to 4). When an input level at the pin becomes low, data transmission starts. If the input level changes to high during transmission, the transmission of the next data is stopped. In synchronous serial interface mode, the transmitter is required to operate even during the receive operation. If CTS function is enabled, the input level at the $\overline{\text{CTSi/RTSi}}$ pin should be low to start data reception as well. RTS function indicates receiver status using the CTSi/RTSi pin. When data reception is ready, the output level at the pin becomes low. It becomes high on the first falling edge of the CLKi pin. # 17.2 Asynchronous Serial Interface Mode (UART Mode) The UART mode enables data transmission/reception synchronized with an internal clock generated by a trigger on the falling edge of the start bit. Table 17.5 lists specifications of UART mode. Table 17.5 UART Mode Specifications | Item | Specification | | | | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Data format | Start bit: 1-bit Data bit (data character): 7-bit, 8-bit, or 9-bit Parity bit: odd, even, or none Stop bit: 1-bit or 2-bit | | | | | Transmit/receive clock | The CKDIR bit in the UiMR register is 0 (internal clock) (i = 0 to 4): | | | | | | $\frac{fx}{16(m+1)}$ $fx = f1, f8, f2n; m$ : UiBRG register setting value, 00h to FFh • The CKDIR bit is 1 (external clock) $\frac{fEXT}{16(m+1)}$ $fEXT$ : Clock applied to the CLKi pin | | | | | Transmit/receive control | CTS function enabled, RTS function enabled, or CTS/RTS function disabled | | | | | Transmit start conditions | The conditions for starting data transmission are as follows: • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data held in the UiTB register) • Input level at the CTSi pin is low when CTS function is selected | | | | | Receive start conditions | The conditions for starting data reception are as follows: • The RE bit in the UiC1 register is 1 (reception enabled) • The start bit is detected | | | | | Interrupt request generating timing | <ul> <li>In transmit interrupt, one of the following conditions can be selected by setting the UiIRS bit in registers U0C1 to U2C1 and the U34CON register:</li> <li>The UiIRS bit is 0 (transmit buffer is empty): when data is transferred from the UiTB register to the UARTi transmit register (when the transmission has started)</li> <li>The UiIRS bit is 1 (transmission is completed): when data transmission from the UARTi transmit register is completed</li> <li>In receive interrupt,</li> <li>When data is transferred from the UARTi receive register to the UiRB register (when reception is completed)</li> </ul> | | | | | Error detection | <ul> <li>Overrun error <sup>(1)</sup> This error occurs when 1 bit prior to the stop bit (when 1 stop bit length is selected) or the first stop bit (when 2 stop bit length is selected) of the next data is received before the UiRB register is read</li> <li>Framing error This error occurs when the required number of stop bits is not detected</li> <li>Parity error This error occurs when an even number of 1's in parity and character bits is detected while the odd number is set, or vice versa. The parity should be enabled</li> <li>Error sum flag This flag becomes 1 when any of overrun error, framing error, or parity error occurs</li> </ul> | | | | | Other functions | Bit order selection LSB first or MSB first Serial data logic inversion This function logically inverses transmit/receive data. The start bit and stop bit are not inverted TXD/RXD I/O polarity switching The output level from the TXD pin and the input level to the RXD pin are inverted. All I/O levels are inverted | | | | ## Note: 1. The UiRB register is undefined when an overrun error occurs. The IR bit in the SiRIC register does not change to 1 (interrupt requested). Tables 17.6 and 17.7 list register settings. When UARTi operating mode is selected, a high is output at the TXDi pin until transmission starts (the TXDi pin is high-impedance when the N-channel open drain output is selected) (i = 0 to 4). Figures 17.23 and 17.24 show examples of transmit operations in UART mode. Figure 17.25 shows an example of receive operation. Table 17.6 Register Settings in UART Mode (UART0 to UART2) | Register | Bits | Function | |------------|-------------------------|----------------------------------------------------------------------| | UiMR | IOPOL | Select I/O polarity of pins TXD and RXD | | | PRY and PRYE | Select parity enabled or disabled, and odd or even | | | STPS | Select a stop bit length | | | CKDIR | Select an internal clock or external clock | | | SMD2 to SMD0 | Set the bits to 100b in 7-bit character length | | | | Set the bits to 101b in 8-bit character length | | | | Set the bits to 110b in 9-bit character length | | UiC0 | UFORM | Select LSB first or MSB first in 8-bit character length. Set the bit | | | | to 0 in 7-bit or 9-bit character length | | | CKPOL | Set the bit to 0 | | | NCH | Select an output mode for the TXDi pin | | | CRD | Select CTS function enabled or disabled | | | TXEPT | Transmit register empty flag | | | 2 | Set the bit to 0 | | | CLK1 and CLK0 | Select a count source for the UiBRG register | | UiC1 | IiC1 7 Set the bit to 0 | | | | UiLCH | Set the bit to 1 to use logic inversion | | | UiRRM | Set the bit to 0 | | | UilRS | Select an interrupt source for UARTi transmission | | | RI | Receive complete flag | | | RE | Set the bit to 1 to enable data reception | | | TI | Transmit buffer empty flag | | | TE | Set the bit to 1 to enable data transmission | | UiSMR | 7 to 0 | Set the bits to 00h | | UiSMR2 | 7 to 0 | Set the bits to 00h | | UiSMR3 | 7 to 0 | Set the bits to 00h | | UiSMR4 | 7 to 0 | Set the bits to 00h | | UiBRG | 7 to 0 | Set the bit rate | | UiTB | 8 to 0 | Set the data to be transmitted <sup>(1)</sup> | | UiRB | OER, FER, PER, and SUM | Error flag | | | 8 to 0 | Received data is read <sup>(1)</sup> | | i = 0 to 2 | | | i = 0 to 2 Note: 1. The bits used are as follows: 7-bit character length: bits 6 to 0 8-bit character length: bits 7 to 0 9-bit character length: bits 8 to 0 Table 17.7 Register Settings in UART Mode (UART3, UART4) | Register | Bits | Function | | |----------|------------------------|--------------------------------------------------------------------------------------------------------------|--| | UiMR | PRY and PRYE | Select parity enabled or disabled, and odd or even | | | | STPS | Select a stop bit length | | | | CKDIR | Select an internal clock or external clock | | | | SMD2 to SMD0 | Set the bits to 100b in 7-bit character length | | | | | Set the bits to 101b in 8-bit character length | | | | | Set the bits to 110b in 9-bit character length | | | UiC0 | UFORM | Select LSB first or MSB first in 8-bit character length. Set the bit to 0 in 7-bit or 9-bit character length | | | | CKPOL | Set the bit to 0 | | | | 5 | Set the bit to 0 | | | | CRD | Select CTS function enabled or disabled | | | | TXEPT | Transmit register empty flag | | | | 2 | Set the bit to 0 | | | | CLK1 and CLK0 | Select a count source for the UiBRG register | | | UiC1 | RI | Receive complete flag | | | | RE | Set the bit to 1 to enable data reception | | | | TI | Transmit buffer empty flag | | | | TE | Set the bit to 1 to enable data transmission | | | U34CON | UiRRM | Set the bit to 0 | | | | UilRS | Select an interrupt source for UARTi transmission | | | UiBRG | 7 to 0 | Set the bit rate | | | IFS0 | IFS04 | Select input pins for CLK4, RXD4, and CTS4 | | | UiTB | 8 to 0 | Set the data to be transmitted (1) | | | UiRB | OER, FER, PER, and SUM | Error flag | | | | 8 to 0 | Received data is read <sup>(1)</sup> | | i = 3, 4 ### Note: 1. The bits used are as follows: 7-bit character length: bits 6 to 0 8-bit character length: bits 7 to 0 9-bit character length: bits 8 to 0 Figure 17.23 Transmit Operation in UART Mode (1/2) (i = 0 to 4) Figure 17.24 Transmit Operation in UART Mode (2/2) (i = 0 to 4) Figure 17.25 Receive Operation in UART Mode (i = 0 to 4) #### 17.2.1 Bit Rate In UART mode, the bit rate is a clock frequency which is divided by a setting value of the UiBRG register and again divided by 16 (i = 0 to 4). Table 17.8 lists an example of bit rate setting. Table 17.8 Bit Rate Setting | | Count Source of Peripheral Clock: 30 MHz | | Peripheral Clock: 32 MHz | | | |----------------|------------------------------------------|------------------|--------------------------|------------------|-----------------| | Bit Rate (bps) | BRG | Setting value of | Actual bit rate | Setting value of | Actual bit rate | | | BICO | BRG: n | (bps) | BRG: n | (bps) | | 1200 | f8 | 194 (C2h) | 1202 | 207 (CHh) | 1202 | | 2400 | f8 | 97 (61h) | 2392 | 103 (67h) | 2404 | | 4800 | f8 | 48 (30h) | 4783 | 51 (33h) | 4808 | | 9600 | f1 | 194 (C2h) | 9615 | 207 (CFh) | 9615 | | 14400 | f1 | 129 (81h) | 14423 | 138 (8Ah) | 14388 | | 19200 | f1 | 97 (61h) | 19133 | 103 (67h) | 19231 | | 28800 | f1 | 64 (40h) | 28846 | 68 (44h) | 28986 | | 31250 | f1 | 59 (3Bh) | 31250 | 63 (3Fh) | 31250 | | 38400 | f1 | 48 (30h) | 38265 | 51 (33h) | 38462 | | 51200 | f1 | 36 (24h) | 50676 | 38 (26h) | 51282 | #### 17.2.2 Reset Procedure on Transmit/Receive Error When a transmit/receive error occurs in UART mode, follow the procedure below to perform a reset: - A. Reset procedure for the UiRB register (i = 0 to 4) - (1) Set the RE bit in the UiC1 register to 0 (reception disabled). - (2) Set the RE bit in the UiC1 register to 1 (reception enabled). - B. Reset procedure for the UiTB register - (1) Set bits SMD2 to SMD0 in the UiMR register to 000b (serial interface disabled). - (2) Set again bits SMD2 to SMD0 to either of 001b, 101b, or 110b. - (3) Irrespective of its status, set the TE bit in the UiC1 register to 1 (transmission enabled). ### 17.2.3 LSB First and MSB First Selection As shown in Figure 17.26, the bit order is selected by setting the UFORM bit in the UiC0 register (i = 0 to 4). This function is available when the character length is 8-bit. Figure 17.26 Bit Order (i = 0 to 4) ## 17.2.4 Serial Data Logic Inversion When the UiLCH bit in the UiC1 register is 1 (data is logic inverted), the logical value written in the UiTB register is inverted before being transmitted (i = 0 to 2). The UiRB register is read as logic-inverted receive data. The parity bit is not inverted. Figure 17.27 shows the logic inversion of serial data. Figure 17.27 Serial Data Logic Inversion (i = 0 to 2) ## 17.2.5 TXD and RXD I/O Polarity Inversion The output level at the TXD pin and the input level at the RXD pin are inverted by this function. All I/O data levels, including the start bit, stop bit, and parity bit are inverted by setting the IOPOL bit in the UiMR register to 1 (inverted) (i = 0 to 2). Figure 17.28 shows TXD and RXD I/O polarity inversion. Figure 17.28 TXD and RXD I/O Polarity Inversion (i = 0 to 2) ### 17.2.6 CTS/RTS Function CTS function controls data transmission using the $\overline{\text{CTSi}/\text{RTSi}}$ pin (i = 0 to 4). When an input level at the pin becomes low, data transmission starts. If the input level changes to high during transmit operation, transmission of the next data is stopped. RTS function indicates receiver status using the $\overline{\text{CTSi}/\text{RTSi}}$ pin. When the MCU is ready to receive data, the output level at the pin becomes low. It becomes high on the first falling edge of the CLKi pin. ## 17.3 Special Mode 1 (I<sup>2</sup>C Mode) This mode uses an I<sup>2</sup>C-typed interface for communication. Table 17.9 lists specifications of the I<sup>2</sup>C mode. Table 17.9 I<sup>2</sup>C Mode Specifications | Item | Specification | | | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Data format | 8-bit character length | | | | Transmit/receive clock | In master mode • The CKDIR bit in the UiMR register is 0 (internal clock) (i = 0 to 2): | | | | | $\frac{fx}{2(m+1)}$ $fx = f1, f8, f2n$ | | | | | m: UiBRG register setting value, 00h to FFh | | | | | In slave mode • The CKDIR bit is 1 (external clock): input to the SCLi pin | | | | Transmit start conditions | The conditions for starting data transmission are as follows (1): • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data held in the UiTB register) | | | | Receive start conditions | The conditions for starting data reception are as follows (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 held in the UiTB register) | | | | Interrupt request generating timing | When any of the following is detected: start condition, stop condition, NACK (not-acknowledge), or ACK (acknowledge) | | | | Error detection | Overrun error <sup>(2)</sup> This error occurs when the eighth bit of the next data is received before the UiRB register is read | | | | Other functions | <ul> <li>Arbitration lost Update timing of the ABT bit in the UiRB register can be selected</li> <li>SDAi digital delay No digital delay or two to eight cycles of digital delay of UiBRG count source</li> <li>Clock phase setting Clock delayed or no clock delay</li> </ul> | | | #### Notes: - 1. When an external clock is selected, the conditions should be met while the external clock signal is held high. - 2. The UiRB register is undefined when an overrun error occurs. The IR bit in the SiRIC register does not change to 1 (interrupt requested). Table 17.10 lists register settings in $I^2C$ mode, and Tables 17.11 and 17.12 list $I^2C$ mode functions. Figure 17.29 shows a block diagram of $I^2C$ mode, and Figure 17.30 shows timings for the transfer to the UiRB register and the interrupt (i = 0 to 2). As shown in Tables 17.11 and 17.12, UARTi enters this mode when bits SMD2 to SMD0 in the UiMR register are set to 010b, and the IICM bit in the UiSMR register is set to 1 (i = 0 to 2). Since a transmit signal at the SDAi pin is output via the delay circuit, it changes after the SCLi pin is stably held low. Figure 17.29 I<sup>2</sup>C Mode Block Diagram (i = 0 to 2) Table 17.10 Register Settings in I<sup>2</sup>C Mode (i = 0 to 2) | Dogiotor | Dita | Function | | | | | |----------|---------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|--| | Register | Bits | Master | Slave | | | | | UiMR | IOPOL | Set the bit to 0 | • | | | | | | CKDIR | Set the bit to 0 | Set the bit to 1 | | | | | | SMD2 to SMD0 | Set the bit to 010b | • | | | | | UiC0 | 7 to 4 | Set the bits to 1011b | | | | | | | TXEPT | Transmit register empty flag | | | | | | | 2 | Set the bit to 0 | | | | | | | CLK1 and CLK0 | Select a count source for the UiBRG register | Disabled | | | | | UiC1 | 7 to 5 | Set the bits to 000b | | | | | | | UilRS | Set the bit to 1 | | | | | | | RI | Receive complete flag | | | | | | | RE | Set the bit to 1 to enable data reception | | | | | | | TI | Transmit buffer empty flag | | | | | | | TE | Set the bit to 1 to enable data transmission/reception | | | | | | UiSMR | 7 to 3 | Set the bits to 00000b | | | | | | | BBS | Bus busy flag | | | | | | | ABC | Select an arbitration lost detection timing | Disabled | | | | | | IICM | Set the bit to 1 | | | | | | UiSMR2 | 7 | Set the bit to 0 | | | | | | | SDHI | Set the bit to 1 to disable the SDA output | | | | | | | SWC2 | Set the bit to 1 to hold the SCL output at a forcible low | | | | | | | STC | Set the bit to 0 | Set the bit to 1 to reset UARTi by detecting the start condition | | | | | | ALS | Set the bit to 1 to stop the output at the SDAi pin to detect an arbitration lost | Set the bit to 0 | | | | | | SWC | Set the bit to 1 to hold a low output at the SCLi pin after receiving the eighth bit of the clock | | | | | | | CSC | Set the bit to 1 to enable clock synchronization | Set the bit to 0 | | | | | | IICM2 | Refer to Tables 17.11 and 17.12 | | | | | | UiSMR3 | DL2 to DL0 | Set the digital delay value of SDAi | | | | | | | 4 to 2 | Set the bit to 000b | | | | | | | СКРН | Refer to Tables 17.11 and 17.12 | | | | | | | SSE | Set the bit to 0 | | | | | | UiSMR4 | SWC9 | Set the bit to 0 | Set the bit to 1 to hold a low output at the SCLi pin after receiving the ninth bit of the clock | | | | | | SCLHI | Set the bit to 1 to stop the SCL output to detect stop condition | Set the bit to 0 | | | | | | ACKC | Set the bit to 1 for ACK data output | | | | | | | ACKD | Select ACK or NACK | | | | | | | STSPSEL | Set the bit to 1 when any condition is output | Set the bit to 0 | | | | | | STPREQ | Set the bit to 1 to generate a stop condition | Set the bit to 0 | | | | | | RSTAREQ | Set the bit to 1 to generate a restart condition | Set the bit to 0 | | | | | | STAREQ | Set the bit to 1 to generate a start condition | Set the bit to 0 | | | | | UiBRG | 7 to 0 | Set the bit rate | Disabled | | | | | UiTB | 8 | Set the bit to 1 when transmitting. Set the bit to the value of the A | CK bit when receiving | | | | | | 7 to 0 | Set the data to be transmitted when transmitting. Set the register | | | | | | UiRB | OER | Overrun error flag | | | | | | | ABT | Arbitration lost detection flag | Disabled | | | | | | 8 | D0 is loaded immediately after a receive interrupt occurs. ACK or NACK is loaded after a transmit interrupt occurs | | | | | | | 7 to 0 | D7 to D1 are read immediately after a receive interrupt occurs. Di interrupt occurs | 7 to D0 are read after a transmit | | | | Table 17.11 $I^2C$ Mode Functions (i = 0 to 2) (1/2) | | Synchronous | I <sup>2</sup> C Mode (SMD2 to SMD0 are 010b, IICM is 1) | | | | | |--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------|--| | Function | Serial Interface<br>Mode | IICM2 is 0<br>(ACK/NACK interrupt) | | | 2 is 1<br>eive interrupt) | | | | (SMD2 to SMD0<br>are 001b,<br>IICM is 0) | CKPH is 0<br>(No clock<br>delay) | CKPH is 1<br>(Clock<br>delayed) | CKPH is 0<br>(No clock delay) | CKPH is 1<br>(Clock delayed) | | | Source of software interrupt numbers 39 to 41 (1) (refer to Figure 17.30) | _ | Start condition or stop con | | dition detection (refer to | Table 17.13) | | | Source of software interrupt numbers 17, 19, and 33 <sup>(1)</sup> (refer to Figure 17.30) | UARTi<br>transmission:<br>Transmission<br>started or<br>completed<br>(selected using<br>the UiIRS<br>register) | NACK detection: Rising edge of the ninth bit of SCLi | | UARTi transmission:<br>Rising edge of the<br>ninth bit of SCLi | UARTi transmission:<br>Falling edge of the<br>ninth bit of SCLi | | | Source of software interrupt numbers 18, 20, and 34 <sup>(1)</sup> (refer to Figure 17.30) | UARTi reception: Receiving at eighth bit CKPOL is 0 (rising edge) CKPOL is 1 (falling edge) | ACK detection edge of the name | | UARTi reception: Falling of SCLi | g edge of the eighth bit | | | Data transfer timing from<br>the UART receive<br>register to the UiRB<br>register | CKPOL is 0<br>(rising edge)<br>CKPOL is 1<br>(falling edge) | Rising edge of bit of SCLi | of the ninth | Falling edge of the eighth bit of SCLi | Falling edge of the eighth bit and rising edge of the ninth bit of SCLi | | | UARTi transmit output delay | No delay | Delayed | | | | | | Pins P5_7, P4_7, and P7_0 | TXDi output | SDAi I/O | | | | | | Pins P5_6, P4_6, and P7_4 | RXDi input | SCLi I/O | | | | | | Pins P5_5, P4_5, and P7_5 | Select CLKi input or output | —<br>(Not used in | <sup>2</sup> C mode) | | | | #### Note: - 1. Steps to change an interrupt source are as follows: - (1) Disable the interrupt of the corresponding software interrupt number. - (2) Change the source of interrupt. - (3) Set the IR bit of the corresponding software interrupt number to 0 (no interrupt requested). - (4) Set bits ILVL2 to ILVL0 of the corresponding software interrupt number. Table 17.12 $I^2C$ Mode Functions (i = 0 to 2) (2/2) | | Synchronous | | I <sup>2</sup> C Mode (S | MD2 to SMD0 are 010b, | IICM is 1) | |--------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Function | Serial Interface<br>Mode | IICM2 is 0<br>(ACK/NACK interrupt) | | IICM2 is 1 (Transmit/receive interrupt) | | | | (SMD2 to SMD0<br>are 001b,<br>IICM is 0) | CKPH is 0<br>(No clock<br>delay) | CKPH is 1<br>(Clock<br>delayed) | CKPH is 0<br>(No clock delay) | CKPH is 1<br>(Clock delayed) | | Read level at pins RXDi and SCLi | Readable irrespec | ctive of the po | rt direction bit | i i | | | Default output value at the SDAi pin | _ | | set in the port<br>ct registers (i | Pi register if the I/O port = 0 to 7)) | is selected by output | | SCLi default and end values | _ | High | Low | High | Low | | DMA source (refer to Figure 17.30) | UARTi reception | ACK detection | | UARTi reception: Falling edge of the eighth bit of SCLi | | | Store received data | The first to<br>eighth bits of<br>received data<br>are stored into<br>bits 0 to 7 in the<br>UiRB register | The first to ei<br>received data<br>into bits 7 to 0<br>register | • | The first to seventh bits of received data are stored into bits 6 to 0 in the UiRB register and the eighth bit is stored into bit 8 | Same as on the left column on the first data storing. (1) The first to eighth bits of received data are stored into 7 to 0 bits in the UiRB register and the ninth bit is stored into bit 8 on the second data storing (2) | | Read received data | The UiRB register status is read as it is | | Bits 6 to 0 in the UiRB register are read as bits 7 to 1 and bit 8 is read as bit 0 | Same as on the left column on the first read. (1) The UiRB register status is read as it is on the second read (2) | | ### Notes: - 1. The first data transfer to the UiRB register starts on the rising edge of the eighth bit of SCLi. - 2. The second data transfer to the UiRB register starts on the rising edge of the ninth bit of SCLi. Figure 17.30 Timings for the Transfer and Interrupt to the UiRB Register (i = 0 to 2) ## 17.3.1 Start Condition and Stop Condition Detection The start condition and stop condition are detected by their respective detectors. The start condition detection interrupt request is generated by a high-to-low transition at the SDAi pin while the SCLi pin is held high (i = 0 to 2). The stop condition detection interrupt request is generated by a low-to-high transition at the SDAi pin while the SCLi pin is held high. The start condition detection interrupt shares interrupt control registers and vectors with the stop condition detection interrupt. The BBS bit in the UiSMR register determines which interrupt is requested. To detect a start condition or stop condition, both set-up and hold times require at least six cycles of the peripheral clock (f1) as shown in Figure 17.31. To meet the condition for the Fast-mode specification, f1 must be at least 10 MHz. Figure 17.31 Start Condition and Stop Condition Detection Timing (i = 0 to 2) #### 17.3.2 Start Condition and Stop Condition Generation The start condition, restart condition, and stop condition are generated by bits STAREQ, RSTAREQ, and STPREQ in the UiSMR4 register, respectively (i = 0 to 2). To output a start condition, set the STSPSEL bit in the UiSMR4 register to 1 (select start condition/stop condition generation circuit) after setting the STAREQ bit to 1 (start). To output a restart condition or stop condition, set the STSPSEL bit to 1 after setting RSTAREQ bit or STPREQ bit to 1, respectively. Table 17.13 and Figure 17.32 show the functions of the STSPSEL bit. Table 17.13 STSPSEL Bit Functions | Function | STSPSEL is 0 | STSPSEL is 1 | |------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------| | Start condition and stop condition generation | Output is provided by the program with port (no auto generation by hardware) | Start condition or stop condition is output according to the STAREQ, RSTAREQ, or STPREQ bit | | Start condition and stop condition interrupt request generating timing | · | When start condition or stop condition generation is completed | Figure 17.32 STSPSEL Bit Functions (i = 0 to 2) #### 17.3.3 Arbitration The MCU determines whether the transmit data matches data input to the SDAi pin on the rising edge of the SCLi. If it does not match the input data, the arbitration takes place at the SDAi pin by switching off the data output stage. The ABC bit in the UiSMR register determines the update timing for the ABT bit in the UiRB register (i = 0 to 2). When the ABC bit is 0 (update every bit), the ABT bit becomes 1 (detected (lose)) as soon as a data discrepancy is detected. If not detected, the ABT bit becomes 0 (not detected (win)). When the ABC bit is 1 (update every byte), the ABT bit becomes 1 on the falling edge of the eighth bit of the SCLi if any discrepancy is detected. In this ABC bit setting, set the ABT bit to 0 to start the next 1-byte transfer. When the ALS bit in the UiSMR2 register is 1 (stop the SDAi output), the SDAi pin becomes high- impedance as the ABT bit becomes 1 when an arbitration lost occurs. ## 17.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 17.30. The clock speed increase makes it difficult to secure the required time for ACK generation and data transmit procedure. 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 is used to insert a wait-state for ACK generation (i = 0 to 2). When the SWC bit is 1 (hold the SCLi pin low after the eighth bit is received), the SCLi pin is held low on the falling edge of the eighth bit of the SCLi. When the SWC bit is 0 (no wait-state/wait-state cleared), the SCLi line is released. When the SWC2 bit in the UiSMR2 register is 1 (hold the SCLi pin low), the SCLi pin is forced low even during transmission or reception. When the SWC2 bit is 0 (output the transmit/receive clock 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 (hold the SCLi pin low after the ninth bit is received), the SCLi pin is held low on the falling edge of the ninth bit of the SCLi. When the SWC9 bit is set to 0 (no wait-state/wait-state cleared), the SCLi line is released. Figure 17.33 Wait-state Insertion Using the SWC or SWC9 Bit (i = 0 to 2) The CSC bit in the UiSMR2 register is used to synchronize an internally generated clock with the clock applied to the SCLi pin. For example, if a wait-state is inserted from another device, 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 value of the UiBRG register and to 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 the SCLi. The synchronized period starts from one clock prior to the first synchronized 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 0 (internal clock). 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 in transmit/receive operation. If the SCLHI bit is set to 1 (stop SCLi output), the SCLi pin is open (the pin is high-impedance) when a stop condition is detected and the clock output is stopped. Figure 17.34 Clock Synchronization (i = 0 to 2) ### **17.3.5** SDA Output Values set to bits 8 to 0 (D8 to D0) in the UiTB register are output starting from D7 to D0, and lastly D8, which is a bit for the acknowledge signal (i = 0 to 2). When transmitting, D8 should be set to 1 to free the bus. When receiving, D8 should be set to ACK or NACK. Bits DL2 to DL0 in the UiSMR3 register set a delay time of the SDAi on the falling edge of the SCLi. Based on the UiBRG count source, the delay time can be selected from zero cycles (no delay) or two to eight cycles. The SDAi pin can be high-impedance at any given time once the SDHI bit in the UiSMR2 register is set to 1 (stop the output). Output at the SDAi pin is low if an I/O port is selected for the SDAi and the pin is specified as the output port after selecting I<sup>2</sup>C mode. In this case, if the SDHI bit is 1, the SDAi pin becomes high-impedance. When the SDHI bit is rewritten while the SCLi pin is held high, a start condition or stop condition is generated. When it is rewritten immediately before the rising edge of SCLi, arbitration lost may be accidently detected. Therefore, the SDHI bit should be rewritten so the SDAi pin level changes while the SCLi pin is low. ## 17.3.6 SDA Input When the IICM2 bit in the UiSMR2 register is 0 (use ACK/NACK interrupt), the first 8 bits of received data (D7 to D0) are stored into bits 7 to 0 in the UiRB register and the ninth bit (ACK/NACK) is stored into bit 8 (i = 0 to 2). When the IICM2 bit is 1, the first 7 bits of received data (D7 to D1) are stored into bits 6 to 0 in the UiRB register and eighth bit (D0) is stored into bit 8. If the IICM2 bit is 1 and the CKPH bit in the UiSMR3 register is 1 (clock delayed), the same data that is set when the IICM2 bit is 0 can be read. To read this data, read the UiRB register after data in the ninth bit is latched on the rising edge of the SCLi. ### 17.3.7 Acknowledge When data is to be received in master mode, 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 is 0 (select serial I/O circuit) and the ACKC bit is 1 (ACK data output), the value of the ACKD bit is output at the SDAi pin (i = 0 to 2). If the IICM2 bit is 0, a NACK interrupt request is generated when the SDAi pin is high on the rising edge of the ninth bit of the SCLi. An ACK interrupt request is generated when the SDAi pin is low. When the DMA request source is "UARTi receive interrupt request or ACK interrupt request", the DMA transfer starts when an ACK is detected. ### 17.3.8 Initialization of Transmit/Receive Operation Reset When the CKDIR bit in the UiMR register is 1 (external clock), the STC bit in the UiSMR2 register is 1 (initialize the circuit), and a start condition is detected, the following three operations are performed (i = 0 to 2): - The transmit register is reset and the UiTB register value is transferred to the transmit register. New data transmission starts on the falling edge of the first bit of the next SCLi as transmit clock. The transmit register value before the reset is output at the SDAi pin in the period from the falling edge of the SCLi until the first data output. - The receive register is reset and the new data reception starts on the falling edge of the first bit of the next SCLi. - The SWC bit in the UiSMR2 register becomes 1 (hold the SCLi pin low after the eighth bit is received). The TI bit in the UiC1 register does not change when using this function to start the UARTi transmission/reception. ## 17.4 Special Mode 2 Special mode 2 enables serial communication between one or multiple masters and multiple slaves. The $\overline{SSi}$ input pin controls serial bus communication (i = 0 to 2). Table 17.14 lists specifications of special mode 2. Table 17.14 Special Mode 2 Specifications | Item | Specification | | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Data format | 8-bit character length | | | Transmit/receive clock | <ul> <li>The CKDIR bit in the UiMR register is set to 0 (internal clock) (i = 0 to 2):</li> <li> fx 2(m+1) </li> <li>The CKDIR bit is set to 1 (external clock): input to the CLKi pin</li> </ul> | | | Transmit/receive control | SS function | | | Transmit start conditions | The conditions for starting data transmission are as follows (1): • The TE bit in the UiC1 register is 1 (transmission enabled) • The TI bit in the UiC1 register is 0 (data held in the UiTB register) | | | Receive start conditions | The conditions for starting data reception are as follows (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 held in the UiTB register) | | | Interrupt request generating timing | bit in registers U0C1 to U2C1: • The UiIRS bit is 0 (transmit buffer is empty): when data is transferred from the UiTB register to the UARTi transmit register (when the transmission has started) • The UiIRS bit is 1 (transmission is completed): when data transmission from the UARTi transmit register is completed In receive interrupt, • When data is transferred from the UARTi receive register to the UiRB register (when the reception is completed) | | | Error detection | Overrun error <sup>(2)</sup> This error occurs when the seventh bit of the next data has been received before reading the UiRB register | | | Other functions | CLK polarity Rising or falling edge of the transmit/receive clock for transfer data input and output Bit order selection LSB first or MSB first Continuous receive mode Data reception is enabled by a read access to the UiRB register Serial data logic inversion This function logically inverses transmit/receive data Clock phase selection One of four combinations of transmit/receive clock polarity and phases SSi input pin function Output pin can be high-impedance when the SSi pin is high | | ### Notes: - 1. When selecting an external clock, the following preconditions should be met: - The CLKi pin is held high when the CKPOL bit in the UiC0 register is 0 (transmit data output on the falling edge of the transmit/receive clock and receive data input on the rising edge). - The CLKi pin is held low when the CKPOL bit is 1 (transmit data output on the rising edge of the transmit/ receive clock and receive data input on the falling edge). - 2. The UiRB register is undefined when an overrun error occurs. The IR bit in the SiRIC register does not change to 1 (interrupt requested). Table 17.15 lists register settings in special mode 2. Table 17.15 Register Settings in Special Mode 2 (i = 0 to 2) | Register | Bits | Function | |----------|---------------|-----------------------------------------------------------------------------------------| | UiMR | 7 to 4 | Set the bits to 0000b | | | CKDIR | Set the bit to 0 in master mode and set it to 1 in slave mode | | | SMD2 to SMD0 | Set the bits to 001b | | UiC0 | UFORM | Select either LSB first or MSB first | | | CKPOL | Clock phase can be set by the combination of bits CKPOL and CKPH in the UiSMR3 register | | | NCH | Select an output mode for the TXDi pin | | | CRD | Set the bit to 1 | | | TXEPT | Transmit register empty flag | | | 2 | Set the bit to 0 | | | CLK1 and CLK0 | Select a count source for the UiBRG register | | UiC1 | 7 and 6 | Set the bits to 00b | | | UiRRM | Set the bit to 1 to use continuous receive mode | | | UilRS | Select a source for UARTi transmit interrupt | | | RI | Receive complete flag | | | RE | Set the bit to 1 to enable data reception | | | TI | Transmit buffer empty flag | | | TE | Set the bit to 1 to enable data transmission/reception | | UiSMR | 7 to 0 | Set the bits to 00h | | UiSMR2 | 7 to 0 | Set the bits to 00h | | UiSMR3 | 7 to 5 | Set the bits to 000b | | | ERR | Mode fault flag | | | NODC | Set the bit to 0 | | | DINC | Set to 0 in master mode and set to 1 in slave mode | | | СКРН | Clock phase can be set by the combination of bits CKPH and CKPOL in the UiC0 register | | | SSE | Set the bit to 1 | | UiSMR4 | 7 to 0 | Set the bits to 00h | | UiBRG | 7 to 0 | Set the bit rate | | UiTB | 7 to 0 | Set the data to be transmitted | | UiRB | OER | Overrun error flag | | | 7 to 0 | Received data is read | ## 17.4.1 $\overline{SSi}$ Input Pin Function (i = 0 to 2) Special mode 2 is selected by setting the SSE bit in the UiSMR3 register to 1 (SS function enabled). The CTSi/RTSi/SSi pin functions as SSi input. The DINC bit in the UiSMR3 register determines which MCU performs as a master or slave. When multiple MCUs perform as masters (multi-master system), the $\overline{SSi}$ pin setting determines which master MCU is active and when. #### 17.4.1.1 SS Function in Slave Mode When the DINC bit is 1 (slave mode) while input at the $\overline{SSi}$ pin is high, the STXDi pin becomes high-impedance and the clock input at the CLKi pin is ignored. When input at the $\overline{SSi}$ pin is low, the clock input is valid and serial data is output from the STXDi pin to enable serial communication. ## 17.4.1.2 SS Function in Master Mode When the DINC bit is 0 (master mode) while input at the $\overline{SSi}$ pin is high, which means there is the only one master MCU or no other master MCU is active, the MCU as master starts communication. The master provides the transmit/receive clock output at the CLKi pin. When input at the $\overline{SSi}$ pin is low, which means that there are more masters, pins TXDi and CLKi become high-impedance. This error is called a mode fault. It can be verified using the ERR bit in the UiSMR3 register. The ongoing data transmission/reception does not stop even if a mode fault occurs. To stop transmission/reception, bits SMD2 to SMD0 in the UiMR register should be set to 000b (serial interface disabled). Figure 17.35 Serial Bus Communication Control with the SSi Pin ## 17.4.2 Clock Phase Setting The CKPH bit in the UiSMR3 register and the CKPOL bit in the UiC0 register select one of four combinations of transmit/receive clock polarity and serial clock phase (i = 0 to 2). The transmit/receive clock phase and polarity should be identical for the master device and the communicating slave device. ## 17.4.2.1 Transmit/Receive Timing in Master Mode When the DINC bit is 0 (master mode), the CKDIR bit in the UiMR register should be set to 0 (internal clock) to generate the clock. Figure 17.36 shows transmit/receive timing of each clock phase. Figure 17.36 Transmit/Receive Timing in Master Mode R32C/161 Group 17. Serial Interface # 17.4.2.2 Transmit/Receive Timing in Slave Mode When the DINC bit is 1 (slave mode), the CKDIR bit in the UiMR register should be set to 1 (external clock). When the CKPH bit is 0 (no clock delay) while input at the $\overline{SSi}$ pin is high, the STXDi pin becomes high-impedance. When input at the $\overline{SSi}$ pin is low, the conditions for data transmission are all met, but output is undefined. Then the data transmission/reception starts synchronizing with the clock. Figure 17.37 shows the transmit/receive timing. When the CKPH bit is 1 (clock delayed) while input at the $\overline{SSi}$ pin is high, the STXDi pin becomes high-impedance. When input at the $\overline{SSi}$ pin is low, the first data is output. Then the data transmission starts synchronizing with the clock. Figure 17.38 shows the transmit/receive timing. Figure 17.37 Transmit/Receive Timing in Slave Mode (CKPH = 0) Figure 17.38 Transmit/Receive Timing in Slave Mode (CKPH = 1) R32C/161 Group 17. Serial Interface ### 17.5 Notes on Serial Interface # 17.5.1 Changing the UiBRG Register (i = 0 to 4) • Set the UiBRG register after setting bits CLK1 and CLK0 in the UiC0 register. When these bits are changed, the UiBRG register must be set again. • When a clock is input immediately after the UiBRG register is set to 00h, the counter may become FFh. In this case, it requires extra 256 clocks to reload 00h to the register. Once 00h is reloaded, the counter performs the operation without dividing the count source according to the setting. ### 17.5.2 Pin Output When the NCH bit in the U2C0 register is set to 1, pins assigned for TXD2/SDA2 and SCL2 function as N-channel open drain output even if the UART output function is not selected in output function select register. When the NODC bit in the U2SMR3 register is set to 1, CLK2 pins function as N-channel open drain output even if the UART output function is not selected in output function select register. # 17.5.3 Synchronous Serial Interface Mode # 17.5.3.1 Selecting an External Clock - If an external clock is selected, the following conditions must be met while the external clock is held high when the CKPOL bit in the UiC0 register is 0 (transmit data output on the falling edge of the transmit/receive clock and receive data input on the rising edge), or while the external clock is held low when the CKPOL bit is 1 (transmit data output on the rising edge of the transmit/receive clock and receive data input on the falling edge) (i = 0 to 4): - The TE bit in the UiC1 register is 1 (transmission enabled). - The RE bit in the UiC1 register is 1 (reception enabled). This bit setting is not required when only transmitting. - The TI bit in the UiC1 register is 0 (data held in the UiTB register). ### 17.5.3.2 Receive Operation - In synchronous serial interface mode, the transmit/receive clock is controlled by the transmit control circuit. Set UARTi-associated registers for a transmit operation, even if the MCU is used only for receive operation (i = 0 to 4). Dummy data is output from the TXDi pin while receiving when the TXDi pin is set to output mode. - When data is received continuously, an overrun error occurs when the RI bit in the UiC1 register is 1 (data held in the UiRB register) and the seventh bit of the next data is received in the UARTi receive shift register. Then, the OER bit in the UiRB register becomes 1 (overrun error occurred). In this case, the UiRB register becomes undefined. If an overrun error occurs, the IR bit in the SiRIC register does not change to 1. # 17.5.4 Special Mode 1 (I<sup>2</sup>C Mode) • To generate a start condition, stop condition, or restart condition, set the STSPSEL bit in the UiSMR4 register to 0 (i = 0 to 2). Then, wait a half or more clock cycles of the transmit/receive clock to change the condition generate bits (STAREQ, RSTAREQ, or STPREQ bit) from 0 to 1. R32C/161 Group 17. Serial Interface ### 17.5.5 Reset Procedure on Communication Error Operations which result in communication errors such as rewriting function select registers during transmission/reception should not be performed. Follow the procedure below to reset the internal circuit once the communication error occurs in the following cases: when the operation above is performed by a receiver or transmitter or when a bit slip is caused by noise. #### A. Synchronous Serial Interface Mode - (1) Set the TE bit in the UiC1 register to 0 (transmission disabled) and the RE bit to 0 (reception disabled) (i = 0 to 4). - (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 (synchronous serial interface mode). - (4) Set the TE bit in the UiC1 register to 1 (transmission enabled) and the RE bit to 1 (reception enabled) if necessary. #### B. UART Mode - (1) Set the TE bit in the UiC1 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, 7-bit character length), 101b (UART mode, 8-bit character length), or 110b (UART mode, 9-bit character length). - (4) Set the TE bit in the UiC1 register to 1 (transmission enabled) and the RE bit to 1 (reception enabled) if necessary. # 18. A/D Converter The A/D converter consists of one 10-bit successive approximation A/D converter with a capacitive coupling amplifier. A/D converted results are stored in the A/D registers corresponding to selected pins. Results are stored in the AD00 register only when the DMAC operating mode is enabled. When the A/D converter is not in use, power consumption can be reduced by setting the VCUT bit in the AD0CON1 register to 0 (VREF disconnected). This bit setting enables the power supply from the VREF pin to the resistor ladder to stop. Table 18.1 lists specifications of the A/D converter. Figure 18.1 shows a block diagram of the A/D converter. Figures 18.2 to 18.7 show registers associated with the A/D converter. Table 18.1 A/D Converter Specifications | Item | Specification | | | |--------------------------------|---------------------------------------------------------------------------------|--|--| | A/D conversion method | Capacitance-based successive approximation | | | | Analog input voltage (1) | 0 V to AVCC (VCC) | | | | Operating clock, $\phi$ AD (2) | fAD, fAD divided by 2, fAD divided by 3, fAD divided by 4, fAD divided by 6, or | | | | | fAD divided by 8 | | | | Resolution | 8 bits or 10 bits | | | | Operating modes | One-shot mode, repeat mode, single sweep mode, repeat sweet mode 0, repeat | | | | | sweep mode 1, and self test mode | | | | Analog input pins (3) | 23 | | | | | 5 pins for AN, 8 pins each for AN0 and AN2 | | | | | 2 function-extended input pins (ANEX0 and ANEX1) | | | | A/D conversion start | Software trigger | | | | conditions | The ADST bit in the AD0CON0 register is set to 1 (A/D conversion started) by a | | | | | program | | | | | External trigger (retrigger is enabled) | | | | | An input signal at the ADTRG pin switches from high to low after the ADST bit | | | | | is set to 1 by a program | | | | | Hardware trigger (retrigger is enabled) | | | | | Generation of a timer B2 interrupt request which has passed through the | | | | | circuit to set an interrupt generating frequency in the three-phase motor | | | | | control timers after the ADST bit is set to 1 by a program | | | | | Generation of a timer A0 interrupt request after the ADST bit is set to 1 | | | | Conversion rates per pin | · | | | | | 49 φAD cycles at 8-bit resolution | | | | | 59 φAD cycles at 10-bit resolution | | | | | including 2 φAD cycles for sampling time | | | | | With sample and hold function | | | | | 28 φAD cycles at 8-bit resolution | | | | | 33 φAD cycles at 10-bit resolution | | | | | including 3 φAD cycles for sampling time | | | ### Notes: - 1. The analog input voltage is not dependent on whether the sample and hold function is enabled or disabled. - 2. The $\phi$ AD frequency should be as follows: - When VCC = 4.2 to 5.5 V, 16 MHz or below - When VCC = 3.0 to 4.2 V, 10 MHz or below - When not using the sample and hold function, 250 kHz or above - When using the sample and hold function, 1 MHz or above - 3. When AVCC = VREF = VCC, A/D input voltage for pins AN\_0 to AN\_4, ANO\_0 to ANO\_7, ANO\_1, A Figure 18.1 A/D Converter Block Diagram #### Notes: - 1. When this register is rewritten during an A/D conversion, the converted result is undefined. - 2. Analog input pins should be reset after the A/D operating mode is changed. - 3. This bit setting is enabled in one-shot mode or repeat mode. - 4. The AN, AN0, or AN2 port should be selected by using bits APS1 and APS0 in the AD0CON2 register. - 5. Do not select pins AN\_5 to AN\_7. - 6. To use the external trigger or the hardware trigger, select the source of the trigger by setting bits TRG1 and TRG0 in the AD0CON2 register. Then set the ADST bit to 1 after setting the TRG bit to 1. - 7. The $\phi AD$ frequency should be as follows: 16 MHz or below when VCC = 5 V, 10 MHz or below when VCC = 3.3 V The $\phi$ AD frequency is selected from the combination of bits CKS0, CKS1, and CKS2 shown as below: | CKS2 Bit in the AD0CON3 Register | CKS0 Bit in the AD0CON0 Register | CKS1 Bit in the<br>AD0CON1 Register | φAD | | |----------------------------------|----------------------------------|-------------------------------------|------------------|------------------| | 0 | | 0 | 0 | fAD divided by 4 | | | 0 | 1 | fAD divided by 3 | | | | 1 | 0 | 0 | fAD divided by 2 | | | | 1 | fAD | | | 1 | 0 | 1 | 0 | fAD divided by 8 | | | | 1 | fAD divided by 6 | | Figure 18.2 AD0CON0 Register #### Notes: - 1. When this register is rewritten during A/D conversion, the converted result is undefined. - 2. This bit setting is enabled in single sweep mode, repeat sweep mode 0, or repeat sweep mode 1. - 3. The AN, AN0, AN2, or AN15 port should be selected by using bits APS1 and APS0 in the AD0CON2 register. - 4. The converted result of signals AN\_5 to AN\_7 is undefined. The bit setting should not include these signals. - 5. These pins are commonly used in A/D conversion when the MD2 bit is set to 1. - 6. Refer to the note on the CKS0 bit in the AD0CON0 register. - 7. This bit controls the reference voltage to the A/D converter. - 8. Do not set the VCUT bit to 0 during A/D conversion. - 9. When the VCUT bit is changed from 0 to 1, A/D conversion should be started after 1 µs or more. - 10.Bits OPA1 and OPA0 can be set to 01b or 10b only in one-shot mode or repeat mode. Set them to 00b or 11b in other modes. Figure 18.3 AD0CON1 Register Figure 18.4 AD0CON2 Register - 1. When this register is rewritten during A/D conversion, the converted result is undefined. - 2. This register may be read incorrectly during A/D conversion. It should be read or written after the A/D converter stops operating. - 3. When the DUS bit is set to 1, all A/D converted results are stored into the AD00 register. - 4. Configure DMAC when it is used to transfer converted results. - 5. Refer to the note on the CKS0 bit in the AD0CON0 register. Figure 18.5 AD0CON3 Register #### Notes - 1. When this register is rewritten during A/D conversion, the converted result is undefined. - 2. An 8-bit read access to this register should be performed. - Appropriate evaluation for each system should be performed since A/D converted result for open-circuit detection varies with external circuits. - 4. To use the self test assist or open-circuit detection assist, set the SMP bit in the AD0CON2 register to 1 (with sample and hold function). Figure 18.6 AD0CON5 Register - 1. If this register is read by a program while the DMAC is configured to transfer converted results, the value is undefined. - 2. The register value written while the A/D converter stops operating is undefined. - 3. Only the AD00 register is available when the DUS bit in the AD0CON3 register is 1 (DMAC operating mode enabled). Other registers are undefined. - 4. When a converted result is transferred by DMAC at 10-bit mode, the DMAC should be set for a 16-bit transfer. Figure 18.7 Registers AD00 to AD07 # 18.1 Mode Descriptions ### 18.1.1 One-shot Mode In one-shot mode, the analog voltage applied to a selected pin is converted into a digital code only once. Table 18.2 lists specifications of one-shot mode. Table 18.2 One-shot Mode Specifications | Item | Specification | | | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | Converts the analog voltage applied to a pin into a digital code only once. The pin is selected by setting bits CH2 to CH0 in the AD0CON0 register, bits OPA1 and OPA0 in the AD0CON1 register, and bits APS1 and APS0 in the AD0CON2 register | | | | Start conditions | <ul> <li>When the TRG bit in the AD0CON0 register is 0 (software trigger) The ADST bit in the AD0CON0 register is set to 1 (A/D conversion started) by a program.</li> <li>When the TRG bit is 1 (external trigger or hardware trigger) Set bits TRG1 and TRG0 in the AD0CON2 register to select external trigger request source.</li> <li>When 00b is selected, an input signal at the ADTRG pin switches from high to low after the ADST bit is set to 1 by a program.</li> <li>When 01b is selected, generation of a timer B2 interrupt request which has passed through the circuit to set the interrupt generating frequency in the three-phase motor control timers after the ADST bit is set to 1 by a program.</li> <li>When 10b is selected, generation of a timer A0 interrupt request after the ADST bit is set to 1</li> </ul> | | | | Stop conditions | <ul> <li>A/D conversion is completed (the ADST bit is set to 0 when the software trigger is selected)</li> <li>The ADST bit is set to 0 (A/D conversion stopped) by a program</li> </ul> | | | | Interrupt request generation timing | When A/D conversion is completed, an interrupt request is generated | | | | Input pin to be selected | One pin is selected from among AN_0 to AN_4, AN0_0 to AN0_7, AN2_0 to AN2_7, ANEX0, and ANEX1 | | | | Reading A/D converted result | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode disabled) Read the AD0j register corresponding to the selected pin (j = 0 to 7) When the DUS bit is 1 (DMAC operating mode enabled) Configure the DMAC (refer to 12. "DMAC"). Then the A/D converted result is stored in the AD00 register after the conversion is completed. The DMAC transfers the converted result from the AD00 register to a given memory space. Do not read the AD00 register by a program | | | # 18.1.2 Repeat Mode In repeat mode, the analog voltage applied to a selected pin is repeatedly converted into a digital code. Table 18.3 lists specifications of repeat mode. Table 18.3 Repeat Mode Specifications | Item | Specification | | | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | Converts the analog voltage input to a pin into a digital code repeatedly. The pin is selected by setting bits CH2 to CH0 in the AD0CON0 register, bits OPA1 and OPA0 in the AD0CON1 register, and bits APS1 and APS0 in the AD0CON2 register | | | | Start conditions | <ul> <li>When the TRG bit in the AD0CON0 register is 0 (software trigger) The ADST bit in the AD0CON0 register is set to 1 (A/D conversion started) by a program.</li> <li>When the TRG bit is 1 (external trigger or hardware trigger) Set bits TRG1 and TRG0 in the AD0CON2 register to select external trigger request source.</li> <li>When 00b is selected, an input signal at the ADTRG pin switches from high to low after the ADST bit is set to 1 by a program.</li> <li>When 01b is selected, generation of a timer B2 interrupt request which has passed through the circuit to set the interrupt generating frequency in the three-phase motor control timers after the ADST bit is set to 1 by a program.</li> <li>When 10b is selected, generation of a timer A0 interrupt request after the ADST bit is set to 1</li> </ul> | | | | Stop conditions | The ADST bit is set to 0 (A/D conversion stopped) by a program | | | | Interrupt request generation timing | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode disabled), no interrupt request is generated. When the DUS bit is 1 (DMAC operating mode enabled), each time A/D conversion is completed, an interrupt request is generated | | | | Analog voltage input | One pin is selected from among AN_0 to AN_4, ANO_0 to ANO_7, AN2_0 to | | | | pins | AN2_7, ANEX0, and ANEX1 | | | | Reading A/D converted result | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode disabled) Read the AD0j register corresponding to the selected pin (j = 0 to 7) When the DUS bit is 1 (DMAC operating mode enabled) • When the converted result is transferred by DMAC Configure the DMAC (refer to 12. "DMAC"). Then the A/D converted result is stored in the AD00 register after the conversion is completed. The DMAC transfers the converted result from the AD00 register to a given memory space. Do not read the AD00 register by a program • When the converted result is transferred by a program Read the AD00 register after the IR bit in the AD0IC register becomes 1. Set the IR bit back to 0 | | | # 18.1.3 Single Sweep Mode In single sweep mode, the analog voltage applied to selected pins is converted one-by-one into a digital code. Table 18.4 lists specifications of single sweep mode. Table 18.4 Single Sweep Mode Specifications | Item | Specification | |-----------------------|------------------------------------------------------------------------------------| | Function | Converts the analog voltage input to a set of pins into a digital code one-by-one. | | | The pins are selected by setting bits SCAN1 and SCAN0 in the AD0CON1 | | Otract and Pitting | register and bits APS1 and APS0 in the AD0CON2 register | | Start conditions | When the TRG bit in the AD0CON0 register is 0 (software trigger) | | | The ADST bit in the AD0CON0 register is set to 1 (A/D conversion started) by | | | a program. | | | When the TRG bit is 1 (external trigger or hardware trigger) | | | Set bits TRG1 and TRG0 in the AD0CON2 register to select external trigger | | | request source. • When 00b is selected, | | | an input signal at the ADTRG pin switches from high to low after the ADST bit | | | is set to 1 by a program. | | | • When 01b is selected, | | | generation of a timer B2 interrupt request which has passed through the | | | circuit to set the interrupt generating frequency in the three-phase motor | | | control timers after the ADST bit is set to 1 by a program. | | | • When 10b is selected, | | | generation of a timer A0 interrupt request after the ADST bit is set to 1 | | Stop conditions | A/D conversion is completed (the ADST bit is set to 0 when the software | | | trigger is selected) | | | The ADST bit is set to 0 (A/D conversion stopped) by a program | | Interrupt request | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode | | generation timing | disabled) when a sweep is completed, an interrupt request is generated. | | | When the DUS bit is 1 (DMAC operating mode enabled), each time A/D | | | conversion is completed, an interrupt request is generated | | Analog voltage input | Selected from a group of 2 pins (ANi_0 and ANi_1), 4 pins (ANi_0 to ANi_3), 6 | | pins | pins (ANi_0 to ANi_5), or 8 pins (ANi_0 to ANi_7) (i = no value, 0, 2) (1) | | Reading A/D converted | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode | | result | disabled) | | | Read the AD0j register corresponding to the selected pin (j = 0 to 7) | | | When the DUS bit is 1 (DMAC operating mode enabled) | | | Configure the DMAC (refer to 12. "DMAC"). | | | Then the A/D converted result is stored in the AD00 register after the | | | conversion is completed. The DMAC transfers the converted result from the | | | AD00 register to a given memory space. | | | Do not read the AD00 register by a program | #### Note: When bits APS1 and APS0 are set to 00b (AN\_0 to AN4, ANEX0, and ANEX1 selected), set bits SCAN1 and SCAN0 to 00b (ANi\_0 and ANi\_1 selected) or 01b (ANi\_0 to ANi\_3 selected). If bits SCAN1 and SCAN0 are set to 10b (ANi\_0 to ANi\_5 selected), the converted result of the AN\_5 signal is undefined. # 18.1.4 Repeat Sweep Mode 0 In repeat sweep mode 0, the analog voltage applied to selected pins is repeatedly converted into a digital code. Table 18.5 lists specifications of repeat sweep mode 0. Table 18.5 Repeat Sweep Mode 0 Specifications | Item | Specification | | | |-----------------------|------------------------------------------------------------------------------------|--|--| | Function | Converts the analog voltage input to a set of pins into a digital code repeatedly. | | | | | The pins are selected by setting bits SCAN1 and SCAN0 in the AD0CON1 | | | | | register and APS1 and APS0 in the AD0CON2 register | | | | Start conditions | When the TRG bit in the AD0CON0 register is 0 (software trigger) | | | | | The ADST bit in the AD0CON0 register is set to 1 (A/D conversion started) by | | | | | a program. | | | | | When the TRG bit is 1 (external trigger or hardware trigger) | | | | | Set bits TRG1 and TRG0 in the AD0CON2 register to select external trigger | | | | | request source. | | | | | • When 00b is selected, | | | | | an input signal at the ADTRG pin switches from high to low after the ADST bit | | | | | is set to 1 by a program. | | | | | • When 01b is selected, | | | | | generation of a timer B2 interrupt request which has passed through the | | | | | circuit to set the interrupt generating frequency in the three-phase motor | | | | | control timers after the ADST bit is set to 1 by a program. | | | | | • When 10b is selected, | | | | | generation of a timer A0 interrupt request after the ADST bit is set to 1 | | | | Stop conditions | The ADST bit is set to 0 (A/D conversion stopped) by a program | | | | Interrupt request | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode | | | | generation timing | disabled), no interrupt request is generated. | | | | | When the DUS bit is 1 (DMAC operating mode enabled), each time A/D | | | | | conversion is completed, an interrupt request is generated | | | | Analog voltage input | Selected from a group of 2 pins (ANi_0 and ANi_1), 4 pins (ANi_0 to ANi_3), 6 | | | | pins | pins (ANi_0 to ANi_5), or 8 pins (ANi_0 to ANi_7) (i = no value, 0, 2) (1) | | | | Reading A/D converted | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode | | | | result | disabled) | | | | | Read the AD0j register corresponding to the selected pin (j = 0 to 7) | | | | | When the DUS bit is 1 (DMAC operating mode enabled) | | | | | When the converted result is transferred by DMAC | | | | | Configure the DMAC (refer to 12. "DMAC"). | | | | | Then the A/D converted result is stored in the AD00 register after the | | | | | conversion is completed. The DMAC transfers the converted result from the | | | | | AD00 register to a given memory space. | | | | | Do not read the AD00 register by a program | | | | | When the converted result is transferred by a program | | | | | Read the AD00 register after the IR bit in the AD0IC register becomes 1. Set | | | | | the IR bit back to 0 | | | ### Note: 1. When bits APS1 and APS0 are set to 00b (AN\_0 to AN4, ANEX0, and ANEX1 selected), set bits SCAN1 and SCAN0 to 00b (ANi\_0 and ANi\_1 selected) or 01b (ANi\_0 to ANi\_3 selected). If bits SCAN1 and SCAN0 are set to 10b (ANi\_0 to ANi\_5 selected), the converted result of the AN\_5 signal is undefined. # 18.1.5 Repeat Sweep Mode 1 In repeat sweep mode 1, the analog voltage applied to eight selected pins including one to four prioritized pins is repeatedly converted into a digital code. Table 18.6 lists specifications of repeat sweep mode 1. Table 18.6 Repeat Sweep Mode 1 Specifications | Item | Specification | | | |-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | The analog voltage applied to eight selected pins including one to four prioritized pins is repeatedly converted into a digital code. The prioritized pins are selected | | | | | by setting bits SCAN1 and SCAN0 in the AD0CON1 register and bits APS1 and APS0 in the AD0CON2 register | | | | | For example, when ANO_0 is selected, the A/D conversion is performed in the | | | | | following order: AN0_0→AN0_1→AN0_0→AN0_2→AN0_0→AN0_3••• | | | | Start conditions | When the TRG bit in the AD0CON0 register is 0 (software trigger) | | | | | The ADST bit in the AD0CON0 register is set to 1 (A/D conversion started) by a program. | | | | | When the TRG bit is 1 (external trigger or hardware trigger) | | | | | Set bits TRG1 and TRG0 in the AD0CON2 register to select external trigger | | | | | request source. | | | | | • When 00b is selected, | | | | | an input signal at the ADTRG pin switches from high to low after the ADST bit | | | | | is set to 1 by a program. Retrigger is invalid. | | | | | • When 01b is selected, | | | | | generation of a timer B2 interrupt request which has passed through the circuit | | | | | to set the interrupt generating frequency in the three-phase motor control | | | | | timers after the ADST bit is set to 1 by a program. | | | | | • When 10b is selected, | | | | Otana and ditions | generation of a timer A0 interrupt request after the ADST bit is set to 1 | | | | Stop conditions | The ADST bit is set to 0 (A/D conversion stopped) by a program | | | | Interrupt request | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode | | | | generation timing | disabled), no interrupt request is generated. When the DUS bit is 1 (DMAC operating mode enabled), each time A/D | | | | | conversion is completed, an interrupt request is generated | | | | Analog voltage input | 8 (ANi 0 to ANi 7) (i = 0, 2) (1) | | | | pins | 0 (AIVI_0 to AIVI_1) (1 = 0, 2) (7 | | | | Prioritized pin(s) | Selected from a group of 1 pin (ANi_0), 2 pins (ANi_0 and ANi_1), 3 pins (ANi_0 | | | | | to ANi_2), or 4 pins (ANi_0 to ANi_3) | | | | Reading A/D converted | When the DUS bit in the AD0CON3 register is 0 (DMAC operating mode | | | | result | disabled) | | | | | Read the AD0j register corresponding to the selected pin (j = 0 to 7) | | | | | When the DUS bit is 1 (DMAC operating mode enabled) | | | | | When the converted result is transferred by DMAC | | | | | Configure the DMAC (refer to 12. "DMAC"). | | | | | Then the A/D converted result is stored in the AD00 register after the | | | | | conversion is completed. The DMAC transfers the converted result from the | | | | | AD00 register to a given memory space. | | | | | Do not read the AD00 register by a program | | | | | When the converted result is transferred by a program | | | | | Read the AD00 register after the IR bit in the AD0IC register becomes 1. Set | | | | | the IR bit back to 0 | | | ### Note: 1. The converted result of signals AN\_5 to AN\_7 is undefined. ### 18.2 Functions #### 18.2.1 Resolution Selection Resolution is selected by setting the BITS bit in the AD0CON1 register. When the BITS bit is set to 1 (10-bit precision), the A/D converted result is stored into bits 9 to 0 in the AD0i register (i = 0 to 7). When the BITS bit is set to 0 (8-bit precision), the result is stored into bits 7 to 0 in the AD0i register. ### 18.2.2 Sample and Hold Function This function improves the conversion rate per pin to 28 $\phi$ AD cycles at 8-bit resolution and 33 $\phi$ AD cycles for 10-bit resolution. This function is available in all operating modes and is enabled by setting the SMP bit in the AD0CON2 register to 1 (with sample and hold function). Start A/D conversion after setting the SMP bit. ## 18.2.3 Trigger Selection A trigger to start A/D conversion is specified by the combination of TRG bit in the AD0CON0 register and bits TRG1 and TRG0 in the AD0CON2 register. Table 18.7 lists the settings of the trigger selection. Table 18.7 Trigger Selection Settings | Bit and Setting | | Trigger | | |---------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | AD0CON0 register | AD0CON2 register | mgger | | | TRG = 0 | _ | Software trigger The ADST bit in the AD0CON0 register is set to 1 | | | TRG = 1 <sup>(1, 2)</sup> | TRG1 = 0, TRG0 = 0 | External trigger Falling edge of a signal applied to the ADTRG pin | | | | TRG1 = 0, TRG0 = 1 | Hardware trigger Generation of a timer B2 interrupt request which has passed through the circuit to set the interrupt generating frequency in the three-phase motor control timers | | | | TRG1 = 1, TRG0 = 0 | Hardware trigger<br>Generation of a timer A0 interrupt request | | #### Notes: - 1. A/D conversion starts when a trigger is generated while the ADST bit is 1 (A/D conversion started). - 2. When an external trigger or a hardware trigger is generated during A/D conversion, the A/D converter aborts the operation in progress. Then, it restarts the operation. # 18.2.4 DMAC Operating Mode DMAC operating mode can be used in all operating modes. When the DUS bit in the AD0CON3 register is set to 1 (DMAC operating mode enabled), all A/D converted results are stored in the AD00 register. The DMAC transfers the data from the AD00 register to a given memory space every time A/D conversion is completed at a pin. 8-bit DMA transfer should be selected for 8-bit resolution. For 10-bit resolution, 16-bit DMA transfer should be selected. Refer to 12. "DMAC" for details. # 18.2.5 Function-extended Analog Input Pins In one-shot mode and repeat mode, pins ANEX0 and ANEX1 can be used as analog input pins by setting bits OPA1 and OPA0 in the AD0CON1 register (refer to Table 18.8). The A/D converted results of pins ANEX0 and ANEX1 are stored into registers AD00 and AD01, respectively. However, when the DUS bit in the AD0CON3 register is set to 1 (DMAC operating mode enabled), all results are stored into the AD00 register. To use function-extended analog input pins, bits APS1 and APS0 in the AD0CON2 register should be set to 00b (AN0 to AN7, ANEX0, ANEX1 function as analog input ports). | AD0CON | 1 Register | ANEX0 | ANEX1 | | |--------|------------|------------------------------------------------------------|----------|--| | OPA1 | OPA0 | ANEXU | | | | 0 | 0 | Not used | Not used | | | 0 | 1 | Analog input | Not used | | | 1 | 0 | Not used Analog input | | | | 1 | 1 | Output to an external op-amp Input from an external op-amp | | | Table 18.8 Function-extended Analog Input Pin Settings ## 18.2.6 External Operating Amplifier (Op-Amp) Connection Mode In external op-amp connection mode, multiple analog inputs can be amplified by one external op-amp using function-extended analog input pins ANEX0 and ANEX1. When bits OPA1 and OPA0 in the AD0CON1 register are 11b (external op-amp connected), the voltage applied to pins AN0 to AN7 is output from the ANEX0 pin. This output signal should be amplified by an external op-amp and applied to the ANEX1 pin. The analog voltage applied to the ANEX1 pin is converted into a digital code. The converted result is stored in the corresponding AD0i register (i = 0 to 7). The conversion rate varies with the response of the external op-amp. Note that the ANEX0 pin should not be connected to the ANEX1 pin directly. To use external op-amp connection mode, set bits APS1 and APS0 in the AD0CON2 register to 00b. Figure 18.8 shows an example of an external op-amp connection. Figure 18.8 External Op-Amp Connection ### 18.2.7 Self Test/Open-circuit Detection Assist This function enables the MCU to detect open-circuit in analog input pins. It also enables it to perform a self test. Figure 18.9 shows a block diagram of open-circuit detection assist circuit. Figure 18.9 Open-circuit Detection Assist Circuit To detect open-circuit, the ASTSEL bit in the AD0CON5 register should be set to 0 (open-circuit detection assist). Va in Figure 18.9 above is a voltage with a value between AVCC and the A/D applied voltage in the following bit settings: the ASTEN bit is 1 (assist enabled), the ASTSEL bit is 0, and the ASTMTD bit is 0 (pull-up). If the A/D input pin is open, Va is almost equal to AVCC. When the ASTEN bit is 1, the ASTSEL bit is 0, and the ASTMTD bit is 1 (pull-down), Va is between AVSS and the A/D applied voltage. If the A/D input pin is open, Va is almost AVSS. That is, the A/D input pin is considered open if the result value of A/D conversion is almost the maximum/minimum voltage. To enable the self test function, the ASTSEL bit in the AD0CON5 register should be set to 1 (self test assist). Va is almost equal to AVCC in the bit settings as the ASTEN bit is 1, the ASTSEL bit is 1, and the ASTMTD bit is 0. When the ASTEN bit is 1, the ASTSEL bit is 1, and the ASTMTD bit is 1, Va is almost AVSS. That is, if the result value of A/D conversion is almost the maximum/minimum voltage in each bit setting, the A/D converter is considered to be functioning normally. # 18.2.8 Power Saving When the A/D converter is not in use, power consumption can be reduced by setting the VCUT bit in the AD0CON1 to 0 (VREF disconnected). With this bit setting, the reference voltage input pin (VREF) can be disconnected from the resistor ladder, which enables the power supply from the VREF to the resistor ladder to stop. To use the A/D converter, set the VCUT bit to 1 (VREF connected) and wait at least 1 µs before setting the ADST bit in the AD0CON0 register to 1 (A/D conversion started). Bits ADST and VCUT should not be set to 1 simultaneously. The VCUT bit should not be set to 0 during A/D conversion. The VCUT bit does not affect VREF performance of the D/A converter (refer to Figure 18.10). Figure 18.10 Power Supply by VCUT Bit # 18.2.9 Output Impedance of Sensor Equivalent Circuit under A/D Conversion Figure 18.11 shows an analog input pin and external sensor equivalent circuit. To perform A/D conversion correctly, the internal capacitor (C) charging, shown in Figure 18.11, should be completed within the specified period. This period, called the sampling time, is $2 \phi AD$ cycles for conversion without the sample and hold function and $3 \phi AD$ cycles for conversion with this function. Figure 18.11 Analog Input Pin and External Sensor Equivalent Circuitry The voltage between pins (VC) is expressed as follows: $$VC = VIN \left\{ 1 - e^{-\frac{t}{C(R0 + R)}} \right\}$$ When t = T and the precision (error) is x or less, $$VC = VIN - \frac{x}{y}VIN = VIN\left(1 - \frac{x}{y}\right)$$ Thus, output impedance of the sensor equivalent circuit (R0) is determined by the following formulas: $$e^{\frac{T}{C(R0+R)}} = \frac{x}{y}$$ $$-\frac{T}{C(R0+R)} = \ln \frac{x}{y}$$ $$R0 = -\frac{T}{C\ln \frac{x}{y}} - R$$ where: T[s] = Sampling time $R0[\Omega]$ = Output impedance of the sensor equivalent circuit VC = Potential difference between edges of capacitor C $R[\Omega]$ = Internal resistance of the MCU x[LSB] = Precision (error) of the A/D converter y[step] = Resolution of the A/D converter (1024 steps at 10-bit mode, 256 steps at 8-bit mode) When $\phi AD = 10$ MHz, the A/D conversion mode is 10-bit resolution with the sample and hold function, the output impedance (R0) with the precision (error) of 0.1 LSB or less is determined by the following formula: Using T = 0.3 $\mu$ s, R = 2.0 $k\Omega$ (reference value), C = 6.5 pF (reference value), x = 0.1, y = 1024, $$R0 = -\frac{0.3 \times 10^{-6}}{6.5 \times 10^{-12} \times 10^{-12}} - 2.0 \times 10^{3}$$ $$= 2998$$ Thus, the allowable output impedance of the sensor equivalent circuit (R0), making the precision (error) of 0.1 LSB or less, should be less than 3 k $\Omega$ . The actual error, however, is the value of absolute precision added to the 0.1 LSB mentioned above. ### 18.3 Notes on A/D Converter # 18.3.1 Notes on Designing Boards • Three capacitors should be placed between the AVSS pin and pins such as AVCC, VREF, and analog inputs (AN\_0 to AN\_4, AN0\_0 to AN0\_7, and AN2\_0 to AN2\_7) to avoid erroneous operations caused by noise or latchup, and to reduce conversion errors. Figure 18.12 shows an example of pin configuration for A/D converter. Figure 18.12 Pin Configuration for the A/D Converter • When AVCC = VREF = VCC, A/D input voltage for pins AN\_0 to AN\_4, AN0\_0 to AN0\_7, AN2\_0 to AN2\_7, ANEX0, and ANEX1 should be VCC or lower. # 18.3.2 Notes on Programming • The following registers should be written while A/D conversion is stopped. That is, before a trigger occurs: AD0CON0 (except the ADST bit), AD0CON1, AD0CON2, AD0CON3, and AD0CON5. - When the VCUT bit in the AD0CON1 register is changed from 0 (VREF connected) to 1 (VREF disconnected), wait for at least 1 µs before starting A/D conversion. When not performing A/D conversion, set the VCUT bit to 0 to reduce power consumption. - Set the port direction bit for the pin to be used as an analog input pin to 0 (input). Set the ASEL bit of the corresponding port function select register to 1 (port is used as A/D input). - When the TRG bit in the AD0CON0 register is 1 (external trigger or hardware trigger), set the corresponding port direction bit (PD9\_7 bit) for the ADTRG pin to 0 (input). - The $\phi$ AD frequency should be 16 MHz or lower when VCC is 4.2 to 5.5 V, and 10 MHz or lower when VCC is 3.0 to 4.2 V. It should be 1 MHz or higher when the sample and hold function is enabled. If not, it should be 250 kHz or higher. - When A/D operating mode (bits MD1 and MD0 in the AD0CON0 register or the MD2 bit in the AD0CON1 register) has been changed, reselect analog input pins by setting bits CH2 to CH0 in the AD0CON0 register or bits SCAN1 and SCAN0 in the AD0CON1 register. - If the AD0i register is read when the A/D converted result is stored to the register, the stored value may have an error (i = 0 to 7). Read the AD0i register after A/D conversion is completed. In one-shot mode or single sweep mode, read the AD0i register after the IR bit in the AD0IC register becomes 1 (interrupt requested). In repeat mode, repeat sweep mode 0, or repeat sweep mode 1, an interrupt request can be generated each time A/D conversion is completed when the DUS bit in the AD0CON3 register is 1 (DMAC operating mode enabled). Similar to the other modes above, read the AD00 register after the IR bit in the AD0IC register becomes 1 (interrupt requested). - When an A/D conversion is halted by setting the ADST bit in the AD0CON0 register to 0, the converted result is undefined. In addition, the unconverted AD0i register may also become undefined. Consequently, the AD0i register should not be used just after A/D conversion is halted. - External triggers cannot be used in DMAC operating mode. When the DMAC is configured to transfer converted results, do not read the AD00 register by a program. - While in single sweep mode, if A/D conversion is halted by setting the ADST bit in the AD0CON0 register to 0 (A/D conversion is stopped), an interrupt request may be generated even though the sweep is not completed. To halt A/D conversion, disable interrupts before setting the ADST bit to 0. R32C/161 Group 19. CRC Calculator ### 19. CRC Calculator The Cyclic Redundancy Check (CRC) calculator is used for detecting errors in data blocks. A generator polynomial of CRC-CCITT ( $X^{16} + X^{12} + X^5 + 1$ ) generates the CRC. The CRC is a 16-bit code generated for a given set of blocks of 8-bit data. It is set in the CRCD register every time 1-byte data is written to the CRCIN register after a default value is set to the CRCD register. Figure 19.1 shows a block diagram of the CRC calculator. Figures 19.2 and 19.3 show registers associated with the CRC. Figure 19.4 shows an example of the CRC calculation. Figure 19.1 CRC Calculator Block Diagram Figure 19.2 CRCD Register R32C/161 Group 19. CRC Calculator Figure 19.3 CRCIN Register R32C/161 Group 19. CRC Calculator ## CRC Calculation and Setting Procedure to Generate CRC for 80C4h CRC Calculation for R32C CRC: a remainder of the division as follows: reversed-bit-position value in the CRCIN register generator polynominal Generator Polynomial: X<sup>16</sup> + X<sup>12</sup> + X<sup>5</sup> + 1(1 0001 0000 0010 0001b) #### Setting Procedure (1) Reverse the bit position of 80C4h in 1-byte units by a program 80h to 01h, C4h to 23h (2) Set 0000h (default value in reversed bit position) in CRCD register (3) Set 01h (80h in reversed bit position) in CRCIN register (4) Set 23h (C4h in reversed bit position) in CRCIN register #### Details of the CRC Calculation As shown in (3) above, add 1000 0000 0000 0000 0000 0000 as 80h (1000 0000b) plus 16 digits to 0000 0000 0000 0000 0000 0000 b as the default value of the CRCD register, 0000h plus eight digits to perform the modulo-2 division. $0001\ 0001\ 1000\ 1001b\ (1189h)$ , the reversed-bit-position value of remainder 1001 0001 1000 1000b (9188h) can be read from the CRCD register. When continuing on to (4) above, add 1100 0100 0000 0000 0000 as C4h (1100 0100b) plus 16 digits to 1001 0001 1000 1000 0000 0000b as the remainder of (3) left in the CRCD register plus eight digits to perform the modulo-2 division. 0000 1010 0100 0001b (0A41h), the reversed-bit-position value of remainder 1000 0010 0101 0000b (8250h) can be read from the CRCD register. Figure 19.4 CRC Calculation ### 20. X-Y Conversion X-Y conversion rotates a 16 × 16-bit matrix data 90 degrees or reverses the bit position of 16-bit data. X-Y conversion is set using the XYC register shown in Figure 20.1. Data is written to the write-only XiR registers and converted data is read from the read-only YjR register (i = 0 to 15; j = 0 to 15). These registers are allocated to the same address. Figures 20.2 and 20.3 show registers XiR and YjR, respectively. A write/read access to registers XiR and YjR should be performed in 16-bit units from an even address. 8-bit access operation results are undefined. Figure 20.1 XYC Register Figure 20.2 Registers X0R to X15R Figure 20.3 Registers Y0R to Y15R # 20.1 Data Conversion When Reading Set the XYC0 bit in the XYC register to select a read mode for the YjR register. When the XYC0 bit is 0 (data rotation), bit j in the corresponding registers X0R to X15R is automatically read upon reading the YjR register (j = 0 to 15). More concretely, upon reading bit i (i = 0 to 15) in the Y0R register, the data of bit 0 in the XiR register is read. That is, the read data of bit 0 in the Y15R register means the data of bit 15 in the X0R register and the data of bit 15 in the Y0R register is identical to that of bit 0 in the X15R register. Figure 20.4 shows the conversion table when the XYC0 bit is 0 and Figure 20.5 shows an example of X-Y conversion. Figure 20.4 Conversion Table (XYC0 Bit is 0) Figure 20.5 X-Y Conversion When the XYC0 bit is set to 1 (no data rotation), the data of each bit in the YjR register is identical to that written in the XiR register. Figure 20.6 shows the conversion table when the XYC0 bit is set to 1. Figure 20.6 Conversion Table (XYC0 Bit is 1) ## 20.2 Data Conversion When Writing Set the XYC1 bit in the XYC register to select a write mode for the XiR register. When the XYC1 bit is set to 0 (no bit position reverse), the data is written in order. When it is set to 1 (bit position reverse), the data is written in reversed order. Figure 20.7 shows the conversion table when the XYC1 bit is set to 1. Figure 20.7 Conversion Table (XYC1 Bit is 1) # 21. Intelligent I/O The intelligent I/O is a multifunctional I/O port for time measurement and waveform generation. It contains a module "group 0" which has one free-running 16-bit base timer and eight 16-bit registers for time measurement or waveform generation. Table 21.1 lists the functions and channels of the intelligent I/O. Table 21.1 Intelligent I/O Functions and Channels | | Group 0 | | |-------------------------|-----------------------------------|------------| | Time measurement (1) | Digital filter | 8 channels | | | Prescaler | 2 channels | | | Gating | 2 channels | | | Digital debounce | 1 channel | | Waveform generation (1) | Single-phase waveform output mode | 8 channels | | | Inverted waveform output mode | 8 channels | | | SR waveform output mode | 8 channels | | | Phase shift waveform output mode | 8 channels | #### Note: 1. The time measurement and waveform generation functions share a pin. Each channel can be individually assigned for time measurement or waveform generation function. Figure 21.1 shows a block diagram of the intelligent I/O. Figure 21.1 Intelligent I/O Group 0 Block Diagram (j = 0 to 7) Figures 21.2 to 21.13 show registers associated with the intelligent I/O base timer, time measurement, and waveform generation. Figure 21.2 G0BT Register Figure 21.3 G0BCR0 Register - 1. The base timer is reset after two fBT0 clock cycles when the base timer value matches the G0PO0 register setting. When the RST1 bit is 1, the value of the G0POj register used for waveform generation should be smaller than that of the G0PO0 register (j = 1 to 7). - 2. The base timer is reset by an input of low signal to the external interrupt input pin selected for the UD0Z signal by the IFS2 register. - 3. In two-phase pulse signal processing mode, the base timer is not reset, even if the RST1 bit is 1, if the timer counter decrements after two clock cycles when the base timer value matches the G0PO0 register. Figure 21.4 G0BCR1 Register Figure 21.5 Registers G0TMCR0 to G0TMCR7 Figure 21.6 Registers G0TPR6 and G0TPR7 Figure 21.7 Registers G0TM0 to G0TM7 #### Notes: - 1. This bit setting is enabled only for even channels. In SR waveform output mode, the corresponding odd channel (the next channel after an even channel) setting is ignored. Waveforms are only output from even channels - The setting value is output by a write operation to the IVL bit when the FSCj bit in the G0FS register is 0 (select the waveform generation) and the IFEj bit in the G0FE register is 1 (enable the channel j function). - 3. This bit is available only in the GOPOCR0 register. Set bit 6 in registers GOPOCR1 to GOPOCR7 to 0. - 4. To set the BTRE bit to 1, set bits BCK1 and BCK0 in the G0BCR0 register to 01b (timer B0 interrupt) or 11b (f1) and bits UD1 and UD0 in the G0BCR1 register to 00b (increment mode). - 5. The output level inversion is the final step in the waveform generation process. When the INV bit is 1, high is output by setting the IVL bit to 0, and vice versa. Figure 21.8 Registers G0POCR0 to G0POCR7 Figure 21.9 Registers G0PO0 to G0PO7 Figure 21.10 G0SDR Register Figure 21.11 G0PSCR Register Figure 21.12 G0FS Register Figure 21.13 G0FE Register ## 21.1 Base Timer The base timer is a free-running counter that counts an internally generated count source. Table 21.2 lists specifications of the base timer. Figures 21.2 to 21.13 show registers associated with the base timer. Figure 21.14 shows a block diagram of the base timer. Figures 21.15, 21.16, and 21.17 show operation examples of the base timer in increment mode, increment/decrement mode, and two-phase pulse signal processing mode, respectively. Table 21.2 Base Timer Specifications | Item | Specification | | | |------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count source (fBT0) | f1 divided by 2(n+1), two-phase pulse input divided by 2(n+1) n: setting value using bits DIV4 to DIV0 in the G0BCR0 register n = 0 to 31; however no division when n = 31 Timer B0 interrupt divided by 2(m+1) m: setting value using bits DIV4 to DIV0 in the G0BCR0 register m = 0 to 30 | | | | Count operations | Increment Increment/decrement Two-phase pulse signal processing | | | | Count start conditions | The BTS bit in the G0BCR1 register is 1 (start counting) | | | | Count stop condition | The BTS bit in the G0BCR1 register is 0 (reset the base timer) | | | | Reset conditions | The base timer value matches the G0PO0 register setting An input of low signal into the external interrupt pin (INT0 or INT1) as follows: for group 0: selected using the IFS22 bit in the IFS2 register The overflow of bit 15 or bit 9 in the base timer | | | | Reset value | 0000h | | | | Interrupt request | When the BT0R bit in the interrupt request register becomes 1 (interrupt requested) by the overflow of bit 9, 14, or 15 in the base timer (refer to Figure 10.12) | | | | Read from base timer | <ul> <li>The G0BT register indicates a counter value while the base timer is running</li> <li>The G0BT register is undefined while the base timer is being reset</li> </ul> | | | | Write to base timer | When a value is written while the base timer is running, the timer counter immediately starts counting from this value. No value can be written while the base timer is being reset | | | | Other functions | <ul> <li>Increment/decrement mode The base timer starts counting when the BTS bit is set to 1. When the base timer reaches FFFFh, it starts decrementing. When the RST1 bit in the G0BCR1 register is 1 (the base timer is reset by matching with the G0PO0 register), the timer counter starts decrementing two counts after the base timer value matches the G0PO0 register setting. When the timer counter reaches 0000h, it starts incrementing again (refer to Figure 21.16).</li> <li>Two-phase pulse signal processing mode Two-phase pulse signals at pins UD0A and UD0B are counted (refer to Figure 21.17).</li> </ul> | | | | | UD0B The timer counter increments on all edges The timer counter decrements on all edges | | | Figure 21.14 Base Timer Block Diagram Table 21.3 Base Timer Associated Register Settings (Common Settings for Time Measurement, Waveform Generation, and Serial Interface) | Register | Bits | Function | | |----------|---------------|----------------------------------------------------------------|--| | G0BCR0 | BCK1 and BCK0 | and BCK0 Select a count source | | | | DIV4 to DIV0 | Select a count source divide ratio | | | | IT | Select a base timer interrupt source | | | G0BCR1 | RST2 and RST1 | Select a timing for base timer reset | | | | BTS | Use this bit when each base timer individually starts counting | | | | UD1 and UD0 | Select a count mode | | | G0POCR0 | BTRE | Select a source for base timer reset | | | G0BT | _ | Read or write the base timer value | | The following register settings are required to set the RST1 bit to 1 (the base timer is reset by matching with the G0PO0 register). | G0POCR0 | MOD2 to MOD0 | Set to 000b (single-phase waveform output mode) | |---------|--------------|---------------------------------------------------| | G0PO0 | _ | Set the reset cycle | | G0FS | FSC0 | Set the bit to 0 (select the waveform generation) | | G0FE | IFE0 | Set the bit to 1 (channel operation starts) | Figure 21.15 Base Timer Increment Mode Figure 21.16 Base Timer Increment/Decrement Figure 21.17 Base Timer Two-phase Pulse Signal Processing Mode ## 21.2 Time Measurement Every time an external trigger is input, the base timer value is stored into the G0TMj register (j = 0 to 7). Table 21.4 lists specifications of the time measurement and Table 21.5 lists its register settings. Figures 21.18 and 21.19 show operation examples of the time measurement and Figure 21.20 shows operation examples with the prescaler or gate function. Table 21.4 Time Measurement Specifications (j = 0 to 7) | Item | Specification | |----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Time measurement channels | Group 0: Channels 0 to 7 | | Trigger input polarity | Rising edge, falling edge, or both edges of the IIO0_j pin | | Time measurement start condition | The IFEj bit in the G0FE register is 1 (enable the channel j function) while the FSCj bit in the G0FS register is 1 (select the time measurement) | | Time measurement stop condition | The IFEj bit is 0 (disable the channel j function) | | Time measurement timing | <ul> <li>Without the prescaler: every time a trigger is input</li> <li>With the prescaler for channels 6 and 7: every [G0TPRk register value + 1] times a trigger is input (k = 6, 7)</li> </ul> | | Interrupt request | When the TM0jR bit in the interrupt request register becomes 1 (interrupt requested) (refer to Figure 10.12) | | IIO0_j input pin function | Trigger input | | Other functions | <ul> <li>Digital filter The digital filter determines a trigger input level every f1 or fBT0 cycle and passes the signals holding the same level during three sequential cycles</li> <li>Prescaler for channels 6 and 7 Time measurement is executed every [G0TPRk register value + 1] times a trigger is input</li> <li>Gating for channels 6 and 7 This function disables any trigger input to be accepted after the time measurement by the first trigger input. However, the trigger input can be accepted again if any of following conditions are met while the GOC bit in the G0TMCRk register is 1 (the gating is cleared when the base timer matches the G0POp register) (p = 4, 5; p = 4 when k = 6; p = 5 when k = 7):</li> <li>The base timer value matches the G0POp register setting</li> <li>The GSC bit in the G0TMCRk register is 1</li> </ul> | Table 21.5 Time Measurement Associated Register Settings (j = 0 to 7; k = 6, 7) | Register | Bits | Function | |----------|---------------|--------------------------------------------------| | G0TMCRj | CTS1 and CTS0 | Select a time measurement trigger | | | DF1 and DF0 | Select a digital filter | | | GT, GOC, GSC | Select if the gating is used | | | PR | Select if the prescaler is used | | G0TPRk | _ | Set the prescaler value | | G0FS | FSCj | Set the bit to 1 (select the time measurement) | | G0FE | IFEj | Set the bit to 1 (enable the channel j function) | Bit configurations and functions vary with channels. Registers associated with the time measurement should be set after setting the base timer-associated registers. Figure 21.18 Time Measurement Operation (1/2) (j = 0 to 7) Figure 21.19 Time Measurement Operation (2/2) (j = 0 to 7) Figure 21.20 Prescaler and Gate Operations (j = 6, 7; k = 4, 5) ## 21.3 Waveform Generation Waveforms are generated when the base timer value matches the G0POj register setting (j = 0 to 7). Waveform generation has the following four modes: - Single-phase waveform output mode - Inverted waveform output mode - Set/reset waveform output (SR waveform output) mode - Phase shift waveform output mode Table 21.6 lists registers associated with the waveform generation. Table 21.6 Waveform Generation Associated Register Settings (j = 0 to 7) | Register | Bits | Function | |----------|--------------|-------------------------------------------------------------| | G0POCRj | MOD2 to MOD0 | Select a waveform output mode | | | IVL | Select a default value | | | RLD | Select a timing to reload the value into the G0POj register | | | INV | Select if output level is inverted | | G0POj | | Set the timing to invert output waveform level | | G0FS | FSCj | Set the bit to 0 (select the waveform generation) | | G0FE | IFEj | Set the bit to 1 (enable the channel j function) | Bit configurations and functions vary with channels. Registers associated with the waveform generation should be set after setting the base timer-associated registers. # 21.3.1 Single-phase Waveform Output Mode The output level at the IIO0\_j pin becomes high when the base timer value matches the G0POj register (j = 0 to 7). It switches to low when the base timer reaches 0000h. If the IVL bit in the G0POCRj register is set to 1 (output high as default value), a high level output is provided when a waveform output starts. If the INV bit is set to 1 (invert the output level), a waveform with an inverted level is output. Refer to Figure 21.21 for details on single-phase waveform mode operation. Table 21.7 lists specifications of single-phase waveform output mode. Table 21.7 Single-phase Waveform Output Mode Specifications | Item | Specification | | | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--| | Output waveform (1) | • Free-running operation are 00b) | (when bits RST2 and RST1 in the G0BCR1 register | | | | Cycle: | 65536<br>fBT0 | | | | Low level width: | $\frac{m}{fBT0}$ | | | | High level width: | $\frac{65536 - m}{fBT0}$ | | | | • The base timer is reset | ng value (j = 0 to 7), 0000h to FFFFh by matching the base timer value with the G0PO0 bits RST2 and RST1 are 01b) | | | | Cycle: | $\frac{n+2}{fBT0}$ | | | | Low level width: | $\frac{m}{fBT0}$ | | | | High level width: | $\frac{n+2-m}{fBT0}$ | | | | | ng value (j = 1 to 7), 0000h to FFFFh<br>ng value, 0001h to FFFDh | | | | If $m \ge n + 2$ , the output | level is fixed to low | | | Waveform output start condition (2) | The IFEj bit in the G0FE r | register is 1 (enable the channel j function) (j = 0 to 7) | | | Waveform output stop condition | The IFEj bit is 0 (disable | the channel j function) | | | Interrupt request | When the PO0jR bit in the intelligent I/O interrupt request register becomes 1 (interrupt requested) by matching the base timer value with the G0POj register setting (refer to Figure 10.12) | | | | IIO0_j output pin function | Pulse signal output | | | | Other functions | Output level inversion | es the starting waveform output level e waveform output level and outputs the inverted | | | | signal from the IIO0_j p | • | | #### Notes: - 1. When the INV bit in the G0POCRj register is 1 (invert the output level), the high and low widths are inverted. - 2. To use channels shared by time measurement and waveform generation, set the FSCj bit in the G0FS register to 0 (select the waveform generation). j = 0 to 7 m: G0POj register setting value (0000h to FFFFh) PO0jR: Bits in registers IIO0IR to IIO11IR Notes: - 1. Output waveform when the INV bit in the G0POCRj register is 0 (do not invert the output level) and the IVL bit is 0 (output low as default value). - 2. Output waveform when the INV bit is 0 (do not invert the output level) and the IVL bit is 1 (output high as default value). This figure applies under the following condition: - Bits UD1 and UD0 in the G0BCR1 register are 00b (increment mode) - (B) The base timer is reset by matching the base timer value with the G0PO0 register setting (bits RST2 and RST1 in the G0BCR register are 01b) j = 1 to 7 m: G0POj register setting value (0000h to FFFFh) n: G0PO0 register setting value (0001h to FFFDh) PO0jR: Bits in registers IIO0IR to IIO11IR This figure applies under the following conditions: - The IVL bit in the G0POCRj register is 0 (output low as default value) and the INV bit is 0 (do not invert the output level) - Bits UD1 and UD0 in the G0BCR1 register are 00b (increment mode) - m < n + 2 Figure 21.21 Single-phase Waveform Output Mode Operation # 21.3.2 Inverted Waveform Output Mode The output level at the $IIO0_j$ pin is inverted every time the base timer value matches the G0POj register setting (j = 0 to 7). Table 21.8 lists specifications of the inverted waveform output mode. Figure 21.22 shows an example of the inverted waveform output mode operation. **Table 21.8** Inverted Waveform Output Mode Specifications | Item | Specification | | | |------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Output waveform | <ul> <li>Free-running operation (when bits RST2 and RST1 in the G0BCR1 register<br/>are 00b)</li> </ul> | | | | | Cycle: $\frac{65536 \times 2}{fBT0}$ | | | | | High or low level width: $\frac{65536}{fBT0}$ | | | | | <ul> <li>m: G0POj register setting value (j = 0 to 7), 0000h to FFFFh</li> <li>The base timer is reset by matching the base timer value with the G0PO0 register setting (when bits RST2 and RST1 are 01b)</li> </ul> | | | | | Cycle: $\frac{2(n+2)}{fBT0}$ | | | | | High or low level width: $\frac{n+2}{fBT0}$ | | | | | n: G0PO0 register setting value, 0001h to FFFDh | | | | | G0POj register setting value (j = 1 to 7), 0000h to FFFFh | | | | | If the G0POj register setting $\geq n+2$ , the output level is not inverted | | | | Waveform output start condition <sup>(1)</sup> | The IFEj bit in the G0FE register is 1 (enable the channel j function) (j = 0 to 7) | | | | Waveform output stop condition | The IFEj bit is 0 (disable the channel j function) | | | | Interrupt request | When the PO0jR bit in the intelligent I/O interrupt request register becomes 1 (interrupt requested) by matching the base timer value with the G0POj register setting (refer to Figure 10.12) | | | | IIO0_j output pin function | Pulse signal output | | | | Other functions | Default value setting This function determines the starting waveform output level Output level inversion This function inverte the waveform output level and outputs the inverted. | | | | | This function inverts the waveform output level and outputs the inverted signal from the IIO0_j pin | | | ### Note: 1. To use channels shared by time measurement and waveform generation, set the FSCj bit in the G0FS register to 0 (select the waveform generation). j = 0 to 7 m: G0POj register setting value (0000h to FFFFh) PO0jR: Bits in registers IIO0IR to IIO11IR #### Notes: - 1. Output waveform when the INV bit in the G0POCRj register is 0 (do not invert the output level) and the IVL bit is 0 (output low as default value). - 2. Output waveform when the INV bit is 0 (do not invert the output level) and the IVL bit is 1 (output high as default value). This figure applies under the following condition: - Bits UD1 and UD0 in the G0BCR1 register are 00b (increment mode) - $\textbf{(B)} \ \ \text{The base timer is reset by matching the base timer value with the G0PO0 register setting}$ (bits RST2 and RST1 are 01b) j = 1 to 7 m: G0POj register setting value (0000h to FFFFh) n: G0PO0 register setting value (0001h to FFFDh) PO0jR: Bits in registers IIO0IR to IIO11IR This figure applies under the following conditions: - The IVL bit in the G0POCRj register is 0 (output low as default value) and the INV bit is 0 (do not invert the output level) - Bits UD1 and UD0 in the G0BCR1 register are 00b (increment mode) - m < n + 2 Figure 21.22 Inverted Waveform Output Mode Operation # 21.3.3 Set/Reset Waveform Output Mode (SR Waveform Output Mode) The output level at the IIOO\_j pin becomes high when the base timer value matches the G0POj register setting (j = 0, 2, 4, 6). It becomes low when the base timer value matches the G0POk register setting or the base timer reaches 0000h (k = j + 1). When the IVL bit in the G0POCRj register is set to 1 (output high as default value), a high output level is provided when a waveform output starts (j = 0 to 7). When the INV bit is set to 1 (invert the output level), a waveform with inverted level is output. Refer to Figure 21.23 for details on SR waveform mode operation. Tables 21.9 and 21.10 list specifications of SR waveform output mode. Table 21.9 SR Waveform Output Mode Specifications (1/2) | Item | | Specification | | |--------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------|--| | Output waveform <sup>(1)</sup> | are 00b) | on (when bits RST2 and RST1 in the G0BCR1 register | | | | (A) $m < n$ | | | | | High level width: | $\frac{n-m}{fBT0}$ | | | | Low level width: | $\frac{m}{fBT0}$ (See Note 2) + $\frac{65536 - n}{fBT0}$ (See Note 3) | | | | (B) $m \ge n$ | | | | | High level width: | $\frac{65536 - m}{fBT0}$ | | | | Low level width: | $\frac{m}{fBT0}$ | | | | | etting value (j = 0, 2, 4, 6), 0000h to FFFFh<br>etting value (k = j + 1), 0000h to FFFFh | | | | | set by matching with the G0PO0 register (when bits | | | | RST2 and RST1 are | 01b) <sup>(4)</sup> | | | | (A) $m < n < p + 2$ | | | | | High level width: | $\frac{n+m}{fBT0}$ | | | | Low width: | $\frac{m}{fBT0}$ (See Note 2) + $\frac{p+2-n}{fBT0}$ (See Note 3) | | | | (B) $m$ | | | | | High level width: | $\frac{p+2-m}{fBT0}$ | | | | Low level width: | $\frac{m}{fBT0}$ | | | | (C) $m \ge p + 2$ , output | | | | | p: G0PO0 register setting value, 0001h to FFFDh | | | | | | etting value (j = 2, 4, 6), 0000h to FFFFh<br>etting value (k = j + 1), 0000h to FFFFh | | ### Notes: - 1. When the INV bit in the G0POCRj register is 1 (invert the output level), the high and low widths are inverted. - 2. Output period from a base timer reset until when the output level becomes high. - 3. Output period from when the output level becomes low until the next base timer reset. - 4. When the G0PO0 register resets the base timer, channel 0 and channel 1 SR waveform generation functions are not available. Table 21.10 SR Waveform Output Mode Specifications (2/2) | Item | Specification | |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Waveform output start | The IFEq bit in the G0FE register is 1 (enable the channel q function) (q = 0 to | | condition (1) | 7) | | Waveform output stop condition | The IFEq bit is 0 (disable the channel q function) | | Interrupt request | When the PO0jR bit in the intelligent I/O interrupt request register becomes 1 (interrupt requested) by matching the base timer value with the G0POj register setting. When the PO0kR bit becomes 1 (interrupt requested) by matching the base timer value with the G0POk register setting (refer to Figure 10.12) | | IIO0_j output pin function | | | Other functions | Default value setting This function determines the starting waveform output level Output level inversion This function inverts the waveform output level and outputs the inverted signal from the IIOO_j pin | ## Note: 1. To use channels shared by time measurement and waveform generation, set the FSCj bit in the G0FS register to 0 (select the waveform generation). Figure 21.23 SR Waveform Output Mode Operation ## 21.3.4 Phase Shift Waveform Output Mode PWM output is phase-shifted at every channel in this mode. This mode enables functions that help to reduce switching noise and instantaneous power consumption. The following bit settings are necessary to enable this mode; set bits MOD2 to MOD0 in the G0POCRj register to 000b (single-phase waveform output mode), the IVL bit to 0 (output low as default value), the BTRE bit to 1 (reset the base timer when bit 9 overflows), the INV bit to 1 (invert the output level), and the IT bit in the G0BCR0 register to 0 (interrupt occurs when bit 15 or bit 9 overflows) (j = 0 to 7). When the phase shift waveform output mode is disabled, the output level at the IIO0\_j pin becomes low if the base timer matches the G0POj register, and becomes high when the base timer reaches 0000h (refer to (A) in Figure 21.24). When this mode is enabled, the phase shifter controls the timing of the output level to be high. The phase shift clock to be input to the phase shifter is the count source for the base timer fBT0 divided by m + 1. Every time the phase shift clock is input, each output level of the IIO0\_j pin starting from the IIO0\_0 sequentially becomes high (refer to (B) in Figure 21.24). The base timer overflow interrupt signal BT0R controls reloading of the divided-by-m + 1 divider and the reset of the phase shifter. Figure 21.25 shows some more examples of output waveforms using different settings. Note that if all channels are set to phase shift waveform output mode and the phase shift clock frequency is set to the lowest, the phase shift clock for channel 7 is not generated. Consequently, the output level at the IIO0 7 pin is held low. When phase shift output mode is enabled, the output level of a pin cannot be fixed to low. To hold the level low, the corresponding pin should be switched to the port by the output function select register. This figure applies under the following conditions: - The PSME bit in the G0PSCR register is 0 (phase shift waveform output mode is disabled) - Bits MOD2 to MOD0 in the G0POCRj register are 000b (single-phase waveform output mode), the IVL bit is 0 (output low as default value), and the INV bit is 1 (invert the output level) (j = 0 to 4) - Bits RST2 and RST1 in the G0BCR1 register are 00b (base timer is not reset) and bits UD1 and UD0 are 00b (increment mode) ### (B) The phase shift waveform output mode is enabled This figure applies under the following conditions: - The PSME bit in the G0PSCR register is 1 (phase shift waveform output mode is enabled) and bits PSS1 and PSS0 are 00b (pins IIO0 0 to IIO0 4 are available) - Bits MOD2 to MOD0 in the G0POCRj register are 000b (single-phase waveform output mode), the IVL bit is 0 (output low as default value), the BTRE bit is 1 (reset the base timer when bit 9 overflows), and the INV bit is 1 (invert the output level) (j = 0 to 4) - The IT bit in the G0BCR0 register is 0 (interrupt occurs when bit 15 or bit 9 overflows) - Bits RST2 and RST1 in the G0BCR1 register are 00b (base timer is not reset) and bits UD1 and UD0 are 00b (increment mode) Figure 21.24 Phase Shift Waveform Output Mode (1/2) Figure 21.25 Phase Shift Waveform Output Mode (2/2) # 21.3.5 Digital Debounce Circuit The IIO0\_7 pin has a digital debounce function for noise reduction. This function helps to determine the signal level when the pulse becomes longer than the filter width set by a program after the signal is input on a rising or falling edge. This function does not affect any signals that share the IIO0\_7 pin. Figure 21.26 shows the registers IC07DDR. Figure 21.26 Registers IC07DDR The counter for the digital debounce at the IIOO\_7 pin decrements with a count source of f8. Every time the signal level at the pin changes, the setting value of the IC07DDR register is reloaded to resume counting. The counted value can be read from the IC07DDR register. The input signal to the IIO0\_7 pin is output from the digital debounce circuit on the first rising edge of f8 after the counter value becomes 00h. A value from 00h to FEh can be set to the IC07DDR register when using the digital debounce function. When FFh is set to this register, this function is disabled and the input signal is transmitted without being filtered. Figure 21.27 shows an example of digital debounce filtering. - (1) The IC07DDR register is FFh after a reset. That is, the filtering is disabled, and the input signal is output without being filtered. - (2) The counter is stopped if the input and output levels are the same when setting 03h to the IC07DDR register. - (3) When detecting the input and output levels being different, the counter reloads the setting value of the IC07DDR register and starts counting. - (4) When the input and output levels become the same during counting, the counter stops. The output level does not change when the pulse width of the input signal is too short for the counter to become 00h. - (5) When detecting the input and output levels being different again, the counter reloads the setting value of the ICO7DDR register and starts counting. - (6) The low signal is applied on the first rising edge of f8 after the counter reaches 00h. The output signal becomes low and the counter stops. - (7) When detecting the input and output levels being different again, the counter reloads the setting value of the IC07DDR register and starts counting. - (8) The high signal is applied on the first rising edge of f8 after the counter reaches 00h. The output signal becomes high and the counter stops. When the IC07DDR register is set to FFh, the counter value becomes FFh after 1.5 to 2.5 cycles of f1, and the counter stops. Simultaneously, the filtering is disabled, and the input signal is output without being filtered. Figure 21.27 Digital Debounce Filtering # 22. Serial Bus Interface The serial bus interface has one independent channel: SBI0. SBI0 has its own transmit/receive clock generator. SBI0 has the following modes: - Synchronous serial communication mode - 4-wire serial bus mode To select a mode, set the SSUMS bit in the SS0MR2 register. Note that each mode has its own bit names, bit symbols, and bit functions in some registers. # 22.1 Synchronous Serial Communication Mode and 4-wire Serial Bus Mode To switch between synchronous serial communication mode and 4-wire serial bus mode, set the SSUMS bit in the SS0MR2 register. Table 22.1 and Figure 22.1 show the specifications of synchronous serial communication mode and its block diagram, respectively. Table 22.2 and Figure 22.2 show the specifications and block diagram of 4-wire serial bus mode, respectively. Figures 22.3 to 22.11 show the associated registers. Table 22.1 Synchronous Serial Communication Mode Specifications | Item | Specification | | | |--------------------------|--------------------------------------------------------------------------------------------|--|--| | Data format | Character length: 8 bits (fixed length) | | | | Master/slave mode | Selectable | | | | I/O pins | SSCK0 (I/O): Clock I/O pin | | | | | SSI0 (input): Data input pin | | | | | SSO0 (output): Data output pin | | | | Transmit/receive clocks | When the MSS bit in the SS0CRH register is 0 (slave mode): | | | | | External clock (input at the SSCK0 pin) | | | | | When the MSS bit is 1 (master mode): | | | | | Internal clock (output from the SSCK0 pin) | | | | | $f_{(\mathrm{BCLK})}$ $f_{(\mathrm{BCLK})}$ : peripheral bus clock frequency | | | | | n: 4, 8, 16, 32, 64, 128, or 256 | | | | Transmit start | The TE bit in the SS0ER register is 1 (transmission enabled) | | | | conditions | • The TDRE bit in the SS0SR register is 0 (unsent data left in the SS0TDR | | | | | register) | | | | | The ORER bit in the SS0SR register is 0 (no overrun error) | | | | | Clock input at the SSCK0 pin (applicable only when the MSS bit in the | | | | | SS0CRH register is 0 (slave mode)) | | | | Receive start conditions | The RE bit in the SS0ER register is 1 (reception enabled) | | | | | The ORER bit in the SS0SR register is 0 (no overrun error) | | | | | • Read operation to the SS0RDR register (applicable only when the MSS bit in | | | | | the SS0CRH register is 1 (master mode)) | | | | | Clock input at the SSCK0 pin (applicable only when the MSS bit in the | | | | | SS0CRH register is 0 (slave mode)) | | | | Error detection | Overrun error | | | | | An overrun error occurs when the next serial data reception is completed | | | | | while the RDRF bit in the SS0SR register is 1 (received data left in the | | | | Intowers to account | SSORDR register) | | | | Interrupt request | Four interrupt request sources: transmit end, transmit data register empty, | | | | sources | receive data register full, and overrun error (1) | | | | Other functions | Bit order select Calcate black with an LCB first on MCB first. | | | | | Selectable either LSB first or MSB first | | | | | • SSCK0 clock polarity | | | | | Selectable either low or high for the SSCK0 pin when clock is stopped • SSCK0 clock phase | | | | | Combination of odd and even edges for changing and loading data | | | | | Combination of our and even edges for changing and loading data | | | ### Note: 1. Each channel has its own interrupt vector. Figure 22.1 Block Diagram of Synchronous Serial Communication Mode Table 22.2 4-wire Serial Bus Mode Specifications | Item | Specification | | | |--------------------------|----------------------------------------------------------------------------------------------|--|--| | Data format | Character length: 8 to 16 bits (variable length) | | | | Master/slave mode | Selectable | | | | I/O pins | SSCK0 (I/O): Clock I/O pin | | | | | SSI0 (I/O): Data I/O pin | | | | | SSO0 (I/O): Data I/O pin | | | | | SCS0 (I/O): Chip select I/O pin | | | | Transmit/receive clocks | When the MSS bit in the SS0CRH register is 0 (slave mode): | | | | | External clock (input at the SSCK0 pin) | | | | | When the MSS bit 1 (master mode): | | | | | Internal clock (output from the SSCK0 pin) | | | | | $f_{(\mathrm{BCLK})}$ $f_{(\mathrm{BCLK})}$ : peripheral bus clock frequency | | | | | n: 4, 8, 16, 32, 64, 128, or 256 | | | | Transmit start | The TE bit in the SS0ER register is 1 (transmission enabled) | | | | conditions | • The TDRE bit in the SS0SR register is 0 (unsent data left in the SS0TDR | | | | | register) | | | | | The ORER bit in the SS0SR register is 0 (no overrun error) | | | | | • Clock input at the SSCK0 pin while the SCS0 pin is low (applicable only when | | | | | the MSS bit in the SS0CRH register is 0 (slave mode)) | | | | Receive start conditions | The RE bit in the SS0ER register is 1 (reception enabled) | | | | | The ORER bit in the SS0SR register is 0 (no overrun error) | | | | | Read operation to the SS0RDR register while the TE bit in the SS0ER | | | | | register is 0 (transmission disabled) (applicable only when the MSS bit in the | | | | | SS0CRH register is 1 (master mode)) | | | | | Clock input at the SSCK0 pin (applicable only when the MSS bit in the | | | | | SS0CRH register is 0 (slave mode)) | | | | Error detection | Overrun error | | | | | An overrun error occurs when the next serial data is received while the RDRF | | | | | bit in the SS0SR register is 1 (received data left in the SS0RDR register) • Conflict error | | | | | A conflict error occurs in either of the following cases: | | | | | (1) An attempt to start serial communication while the SCS0 pin is low | | | | | (applicable when the MSS bit in the SS0CRH register is 1 (master | | | | | mode)) | | | | | (2) The SCSO pin becomes high during data transfer (applicable when | | | | | the MSS bit in the SS0CRH register 0 (slave mode)) | | | | Interrupt request | Five interrupt request sources: transmit end, transmit data register empty, | | | | sources | receive data register full, overrun error, and conflict error (1) | | | | Other functions | • Bit order select | | | | | Selectable either LSB first or MSB first | | | | | SSCK0 clock polarity | | | | | Selectable either low or high for the SSCK0 pin when clock is stopped | | | | | • SSCK0 clock phase | | | | | Combination of odd and even edges for changing and loading data | | | # Note: 1. Each channel has its own interrupt vector. Figure 22.2 Block Diagram of 4-wire Serial Bus Mode #### Notes: - 1. The clock rate selection is applicable only when the MSS bit is 1. - 2. To output the transmit/receive clock from the SSCK0 pin, set this bit to 1. - 3. This bit becomes 0 when the CE bit in the SS0SR register becomes 1 (conflict error occurred). - 4. This bit is disabled when the MSS bit is 0. Figure 22.3 SS0CRH Register 22. Serial Bus Interface R32C/161 Group Notes: - 1. Registers SS0CRH, SS0CRL, SS0MR (excluding bits BC3 to BC0 in 4-wire serial bus mode), SS0ER, SS0SR, SS0MR2, SS0TDR, and SS0RDR. - 2. To change the output pin level, the SOL bit should be set before or after transmitting data. Use the MOV instruction to simultaneously set the SOL bit to 0 or 1, and the SOLP bit to 0. - 3. This bit should not be set during data transmission. Figure 22.4 SS0CRL Register Figure 22.5 SS0MR Register in Synchronous Serial Communication Mode Figure 22.6 SS0MR Register in 4-wire Serial Bus Mode Figure 22.7 SS0ER Register #### Notes: - 1. Writing 1 to this bit has no effect. To set this bit to 0, first read the register then write 0 to the bit and write 1 to the rest of the bits. - 2. This bit becomes 1 under the following conditions: - As an input pin the SCS0 pin is low when the SSUMS bit in the SS0MR2 register is 1 (4-wire serial bus mode), and the MSS bit in the SS0CRH register is 1 (master mode). - As an input pin, the SCS0 pin becomes high during frame transmission/reception when the SSUMS bit is 1 (4-wire serial bus mode), and the MSS bit is 0 (slave mode). - 3. This flag indicates data reception ended unexpectedly because of an overrun error. This bit becomes 1 when the next serial data reception is completed while the RDRF bit is 1. Note that the data reception cannot start while this bit is 1. Data transmission cannot start either, while the MSS bit is 1 (master mode). - 4. This bit becomes 0 when data is read from the SS0RDR register. - 5. This bit becomes 1 when no data is left to be transmitted in the SS0TDR register before the end of the transmission of the last bit of current data. This bit becomes 0 when data is written to the SS0TDR register. - 6. This bit becomes 1 when the TE bit in the SS0ER register is switched from 0 (data transmission disabled) to 1 (data transmission enabled). It also becomes 1 when data is transferred from the SS0TDR register to the transmit/receive shift register. This bit becomes 0 when data is written to the SS0TDR register. Figure 22.8 SS0SR Register #### Notes: - 1. Irrespective of the CSS1 and CSS0 bit setting, the SCS0 pin function is not applicable when the SSUMS bit is 0. - 2. Settings of the port direction register and output function select registers are prioritized over these bit settings. Set these two registers according to the function to be used. - 3. To set bits CSS1 and CSS0 to 11b, first, set them to 10b, and then to 11b after the corresponding port function select register is read as 1. - 4. This pin functions as output only during data transmission/reception. Otherwise, it functions as input pin. - 5. When the SSUMS bit is 0, the BIDE bit setting is ignored and standard mode is always selected. Figure 22.9 SS0MR2 Register Figure 22.10 SS0TDR Register Figure 22.11 SS0RDR Register ### 22.1.1 Transmit/Receive Clock input. To use the serial bus interface in synchronous serial communication mode or 4-wire serial bus mode, set the SCKS bit in the SS0MR2 register to 1 to configure the SSCK0 pin to be a transmit/receive clock pin. - (1) To use the serial bus interface in master mode - When the MSS bit in the SS0CRH register is 1 (master mode), select a transmit/receive clock from among seven internal clocks (f(BCLK) divided-by-4, -8, -16, -32, -64, -128, and -256) with bits CKS2 to CKS0. - Set the corresponding pin to SSCK0 output by the output function select register and set its direction to output by the port direction register. - Since the SSCK0 pin functions as clock output, the selected transmit/receive clock is output from the SSCK0 pin as soon as data transmission/reception starts. - (2) To use the serial bus interface in slave mode When the MSS bit in the SS0CRH register is 0 (slave mode), the external clock is used. Set the corresponding pin to input by the port direction register. The SSCK0 pin functions as clock # 22.1.1.1 Transmit/Receive Clock Polarity and Phase The relation between the transmit/receive clock polarity and phase for transmit/receive data varies with the setting combination of the SSUMS bit in the SS0MR2 register, and bits CPHS and CPOS in the SS0MR register. Figure 22.12 shows the relation between those parameters. Figure 22.12 Transmit/Receive Clock Polarity and Phase of Transmit/Receive Data ## 22.1.2 Transmit/Receive Shift Register The transmit/receive shift register transmits and receives serial data. Data transferred to the transmit/receive shift register is shifted-out with the MSB first. Received data is shifted-in with the LSB first. Figure 22.13 shows transmit/receive shift register operation. ### 22.1.2.1 Bit Order The bit order to be transmitted/received can be selected using the MLS bit in the SS0MR register. When the MLS bit is 1 (LSB first), transmission starts from the LSB and completes with the MSB. In a receive operation, the first received bit is considered to be the LSB. When the MLS bit is 0 (MSB first), the bit order transmitted is reversed and the first received bit is considered to be the MSB. #### (1) Transmit operation When the MLS bit is 0 (MSB first), the written value is reflected in the SS0TDR register in the order written. When the MLS bit is 1 (LSB first), the written value is reflected in the SS0TDR register in the reversed order, that is, the reversed written value is read from the SS0TDR register. In both cases, however, data is transferred to the transmit/receive shift register in the transmitted order. #### (2) Receive operation When the MLS bit is 0 (MSB first), the received data is transferred from the transmit/receive shift register to the SS0RDR register in the order received. When the MLS bit is 1 (LSB first), the received data is transferred from the transmit/receive shift register to the SS0RDR register in the reversed order. # 22.1.2.2 Variable-Length Data Transmission/Reception When the data length is less than 16 bits, the shift-in/shift-out position is changed to adjust the bit position. This function enables transmit/receive data with the LSB in bit 0. Figure 22.13 Transmit/Receive Shift Register Operation # 22.1.3 Data I/O Pin and SS0 Shift Register The connection pattern of the data I/O pins and the transmit/receive shift register varies with the setting combination of the MSS bit in the SS0CRH register, and bits SSUMS and BIDE in the SS0MR2 register. Figure 22.14 shows the relation between those parameters. (A) When the SSUMS bit is 0 (synchronous serial communication mode) (B) When the SSUMS bit is 1 (4-wire serial bus mode), the MSS bit is 0 (slave mode), and the BIDE bit is 0 (normal mode) (C) When the SSUMS bit is 1 (4-wire serial bus mode), the MSS bit is 1 (master mode), and the BIDE bit is 0 (normal mode) (D) When the SSUMS bit is 1 (4-wire serial bus mode) and the BIDE bit is 1 (bidirectional mode) Figure 22.14 Data I/O Pins and Transmit/Receive Shift Register ## 22.1.4 Interrupt Requests In synchronous serial communication mode and 4-wire serial bus mode, there are five interrupt request sources: transmit data register empty, transmit end, receive data register full, overrun error, and conflict error. Since all of these interrupt request sources are assigned to an interrupt vector table, they should be identified by flags in the interrupt handler. Table 22.3 lists the serial bus interface interrupt request sources. Table 22.3 Interrupt Request Sources in Synchronous Serial Communication Mode and 4-wire Serial Bus Mode | Interrupt Request Source | Generating Condition for Interrupt Requests (1, 2) | |------------------------------------|----------------------------------------------------| | Transmit data register empty (TXI) | TIE = 1 and TDRE = 1 | | Transmit end (TEI) | TEIE = 1 and TEND = 1 | | Receive data register full (RXI) | RIE = 1 and RDRF = 1 | | Overrun error (OEI) | RIE = 1 and ORER = 1 | | Conflict error (CEI) | CEIE = 1 and CE = 1 | #### Notes: - 1. CEIE, RIE, TEIE, and TIE: Bits in the SS0ER register - 2. CE, ORER, RDRF, TEND, and TDRE: Bits in the SS0SR register When one or more conditions to generate an interrupt request listed in Table 22.3 are met, a serial bus interface interrupt request is generated. The corresponding interrupt sources should be set to 0 in the interrupt handler. However, bits TDRE (transmit data register empty) and TEND (transmit end) automatically become 0 when the next transmit data is written to the SS0TDR register. The RDRF bit (receive data register full) automatically becomes 0 when the SS0RDR register is read. Note that if no data is being transmitted, the TDRE bit, which became 0 as mentioned above, is set back to 1 (no data left in the SS0TDR register) since the written data is immediately transferred to the transmit/receive shift register. And, if the TDRE bit is set to 0 (unsent data left in SS0TDR register) by a program, it may cause the transmission of an additional data frame. ## 22.1.5 Communication Modes and Pin Functions In synchronous serial communication mode and 4-wire serial bus mode, the function of I/O pins varies with the setting combinations of the MSS bit in the SS0CRH register, and bits RE and TE in the SS0ER register. The SSCK0 pin is used for output in master mode, and input in slave mode. The port direction register and the port function select register need to be configured according to the direction of pins SSI0, SSO0, and SSCK0. Table 22.4 shows the relation between communication modes and I/O pins. Table 22.4 Communication Modes and I/O Pins | Communication Mode | Bit Setting | | | | | Pin State | | | |--------------------------------------------------------------------|-------------|----------|---------------|----|----|-----------|--------|---------------------| | Communication Mode | SSUMS | BIDE | MSS | TE | RE | SSI0 | SSO0 | SSCK0 | | Synchronous serial communication mode | 0 | Disabled | 0<br>(slave) | 0 | 1 | Input | _ (1) | Input | | | | | | 1 | 0 | _ (1) | Output | | | | | | | | 1 | Input | Output | | | | | | 1<br>(master) | 0 | 1 | Input | _ (1) | Output | | | | | | 1 | 0 | _ (1) | Output | | | | | | | | 1 | Input | Output | | | 4-wire serial bus mode<br>(in standard mode) | 1 | 0 | 0<br>(slave) | 0 | 1 | _ (1) | Input | | | | | | | 1 | 0 | Output | _ (1) | Input Output | | | | | | | 1 | Output | Input | | | | | | 1<br>(master) | 0 | 1 | Input | _ (1) | | | | | | | 1 | 0 | _ (1) | Output | | | | | | | | 1 | Input | Output | | | 4-wire bus<br>communication mode<br>(in bidirectional mode)<br>(2) | 1 | 1 | 0 | 0 | 1 | _ (1) | Input | - Input<br>- Output | | | | | (slave) | 1 | 0 | _ (1) | Output | | | | | | 1 | 0 | 1 | _ (1) | Input | | | | | | (master) | 1 | 0 | _ (1) | Output | | ## Notes: - 1. This pin can be used as a programmable I/O port. - 2. In 4-wire bus communication mode (in bidirectional mode), do not use the following combination: TE bit is 1 and RE bit is 1. SSUMS and BIDE: Bits in the SS0MR2 register MSS: Bit in the SS0CRH register TE and RE: Bits in the SS0ER register # 22.1.6 Synchronous Serial Communication Mode # 22.1.6.1 Initialization of Synchronous Communication Mode Figure 22.15 shows the initialization procedure of synchronous serial communication mode. Set the TE bit in the SS0ER register to 0 (transmission disabled) and the RE bit in the SS0ER register to 0 (reception disabled) before the data transmit/receive operation. To change the communication mode or the communication data format, set bits TE and RE to 0 in advance. Note that flags RDRF and ORER and the SS0RDR register are unaffected even if the RE bit is set to 0. Figure 22.15 Initialization Procedure in Synchronous Communication Mode #### 22.1.6.2 Data Transmission Figure 22.16 shows an example of the transmit operation in synchronous serial communication mode. During data transmission, the serial bus interface operates as described below. When operating in master mode, an internally generated clock as a transmit/receive clock is output from the SSCK0 pin. When operating in slave mode, the transmit/receive clock is a clock input from the SSCK0 pin. In both cases, transmit data is output synchronized with the transmit/receive clock. After setting the TE bit in the SS0ER register to 1 (transmission enabled), if transmit data is written to the SS0TDR register, the TDRE bit in the SS0SR register automatically becomes 0 (unsent data left in the SS0TDR register), and data in the SS0TDR register is transferred to the transmit/receive shift register. Then the TDRE bit becomes 1 (no data left in the SS0TDR register) and data transmission starts. And, if the TIE bit in the SS0ER register is 1 (transmit data register empty interrupt enabled), a transmit data empty interrupt request (TXI) is generated. When the TDRE bit is 0, after transmitting one frame of data, the data is transferred from the SS0TDR register to the transmit/receive shift register to start the next data transmission. When the TDRE bit is 1, after transmitting the eighth bit of data, the TEND bit in the SS0SR register becomes 1 (transmission is completed). And, if the TEIE bit in the SS0ER register is 1 (transmit end interrupt enabled), a transmit end interrupt request (TEI) is generated. After data transmission is completed, the SSCK0 pin is fixed to the level specified by the CPOS bit in the SS0MR register. Note that data cannot be transmitted while the ORER bit in the SS0SR register is 1 (overrun error occurred). Set the ORER bit to 0 before data transmission. Figure 22.17 shows an example of data transmission procedure in synchronous serial communication mode. Figure 22.16 Transmit Operation Example in Synchronous Serial Communication Mode Figure 22.17 Data Transmission Example in Synchronous Serial Communication Mode ## 22.1.6.3 Data Reception Figure 22.18 shows an example of the receive operation in synchronous serial communication mode. During data reception, the serial bus interface operates as described below. When operating in master mode, an internally generated clock as transmit/receive clock is output from the SSCK0 pin. When operating in slave mode, the transmit/receive clock is a clock input from the SSCK0 pin. In both cases, receive data is input synchronized with the transmit/receive clock. In master mode, a dummy read of the SS0RDR register evokes the receive clock output to start data reception. When the eighth bit of data is received, the RDRF bit in the SS0SR register becomes 1 (received data left in the SS0RDR register) and the received data is stored into the SS0RDR register. And, if the RIE bit in the SS0ER register is 1 (receive data register full interrupt/overrun error interrupt enabled), a receive data register full interrupt request (RXI) is generated. When the SS0RDR register is read, the RDRF bit automatically becomes 0 (no data left in the SS0RDR register). To end the receive data operation in master mode, set the RSSTP bit in the SS0CRH register to 1 (receive operation ended after receiving the current frame) before reading the data of the second to last frame from the SS0RDR register. Then the transmit/receive clock stops when the last frame reception is completed. When the clock stops, set the RE bit in the SS0ER register to 0 (reception disabled) and the RSSTP bit to 0 (receive operation continued after receiving the current frame) and read the data of the last frame. Note that if the SS0RDR register is read while the RE bit is 1, then the receive clock is output again. If the eighth bit of the data is received when the RDRF bit is 1, the ORER bit in the SS0SR register becomes 1 (overrun error occurred), and the receive operation stops. Note that data cannot be received while the ORER bit is 1. Set the ORER bit to 0 before resuming data reception. Figure 22.19 shows an example of the data reception procedure in master mode of synchronous communication mode. Figure 22.18 Receive Operation Example in Master Mode of Synchronous Serial Communication Mode Figure 22.19 Data Reception Example in Master Mode of Synchronous Serial Communication Mode ## 22.1.6.4 Data Transmission/Reception Data transmission/reception is a combined operation of data transmission and data reception mentioned in sections 22.1.6.2 and 22.1.6.3. Data transmission/reception starts when data is written to the SS0TDR register, and ends when the eighth bit of data is transmitted while the TDRE bit is 1 (no data left in the SS0TDR register). The data transmit/receive operation stops when the ORER bit becomes 1 (overrun error occurred) due to an error. To switch modes from transmit mode (TE bit is 1 and RE bit is 0) or receive mode (TE bit is 0 and RE bit is 1) to transmit/receive mode (TE bit is 1 and RE bit is 1), set bits TE and RE to 0. Then, check that the TEND bit is 0 (transmission continued), the RDRF bit is 0 (no data left in the SS0RDR register), the ORER bit is 0 (no overrun error), and subsequently set bits TE and RE to 1 at the same time. Figure 22.20 shows an example of data transmission/reception procedure in synchronous serial communication mode. Figure 22.20 Data Transmission/Reception Example in Synchronous Communication Mode #### 22.1.7 4-wire Serial Bus Mode In 4-wire serial bus mode, the serial bus interface operates serial communication via four logic signal lines: clock line, data input line, data output line, and chip select line. This mode also contains bidirectional mode, in which a single pin is used for the data input line and data output line. The data input line and data output line share the SSI0 pin and SSO0 pin. The combined setting of the MSS bit in the SS0CRH register and the BIDE bit in the SS0MR2 register determines which line is assigned to which pin. Refer to 22.1.3 "Data I/O Pin and SS0 Shift Register" for more details. In this mode, the clock polarity and phase for transmit/receive data can be configured by setting bits CPOS and CPHS in the SS0MR register, respectively. Refer to 22.1.1.1 "Transmit/Receive Clock Polarity and Phase" for more details. The chip select line functions as an output pin in master mode and as an input pin in slave mode. In master mode, the $\overline{SCSO}$ pin can be assigned as an output pin by setting bits CSS1 and CSS0 in the SS0MR2 register to 10b. Also, a programmable I/O port can be assigned as the chip select pin in this mode. In slave mode, the $\overline{SCSO}$ pin is assigned as an input pin by setting bits CSS1 and CSS0 to 01b. In 4-wire serial bus mode, serial communication is normally performed with the MSB first (the MLS bit in the SS0MR register is set to 0). #### 22.1.7.1 Initialization of 4-wire Serial Bus Mode Figure 22.21 shows the initialization of 4-wire serial bus mode. Initialize the circuit by setting the TE bit in the SS0ER register to 0 (transmission disabled) and the RE bit in the SS0ER register to 0 (reception disabled) before a data transmission/reception. To change the communication mode or the communication data format, set bits TE and RE to 0 in advance. Note that bits RDRF and ORER and the SS0RDR register are unaffected even if the RE bit is set to 0. Figure 22.21 Initialization in 4-wire Serial Bus Mode #### 22.1.7.2 Data Transmission Figure 22.22 shows an example of the transmit operation in 4-wire serial bus mode. During data transmission, the serial bus interface operates as described below. When operating in master mode, an internally generated clock as a transmit/receive clock is output from the SSCK0 pin. When operating in slave mode, the transmit/receive clock is a clock input from the SSCK0 pin while the $\overline{SCS0}$ pin is low. In both cases, transmit data is output synchronized with the transmit/receive clock. After setting the TE bit in the SS0ER register to 1 (transmission enabled), if transmit data is written to the SS0TDR register, the TDRE bit in the SS0SR register automatically becomes 0 (unsent data left in the SS0TDR register), and data in the SS0TDR register is transferred to the transmit/receive shift register. Then the TDRE bit becomes 1 (no data left in the SS0TDR register) and data transmission starts. And, if the TIE bit in the SS0ER register is 1 (transmit data register empty interrupt enabled), a transmit data empty interrupt request (TXI) is generated. When the TDRE bit is 0, after transmitting one frame of data, the data is transferred from the SS0TDR register to the transmit/receive shift register to start the next data transmission. When the TDRE bit is 1, after transmitting the last bit of data, the TEND bit in the SS0SR register becomes 1 (transmission completed). And, if the TEIE bit in the SS0ER register is 1 (transmit end interrupt enabled), a transmit end interrupt request (TEI) is generated. After the data transmission is completed, the SSCK0 pin and the $\overline{SCS0}$ pin become high. To continue data transmission with the $\overline{SCS0}$ pin low, write the data to be transmitted next to the SS0TDR register before the last bit is transmitted. Note that data cannot be transmitted while the ORER bit in the SS0SR register is 1 (overrun error occurred). Set the ORER bit to 0 before data transmission. In contrast to synchronous serial communication mode, the $\overline{SCSO}$ pin is used in 4-wire serial bus mode. When the serial bus interface is in master mode, the SSO0 pin is high-impedance while the output level at the $\overline{SCSO}$ pin is high. In slave mode, the SSIi pin is high-impedance while the input level at the $\overline{SCSO}$ pin is high. Refer to Figure 22.17 for an example of data transmission procedure. Figure 22.22 Transmit Operation Example in 4-wire Serial Bus Mode ## 22.1.7.3 Data Reception Figure 22.23 shows an example of receive operation in 4-wire serial bus mode. During data reception, the serial bus interface operates as described below. When operating in master mode, an internally generated clock as a transmit/receive clock is output from the SSCK0 pin. When operating in slave mode, the transmit/receive clock is a clock input from the SSCKi pin while the $\overline{SCS0}$ pin is low. In both cases, receive data is input synchronized with the transmit/receive clock. In master mode, a dummy read of the SS0RDR register evokes the receive clock output to start data reception. Note that the TE bit in the SS0ER register should be set to 0 before performing the dummy read to exit transmit mode. When the specified data length is received, the RDRF bit in the SS0SR register becomes 1 (received data left in the SS0RDR register) and the received data is stored into the SS0RDR register. And, if the RIE bit in the SS0ER register is 1 (receive data register full interrupt/overrun error interrupt enabled), a receive data register full interrupt request (RXI) is generated. When the SS0RDR register is read, the RDRF bit automatically becomes 0 (no data left in the SS0RDR register). To end the receive data operation in master mode, set the RSSTP bit in the SS0CRH register to 1 (receive operation ended after receiving the current frame) before reading the data of the second to last frame from the SS0RDR register. Then the transmit/receive clock stops when the last frame is received. When the clock stops, set the RE bit in the SS0ER register to 0 (reception disabled) and the RSSTP bit to 0 (receive operation continued after receiving the current frame) and read the data of the last frame. Note that if the SS0RDR register is read while the RE bit is 1, then the receive clock is output again. If the last bit of the data is received when the RDRF bit is 1, the ORER bit in the SS0SR register becomes 1 (overrun error occurred), and the receive operation stops. Note that data cannot be received while the ORER bit is 1. Set the ORER bit to 0 before resuming data reception. Refer to Figure 22.19 for an example of data reception procedure. Figure 22.23 Receive Operation Example in 4-wire Serial Bus Mode # 22.1.7.4 SCSO Pin Control and Arbitration In 4-wire serial bus mode, when bits CSS1 and CSS0 are set to 10b (functions as $\overline{SCS0}$ output pin), and the MSS bit in the SS0CRH register is 1 (master mode), then arbitration is performed by monitoring the $\overline{SCS0}$ pin before starting serial data transmission. When the serial bus interface detects that the synchronized internal $\overline{SCS0}$ signal level drops to low before data transmission, the CE bit in the SS0SR register becomes 1 (conflict error occurred) and the MSS bit automatically becomes 0 (slave mode). Figure 22.24 shows the arbitration timing. Note that the serial bus interface can no longer continue transmitting while the CE bit is 1. To start data transmission, confirm the CE bit is 1 and then set it to 0 (no conflict error). Figure 22.24 Arbitration Timing # 22.2 Note on Serial Bus Interface # 22.2.1 Note on Synchronous Serial Communication Mode and 4-wire Serial Bus Mode # 22.2.1.1 Accessing SBI Associated Registers To read the SBI associated registers (44F06h to 44F0Fh), insert at least three instructions after writing to the registers. • An example of inserting at least three instructions Program example MOV.B #00h, 44F0Bh; Set the SS0ER register to 00h. NOP NOP MOV.B 44F0Bh, R0L # 23. LIN Module The R32C/161 Group implements a local interconnect network (LIN) module, compliant with LIN Protocol Specification Revisions 1.3, 2.0, and 2.1, which transmits and receives frames, and judges errors automatically. Table 23.1 lists the LIN module specifications and Figure 23.1 shows the LIN module block diagram. Table 23.1 LIN Module Specifications | Item | Specification | | | | |--------------------------------|-------------------------------------------------------------------------------------------------|--|--|--| | Protocols | LIN Protocol Specification Revisions 1.3, 2.0, and 2.1 | | | | | Channel | 1 (LIN master) | | | | | Variable frame composition | Transmit break length: 13 to 28 Tbit | | | | | | Transmit break delimiter length: 1 to 4 Tbit | | | | | | Interbyte space (Header): 0 to 7 Tbit | | | | | | (space between Sync field and ID field) (1) | | | | | | Response space: 0 to 7 Tbit (1) | | | | | | Interbyte space: 0 to 3 Tbit | | | | | | (space between bytes in response space) | | | | | Checksum | Classic checksum or enhanced checksum selectable | | | | | | (changeable at each frame) | | | | | Data byte(s) in response field | Variable from 0 to 8 | | | | | Frame transmission modes | Non-frame separate mode or frame separate mode selectable; the | | | | | | former mode transmits a header and response by a single start command | | | | | | and the latter separately transmits them by respective start command | | | | | Wake-up transmission/reception | Available in LIN wake-up mode | | | | | | Wake-up transmission (1 to 16 Tbit) | | | | | | Wake-up reception | | | | | | Input signal low time count (0.5 to 15.5 Tbit) | | | | | | Input signal low detection | | | | | Operational status | Frame/wake-up transmit completion | | | | | | Frame/wake-up receive completion | | | | | | Data 1 receive completion | | | | | | • Input signal low detection | | | | | | • Error detection | | | | | | Operating mode | | | | | Error status | • Bit error | | | | | | Checksum error | | | | | | • Frame timeout error | | | | | | • Physical bus error | | | | | | • Framing error | | | | | | Overrun error Excluding the checkeum error, these errors are detection applie or | | | | | | Excluding the checksum error, these errors are detection enable or detection disable selectable | | | | | Baud rate | | | | | | Daud Tale | The baud rate generator can generate the baud rates in the LIN specifications | | | | | | pheriiirations | | | | ## Note: 1. The interbyte space (Header) has the same value as the response space since both spaces are set in the same register. Figure 23.1 LIN Module Block Diagram - LIN0OUT, LIN0IN: LIN I/O pins - Baud rate generator: Generates a communication clock for LIN - LIN common registers: Common registers for the LIN module - LIN channel 0 dedicated registers: To use these registers, set bits CWS1 and CWS0 in the LCW register to 00 • Interrupt control circuit: Controls the interrupt requests (LIN0 interrupt and LIN low detection interrupt) generated by the LIN module ## 23.1 LIN Module Associated Registers The LIN module has two types of registers: LIN module common registers and LIN channel dedicated registers. The latter compose up to four register banks for channels 0 to 3, of which an appropriate register bank is selected by switching a channel to be shown on the window. The number of channels per module depends on total channels incorporated. ## 23.1.1 LIN Common Registers • LIN channel window select/input signal low detection status register (LCW register) This register is to select a channel and monitor the status of input signal low detection. • LIN baud rate generator control register (LBRG register) This register is to select a count source for the baud rate generator and fLn clock source. Refer to 23.4 "Baud Rate Generator" for details. LIN baud rate prescaler k (LBRPk register) (k = 0, 1) This register is to set the division value for the baud rate prescaler to generate a transmit/receive clock with the count source selected by the LBRG register. # 23.1.2 LIN Channel Dedicated Registers To use these registers, set bits CWS1 and CWS0 in the LCW register to 00. LIN channel dedicated registers can be set via the following registers: • LIN mode register 0 (LMD0 register) This register is used for the initial setting of LIN module including mode selections and interrupt enable settings. • LIN mode register 1 (LMD1 register) This register is used for the initial setting of LIN module including system clock selection and error detection enable settings. LIN wake-up setting register (LWUP register) This register sets the low time pulse width of wake-up transmission and reception. • LIN break field setting register (LBRK register) This register sets the transmit break length and transmit break delimiter length in break field. • LIN space setting register (LSPC register) This register sets each space width required for transmission. • LIN response field setting register (LRFC register) This register sets the number of communication data bytes, the transmit/receive direction, and a checksum model. • LIN ID buffer register (LIDB register) This register sets the transmission ID and ID parity bits. LIN status control register (LSC register) This register changes the LIN operating mode. • LIN transmission control register (LTC register) This register sets to start the frame/wake-up transmission and response field transmission. LIN status register (LST register) This register monitors the status including frame/wake-up transmit completion, frame/wake-up receive completion, Data 1 receive completion, input signal low detection, error detection, and operating mode. LIN error status register (LEST register) This register monitors error status caused by bit, checksum, physical bus, frame timeout, framing, and overrun errors). • LIN data n buffer register (LDBn register) (n = 1 to 8) This register, commonly used as transmission and reception data buffer, sets data to be transmitted and to read received data. # 23.1.3 Register Window and Channel Switching The LIN channel dedicated registers, which are not directly mapped on the memory map of the CPU, are accessed via a register window. The register window is mapped at addresses 44E04h to 44E17h. According to the setting of bits CWS1 and CWS0 in the LCW register, the LIN channel dedicated registers are collectively mapped on the register window. Figure 23.2 shows the block diagram of the register window. Figure 23.2 Register Window Figures 23.3 to 23.18 show LIN module associated registers. Figure 23.3 LCW Register Figure 23.4 LBRG Register Figure 23.5 LBRP0 Register Figure 23.6 LBRP1 Register - - 1. Set these bits in LIN reset mode. - 2. fLIN is the LIN module system clock. - 3. This bit setting is enabled only when the RFT bit in the LRFC register is 1 (response transmission selected). - 4. The LD bit in the LST register becomes 1 and an interrupt request is generated in the following cases: - When the falling edge of the input signal is detected when this bit is 1. - When this bit is set to 1 while the input signal is low. Figure 23.7 LMD0 Register Figure 23.8 LMD1 Register Figure 23.9 LWUP Register Figure 23.10 LBRK Register Figure 23.11 LSPC Register Figure 23.12 LRFC Register Figure 23.13 LIDB Register Figure 23.14 LSC Register - 2. These bits become 0 when transiting to LIN reset mode or LIN wake-up mode. - 3. Set this bit when the FSM bit in the LMD0 register and the FTS bit are both 1 (frame separate mode, and start frame/wake-up transmission). Figure 23.15 LTC Register ### Notes: - 1. These bits do not become 0 automatically. Set them to 0 by a program. Writing 1 to these bits has no effect. - 2. This flag does not become 1 when a header transmission is completed in frame separate mode. - 3. While this bit is 1, no interrupt request is generated even if the conditions of the LD bit becoming 1 are satisfied again. Figure 23.16 LST Register Figure 23.17 LEST Register Figure 23.18 Registers LDB1 to LDB8 ## 23.2 Operating Modes The LIN modules have the following three operating modes: - · LIN reset mode - LIN operating mode - · LIN wake-up mode In LIN reset mode, power consumption is reduced since the clock is not provided to the LIN module. Figure 23.19 shows the transition processes between LIN operating modes and Table 23.2 lists functions available in each mode. Figure 23.19 LIN Operating Mode Transition Table 23.2 Functions Available in Each Operating Mode | LIN Reset Mode | LIN Operating Mode | LIN Wake-up Mode | |----------------------------|----------------------------|----------------------------| | Input signal low detection | Header transmission | Wake-up transmission | | | Response transmission | Wake-up reception | | | Response reception | Error detection | | | Error detection | Input signal low detection | | | Input signal low detection | | Read bits OMM1 and OMM0 in the LST register to verify that the LIN module has entered each operating mode Note that bits OM1 and OM0 and bits OMM1 and OMM0 are allocated differently in each operating mode. ### 23.2.1 LIN Reset Mode When bits OM1 and OM0 in the LSC register are set to 00b or 10b, the LIN channel enters LIN reset mode, and bits OMM1 and OMM0 in the LST register become 00b or 01b. In this mode, all LIN functions are stopped as well as the clock supply to the LIN module (fLIN) of the channel. ## 23.2.2 LIN Operating Mode When bits OM1 and OM0 in the LSC register are set to 11b, the LIN channel enters LIN operating mode, and bits OMM1 and OMM0 in the LST register become 11b. ## 23.2.3 LIN Wake-up Mode When bits OM1 and OM0 in the LSC register are set to 01b, the LIN channel enters LIN wake-up mode, and bits OMM1 and OMM0 in the LST register become 10b. # 23.3 Operational Overview ### 23.3.1 Header Transmission Figure 23.20 shows the operation in header transmission and Table 23.3 lists the processing in header transmission. Figure 23.20 Operation in Header Transmission Table 23.3 Processing in Header Transmission | | Software Processing | LIN Module Processing | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------| | (1) | • Set a baud rate • Set the following bits in the LMD0 register: The FTCIE bit to 1 (frame/wake-up transmit completion interrupt enabled); The FRCIE bit to 1 (frame/wake-up receive completion interrupt enabled); The ERRIE bit to 1 (error detection interrupt enabled) • Change the operating mode • Set the following bits in the LBRK register: Bits BLT3 to BLT0 for break low (13 to 28 Tbit); Bits BDT1 and BDT0 for break delimiter (1 to 4 Tbit) • Set the following bits in the LSPC register: Bits IBSH2 to IBSH0 for interbyte space (Header)/response space (0 to 7 Tbit); Bits IBS1 and IBS0 for interbyte space (0 to 3 Tbit) • Set the following bits in the LIDB register: Bits ID5 to ID0 for ID value; Bits IDP1 and IDP0 for parity value • Set the following bits in the LRFC register: Bits RFDL3 to FRDL0 for data length; The RFT bit for response transmit/receive direction | LIN Module Processing Wait for frame/wake-up transmission start by software (idle) | | | The CSM bit for checksum model • Set the transmit data • Set the ETS bit in the LTC register to 1 (frame/wake up | Transmit break | | (2) | <ul> <li>Set the FTS bit in the LTC register to 1 (frame/wake-up<br/>transmission started)</li> </ul> | | | (3) | Wait for an interrupt request to be generated | Transmit break delimiter | | (4) | | Transmit Sync field (55h) | | (5)<br>(6)<br>(7) | | Transmit interbyte space (Header) | | (6) | | Transmit ID field | | (7) | | Transmit response space | ## 23.3.2 Response Transmission Figure 23.21 shows the operation in response transmission and Table 23.4 lists the processing in response transmission. Figure 23.21 Operation in Response Transmission Table 23.4 Processing in Response Transmission | | Software Processing | LIN Module Processing | |-----|----------------------------------------------------|----------------------------------------------------| | | In frame separate mode | In frame separate mode | | | Set the RTS bit in the LTC register to 1 (response | Transmit response space while waiting for | | (1) | transmission started) | response transmission enabled | | (1) | In non-frame separate mode | In non-frame separate mode | | | Wait for an interrupt request to be generated | Go to (2) if the response space transmission is | | | | completed | | (2) | Wait for an interrupt request to be generated | Transmit Data 1 | | (3) | | Transmit interbyte space | | | | Transmit Data 2, then the next interbyte space | | | | Transmit Data 3, then the next interbyte space | | (4) | | (Repeat this process for the data length specified | | | | in bits RFDL3 to RFDL0 in the LRFC register. Go | | | | to (6) if an error occurs.) | | (5) | | Transmit checksum | | | | Set frame/wake-up transmit completion flag or | | | | error flag | | | | Set the following bits in the LTC register: | | (6) | | The FTS bit to 0 (frame/wake-up transmission | | | | stopped); | | | | The RTS bit to 0 (response transmission | | | | stopped) | | (7) | Processing after communication | Idle | | (1) | Check the LST register and set flags to 0 | | ## 23.3.3 Response Reception Figure 23.22 shows the operation in response reception and Table 23.5 lists the processing in response reception. Figure 23.22 Operation in Response Reception Table 23.5 Processing in Response Reception | | Software Processing | LIN Module Processing | |-----|-------------------------------------------|-------------------------------------------------------------| | (1) | Wait for an interrupt request to be | Wait for a start bit to be detected | | (') | generated (without processing) | | | (2) | Wait for an interrupt request to be | Receive Data 1 due to start bit detection | | (3) | generated | Set Data 1 receive completion flag | | | | Receive Data 2 due to start bit detection | | | | Receive Data 3 due to start bit detection | | | | (Repeat this process for the data length specified in bits | | | | RFDL3 to RFDL0 in the LRFC register. Abort the reception | | (4) | | and go to (5) if an error occurs. Checksum judgement is not | | | | performed in this case.) | | | | : | | | | : | | | | Receive checksum due to start bit detection | | | | Judge the checksum | | (E) | | Set frame receive completion flag or error flag | | (5) | | Set the FTS bit in the LTC register to 0 (frame/wake-up | | | | transmission stopped) | | (6) | Processing after communication | Idle | | (6) | Check the LST register and set flags to 0 | | | | | | #### 23.4 Baud Rate Generator The LIN module system clock (fLIN) is generated by peripheral clock divided by the baud rate generator. The fLIN divided by 8 or 16 is used as the bit rate. The reciprocal of the bit rate is called bit time and expressed as "Tbit". When the BTD bit in the LMD0 register is 0 (1 Tbit is generated by 8 fLIN), the FLNS bit in registers LBRG and LBRP0 should be set so that fLn is 153600 Hz (19200 bps × 8). Therefore, $fLn = 19200 \text{ bps} \times 8 \text{ [Hz]}$ $fLn2 = 9600 \text{ bps} \times 8 \text{ [Hz]}$ $fLn8 = 2400 \text{ bps} \times 8 \text{ [Hz]}$ Then they are divided by 8 in the bit timing generator, which results in 19200 bps, 9600 bps, and 2400 bps, respectively. The baud rate of 10417 bps is generated by the bit setting in the LBRP1 register. When the BTD bit is 1 (1 Tbit is generated by 16 fLIN), the FLNS bit in registers LBRG and LBRP0 should Figure 23.23 shows the block diagram of baud rate generation. be set so fLn is 307200 Hz (= 19200 bps × 16). Figure 23.23 Baud Rate Generation Block Diagram Tables 23.6 and 23.7 list the baud rates (19200, 9600, 2400, and 10417 bps) generated by the peripheral clock frequency, and their errors. Table 23.6 Baud Rate Generation Example (for 19200, 9600, and 2400 bps) | Peripheral<br>Clock | Divide-by-<br>(n + 1) | BRP0 Output | Bit Times | fLn<br>[19200 bps]<br>(unit: bps) | fL2n<br>[9600 bps]<br>(unit: bps) | fL8n<br>[2400 bps]<br>(unit: bps) | Error<br>(unit: %) | |---------------------|-----------------------|-----------------------------|--------------------|-----------------------------------|-----------------------------------|-----------------------------------|--------------------| | 32 MHz | 104 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 30 MHz | 98 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19132.65 | 9566.33 | 2391.58 | -0.35 | | 24 MHz | 78 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 20 MHz | 65 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 16 MHz | 52 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 12 MHz | 39 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 10 MHz | 65 | No division (1) | 8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 8 MHz | 26 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 4 MHz | 13 | No division/<br>divide-by-2 | 16 fLIN/<br>8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | | 2 MHz | 13 | No division (1) | 8 fLIN | 19230.77 | 9615.38 | 2403.85 | +0.16 | ### Note: Table 23.7 Baud Rate Generation Example for 10417 bps | Peripheral | Divide-by- | Dit Timos | Bit Times fLIN Baud Rate [10417 bps] (unit: bps) | | Error | |------------|------------|------------------|------------------------------------------------------|----------|----------| | Clock | (m + 1) | Dit Tillies | | | (unit:%) | | 32 MHz | 48 / 96 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 30 MHz | 45 / 90 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 24 MHz | 36 / 72 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 20 MHz | 30 / 60 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 16 MHz | 24 / 48 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 12 MHz | 18 / 36 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 10 MHz | 15 / 30 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 8 MHz | 12 / 24 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 4 MHz | 6 / 12 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | | 2 MHz | 3/6 | 8 fLIN / 16 fLIN | fLm8 / fLm2 | 10416.67 | -0.003 | <sup>1.</sup> An error does not fulfill the LIN protocol specification (±0.5%) if the BRP0 clock is divided by 2. ## 23.5 Data Transmission and Reception #### 23.5.1 Data Transmission The LIN module transmits 1-bit data per Tbit. The transmitted data returns to the input pin for data reception via the LIN transceiver. Then the received data is compared to the transmitted data and the result is stored in the BER bit in the LEST register (refer to 23.10 "Error Status" for details). The timing to compare the received data is at the fifth clock when the BTD bit in the LMD0 register is 0 (1 Tbit is generated by 8 fLIN), and at the 13th clock when the BTD bit is 1 (1 Tbit is generated by 16 fLIN). Figure 23.24 shows data transmission timing. Figure 23.24 Data Transmission Timing ### 23.5.2 Data Reception Data reception in the LIN module requires an internal signal generated from the input signal at the LINOIN pin by a double-latch clocking scheme. The byte field of this internal signal, called the synchronized LIN0IN, is synchronized with fLIN at the falling edge of the start bit. The synchronized LIN0IN signal is sampled again 0.5 Tbit after a falling edge is detected, and if the signal is low, it is verified as the start bit. It is not verified as the start bit if the LIN0IN signal has been low after a reset is released or high is detected on sampling. Once the start bit is detected, data bits are sampled every Tbit. Figure 23.25 shows the data reception timing. Figure 23.25 Data Reception Timing ## 23.6 Buffer Processing of Transmit/Receive Data This section describes buffer processing when the LIN module is continuously transmitting and receiving data. ### 23.6.1 Transmission of LIN Frame In 8-byte transmission, the values stored in registers LDB1 to LDB8 are transmitted in order to Data 1 to Data 8 of the LIN frame. In 4-byte transmission, the values stored in registers LDB1 to LDB4 are transmitted to Data 1 to Data 4 of the LIN frame, and the values stored in registers LDB5 to LDB8 are not transmitted. Figure 23.26 shows the processing of LIN transmission and buffer. Figure 23.26 Processing of LIN Transmission and Buffer ## 23.6.2 Reception of LIN Frame In 8-byte reception, the values of Data 1 to Data 8 of the LIN frame are stored in registers LDB1 to LDB8 in order at every completion of stop bit reception. In 4-byte reception, the values of Data 1 to Data 4 of the LIN frame are stored in registers LDB1 to LDB4 respectively, and no bits are stored in registers LDB5 to LDB8. Figure 23.27 shows the processing of LIN reception and buffer. Figure 23.27 Processing of LIN Reception and Buffer ## 23.7 Wake-up Transmission and Reception Wake-up transmission and reception can be used in LIN wake-up mode. ## 23.7.1 Wake-up Transmission ## 23.7.1.1 Operation of Wake-up Transmission In LIN wake-up mode, when the FTS bit in the LTC register is set to 1 (frame/wake-up transmission started), the wake-up signal is output at the output pin. Low time pulse width of the wake-up signal is set by bits WUTL3 to WUTL0 in the LWUP register. When low of wake-up is output without any bit error detected, the FTC bit in the LST register becomes 1 (frame/wake-up transmission completed). When the FTCIE bit in the LMD0 register is 1 (frame/wake-up transmit completion interrupt enabled), an interrupt request is generated. When a bit error is detected, the operation is aborted and the BER bit in the LEST register becomes 1 (bit error is detected). Figure 23.28 shows the wake-up transmission timing. Figure 23.28 Wake-up Transmission Timing ### 23.7.1.2 Wake-up Collision When the master and slave transmit wake-up signals simultaneously, a signal collision occurs on the LIN bus. However, no collision of the wake-up signals is detected in the LIN module. Even if the LIN bus is fixed low, it is not recognized as a wake-up signal: the input signal low time count does not function unless a recessive (high) is detected once after the wake-up signals are transmitted. ### 23.7.2 Wake-up Reception ### 23.7.2.1 Wake-up Reception Operation A wake-up is detected by either of the following functions: input signal low time count or input signal low detection. The input signal low time count is available in LIN wake-up mode and the input signal low detection is available in all LIN operating modes. The input signal low time count measures the low time of an input signal at the LIN0IN pin by counting at the same sampling timing as that of data reception. When the counted low time reaches the value set with bits WURL3 to WURL0 in the LWUP register, the FRC bit in the LST register becomes 1 (frame/wake-up reception completed). When the FRCIE bit in the LMD0 register is 1 (frame/wake-up receive completion interrupt enabled), an interrupt request is generated. On the other hand, the input signal low detection is to asynchronously detect the falling edge of the input signal at the LIN0IN pin. While the LDE bit in the LMD0 register is 1 (input signal low detection enabled), the LD bit in the LST register becomes 1 (input signal low detected) when the falling edge is detected, and an interrupt request is generated. Figure 23.29 shows an example of the wake-up detection. When the bit rate is 19200 bps (1 Tbit = 52 $\mu$ s) and the pulse width is 3.5 Tbit (bits WURL3 to WURL0 is 0011b), the low time pulse over 182 $\mu$ s (= 52 $\mu$ s × 3.5) is recognized as the wake-up signal. Figure 23.29 Wake-up Detection The input signal low time count is not available during the wake-up transmission processing, however, the input signal low detection is. If the FTS bit in the LTC register is set to 1 (start frame/ wake-up transmission) while a wake-up reception is being counted, the reception processing is aborted to perform the wake-up transmission. ## 23.8 Low Power Mode Control Using Input Signal Low Detection The input signal low detection can be used as the interrupt to exit wait mode or stop mode. Figure 23.30 shows a setting example before entering wait mode. Refer to 7.7.2 "Wait Mode" and 7.7.3 "Stop Mode" for details on entering wait or stop mode. Figure 23.30 Example of Setting Before Transition to Wait Mode ## 23.9 Operational Status The LIN module detects six types of operational statuses. Statuses that can generate an interrupt request are: frame/wake-up transmit completion, frame/wake-up receive completion, input signal low detection, and error detection. Table 23.8 lists the types of operational statuses. Table 23.8 Operational Statuses | Operational<br>Status | Detecting Condition | Detectable<br>Operating Modes | Corresponding Bits in the LST Register | | |----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------|--| | · | | LIN operating mode | FTC | | | | When a wake-up transmission has been successfully completed | LIN wake-up<br>mode | | | | Frame/wake-up receive completion | When a response frame reception has been successfully completed in the bit setting as follows: RFT bit in the LRFC register is 0 (reception selected) | LIN operating mode | FRC | | | | When the low time of the input signal reaches the setting value of bits WURL3 to WURL0 in the LWUP register | LIN wake-up<br>mode | | | | Input signal low detection | When the falling edge of the input signal at the LINOIN pin is detected with the setting of the LDE bit in the LMD0 register to 1 (input signal low detection enabled), or when setting the LDE bit to 1 while the LINOIN pin is low | All LIN modes | LD | | | Error detection | When any bit from 0 to 5 in the LEST register becomes 1 (error detected) | LIN operating<br>mode<br>LIN wake-up<br>mode | ERR | | | Operating mode | When LIN module has entered the operating mode which was set by bits OM1 and OM0 in the LSC register | All LIN modes | OMM1 and<br>OMM0 | | | Data 1 receive completion | When the reception of the first byte of a response frame has been completed in the bit setting as follows: RFT bit in the LRFC register is 0 (reception selected) (1) | LIN operating mode | D1RC | | ### Note: 1. This status is detected except when bits RFDL3 to RFDL0 in the LRFC register are 0000b (0 bytes + checksum). ### 23.10 Error Status ## 23.10.1 Error Status Types The LIN module detects six types of error statuses. These error statuses can be checked by bits 0 to 5 in the LEST register. Table 23.9 lists the types of error statuses. Table 23.9 Error Statuses | Error<br>Status | Error Detecting Condition | Error Detectable<br>Operating Mode | Communication<br>Processing | Detection<br>Enabled/<br>Disabled | Corresponding Bit in the LEST Register | |---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------|-----------------------------------|----------------------------------------| | Bit error | When the transmitted data does not match with that on the LIN bus monitored by the pin for reception | LIN operating mode<br>LIN wake-up mode | Abort <sup>(1)</sup> | Selectable | BER | | Physical<br>bus<br>error | When LIN bus has already become low just before the break field is transmitted or when it is detected that LIN bus is being fixed to high | LIN operating mode<br>LIN wake-up mode | Abort | Selectable | PBER | | Check<br>sum<br>error | When the checksum judgement of the response frame reception processing results in an error | LIN operating mode | _ | Not<br>selectable | CSER | | Frame<br>timeout<br>error | When the transmit/receive operation is not completed within a specified period of time (2) | LIN operating mode | Abort | Selectable | FTER | | Framing error | When the stop bit of each data byte is low in response frame reception processing | LIN operating mode | Abort | Selectable | FER | | Overrun<br>error | When the first data byte of the next response frame is received while the FRC bit in the LST register is 1 (frame reception successfully completed) | LIN operating mode | Abort | Selectable | OER | #### Notes: - When a bit error is detected, the processing is aborted after the stop bit is transmitted. If it is detected in a non-data space, such as an interbyte space, the transmission processing is aborted after a check in that space is completed. During wake-up transmission, the wake-up transmission is aborted immediately after the error bit is transmitted. - 2. The period of time (as time out value) depends on the response field data length set by bits RFDL3 to RFDL0 in the LRFC register as follows: Time out value = $$50 + (data bytes + 1) \times 14$$ [Tbit] The above period of time will exceed the value of $T_{FRAME\_MAX}$ ({(10 × data bytes + 44) + 1} × 1.4) shown in LIN Specification Package Revision 1.3. ## 23.10.2 LIN Error Detection Targets Figure 23.31 shows the area which the LIN module monitors for error detection. Figure 23.31 LIN Error Detection Targets ### 23.11 LIN Interrupts The LIN module generates the LIN0 interrupt and LIN low detection interrupt. The channel has four interrupt sources: frame/wake-up transmit completion, frame/wake-up receive completion, error detection, and input signal low detection. Interrupt requests by the frame/wake-up transmit completion, frame/wake-up receive completion, and error detection interrupt sources are aggregated by logical OR as an interrupt request "LIN0 interrupt". The input signal low detection interrupt of each channel, on the other hand, is called as LIN low detection interrupt request. The respective interrupt request is output when the corresponding flag in the LST register becomes 1 while the corresponding bit in the LMD0 register is 1 (interrupt enabled). No new interrupt request is generated by the other sources if any of them is 1 since multiple interrupt sources are aggregated. Figures 23.32 and 23.33 show the block diagram of the LIN0 interrupt and the LIN low detection interrupt, respectively. Figure 23.32 LIN0 Interrupt Block Diagram Figure 23.33 LIN Low Detection Interrupt Block Diagram ## 24. CAN Module The R32C/161 Group implements two channels (CAN0 and CAN1) of the Controller Area Network (CAN) module that complies with the ISO 11898-1 standard. The CAN module transmits and receives both formats of messages, namely the standard identifier (11 bits) (identifier hereafter referred to as ID) and extended ID (29 bits). Tables 24.1 and 24.2 list the CAN module specifications, and Figure 24.1 shows the CAN module block diagram. Connect the CAN bus transceiver externally. Table 24.1 CAN Module Specifications (1/2) | Item | Specification | |----------------------|------------------------------------------------------------------------------------------------| | Protocol | ISO 11898-1 compliant | | Bit rate | Maximum 1 Mbps | | Message boxes | 32 mailboxes: | | | Two selectable mailbox modes: | | | Normal mailbox mode | | | All 32 mailboxes can be indivisually configured for transmission or reception | | | FIFO mailbox mode: | | | 24 mailboxes can be indivisually configured for transmission or reception. | | | 4 of the remaining mailboxes can be configured for transmit FIFO and the other | | | 4 mailboxes for receive FIFO | | Reception | Data frames and remote frames can be received | | | • Selectable receiving ID format (standard ID only, extended ID only, or both IDs) | | | Programmable one-shot reception function | | | Selectable overwrite mode (message overwritten) or overrun mode (message | | | discarded) | | | The reception complete interrupt can be enabled or disabled for each mailbox | | Acceptance filtering | 8 acceptance masks: 1 mask for every 4 mailboxes | | | The mask can be enabled or disabled for each mailbox | | Transmission | Data frames and remote frames can be transmitted | | | • Selectable transmitting ID format (standard ID only, extended ID only, or both IDs) | | | Programmable one-shot transmission function | | | Selectable ID priority transmit mode or mailbox number priority transmit mode | | | Transmission request can be aborted (A completed abort operation can be confirmed with a flag) | | | The transmission complete interrupt can be enabled or disabled for each | | | mailbox | | Mode transition for | Mode transition for recovering from the bus-off state can be selected: | | bus-off recovery | • ISO 11898-1 compliant | | | Automatic entry to CAN halt mode at bus-off entry | | | Automatic entry to CAN halt mode at bus-off end | | | Entry to CAN halt mode by a program | | | Transition to the error-active state by a program | Table 24.2 CAN Module Specifications (2/2) | Item | Specification | | | | |-------------------------|-------------------------------------------------------------------------------------|--|--|--| | Error status monitoring | CAN bus errors (stuff error, form error, ACK error, CRC error, bit error, and ACK) | | | | | | delimiter error) can be monitored | | | | | | • Transition to error states can be detected (error-warning, error-passive, bus-off | | | | | | entry, and bus-off recovery) | | | | | | The error counters can be read | | | | | Time stamp function | Time stamp function using a 16-bit counter | | | | | | The reference clock can be selected among 1, 2, 4, and 8 bit times | | | | | Interrupt sources | 6 types: | | | | | | Reception complete | | | | | | Transmission complete | | | | | | Receive FIFO | | | | | | Transmit FIFO | | | | | | • Error | | | | | | Wake-up | | | | | CAN sleep mode | Current consumption can be reduced by stopping the CAN clock | | | | | Software support units | 3 software support units: | | | | | | Acceptance filter support | | | | | | Mailbox search support (receive mailbox search, transmit mailbox search, and | | | | | | message lost search) | | | | | | Channel search support | | | | | CAN clock source | Peripheral bus clock or main clock selectable | | | | | Test modes | 3 test modes available for user evaluation: | | | | | | Listen only mode | | | | | | Self test mode 0 (external loop back) | | | | | | Self test mode 1 (internal loop back) | | | | Figure 24.1 CAN Module Block Diagram (i = 0, 1) - CANIIN/CANIOUT (i = 0, 1): CAN I/O pins - Protocol controller: Handles CAN protocol processing such as bus arbitration, bit timing at transmission and reception, stuffing, error handling, etc. - Message box: Consists of 32 mailboxes which can be individually configured as either a transmit or receive mailbox. Each mailbox has its own ID, data length code, an 8-byte data field, and a time stamp. - Acceptance filter: Filters received messages. Registers CiMKR0 to CiMKR7 are used for the filtering process. - Timer: Used for the time stamp function. The timer value when storing a message into a mailbox is written as the time stamp value. - Wake-up function: Generates a CANi wake-up interrupt request when a message is detected on the CAN bus. - Interrupt generator: Generates the following five types of interrupts: - CANi reception complete interrupt - CANi transmission complete interrupt - CANi receive FIFO interrupt - CANi transmit FIFO interrupt - CANi error interrupt - CAN SFRs: CAN-associated registers. Refer to 24.1 "CAN SFRs" for details. ## 24.1 CAN SFRs CAN-associated registers are shown in Figures 24.2 to 24.11, 24.13, 24.14, 24.16 to 24.20, 24.22, and 24.24 to 24.30. ## 24.1.1 CANi Control Register (CiCTLR) (i = 0, 1) #### Notes: - When bits CANM and SLPM are changed, read the CiSTR register to ensure that the mode has been switched. Do not change bits CANM and SLPM until the mode has been switched. - 2. Write to the SLPM bit in CAN reset mode or CAN halt mode. When rewriting the SLPM bit, set only this bit to 0 or 1. - 3. Write to bits BOM, MBM, IDFM, MLM, TPM, and TSPS in CAN reset mode. - 4. Set the RBOC bit to 1 in bus-off state. - 5. Bits RBOC and TSRC are automatically set back to 0 after being set to 1. They are read as 0. - 6. Set the TSRC bit to 1 in CAN operation mode. Figure 24.2 Registers C0CTLR and C1CTLR ### 24.1.1.1 CANM Bit Set the CANM bit to select one of the following modes for the CAN module: CAN operation mode, CAN reset mode, or CAN halt mode. Refer to 24.2 "Operating Modes" for details. Set the SLPM bit to 1 to select CAN sleep mode. Do not set the CANM bit to 11b. When the CAN module enters CAN halt mode according to the setting of the BOM bit, the CANM bit automatically becomes 10b. #### 24.1.1.2 SLPM Bit When the SLPM bit is set to 1, the CAN module enters CAN sleep mode. When this bit is set to 0, the CAN module exits CAN sleep mode. Refer to 24.2 "Operating Modes" for details. #### 24.1.1.3 BOM Bit Set the BOM bit to select bus-off recovery mode. When the BOM bit is 00b, the recovery from bus-off is ISO 11898-1 compliant, i.e. the CAN module reenters CAN communication (error-active state) after detecting 11 consecutive recessive bits 128 times. A bus-off recovery interrupt request is generated when recovering from bus-off. When the BOM bit is 01b, as soon as the CAN module enters the bus-off state, the CANM bit in the CiCTLR register becomes 10b (CAN halt mode) and the CAN module enters CAN halt mode (i = 0, 1). No bus-off recovery interrupt request is generated when recovering from bus-off and registers CiTECR and CiRECR become 00h. When the BOM bit is 10b, the CANM bit becomes 10b as soon as the CAN module enters the bus-off state. The CAN module enters CAN halt mode after recovering from the bus-off state, i.e. after detecting 11 consecutive recessive bits 128 times. A bus-off recovery interrupt request is generated when recovering from bus-off and registers CiTECR and CiRECR become 00h. When the BOM bit is 11b, the CAN module enters CAN halt mode by setting the CANM bit to 10b while the CAN module is still in the bus-off state. No bus-off recovery interrupt request is generated when recovering from bus-off and registers CiTECR and CiRECR become 00h. However, if the CAN module recovers from bus-off after detecting 11 consecutive recessive bits 128 times before the CANM bit is set to 10b, a bus-off recovery interrupt request is generated. If the CPU requests an entry to CAN reset mode at the same time as the CAN module attempts to enter CAN halt mode (at bus-off entry when the BOM bit is 01b, or at bus-off end when the BOM bit is 10b), then the CPU request to enter CAN reset mode has higher priority. #### 24.1.1.4 RBOC Bit When the RBOC bit is set to 1 (forced recovery from bus-off) in the bus-off state, the CAN module forcibly recovers from the bus-off state. This bit automatically becomes 0. The error state changes from bus-off to error-active. When the RBOC bit is set to 1, registers CiRECR and CiTECR become 00h and the BOST bit in the CiSTR register becomes 0 (CAN module is not in bus-off state). The other registers do not change. No bus-off recovery interrupt request is generated by recovering from the bus-off state. Use the RBOC bit only when the BOM bit is 00b (normal mode). #### 24.1.1.5 MBM Bit When the MBM bit is 0 (normal mailbox mode), mailboxes [0] to [31] are configured as transmit or receive mailboxes. When this bit is 1 (FIFO mailbox mode), mailboxes [0] to [23] are configured as transmit or receive mailboxes, mailboxes [24] to [27] are configured as transmit FIFO, and mailboxes [28] to [31] are as receive FIFO. Transmit data is written into mailbox [24] (mailbox [24] is a window mailbox for the transmit FIFO). Receive data is read from mailbox [28] (mailbox [28] is a window mailbox for the receive FIFO). Table 24.3 lists the mailbox configuration. Table 24.3 Mailbox Configuration | Mailbox | MBM Bit is 0 | MBM Bit is 1 <sup>(1)</sup> | |------------------------|-----------------------|-----------------------------| | Manbox | (Normal mailbox mode) | (FIFO mailbox mode) | | Mailboxes [0] to [23] | Normal mailbox | Normal mailbox | | Mailboxes [24] to [27] | | Transmit FIFO | | Mailboxes [28] to [31] | | Receive FIFO | #### Note: - 1. When the MBM bit is set to 1, note the following: - Transmit FIFO is controlled by the CiTFCR register (i = 0, 1). The CiMCTLj register for mailboxes [24] to [27] is disabled (j = 0 to 31). Registers CiMCTL24 to CiMCTL27 cannot be used. - Receive FIFO is controlled by the CiRFCR register. The CiMCTLj register for mailboxes [28] to [31] is disabled. - Registers CiMCTL28 to CiMCTL31 cannot be used. - Refer to the CiMIER register for the FIFO interrupts. - The corresponding bits in the CiMKIVLR register for mailboxes [24] to [31] are disabled. Set 0 to these bits. - Transmit/receive FIFOs can be used for both data frames and remote frames. ### 24.1.1.6 IDFM Bit Set the IDFM bit to specify the ID format. When this bit is 00b, all mailboxes (including FIFO mailboxes) handle standard IDs only. When this bit is 01b, all mailboxes (including FIFO mailboxes) handle extended IDs only. When this bit is 10b, all mailboxes (including FIFO mailboxes) handle both standard IDs and extended IDs. Standard IDs or extended IDs are specified by setting the IDE bit in the corresponding mailbox in normal mailbox mode. In FIFO mailbox mode, the IDE bit in the corresponding mailbox is used for mailboxes [0] to [23], the IDE bit in registers CiFIDCR0 and CiFIDCR1 is used for the receive FIFO, and the IDE bit in mailbox [24] is used for the transmit FIFO. Do not set 11b to the IDFM bit. #### 24.1.1.7 MLM Bit Set the MLM bit to specify the operation when a new message is captured in an unread mailbox. Overwrite mode or overrun mode can be selected. All mailboxes (including the receive FIFO) are set to either overwrite mode or overrun mode. When the MLM bit is 0, all mailboxes are set to overwrite mode and the new message overwrites the old message. When this bit is 1, all mailboxes are set to overrun mode and the new message is discarded. ### 24.1.1.8 TPM Bit Set the TPM bit to specify the priority of modes when transmitting messages. ID priority transmit mode or mailbox number transmit mode can be selected. All mailboxes are set to either ID priority transmission or mailbox number priority transmission. When the TPM bit is 0, ID priority transmit mode is selected and transmission priority complies with the CAN bus arbitration rule, as specified in the ISO 11898-1 standard. In ID priority transmit mode, mailboxes [0] to [31] (in normal mailbox mode), mailboxes [0] to [23] (in FIFO mailbox mode), and the transmit FIFO are compared with the IDs of mailboxes configured for transmission. If two or more mailbox IDs are the same, the mailbox with the smaller number has higher priority. Only the next message to be transmitted from the transmit FIFO is included in the transmission arbitration. If a transmit FIFO message is being transmitted, the next pending message within the transmit FIFO is included in the transmission arbitration. When the TPM bit is 1, mailbox number transmit mode is selected and the transmit mailbox with the smallest mailbox number has the highest priority. In FIFO mailbox mode, the transmit FIFO has lower priority than normal mailboxes (mailboxes [0] to [23]). #### 24.1.1.9 TSRC Bit Set the TSRC bit to reset the time stamp counter. When this bit is set to 1, the CiTSR register becomes 0000h (i = 0, 1). It automatically becomes 0. #### 24.1.1.10 TSPS Bit Set the TSPS bit to select the prescaler for the time stamp. The reference clock for the time stamp can be selected among 1, 2, 4, and 8 bit times. ## 24.1.2 CANi Clock Select Register (CiCLKR) (i = 0, 1) Figure 24.3 Registers C0CLKR and C1CLKR ### 24.1.2.1 CCLKS Bit When the CCLKS bit is set to 0, the CAN clock source (fCAN) originates from the PLL frequency synthesizer. When this bit is set to 1, fCAN originates directly from the external XIN pin bypassing the PLL. 24. CAN Module R32C/161 Group #### CANi Bit Configuration Register (CiBCR) (i = 0, 1) 24.1.3 - CAN reset mode. Once this register is set, it can be rewritten in CAN reset mode or CAN halt mode. - 2. The CiBCR register consists of 24 bits. A 32-bit read/write access should be performed carefully as to not rewrite the CiCLKR register. Figure 24.4 Registers C0BCR and C1BCR Refer to 24.3 "CAN Communication Speed Configuration" for the bit timing configuration. ### 24.1.3.1 BRP Bit The BRP bit sets the frequency of the CAN communication clock (fCANCLK). One fCANCLK cycle is measured as Time Quantum (Tq). ### 24.1.3.2 TSEG1 Bit Set the TSEG1 bit to specify the total length of the propagation time segment (PROP\_SEG) and phase buffer segment 1 (PHASE\_SEG1) with the value of Tq. A value from 4 to 16 Tq can be set. ### 24.1.3.3 TSEG2 Bit Set the TSEG2 bit to specify the length of phase buffer segment TSEG2 (PHASE\_SEG2) with the value of Tq. A value from 2 to 8 Tq can be set. Set the value smaller than that of the TSEG1 bit. ### 24.1.3.4 SJW Bit Set the SJW bit to specify the resynchronization jump width with the value of Tq. A value from 1 to 4 Tq can be set. Set the value smaller than or equal to that of the TSEG2 bit. # 24.1.4 CANi Mask Register k (CiMKRk) (i = 0, 1; k = 0 to 7) Figure 24.5 Registers C0MKR0 to C1MKR7 Refer to 24.5 "Acceptance Filtering and Masking Function" for the masking function in FIFO mailbox mode. ## 24.1.4.1 EID Bit The EID bit is the filter mask bit corresponding to the CAN extended ID bit. This bit is used to receive extended ID messages. When the EID bit is 0, the corresponding EID bit is not compared for the received ID and the mailbox ID. When this bit is 1, the corresponding EID bit is compared for the received ID and the mailbox ID. ## 24.1.4.2 SID Bit The SID bit is the filter mask bit corresponding to the CAN standard ID bit. This bit is used to receive both standard ID and extended ID messages. When the SID bit is 0, the corresponding SID bit is not compared for the received ID and the mailbox ID. When this bit is 1, the corresponding SID bit is compared for the received ID and the mailbox ID. # 24.1.5 CANi FIFO Received ID Compare Register n (CiFIDCR0 and CiFIDCR1) (i = 0, 1; n = 0, 1) Figure 24.6 Registers C0FIDCR0 to C1FIDCR1 Registers CiFIDCR0 and CiFIDCR1 are enabled when the MBM bit in the CiCTLR register is set to 1 (FIFO mailbox mode). Bits EID, SID, RTR, and IDE in registers CiMB28 to CiMB31 are disabled. Refer to 24.5 "Acceptance Filtering and Masking Function" for details on using these registers. ## 24.1.5.1 EID Bit The EID bit sets the extended ID of data frames and remote frames. This bit is used to receive extended ID messages. #### 24.1.5.2 SID Bit The SID bit sets the standard ID of data frames and remote frames. This bit is used to receive both standard ID and extended ID messages. ## 24.1.5.3 RTR Bit The RTR bit sets the specified frame format of data frames or remote frames. This bit specifies the following operations: - When both RTR bits in registers CiFIDCR0 and CiFIDCR1 are set to 0, only data frames can be received (i = 0, 1). - When both RTR bits in registers CiFIDCR0 and CiFIDCR1 are set to 1, only remote frames can be received. - When the RTR bits in registers CiFIDCR0 and CiFIDCR1 are set with different values, both data frames and remote frames can be received. ## 24.1.5.4 IDE Bit The IDE bit sets the ID format of standard ID or extended ID. This bit is enabled when the IDFM bit in the CiCTLR register is 10b (mixed ID mode). When the IDFM bit is 10b, the IDE bit specifies the following operations: - When both IDE bits in registers CiFIDCR0 and CiFIDCR1 are set to 0, only standard ID frames can be received. - When both IDE bits in registers CiFIDCR0 and CiFIDCR1 are set to 1, only extended ID frames can be received. - When the IDE bits in registers CiFIDCR0 and CiFIDCR1 are set with different values, both standard ID and extended ID frames can be received. # 24.1.6 CANi Mask Invalid Register (CiMKIVLR) (i = 0, 1) Figure 24.7 Registers C0MKIVLR and C1MKIVLR Each bit corresponds to the mailbox with the same number. When each bit is 1, the acceptance mask for the mailbox corresponding to the bit number is disabled. In this case, a received message is stored in the mailbox only if its ID matches bits SID and EID in the CiMBj register (j = 0 to 31). # 24.1.7 CANi Mailbox (CiMBj) (i = 0, 1; j = 0 to 31) Table 24.4 lists the CANi mailbox memory mapping, and Table 24.5 lists the CAN data frame structure. The reset value of the CANi mailbox is undefined. Table 24.4 CANi Mailbox Memory Mapping (i = 0, 1) | Add | ress | Message Content | |----------------------|----------------------|----------------------------| | CAN0 | CAN1 | Memory mapping | | 47C00h + j × 16 + 0 | 47800h + j × 16 + 0 | EID7 to EID0 | | 47C00h + j × 16 + 1 | 47800h + j × 16 + 1 | EID15 to EID8 | | 47C00h + j × 16 + 2 | 47800h + j × 16 + 2 | SID5 to SID0, EID17, EID16 | | 47C00h + j × 16 + 3 | 47800h + j × 16 + 3 | IDE, RTR, SID10 to SID6 | | 47C00h + j × 16 + 4 | 47800h + j × 16 + 4 | _ | | 47C00h + j × 16 + 5 | 47800h + j × 16 + 5 | Data length code (DLC) | | 47C00h + j × 16 + 6 | 47800h + j × 16 + 6 | Data byte 0 | | 47C00h + j × 16 + 7 | 47800h + j × 16 + 7 | Data byte 1 | | : | : | : | | : | : | : | | : | : | : | | 47C00h + j × 16 + 13 | 47800h + j × 16 + 13 | Data byte 7 | | 47C00h + j × 16 + 14 | 47800h + j × 16 + 14 | Time stamp lower byte | | 47C00h + j × 16 + 15 | 47800h + j × 16 + 15 | Time stamp upper byte | j: Mailbox number (j = 0 to 31) Table 24.5 CAN Data Frame Structure | SID10 to | SID5 to | EID17 to | EID15 to | EID7 to | DLC3 to | DATA0 | DATA1 | DATA7 | ĺ | |----------|---------|----------|----------|---------|---------|-------|-------|-----------|---| | SID6 | SID0 | EID16 | EID8 | EID0 | DLC0 | DATAU | DAIAI | <br>DAIAI | ĺ | RENESAS Figure 24.8 Registers C0MBj and C1MBj The previous value of each mailbox is retained unless a new message is received. ## 24.1.7.1 EID Bit The EID bit sets the extended ID of data frames and remote frames. This bit is used to transmit or receive extended ID messages. #### 24.1.7.2 SID Bit The SID bit sets the standard ID of data frames and remote frames. This bit is used to transmit or receive both standard ID and extended ID messages. ## 24.1.7.3 RTR Bit The RTR bit sets the frame format of data frames or remote frames. This bit specifies the following operations: - The receive mailbox receives only frames with the format specified by the RTR bit. - The transmit mailbox transmits according to the frame format specified by the RTR bit. - The receive FIFO mailbox receives the data frame, remote frame, or both frames specified by the RTR bit in registers CiFIDCR0 and CiFIDCR1 (i = 0, 1). - The transmit FIFO mailbox transmits the data frame or remote frame specified by the RTR bit in the relevant transmitting message. ## 24.1.7.4 IDE Bit The IDE bit sets the ID format of standard IDs or extended IDs. This bit is enabled when the IDFM bit in the CiCTLR register is 10b (mixed ID mode). When the IDFM bit is 10b, the IDE bit specifies the following operations: - The receive mailbox receives only the ID format specified by the IDE bit. - The transmit mailbox transmits according to the ID format specified by the IDE bit. - The receive FIFO mailbox receives messages with the standard ID, extended ID, or both IDs specified by the IDE bit in registers CiFIDCR0 and CiFIDCR1. - The transmit FIFO mailbox transmits messages with the standard ID or extended ID specified by the IDE bit in the relevant transmitting message. ## 24.1.7.5 DLC The DLC sets the number of data bytes to be transmitted in a data frame. When data is requested using a remote frame, the number of data bytes to be requested is set. When a data frame is received, the number of received data bytes is stored. When a remote frame is received, the number of requested data bytes is stored. Table 24.6 lists the data length corresponding to the DLC. Table 24.6 Data Length Corresponding to the DLC | DLC[3] | DLC[2] | DLC[1] | DLC[0] | Data Length | |--------|--------|--------|--------|-------------| | 0 | 0 | 0 | 0 | 0 bytes | | 0 | 0 | 0 | 1 | 1 byte | | 0 | 0 | 1 | 0 | 2 bytes | | 0 | 0 | 1 | 1 | 3 bytes | | 0 | 1 | 0 | 0 | 4 bytes | | 0 | 1 | 0 | 1 | 5 bytes | | 0 | 1 | 1 | 0 | 6 bytes | | 0 | 1 | 1 | 1 | 7 bytes | | 1 | Х | Х | Х | 8 bytes | X: Any value ## 24.1.7.6 DATA0 to DATA7 DATA0 to DATA7 store the transmitted or received CAN message data. Transmission or reception starts from DATA0. The bit order on the CAN bus is MSB first, and transmission or reception starts from bit 7. ## 24.1.7.7 TSL and TSH TSL and TSH store the counter value of the time stamp when received messages are stored in the mailbox. ## 24.1.8 CANi Mailbox Interrupt Enable Register (CiMIER) (i = 0, 1) Figure 24.9 Registers COMIER and C1MIER Interrupts can be individually enabled for each mailbox. In normal mailbox mode (bits 0 to 31) and in FIFO mailbox mode (bits 0 to 23), each bit corresponds to the mailbox with the same number. These bits enable or disable transmission/reception complete interrupts for the corresponding mailboxes. In FIFO mailbox mode, bits 24, 25, 28, and 29 specify whether transmit/receive FIFO interrupts are enabled/disabled and timing when interrupt requests are generated. "Buffer warning" indicates a state in which the third unread message is stored in the receive FIFO. # 24.1.9 CANi Message Control Register j (CiMCTLj) (i = 0, 1; j = 0 to 31) - 1. Write to the CiMCTLj register in CAN operation mode or CAN halt mode. - 2. Do not use registers CiMCTL24 to CiMCTL31 in FIFO mailbox mode. - 3. It can only be set to 0. Writing 1 to this bit has no effect. - 4. When writing 0 to bits NEWDATA, SENTDATA, MSGLOST, TRMABT, RECREQ, and TRMREQ by a program, use the MOV instruction to ensure that only the specified bit is set to 0 and the other bits are set to 1. - 5. To enter one-shot receive mode, write 1 to the ONESHOT bit at the same time as setting the RECREQ bit to 1. To exit one-shot receive mode, write 0 to the ONESHOT bit after writing 0 to the RECREQ bit and confirming it has been set to 0. - To enter one-shot transmit mode, write 1 to the ONESHOT bit at the same time as setting the TRMREQ bit to 1. To exit one-shot transmit mode, write 0 to the ONESHOT bit after the message has been transmitted or aborted. - 6. Do not set both the RECREQ and TRMREQ bits to 1. - 7. When setting the RECREQ bit to 0, set bits MSGLOST, NEWDATA, RECREQ to 0 simultaneously. Figure 24.10 Registers C0MCTLj and C1MCTLj ## 24.1.9.1 NEWDATA Bit The NEWDATA bit becomes 1 when a new message is being stored or has been stored to the mailbox. The timing for setting this bit to 1 is simultaneous with the INVALDATA bit. The NEWDATA bit is set to 0 by writing 0 by a program. It cannot be set to 0 by a program while the related INVALDATA bit is 1. #### 24.1.9.2 **SENTDATA Bit** The SENTDATA bit becomes 1 when data transmission from the corresponding mailbox is completed. This bit is set to 0 by writing 0 by a program. Set the TRMREQ bit to 0 before setting the SENTDATA bit to 0. Bits SENTDATA and TRMREQ cannot be set to 0 simultaneously. To transmit a new message from the corresponding mailbox, set the SENTDATA bit to 0. #### 24.1.9.3 INVALDATA Bit After a message has been received, the INVALDATA bit becomes 1 while the received message is being updated into the corresponding mailbox. This bit becomes 0 immediately after the message has been stored. When the mailbox is read while this bit is 1, the data is undefined. ## 24.1.9.4 TRMACTIVE Bit The TRMACTIVE bit becomes 1 when the corresponding mailbox of the CAN module begins transmitting a message. This bit becomes 0 when the CAN module loses CAN bus arbitration, a CAN bus error occurs, or data transmission is completed. ## 24.1.9.5 MSGLOST Bit While the NEWDATA bit is 1, the MSGLOST bit becomes 1 when the mailbox is overwritten or overrun by a newly received message. This bit becomes 1 at the end of the sixth bit of EOF. This bit is set to 0 by writing 0 by a program. In both overwrite and overrun modes, during five cycles of the peripheral bus clock following the sixth bit of EOF, the MSGLOST bit does not become 0 even if it is set to 0 by a program. ## 24.1.9.6 TRMABT Bit The TRMABT bit becomes 1 in the following cases: - Following a transmission abort request, the transmission abort is completed before starting transmission. - Following a transmission abort request, the CAN module detects CAN bus arbitration lost or a CAN bus error. - In one-shot transmission mode (the RECREQ bit is 0, the TRMREQ bit is 1, and the ONESHOT bit is 1), the CAN module detects CAN bus arbitration lost or a CAN bus error. The TRMABT bit does not become 1 when data transmission is completed. In this case, the SENTDATA bit becomes 1. The TRMABT bit can be set to 0 by a program. ## 24.1.9.7 **ONESHOT Bit** The ONESHOT bit can be used in receive mode and transmit mode. ## (1) One-shot Receive Mode When the ONESHOT bit is set to 1 in receive mode (the RECREQ bit is 1 and the TRMREQ bit is 0), the mailbox receives a message only once. The mailbox does not behave as a receive mailbox after having received a message once. The behavior of bits NEWDATA and INVALDATA is the same as in normal reception mode. In one-shot receive mode, the MSGLOST bit does not become 1 To set the ONESHOT bit to 0, first write 0 to the RECREQ bit and ensure that it has been set to 0. ## (2) One-shot Transmit Mode When the ONESHOT bit is set to 1 in transmit mode (the RECREQ bit is 0 and the TRMREQ bit is 1), the CAN module transmits a message only once. The CAN module does not transmit the message again if a CAN bus error or CAN bus arbitration lost occurs. When the transmission is completed, the SENTDATA bit becomes 1. If the transmission cannot be completed due to a CAN bus error or CAN bus arbitration lost, the TRMABT bit becomes 1. Set the ONESHOT bit to 0 after the SENTDATA or TRMABT bit is set to 1. ## 24.1.9.8 RECREQ Bit Set the RECREQ bit to select one of the receive modes shown in Table 24.11. When the RECREQ bit is set to 1, the corresponding mailbox is configured to receive a data frame or a remote frame. When this bit is set to 0, the corresponding mailbox is not configured for reception of a data frame or a remote frame. Due to hardware protection, the RECREQ bit cannot be set to 0 by a program during the following period: Hardware protection is started • from the acceptance filter procedure (the beginning of the CRC field) Hardware protection is released - for the mailbox that is specified to receive the incoming message, after the received data is stored into the mailbox or a CAN bus error occurs (i.e. a maximum period of hardware protection is from the beginning of the CRC field to the end of the seventh bit of EOF) - for the other mailboxes, after the acceptance filter procedure - if no mailbox is specified to receive the message, after the acceptance filter procedure When setting the RECREQ bit to 1, do not set 1 to the TRMREQ bit. To change the configuration of a mailbox from transmit to receive, first abort the transmission and then set bits SENTDATA and TRMABT to 0 before changing to receive. #### 24.1.9.9 TRMREQ Bit The TRMREQ bit selects transmit modes shown in Table 24.11. When this bit is set to 1, the corresponding mailbox is configured to transmit a data frame or a remote frame. When this bit is set to 0, the corresponding mailbox is not configured to transmit a data frame or a remote frame. If the TRMREQ bit is changed from 1 to 0 to cancel the corresponding transmission request, either the TRMABT or SENTDATA bit is set to 1. When setting the TRMREQ bit to 1, do not set the RECREQ bit to 1. To change the configuration of a mailbox from receive to transmit, first abort the reception and then set bits NEWDATA and MSGLOST to 0 before changing to transmit. # 24.1.10 CANi Receive FIFO Control Register (CiRFCR) (i = 0, 1) Figure 24.11 Registers C0RFCR and C1RFCR ## 24.1.10.1 RFE Bit When the RFE bit is set to 1, the receive FIFO is enabled. When this bit is set to 0, the receive FIFO is disabled for reception and becomes empty (the RFEST bit is 1). Do not set this bit to 1 in normal mailbox mode (the MBM bit in the CiCTLR register is 0 (i = 0, 1)). Due to hardware protection, the RFE bit cannot be set to 0 by a program during the following period: Hardware protection is started • from the acceptance filter procedure (the beginning of the CRC field) Hardware protection is released - if the receive FIFO is specified to receive the incoming message, after the received data is stored into the receive FIFO or a CAN bus error occurs (i.e. a maximum period of hardware protection is from the beginning of the CRC field to the end of the seventh bit of EOF). - if the receive FIFO is not specified to receive the message, after the acceptance filter procedure. ## 24.1.10.2 RFUST Bit The RFUST bit indicates the number of unread messages in the receive FIFO. The value of this bit is initialized to 000b when the RFE bit is set to 0. ## 24.1.10.3 RFMLF Bit The RFMLF bit becomes 1 (receive FIFO message lost has occurred) when the receive FIFO receives a new message and the receive FIFO is full. This bit becomes 1 at the end of the sixth bit of EOF. The RFMLF bit is set to 0 by writing 0 by a program. In both overwrite and overrun modes, this bit cannot be set to 0 (no receive FIFO message lost has occurred) by a program due to hardware protection during the five cycles of the peripheral bus clock following the sixth bit of EOF, when the receive FIFO is full and determined to receive the message. #### 24.1.10.4 RFFST Bit The RFFST bit becomes 1 (receive FIFO is full) when there are four unread messages in the receive FIFO. This bit becomes 0 (receive FIFO is not full) when there are less than four unread messages in the receive FIFO. This bit becomes 0 when the RFE bit is 0. ## 24.1.10.5 RFWST Bit The RFWST bit becomes 1 (receive FIFO is buffer warning) when there are three unread messages in the receive FIFO. This bit becomes 0 (receive FIFO is not buffer warning) when there are less than three or equal to four unread messages in the receive FIFO. This bit becomes 0 when the RFE bit is 0. ## 24.1.10.6 RFEST Bit The RFEST bit becomes 1 (no unread message in receive FIFO) when there are no unread messages in the receive FIFO. This bit becomes 1 when the RFE bit is set to 0. The RFEST bit becomes 0 (unread message in receive FIFO) when there is one or more unread messages in the receive FIFO. Figure 24.12 shows receive FIFO mailbox operation. Figure 24.12 Receive FIFO Mailbox Operation (Bits 29 and 28 in CiMIER Register are 01b and 11b) (i = 0, 1) ## 24.1.11 CANI Receive FIFO Pointer Control Register (CiRFPCR) (i = 0, 1) Figure 24.13 Registers C0RFPCR and C1RFPCR When there are messages in the receive FIFO, write FFh to the CiRFPCR register by a program to increment the CPU-side pointer for the receive FIFO to the next mailbox location. Do not write to the CiRFPCR register when the RFE bit in the CiRFCR register is 0 (receive FIFO disabled). Both the CAN-side pointer and the CPU-side pointer increment when a new message is received and the RFFST bit is 1 (receive FIFO is full) in overwrite mode. When the RFMLF bit is 1 in this condition, the CPU-side pointer does not increment by writing to the CiRFPCR register by a program. ## 24.1.12 CANi Transmit FIFO Control Register (CiTFCR) (i = 0, 1) Figure 24.14 Registers C0TFCR and C1TFCR ## 24.1.12.1 TFE Bit When the TFE bit is set to 1, the transmit FIFO is enabled. When this bit is set to 0, the transmit FIFO becomes empty (TFEST bit is 1) and then unsent messages from the transmit FIFO are lost as described below: - If a message from the transmit FIFO is not scheduled for the next transmission or during transmission. - Following the completion of a transmission, a CAN bus error, CAN bus arbitration lost, or entry to CAN halt mode if a message from the transmit FIFO is scheduled for the next transmission or already during transmission. Before setting the TFE bit to 1 again, ensure that the TFEST bit is 1. After setting the TFE bit to 1, write transmit data to the CiMB24 register. Do not set this bit to 1 in normal mailbox mode (MBM bit in the CiCTLR register is 0). ## 24.1.12.2 TFUST Bit The TFUST bit indicates the number of unsent messages in the transmit FIFO. After the TFE bit is set to 0, the value of the TFUST bit is initialized to 000b when transmission abort or transmission is completed. ## 24.1.12.3 TFFST Bit The TFFST bit becomes 1 (transmit FIFO is full) when there are four unsent messages in the transmit FIFO. This bit becomes 0 (transmit FIFO is not full) when there are less than four unsent messages in the transmit FIFO. This bit becomes 0 when a transmission from the transmit FIFO has been aborted. #### 24.1.12.4 TFEST Bit The TFEST bit becomes 1 (no unsent message in transmit FIFO) when there are no unsent messages in the transmit FIFO. This bit becomes 1 when transmission from the transmit FIFO has been aborted. The TFEST bit becomes 0 (unsent message in transmit FIFO) when there is at least one unsent messages in the transmit FIFO. Figure 24.15 shows transmit FIFO mailbox operation. Figure 24.15 Transmit FIFO Mailbox Operation (Bits 25 and 24 in CiMIER Register are 01b and 11b) (i = 0, 1) # 24.1.13 CANi Transmit FIFO Pointer Control Register (CiTFPCR) (i = 0, 1) Figure 24.16 Registers C0TFPCR and C1TFPCR When the transmit FIFO is not full, write FFh to the CiTFPCR register by a program to increment the CPU-side pointer for the transmit FIFO to the next mailbox location. Do not write to the CiTFPCR register when the TFE bit in the CiTFCR register is 0 (transmit FIFO disabled). # 24.1.14 CANi Status Register (CiSTR) (i = 0, 1) Figure 24.17 Registers COSTR and C1STR ## 24.1.14.1 RSTST Bit The RSTST bit becomes 1 when the CAN module enters CAN reset mode. This bit is 0 when the CAN module is not in CAN reset mode. Even when the state is changed from CAN reset mode to CAN sleep mode, the RSTST bit remains 1. #### 24.1.14.2 HLTST Bit The HLTST bit becomes 1 when the CAN module enters CAN halt mode. This bit is 0 when the CAN module is not in CAN halt mode. Even when the state is changed from CAN halt mode to CAN sleep mode, the HLTST bit remains 1. #### 24.1.14.3 SLPST Bit The SLPST bit becomes 1 when the CAN module enters CAN sleep mode. This bit is 0 when the CAN module is not in CAN sleep mode. ## 24.1.14.4 EPST Bit The EPST bit becomes 1 when the value of the CiTECR or CiRECR register exceeds 127 and the CAN module enters the error-passive state ( $128 \le \text{TEC} < 256$ or $128 \le \text{REC} < 256$ ) (i = 0, 1). This bit is 0 when the CAN module is not in the error-passive state. TEC indicates the value of the transmit error counter (CiTECR register) and REC indicates the value of the receive error counter (CiRECR register). ## 24.1.14.5 BOST Bit The BOST bit becomes 1 when the value of the CiTECR register exceeds 255 and the CAN module enters the bus-off state (TEC $\geq$ 256). This bit is 0 when the CAN module is not in the bus-off state. #### 24.1.14.6 TRMST Bit The TRMST bit becomes 1 when the CAN module performs as a transmitter node or enters the bus-off state. This bit becomes 0 when the CAN module performs as a receiver node or enters the bus-idle state. #### 24.1.14.7 RECST Bit The RECST bit becomes 1 when the CAN module performs as a receiver node. This bit becomes 0 when the CAN module performs as a transmitter node or enters the bus-idle state. ## 24.1.14.8 NDST Bit The NDST bit becomes 1 when at least one NEWDATA bit in the CiMCTLj register is 1 regardless of the value of the CiMIER register (j = 0 to 31). The NDST bit becomes 0 when all NEWDATA bits are 0. ## 24.1.14.9 SDST Bit The SDST bit becomes 1 when at least one SENTDATA bit in the CiMCTLj register is 1 regardless of the value of the CiMIER register (i = 0, 1; j = 0 to 31). The SDST bit becomes 0 when all SENTDATA bits are 0. #### 24.1.14.10 RFST Bit The RFST bit is 1 when there are messages in the receive FIFO. This bit is 0 when the receive FIFO is empty. This bit becomes 0 when normal mailbox mode is selected. ## 24.1.14.11 TFST Bit The TFST bit is 1 when the transmit FIFO is not full. This bit is 0 when the transmit FIFO is full. This bit becomes 0 when normal mailbox mode is selected. #### 24.1.14.12 NMLST Bit The NMLST bit becomes 1 when at least one MSGLOST bit in the CiMCTLj register is 1 regardless of the value of the CiMIER register. The NMLST bit becomes 0 when all MSGLOST bits are 0. ## 24.1.14.13 FMLST Bit The FMLST bit becomes 1 when the RFMLF bit in the CiRFCR register is 1 regardless of the value of the CiMIER register. The FMLST bit becomes 0 when the RFMLF bit is 0. ## 24.1.14.14 TABST Bit The TABST bit becomes 1 when at least one TRMABT bit in the CiMCTLj register is 1 regardless of the value of the CiMIER register. The TABST bit becomes 0 when all TRMABT bits are 0. #### 24.1.14.15 EST Bit The EST bit becomes 1 when at least one error is detected by the CiEIFR register regardless of the value of the CiEIER register. This bit becomes 0 when no error is detected by the CiEIFR register. # 24.1.15 CANi Mailbox Search Mode Register (CiMSMR) (i = 0, 1) Figure 24.18 Registers C0MSMR and C1MSMR ## 24.1.15.1 MBSM Bit Set the MBSM bit to select the search mode for the mailbox search function. When this bit is 00b, receive mailbox search mode is selected. In this mode, the search targets are the NEWDATA bit in the CiMCTLj register for the normal mailbox and the RFEST bit in the CiRFCR register (j = 0 to 31). When the MBSM bit is 01b, transmit mailbox search mode is selected. In this mode, the search target is the SENTDATA bit in the CiMCTLj register. When the MBSM bit is 10b, message lost search mode is selected. In this mode, the search targets are the MSGLOST bit in the CiMCTLj register for the normal mailbox and the RFMLF bit in the CiRFCR register. When the MBSM bit is 11b, channel search mode is selected. In this mode, the search target is the CiCSSR register. Refer to 24.1.17 "CANi Channel Search Support Register (CiCSSR) (i = 0, 1)". # 24.1.16 CANi Mailbox Search Status Register (CiMSSR) (i = 0, 1) Figure 24.19 Registers C0MSSR and C1MSSR ## 24.1.16.1 MBNST Bit The MBNST bit outputs the smallest mailbox number that is searched in each mode of the CiMSMR register (i = 0, 1). In receive mailbox, transmit mailbox, and message lost search modes, the value of the mailbox, i.e., the search result to be output, is updated as follows: - When the NEWDATA, SENTDATA, or MSGLOST bit for the output mailbox is set to 0. - When the NEWDATA, SENTDATA, or MSGLOST bit for a higher-priority mailbox is set to 1. In receive mailbox search and message lost search modes, the receive FIFO (mailbox [28]) is output when there are messages in the receive FIFO, and there are no unread received messages or lost messages in any of the normal mailboxes (mailboxes [0] to [23]). In transmit mailbox search mode, the transmit FIFO (mailbox [24]) is not output. Table 24.7 lists the operation of MBNST bit in FIFO mailbox mode. Table 24.7 Operation of MBNST Bit in FIFO Mailbox Mode | MBSM Bit | Mailbox [24] | Mailbox [28] | |--------------|----------------------------|-----------------------------------------------------------| | IVIDOIVI DIL | (Transmit FIFO) | (Receive FIFO) | | | Mailbox [24] is not output | Mailbox [28] is output when no NEWDATA bit for the normal | | 00b | | mailbox is set to 1 and there are messages in the receive | | | | FIFO | | 01b | | Mailbox [28] is not output | | | | Mailbox [28] is output when no MSGLOST bit for the normal | | 10b | | mailbox is set to 1 and the RFMLF bit is set to 1 in the | | | | receive FIFO | | 11b | | Mailbox [28] is not output | In channel search mode, the MBNST bit outputs the corresponding channel number. After the CiMSSR register is read by a program, the next target channel number is output. ## 24.1.16.2 SEST Bit The SEST bit becomes 1 when no corresponding mailbox is found after searching all mailboxes. For example, in transmit mailbox search mode, the SEST bit becomes 1 when no SENTDATA bit for mailboxes is 1. The SEST bit becomes 0 when at lease one SENTDATA bit is 1. When the SEST bit is 1, the value of the MBNST bit is undefined. # 24.1.17 CANi Channel Search Support Register (CiCSSR) (i = 0, 1) Figure 24.20 Registers C0CSSR and C1CSSR The bits in the CiCSSR register, which are set to 1, are encoded by an 8-to-3 priority encoder (the lower bit position, the higher priority) and output to the MBNST bits in the CiMSSR register. The value of the CiMSSR register is updated whenever the CiMSSR register is read. Figure 24.21 shows the write and read of registers CiCSSR and CiMSSR. Figure 24.21 Write and Read of Registers CiCSSR and CiMSSR (i = 0, 1) The value of the CiCSSR register is also updated whenever the CiMSSR register is read. When the CiCSSR register is read, the value before the 8-to-3 priority encoder conversion is read. ## 24.1.18 CANi Acceptance Filter Support Register (CiAFSR) (i = 0, 1) Figure 24.22 Registers C0AFSR and C1AFSR The acceptance filter support unit (ASU) can be used for data table (8 bits $\times$ 256) search. In the data table, all standard IDs created by the user are set to be enabled/disabled in bit units. When the CiAFSR register is written with 16-bit unit data including the SID bit in the CiMBj register, in which a received ID is stored, a decoded row (byte offset) position and column (bit) position for data table search can be read (j = 0 to 31). The ASU can be used for standard (11-bit) IDs only. The ASU is enabled in the following cases: - When the ID to receive cannot be masked by the acceptance filter. Example: IDs to receive: 078h, 087h, 111h - When there are too many IDs to receive and software filtering time is expected to be shortened. Figure 24.23 shows the write and read of CiAFSR register. Figure 24.23 Write and Read of CiAFSR Register (i = 0, 1; j = 0 to 31) # 24.1.19 CANi Error Interrupt Enable Register (CiEIER) (i = 0, 1) Figure 24.24 Registers C0EIER and C1EIER The CiEIER register is used to set the error interrupt enabled/disabled individually for each error interrupt source in the CiEIFR register. ## 24.1.19.1 BEIE Bit When the BEIE bit is 0, no error interrupt request is generated even if the BEIF bit in the CiEIFR register is set to 1 (i = 0, 1). When the BEIE bit is 1, an error interrupt request is generated if the BEIF bit is set to 1. #### 24.1.19.2 EWIE Bit When the EWIE bit is 0, no error interrupt request is generated even if the EWIF bit in the CiEIFR register is set to 1. When the EWIE bit is 1, an error interrupt request is generated if the EWIF bit is set to 1. ## 24.1.19.3 EPIE Bit When the EPIE bit is 0, no error interrupt request is generated even if the EPIF bit in the CiEIFR register is set to 1. When the EPIE bit is 1, an error interrupt request is generated if the EPIF bit is set to 1. #### 24.1.19.4 BOEIE Bit When the BOEIE bit is 0, no error interrupt request is generated even if the BOEIF bit in the CiEIFR register is set to 1. When the BOEIE bit is 1, an error interrupt request is generated if the BOEIF bit is set to 1. ## 24.1.19.5 BORIE Bit When the BORIE bit is 0, an error interrupt request is not generated even if the BORIF bit in the CiEIFR register is set to 1. When the BORIE bit is 1, an error interrupt request is generated if the BORIF bit is set to 1. ## 24.1.19.6 ORIE Bit When the ORIE bit is 0, no error interrupt request is generated even if the ORIF bit in the CiEIFR register is set to 1. When the ORIE bit is 1, an error interrupt request is generated if the ORIF bit is set to 1. #### 24.1.19.7 OLIE Bit When the OLIE bit is 0, no error interrupt request is generated even if the OLIF bit in the CiEIFR register is set to 1. When the OLIE bit is 1, an error interrupt request is generated if the OLIF bit is set to 1. ## 24.1.19.8 BLIE Bit When the BLIE bit is 0, no error interrupt request is generated even if the BLIF bit in the CiEIFR register is set to 1. When the BLIE bit is 1, an error interrupt request is generated if the BLIF bit is set to 1. # 24.1.20 CANi Error Interrupt Factor Judge Register (CiEIFR) (i = 0, 1) Figure 24.25 Registers C0EIFR and C1EIFR If an event corresponding to each bit occurs, the corresponding bit in the CiEIFR register is set to 1 regardless of the setting of the CiEIER register. To set each bit to 0, write 0 by a program. If the set timing occurs simultaneously with the clear timing by the program, the bit becomes 1. #### 24.1.20.1 BEIF Bit The BEIF bit becomes 1 when a bus error is detected. ## 24.1.20.2 EWIF Bit The EWIF bit becomes 1 when the value of the receive error counter (REC) or transmit error counter (TEC) exceeds 95. This bit becomes 1 only when the REC or TEC initially exceeds 95. Thus, if 0 is written to the EWIF bit by a program while the REC or TEC remains greater than 95, this bit does not become 1 until the REC and the TEC go below 95 and then exceed 95 again. ## 24.1.20.3 EPIF Bit The EPIF bit becomes 1 when the CAN error state enters the error-passive state (the REC or TEC value exceeds 127). This bit becomes 1 only when the REC or TEC initially exceeds 127. Thus, if 0 is written to the EPIF bit by a program while the REC or TEC remains greater than 127, this bit does not become 1 until the REC and the TEC go below 127 and then exceed 127 again. ## 24.1.20.4 BOEIF Bit The BOEIF bit becomes 1 when the CAN error state enters the bus-off state (the TEC value exceeds 255). This bit also becomes 1 when the BOM bit in the CiCTLR register is 01b (entry to CAN halt mode automatically at bus-off entry) and the CAN module enters the bus-off state (i = 0, 1). #### 24.1.20.5 BORIF Bit The BORIF bit becomes 1 when the CAN module recovers from the bus-off state normally by detecting 11 consecutive bits 128 times in the following conditions: - (1) When the BOM bit in the CiCTLR register is 00b - (2) When the BOM bit is 10b - (3) When the BOM bit is 11b The BORIF bit does not become 1 if the CAN module recovers from the bus-off state in the following conditions: - (1) When the CANM bit in the CiCTLR register is set to 01b (CAN reset mode) - (2) When the RBOC bit in the CiCTLR register is set to 1 (forced recovery from bus-off) - (3) When the BOM bit is 01b - (4) When the BOM bit is 11b and the CANM bit is set to 10b (CAN halt mode) before normal recovery occurs Table 24.8 lists the operation of bits BOEIF and BORIF according to BOM bit setting value. Table 24.8 Operation of Bits BOEIF and BORIF According to BOM Bit Setting Value | BOM Bit | BOEIF Bit | BORIF Bit | |---------|-----------------------------|--------------------------------------------------------| | 00b | Becomes 1 when entering the | Becomes 1 when recovering from the bus-off state | | 01b | bus-off state | Does not become 1 | | 10b | | Becomes 1 when recovering from the bus-off state | | 11b | | Becomes 1 if normal bus-off recovery occurs before the | | | | CANM bit is set to 10b (CAN halt mode) | #### 24.1.20.6 ORIF Bit The ORIF bit becomes 1 when a receive overrun occurs. This bit does not become 1 in overwrite mode. In overwrite mode, a reception complete interrupt request is generated if an overwrite condition occurs, thus this bit does not become 1. In normal mailbox mode, if an overrun occurs in any mailbox from [0] to [31] in overrun mode, this bit is set to 1. In FIFO mailbox mode, if an overrun occurs in any mailbox from [0] to [23] or the receive FIFO in overrun mode, this bit becomes 1. ## 24.1.20.7 OLIF Bit The OLIF bit becomes 1 if the transmitting condition of an overload frame is detected when the CAN module performs transmission or reception. ## 24.1.20.8 BLIF Bit The BLIF bit becomes 1 if 32 consecutive dominant bits are detected on the CAN bus while the CAN module is in CAN operation mode. After the BLIF bit becomes 1, 32 consecutive dominant bits are detected again under either of the following conditions: - After this bit is set to 0 from 1, recessive bits are detected. - After this bit is set to 0 from 1, the CAN module enters CAN reset mode or CAN halt mode and then enters CAN operation mode again. # 24.1.21 CANi Receive Error Count Register (CiRECR) (i = 0, 1) Figure 24.26 Registers C0RECR and C1RECR The CiRECR register indicates the value of the receive error counter. Refer to the CAN Specification (ISO 11898-1) for the increment/decrement conditions of the receive error counter. # 24.1.22 CANi Transmit Error Count Register (CiTECR) (i = 0, 1) Figure 24.27 Registers C0TECR and C1TECR The CiTECR register indicates the value of the TEC error counter. Refer to the CAN Specification (ISO 11898-1) for the increment/decrement conditions of the transmit error counter. # 24.1.23 CANi Error Code Store Register (CiECSR) (i = 0, 1) - 1. Writing 1 to this bit has no effect. - 2. When writing 0 to bits SEF, FEF, AEF, CEF, BE1F, BE0F, and ADEF by a program, use the MOV instruction to ensure that only the specified bit is set to 0 and the other bits are set to 1. - 3. Write to the EDPM bit in CAN reset mode or CAN halt mode. - 4. If more than one error condition is detected simultaneously, all corresponding bits are set to 1. Figure 24.28 Registers C0ECSR and C1ECSR The CiECSR register can be used to monitor whether an error has occurred on the CAN bus. Refer to the CAN Specification (ISO 11898-1) to check the generation conditions of each error. To set each bit except the EDPM bit to 0, write 0 by a program. If the timing at which each bit is set to 1 and the timing at which is written by a program are the same, the relevant bit is set to 1. ## 24.1.23.1 SEF Bit The SEF bit becomes 1 when a stuff error is detected. #### 24.1.23.2 FEF Bit The FEF bit becomes 1 when a form error is detected. #### 24.1.23.3 AEF Bit The AEF bit becomes 1 when an ACK error is detected. ## 24.1.23.4 CEF Bit The CEF bit becomes 1 when a CRC error is detected. ## 24.1.23.5 BE1F Bit The BE1F bit becomes 1 when a recessive bit error is detected. ## 24.1.23.6 BE0F Bit The BE0F bit becomes 1 when a dominant bit error is detected. ## 24.1.23.7 ADEF Bit The ADEF bit becomes 1 when a form error is detected with the ACK delimiter during transmission. ## 24.1.23.8 EDPM Bit The EDPM bit selects the output mode of the CiECSR register (i = 0, 1). When this bit is set to 0, the CiECSR register outputs the first error code. When this bit is set to 1, the CiECSR register outputs the accumulated error code. # 24.1.24 CANi Time Stamp Register (CiTSR) (i = 0, 1) Figure 24.29 Registers C0TSR and C1TSR When the CiTSR register is read, the value of the time stamp counter (16-bit free-running counter) at that moment is read. The value of the time stamp counter reference clock is a multiple of 1 bit time, as configured by the TSPS bit in the CiCTLR register. The time stamp counter stops in CAN sleep mode and CAN halt mode, and is initialized in CAN reset mode. The time stamp counter value is stored to TSL and TSH in the CiMBj register when a received message is stored in a receive mailbox (j = 0 to 31). # 24.1.25 CANi Test Control Register (CiTCR) (i = 0, 1) Figure 24.30 Registers C0TCR and C1TCR ### 24.1.25.1 TSTE Bit When the TSTE bit is set to 0, CAN test mode is disabled. When this bit is set to 1, CAN test mode is enabled. #### 24.1.25.2 TSTM Bit The TSTM bit selects the CAN test mode. The details of each CAN test mode are described below. ## 24.1.25.3 Listen Only Mode The ISO 11898-1 recommends an optional bus monitoring mode. In listen only mode, the CAN node is able to receive valid data frames and valid remote frames. It sends only recessive bits on the CAN bus and the protocol controller is not required to send the ACK bit, overload flag, or active error flag. Listen only mode can be used for baud rate detection. Do not request transmission from any mailboxes in this mode. Figure 24.31 shows the connection when listen only mode is selected. Figure 24.31 Connection when Listen Only Mode is Selected (i = 0, 1) ## 24.1.25.4 Self Test Mode 0 (External Loop Back) Self test mode 0 is provided for CAN transceiver tests. In this mode, the protocol controller treats its own transmitted messages as messages received via the CAN transceiver and stores them into a receive mailbox. To be independent from external stimulation, the protocol controller generates the ACK bit. Connect the CANiOUT/CANiIN pins to the transceiver (i = 0, 1). Figure 24.32 shows the connection when self test mode 0 is selected. Figure 24.32 Connection when Self Test Mode 0 is Selected (i = 0, 1) # 24.1.25.5 Self Test Mode 1 (Internal Loop Back) Self test mode 1 is provided for self test functions. In this mode, the protocol controller treats its transmitted messages as received messages and stores them into a receive mailbox. To be independent from external stimulation, the protocol controller generates the ACK bit. In self test mode 1, the protocol controller performs an internal feedback from the internal CANiOUT pin to the internal CANiIN pin (i = 0, 1). The input value of the external CANiIN pin is ignored. The external CANiOUT pin outputs only recessive bits. The CANiOUT/CANiIN pins do not need to be connected to the CAN bus or any external device. Figure 24.33 shows the connection when self test mode 1 is selected. Figure 24.33 Connection when Self Test Mode 1 is Selected (i = 0, 1) ## 24.2 Operating Modes The CAN module has the following four operating modes: - CAN reset mode - CAN halt mode - · CAN operation mode - · CAN sleep mode Figure 24.34 shows the transition between CAN operating modes. Figure 24.34 Transition between CAN Operating Modes (i = 0, 1) #### 24.2.1 CAN Reset Mode CAN reset mode is provided for CAN communication configuration. When the CANM bit in the CiCTLR register is set to 01b, the CAN module enters CAN reset (i = 0, 1). Then the RSTST bit in the CiSTR register becomes 1. Do not change the CANM bit until the RSTST bit becomes 1. Configure the CiBCR register before exiting CAN reset mode and entering any other mode. The following registers are initialized to their reset values after entering CAN reset mode and their initialized values are retained during CAN reset mode: - CiMCTLj register (j = 0 to 31) - CiSTR register (except bits SLPST and TFST) - CiEIFR register - CiRECR register - CiTECR register - CiTSR register - CiMSSR register - CiMSMR register - CiRFCR register - CiTFCR register - CiTCR register - CiECSR register (except EDPM bit) The previous values of the following registers are retained after entering CAN reset mode: - CiCLKR register - CiCTLR register - CiSTR register (bits SLPST and TFST) - CiMIER register - CiEIER register - CiBCR register - CiCSSR register - CiECSR register (EDPM bit only) - · CiMBj register - Registers CiMKR0 to CiMKR7 - Registers CiFIDCR0 and CiFIDCR1 - CiMKIVLR register - CiAFSR register - CiRFPCR register - CiTFPCR register #### 24.2.2 CAN Halt Mode CAN halt mode is used for mailbox configuration and test mode setting. When the CANM bit in the CiCTLR register is set to 10b, CAN halt mode is selected (i = 0, 1). Then the HLTST bit in the CiSTR register becomes 1. Do not change the CANM bit until the HLTST bit becomes 1. Refer to Table 24.9 "Operation in CAN Reset Mode and CAN Halt Mode" regarding the state transition conditions when transmitting or receiving. All registers except bits RSTST, HLTST, and SLPST in the CiSTR register remain unchanged when the CAN module enters CAN halt mode. Do not change registers CiCLKR, CiCTLR (except bits CANM and SLPM), and CiEIER in CAN halt mode. The CiBCR register can be changed in CAN halt mode only when listen only mode is selected to use with automatic bit rate detection. Table 24.9 Operation in CAN Reset Mode and CAN Halt Mode | Mode | Receiver | Transmitter | Bus-off | |------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CAN reset | CAN module enters CAN reset | CAN module enters CAN reset | CAN module enters CAN reset | | mode | mode without waiting for the end | mode after waiting for the end of | mode without waiting for the end | | | of message reception | message transmission (1, 4) | of bus-off recovery | | CAN halt<br>mode | CAN module enters CAN halt mode after waiting for the end of message reception (2, 3) | CAN module enters CAN halt mode after waiting for the end of message transmission (1, 4) | When the BOM bit is 00b A halt request from a program will be acknowledged only after bus-off recovery | | | | | - When the BOM bit is 01b CAN module automatically enters CAN halt mode without waiting for the end of bus-off recovery (regardless of a halt request from a program) - When the BOM bit is 10b CAN module automatically enters CAN halt mode after waiting for the end of bus-off recovery (regardless of a halt request from a program) - When the BOM bit is 11b CAN module enters CAN halt mode (without waiting for the end of bus-off recovery) if a halt is requested by a program during bus-off | BOM bit: Bit in the CiCTLR register (i = 0, 1) Notes: - If several messages are requested to be transmitted, mode transition occurs after the completion of the first message transmission. When CAN reset mode is being requested during suspend transmission, mode transition occurs when the bus is idle, the next transmission ends, or the CAN module becomes a receiver. - 2. If the CAN bus is locked at the dominant level, the program can detect this state by monitoring the BLIF bit in the CiEIFR register. - 3. If a CAN bus error occurs during reception after CAN halt mode is requested, the CAN mode transits to CAN halt mode. - 4. If a CAN bus error or arbitration lost occurs during transmission after CAN reset mode or CAN halt mode is requested, the CAN mode transits to the requested CAN mode. ## 24.2.3 CAN Sleep Mode CAN sleep mode is used for reducing current consumption by stopping the clock supply to the CAN module. After a MCU reset, the CAN module starts from CAN sleep mode. When the SLPM bit in the CiCTLR register is set to 1, the CAN module enters CAN sleep mode (i = 0, 1). Then the SLPST bit in the CiSTR register becomes 1. Do not change the value of the SLPM bit until the SLPST bit becomes 1. Other registers remain unchanged when the MCU enters CAN sleep mode. Write to the SLPM bit in CAN reset mode and CAN halt mode. Do not change any other registers (except the SLPM bit) during CAN sleep mode. Read operations are still allowed. When the SLPM bit is set to 0, the CAN module is released from CAN sleep mode. When the CAN module exits CAN sleep mode, the other registers remain unchanged. # 24.2.4 CAN Operation Mode (Excluding Bus-off State) CAN operation mode is used for CAN communication. When the CANM bit in the CiCTLR register is set to 00b, the CAN module enters CAN operation mode (i = 0, 1). Then bits RSTST and HLTST in the CiSTR register become 0. Do not change the value of the CANM bit until these bits become 0. If 11 consecutive recessive bits are detected after entering CAN operation mode, the CAN module is in the following states: - The CAN module becomes an active node on the network that enables transmission and reception of CAN messages. - Error monitoring of the CAN bus, such as receive and transmit error counters, is performed. During CAN operation mode, the CAN module may be in one of the following three submodes, depending on the status of the CAN bus: - Idle mode: Transmission or reception is not being performed. - Receive mode: A CAN message sent by another node is being received. - Transmit mode: A CAN message is being transmitted. The CAN module may receive its own message simultaneously when self test mode 0 (TSTM bits in the CiTCR register are 10b) or self test mode 1 (TSTM bits are 11b) is selected. Figure 24.35 shows the submode in CAN operation mode. Figure 24.35 Submode in CAN Operation Mode (i = 0, 1) ## 24.2.5 CAN Operation Mode (Bus-off State) The CAN module enters the bus-off state according to the increment/decrement rules for the transmit/ error counters in the CAN Specifications. The following cases apply when recovering from the bus-off state. When the CAN module is in the bus-off state, the values of the associated registers, except registers CiSTR, CiEIFR, CiRECR, CiTECR, and CiTSR, remain unchanged (i = 0, 1). - (1) When the BOM bit in the CiCTLR register is 00b (normal mode) - The CAN module enters the error-active state after it has completed the recovery from the bus-off state and CAN communication is enabled. The BORIF bit in the CiEIFR register becomes 1 (bus-off recovery detected) at this time. - (2) When the RBOC bit in the CiCTLR register is set to 1 (forced recovery from bus-off) The CAN module enters the error-active state when it is in the bus-off state and the RBOC bit is set to 1. CAN communication is enabled again after 11 consecutive recessive bits are detected. The BORIF bit does not become 1 at this time. - (3) When the BOM bit is 01b (entry to CAN halt mode automatically at bus-off entry) The CAN module enters CAN halt mode when it reaches the bus-off state. The BORIF bit does not become 1 at this time. - (4) When the BOM bit is 10b (entry to CAN halt mode automatically at bus-off end) The CAN module enters CAN halt mode when it has completed the recovery from bus-off. The BORIF bit becomes 1 at this time. - (5) When the BOM bit is 11b (entry to CAN halt mode by a program) and the CANM bit in the CiCTLR register is set to 10b (CAN halt mode) during the bus-off state The CAN module enters CAN halt mode when it is in the bus-off state and the CANM bit is set to 10b (CAN halt mode). The BORIF bit does not become 1 at this time. If the CANM bit is not set to 10b during bus-off, the same behavior as (1) applies. # 24.3 CAN Communication Speed Configuration The following description explains about the CAN communication speed configuration. ## 24.3.1 CAN Clock Configuration This group has a CAN clock selector. The CAN clock can be configured by setting the CCLKS bit in the CiCLKR register and the BRP bit in the CiBCR register (i = 0, 1). Figure 24.36 shows the block diagram of CAN clock generator. Figure 24.36 Block Diagram of the CAN Clock Generator (i = 0, 1) ### 24.3.2 Bit Timing Configuration The bit time is a single bit time for transmitting/receiving a message and consists of the three segments in the figure below. Figure 24.37 shows the bit timing. Figure 24.37 Bit Timing ### 24.3.3 Bit rate The bit rate depends on the CAN clock (fCAN), the divisor of the baud rate prescaler, and the number of Tq of 1 bit time. $$Bit \ rate[bps] = \frac{fCAN}{Baud \ rate \ prescaler \ division \ value} = \frac{fCAN}{Number \ of \ Tq \ of \ 1 \ bit \ time} = \frac{fCANCLK}{Number \ of \ Tq \ of \ 1 \ bit \ time}$$ #### Note: Divisor of the baud rate prescaler = P + 1 (P = 0 to 1023)P: Setting value of the BRP bit in the CiBCR register (i = 0, 1) Table 24.10 lists bit rate examples. Table 24.10 Bit Rate Examples | fCAN | 32 M | lHz | 24 M | lHz | 20 M | Hz | 16 M | lHz | 8 MI | Hz | |-----------|-----------|-----|-----------|-----|-----------|-----|-----------|-----|-----------|-----| | Bit Rate | No. of Tq | P+1 | No. of Tq | P+1 | No. of Tq | P+1 | No. of Tq | P+1 | No. of Tq | P+1 | | 1 Mbps | 8 Tq | 4 | 8 Tq | 3 | 10 Tq | 2 | 8 Tq | 2 | 8 Tq | 1 | | | 16 Tq | 2 | | | 20 Tq | 1 | 16 Tq | 1 | | | | 500 kbps | 8 Tq | 8 | 8 Tq | 6 | 10 Tq | 4 | 8 Tq | 4 | 8 Tq | 2 | | | 16 Tq | 4 | 16 Tq | 3 | 20 Tq | 2 | 16 Tq | 2 | 16 Tq | 1 | | 250 kbps | 8 Tq | 16 | 8 Tq | 12 | 10 Tq | 8 | 8 Tq | 8 | 8 Tq | 4 | | | 16 Tq | 8 | 16 Tq | 6 | 20 Tq | 4 | 16 Tq | 4 | 16 Tq | 2 | | 83.3 kbps | 8 Tq | 48 | 8 Tq | 36 | 8 Tq | 30 | 8 Tq | 24 | 8 Tq | 12 | | | 16 Tq | 24 | 16 Tq | 18 | 10 Tq | 24 | 16 Tq | 12 | 16 Tq | 6 | | | | | | | 16 Tq | 15 | | | | | | | | | | | 20 Tq | 12 | | | | | | 33.3 kbps | 8 Tq | 120 | 8 Tq | 90 | 8 Tq | 75 | 8 Tq | 60 | 8 Tq | 30 | | | 10 Tq | 96 | 10 Tq | 72 | 10 Tq | 60 | 10 Tq | 48 | 10 Tq | 24 | | | 16 Tq | 60 | 16 Tq | 45 | 20 Tq | 30 | 16 Tq | 30 | 16 Tq | 15 | | | 20 Tq | 48 | 20 Tq | 36 | | | 20 Tq | 24 | 20 Tq | 12 | # 24.4 Mailbox and Mask Register Structure There are 32 mailboxes with the same structure. Figure 24.38 shows the structure of registers C0MBj to C1MBj (j = 0 to 31). Figure 24.38 Structure of Registers C0MBj to C1MBj (i = 0, 1; j = 0 to 31) There are eight mask registers with the same structure. Figure 24.39 shows the structure of registers C0MKRk to C1MKRk (k = 0 to 7). Figure 24.39 Structure of Registers C0MKRk to C1MKRk (i = 0, 1; k = 0 to 7) There are two FIFO received ID compare registers with the same structure. Figure 24.40 shows the structure of registers C0FIDCRn to C1FIDCRn (n = 0, 1). | | | | | | | | | Addı | ress | | |-------|-------|-------|-------|-------|-------|-------|-------|--------------------|--------------------|----------| | b7 | | | | | | | b0 | CAN0 | CAN1 | | | EID7 | EID6 | EID5 | EID4 | EID3 | EID2 | EID1 | EID0 | 47E20h + n × 4 + 0 | 47A20h + n × 4 + 0 | | | EID15 | EID14 | EID13 | EID12 | EID11 | EID10 | EID9 | EID8 | 47E20h + n × 4 + 1 | 47A20h + n × 4 + 1 | CiFIDCRn | | SID5 | SID4 | SID3 | SID2 | SID1 | SID0 | EID17 | EID16 | 47E20h + n × 4 + 2 | 47A20h + n × 4 + 2 | register | | IDE | RTR | > < | SID10 | SID9 | SID8 | SID7 | SID6 | 47E20h + n × 4 + 3 | 47A20h + n × 4 + 3 | | | | | | | | | | | | _ | | Figure 24.40 Structure of Registers C0FIDCRn to C1FIDCRn (i = 0, 1; n = 0, 1) ## 24.5 Acceptance Filtering and Masking Function Acceptance filtering allows the user to receive messages with a specified range of multiple IDs for mailboxes. Registers CiMKR0 to CiMKR7 can perform masking of the standard ID and the extended ID of 29 bits (i = 0, 1). - The CiMKR0 register corresponds to mailboxes [0] to [3]. - The CiMKR1 register corresponds to mailboxes [4] to [7]. - The CiMKR2 register corresponds to mailboxes [8] to [11]. - The CiMKR3 register corresponds to mailboxes [12] to [15]. - The CiMKR4 register corresponds to mailboxes [16] to [19]. - The CiMKR5 register corresponds to mailboxes [20] to [23]. - The CiMKR6 register corresponds to mailboxes [24] to [27] in normal mailbox mode, and receive FIFO mailboxes [28] to [31] in FIFO mailbox mode. - The CiMKR7 register corresponds to mailboxes [28] to [31] in normal mailbox mode, and receive FIFO mailboxes [28] to [31] in FIFO mailbox mode. The CiMKIVLR register disables acceptance filtering individually for each mailbox. The IDE bit in the CiMBj register is enabled when the IDFM bit in the CiCTLR register is 10b (mixed ID mode) (j = 0 to 31). The RTR bit in the CiMBj register selects a data frame or a remote frame. In FIFO mailbox mode, normal mailboxes (mailboxes [0] to [23]) use the single corresponding register among registers CiMKR0 to CiMKR5 for acceptance filtering. Receive FIFO mailboxes (mailboxes [28] to [31]) use two registers CiMKR6 and CiMKR7 for acceptance filtering. Also, the receive FIFO uses registers CiFIDCR0 and CiFIDCR1 for ID comparison. Bits EID, SID, RTR, and IDE in registers CiMB28 to CiMB31 for the receive FIFO are disabled. As acceptance filtering depends on the result of two ID-mask sets, two ranges of IDs can be received into the receive FIFO. The CiMKIVLR register is disabled for the receive FIFO. If both the settings for standard ID and extended ID are set in the IDE bits in registers CiFIDCR0 and CiFIDCR1 individually, both ID formats are received. If both setting of data frame and remote frame are set in the RTR bits in registers CiFIDCR0 and CiFIDCR1 individually, both the data and remote frames are received. When a combination of two ranges of IDs is not necessary, set the same mask value and the same ID into both of the FIFO ID/mask register sets. Figure 24.41 shows the mask registers and their corresponding mailboxes, and Figure 24.42 shows acceptance filtering. Figure 24.41 Mask Registers and Their Corresponding Mailboxes (i = 0, 1) Figure 24.42 Acceptance Filtering (i = 0, 1; j = 0 to 31; k = 0 to 7) ## 24.6 Reception and Transmission Table 24.11 lists the CAN communication mode configuration. Table 24.11 Configuration for CAN Reception Mode and Transmission Mode | TRMREQ | RECREQ | ONESHOT | Communication Mode of Mailbox | |--------|--------|---------|----------------------------------------------------------------------------------------------------------| | 0 | 0 | 0 | Mailbox disabled or transmission being aborted | | 0 | 0 | 1 | Configurable only when transmission or reception from a mailbox (programmed in one-shot mode) is aborted | | 0 | 1 | 0 | Configured as a receive mailbox for a data frame or a remote frame | | 0 | 1 | 1 | Configured as a one-shot receive mailbox for a data frame or a remote frame | | 1 | 0 | 0 | Configured as a transmit mailbox for a data frame or a remote frame | | 1 | 0 | 1 | Configured as a one-shot transmit mailbox for a data frame or a remote frame | | 1 | 1 | 0 | Do not set | | 1 | 1 | 1 | Do not set | TRMREQ, RECREQ, and ONESHOT: Bits in the CiMCTLj register (i = 0, 1; j = 0 to 31) When a mailbox is configured as a receive mailbox or a one-shot receive mailbox, note the following: - (1) Before a mailbox is configured as a receive mailbox or a one-shot receive mailbox, set the CiMCTLj register to 00h (i = 0, 1; j = 0 to 31). - (2) A received message is stored into the first mailbox that matches the condition according to the result of receive mode configuration and acceptance filtering. Upon deciding which mailbox stores the received message, the mailbox with the smaller number has higher priority. - (3) In CAN operation mode, when a CAN module transmits a message whose ID matches with the ID/ mask set of a mailbox configured to receive messages, the CAN module never receives the transmitted data. In self test mode, however, the CAN module may receive its transmitted data. In this case, the CAN module sends an ACK. When a mailbox is configured as a transmit mailbox or a one-shot transmit mailbox, note the following: (1) Before a mailbox is configured as a transmit mailbox or one-shot transmit mailbox, ensure that the CiMCTLj register is 00h and that there is no pending abort process. #### 24.6.1 Reception Figure 24.43 shows an operation example of data frame reception in overwrite mode. This example shows the operation of overwriting the first message when the CAN module receives two consecutive CAN messages that match the receiving conditions of the CiMCTL0 register (i = 0, 1). Figure 24.43 Operation Example of Data Frame Reception in Overwrite Mode (i = 0, 1; j = 0 to 31) - (1) When an SOF is detected on the CAN bus, the RECST bit in the CiSTR register becomes 1 (reception in progress) if the CAN module has no message ready to start transmission. - (2) The acceptance filter procedure starts at the beginning of the CRC field to select the receive mailbox. - (3) After a message has been received, the NEWDATA bit in the CiMCTLj register for the receive mailbox becomes 1 (new data being updated/stored in the mailbox) (j = 0 to 31). Simultaneously, the INVALDATA bit in the CiMCTLj register becomes 1 (message is being updated), and then the INVALDATA bit becomes 0 (message valid) again after the complete message is transferred to the mailbox. - (4) When the interrupt enable bit in the CiMIER register for the receive mailbox is 1 (interrupt enabled), the CANi reception complete interrupt request is generated. This interrupt occurs when the INVALDATA bit becomes 0. - (5) After reading the message from the mailbox, the NEWDATA bit needs to be set to 0 by a program. - (6) In overwrite mode, if the next CAN message has been received into a mailbox whose NEWDATA bit is still set to 1, the MSGLOST bit in the CiMCTLj register becomes 1 (message has been overwritten). The new received message is transferred to the mailbox. The CANi reception complete interrupt request is generated the same as in (4). Figure 24.44 shows an operation example of data frame reception in overrun mode. This example shows the operation of overrunning the second message when the CAN module receives two consecutive CAN messages that match the receiving conditions of the CiMCTL0 register (i = 0, 1). Figure 24.44 Operation Example of Data Frame Reception in Overrun Mode (i = 0, 1; j = 0 to 31) - (1) to (5) are the same as overwrite mode. - (6) In overrun mode, if the next message has been received before the NEWDATA bit is set to 0, the MSGLOST bit in the CiMCTLj register becomes 1 (message has been overrun) (j = 0 to 31). The new received message is discarded and a CANi error interrupt request is generated if the corresponding interrupt enable bit in the CiEIER register is 1 (interrupt enabled). #### 24.6.2 Transmission Figure 24.45 shows an operation example of data frame transmission. This example shows an operation of transmitting messages that have been set in registers CiMCTL0 and CiMCTL1 (i = 0, 1). Figure 24.45 Operation Example of Data Frame Transmission (i = 0, 1; j = 0 to 31) - (1) When the TRMREQ bit in the CiMCTLj register is set to 1 (transmit mailbox) in the bus-idle state, the mailbox scan procedure starts to decide the highest-priority mailbox for transmission (j = 0 to 31). Once the transmit mailbox is decided, the TRMACTIVE bit in the CiMCTLj register becomes 1 (from when a transmission request is received until transmission is completed, or an error/arbitration lost has occurred), the TRMST bit in the CiSTR register becomes 1 (transmission in progress), and the CAN module starts transmission. (1) - (2) If other TRMREQ bits are set, the transmission scan procedure starts with the CRC delimiter for the next transmission. - (3) If transmission is completed without losing arbitration, the SENTDATA bit in the CiMCTLj register becomes 1 (transmission completed) and the TRMACTIVE bit becomes 0 (transmission is pending, or no transmission request). If the interrupt enable bit in the CiMIER register is 1 (interrupt enabled), the CANi transmission complete interrupt request is generated. - (4) When requesting the next transmission from the same mailbox, set bits SENDTDATA and TRMREQ to 0, then set the TRMREQ bit to 1 after checking that bits SENDTDATA and TRMREQ have been set to 0. #### Note: 1. If arbitration is lost after the CAN module starts transmission, the TRMACTIVE bit becomes 0. The transmission scan procedure is performed again to search for the highest-priority transmit mailbox from the beginning of the CRC delimiter. If an error occurs either during transmission or following the loss of arbitration, the transmission scan procedure is performed again from the start of the error delimiter to search for the highest-priority transmit mailbox. # 24.7 CAN Interrupts The CAN module provides the following CAN interrupts: - CANi wakeup interrupt (i = 0, 1) - CANi reception complete interrupt - CANi transmission complete interrupt - CANi receive FIFO interrupt - · CANi transmit FIFO interrupt - CANi error interrupt There are eight types of interrupt sources for the CANi error interrupts. These sources can be determined by checking the CiEIFR register. - Bus error - Error-warning - Error-passive - Bus-off entry - Bus-off recovery - Receive overrun - Overload frame transmission - Bus lock #### 25. I/O Pins Each pin of the MCU functions as a programmable I/O port or an I/O pin for integrated peripherals. These functions can be switched by the function select registers. The pull-up resistors are enabled for every group of four pins. However, a pull-up resistor is separated from other peripheral functions even if it is enabled, when a pin functions as an output pin. Figure 25.1 shows a block diagram of typical I/O pin. Figure 25.1 Typical I/O Pin Block Diagram (i = 0 to 9; j = 0 to 7) The registers to control I/O pins are as follows: port Pi direction register (PDi register), output function select register, and pull-up control register. The PDi register selects the input or output state of pins. The output function select register which selects an output function consists of bits PSEL2 to PSEL0, and ASEL. Bits PSEL2 to PSEL0 select a function as a programmable I/O or peripheral output (except analog output). The ASEL bit prevents the increase in power consumption of input buffer caused by an intermediate potential when a pin functions as an analog I/O pin. The pull-up control register enables/disables the pull-up resistors. To use a pin as an analog I/O pin, the PDi\_j bit should be set to 0 (input), and bits PSEL2 to PSEL0 should be set to 000b and the ASEL bit should be set to 1. The input-only port P8\_5 shares a pin with $\overline{\text{NMI}}$ and has no function select register or bit 5 in the PD8 register. Port P9\_1 also functions as an input-only port. The function select register and bit 1 in the PD9 register are reserved. Port P9 is protected from unexpected write accesses by the PRC2 bit in the PRCR register. Ports P3, P7, and P8 are protected from unexpected write accesses by the PRC30 bit in the PRCR3 register (refer to 9. "Protection"). ## 25.1 Port Pi Direction Register (PDi Register, i = 0 to 9) The PDi register selects the input or output state of pins. Bits in this register correspond to respective pins. Figure 25.2 shows the PDi register. No register bit is provided for port P8\_5. For port P9\_1, a reserved bit is provided. The PD9 register is protected from unexpected write accesses by setting the PRC2 bit in the PRCR register. Registers PD3, PD7, and PD8 are protected by the PRC30 bit in the PRCR3 register (refer to 9. "Protection"). #### Notes - 1. Rewrite registers PD3, PD7, and PD8 after setting the PRC30 bit in the PRCR3 register to 1 (write enabled). - 2. The following bits are reserved. These bits should be written with 0: bits PD6\_0 to PD6\_4 and PD6\_6 in the PD6 register, bits PD7\_1 to PD7\_3 and PD7\_7 in the PD7 register, bits PD8\_0 and PD8\_1 in the PD8 register, and bits PD9\_0 to PD9\_2 in the PD9 register. - 3. The PD8\_5 bit in the PD8 register is unavailable on this MCU. This bit should be written with 0 and read as an undefined value. - 4. Set the PRC2 bit in the PRCR register to 1 (write enabled) just before rewriting the PD9 register. No interrupt handling or DMA transfers should be inserted between these two instructions. Figure 25.2 Registers PD0 to PD9 # 25.2 Output Function Select Registers When a programmable I/O port and peripheral output share a pin, this register selects the output function of the pin. Regardless of the register setting, a signal is input to all the connected peripherals. The output function select register consists of bits PSEL2 to PSEL0, and ASEL. Bits PSEL2 to PSEL0 select a function as programmable I/O or peripheral output (except analog output). The ASEL bit prevents the increase in power consumption caused by an intermediate potential generated when a pin functions as an analog I/O pin. Table 25.1 shows the peripherals assigned to each PSEL2 to PSEL0 bit combination, and Figures 25.3 to 25.12 show the function select registers. Note that ports P8\_5 and P9\_1 (input only) have no output function select registers. The P9\_iS register is protected from unexpected write accesses by setting the PRC2 bit in the PRCR register and registers P3\_iS, P7\_iS, and P8\_iS are protected by the PRC30 bit in the PRCR3 register (refer to 9. "Protection"). Table 25.1 Peripheral Assignment | Bits PSEL2 to PSEL0 | Peripherals | |---------------------|----------------------------------------------------------| | 001b | Timer | | 010b | Three-phase motor control timers, Serial bus interface 0 | | 011b | UART | | 100b | UART special function | | 101b | Intelligent I/O group 0, CAN channel 0, LIN module | | 110b | CAN channel 1 | | 111b | | Figure 25.3 Registers P0\_0S to P0\_7S Port P0\_i shares a pin with the AN0\_i input pin for the A/D converter (i = 0 to 7). To use it as a programmable I/O port, the P0\_iS register should be set to 00h. To use it as an A/D converter input pin, this register should be set to 80h and the PD0\_i bit should be set to 0 (port P0\_i functions as an input port). 1. Refer to the following table for each pin setting. | Port | | | Setting V | alue of Bits | PSEL2 to F | PSEL0 | | | |------|------|------|--------------|--------------|------------|---------------|------|------| | Foit | 000b | 001b | 010b | 011b | 100b | 101b | 110b | 111b | | P1_0 | P1_0 | (2) | SSO0 output | (2) | (2) | IIO0_0 output | (2) | (2) | | P1_1 | P1_1 | (2) | SSCK0 output | (2) | (2) | IIO0_1 output | (2) | (2) | | P1_2 | P1_2 | (2) | SSI0 output | (2) | (2) | IIO0_2 output | (2) | (2) | | P1_3 | P1_3 | (2) | SCS0 output | (2) | (2) | IIO0_3 output | (2) | (2) | | P1_4 | P1_4 | (2) | (2) | (2) | (2) | IIO0_4 output | (2) | (2) | | P1_5 | P1_5 | (2) | (2) | (2) | (2) | IIO0_5 output | (2) | (2) | | P1_6 | P1_6 | (2) | (2) | (2) | (2) | IIO0_6 output | (2) | (2) | | P1_7 | P1_7 | (2) | (2) | (2) | (2) | IIO0_7 output | (2) | (2) | <sup>2.</sup> Do not use this combination. Figure 25.4 Registers P1\_0S to P1\_7S Port P1\_i shares a pin with the serial bus interface (SBI0), AN\_i input pin for the A/D converter, intelligent I/O group 0 (IIO0), and external interrupt input pin (i = 0 to 7). To use it as an output pin, the PD1\_i bit should be set to 1 (port P1\_i functions as an output port) and a function should be selected according to Figure 25.4. To use it as an input pin (except for the A/D converter), the PD1\_i bit should be set to 0 (port P1\_i functions as an input port). To use it as an A/D converter input pin, this register should be set to 80h and the PD1\_i bit should be set to 0 (port P1\_i functions as an input port). Figure 25.5 Registers P2\_0S to P2\_7S Port P2\_i shares a pin with the AN2\_i pin for the A/D converter (i = 0 to 7). To use it as a programmable I/O port, the P2\_iS register should be set to 00h. To use it as an A/D converter input pin, this register should be set to 80h and the PD2\_i bit should be set to 0 (port P2\_i functions as an input port). - 1. Rewrite these registers after setting the PRC30 bit in the PRCR3 register to 1 (write enabled). - 2. Refer to the following table for each pin setting. | Port | | | Setting | g Value of Bits | PSEL2 to F | PSEL0 | | | |------|------|---------------|------------------|------------------|------------------|---------|------------------|------------------| | Foit | 000b | 001b | 010b | 011b | 100b | 101b | 110b | 111b | | P3_0 | P3_0 | TA0OUT output | — <sup>(3)</sup> | — <sup>(3)</sup> | (3) | LIN0OUT | — <sup>(3)</sup> | — <sup>(3)</sup> | | P3_1 | P3_1 | TA3OUT output | — (3) | — <sup>(3)</sup> | — (3) | (3) | (3) | — (3) | | P3_2 | P3_2 | TA1OUT output | V | — <sup>(3)</sup> | (3) | (3) | (3) | — (3) | | P3_3 | P3_3 | (3) | V | (3) | (3) | (3) | (3) | (3) | | P3_4 | P3_4 | TA2OUT output | W | CLK4 output | (3) | (3) | (3) | — (3) | | P3_5 | P3_5 | (3) | W | — <sup>(3)</sup> | — <sup>(3)</sup> | (3) | (3) | — (3) | | P3_6 | P3_6 | TA4OUT output | U | TXD4 | (3) | (3) | (3) | (3) | | P3_7 | P3_7 | (3) | Ū | RTS4 | (3) | (3) | (3) | (3) | <sup>3.</sup> Do not use this combination. Figure 25.6 Registers P3\_0S to P3\_7S Port P3\_i shares a pin with the timer output, three-phase motor control output, serial interface (UART4), and LIN module (i = 0 to 7). To use it as an output pin, the PD3\_i bit should be set to 1 (port P3\_i functions as an output port) and a function should be selected according to Figure 25.6. To use it as an input pin, the PD3\_i bit should be set to 0 (port P3\_i functions as an input port). 1. Refer to the following table for each pin setting. | Port | | | Setting | Value of Bits P | SEL2 to P | SEL0 | | | |------|------|------|--------------|---------------------|-----------|---------|------|------| | Foit | 000b | 001b | 010b | 011b | 100b | 101b | 110b | 111b | | P4_0 | P4_0 | (2) | SCS0 output | RTS3 | (2) | (2) | (2) | (2) | | P4_1 | P4_1 | (2) | SSCK0 output | CLK3 output | (2) | (2) | (2) | (2) | | P4_2 | P4_2 | (2) | SSI0 output | (2) | (2) | (2) | (2) | (2) | | P4_3 | P4_3 | (2) | SSO0 output | TXD3 | (2) | (2) | (2) | (2) | | P4_4 | P4_4 | (2) | (2) | RTS1 | (2) | LIN0OUT | (2) | (2) | | P4_5 | P4_5 | (2) | (2) | CLK1 output | (2) | (2) | (2) | (2) | | P4_6 | P4_6 | (2) | (2) | SCL1 output | STXD1 | (2) | (2) | (2) | | P4_7 | P4_7 | (2) | (2) | TXD1<br>SDA1 output | (2) | (2) | (2) | (2) | <sup>2.</sup> Do not use this combination. Figure 25.7 Registers P4\_0S to P4\_7S Port P4\_i shares a pin with the serial interface (UART1 and UART3), serial bus interface (SBI0), and LIN module (i = 0 to 7). To use it as an output pin, the PD4\_i bit should be set to 1 (port P4\_i functions as an output port) and a function should be selected according to Figure 25.7. To use it as an input pin, the PD4\_i bit should be set to 0 (port P4\_i functions as an input port). <sup>1.</sup> Refer to the following table for each pin setting. | Port | | | Set | ting Value of Bi | ts PSEL2 to | PSEL0 | | | |------|------|------|------|---------------------|-------------|---------------|------|------| | Foit | 000b | 001b | 010b | 011b | 100b | 101b | 110b | 111b | | P5_0 | P5_0 | (2) | (2) | (2) | (2) | IIO0_0 output | (2) | (2) | | P5_1 | P5_1 | (2) | (2) | (2) | (2) | IIO0_1 output | (2) | (2) | | P5_2 | P5_2 | (2) | (2) | (2) | (2) | IIO0_2 output | (2) | (2) | | P5_3 | P5_3 | (2) | (2) | (2) | (2) | IIO0_3 output | (2) | (2) | | P5_4 | P5_4 | (2) | (2) | RTS0 | (2) | IIO0_4 output | (2) | (2) | | P5_5 | P5_5 | (2) | (2) | CLK0 output | (2) | IIO0_5 output | (2) | (2) | | P5_6 | P5_6 | (2) | (2) | SCL0 output | STXD0 | IIO0_6 output | (2) | (2) | | P5_7 | P5_7 | (2) | (2) | TXD0<br>SDA0 output | (2) | IIO0_7 output | (2) | (2) | <sup>2.</sup> Do not use this combination. Figure 25.8 Registers P5\_0S to P5\_7S Port P5\_i shares a pin with intelligent I/O group 0 (IIO0) and the serial interface (UART0) (i = 0 to 7). To use it as an output pin, the PD5\_i bit should be set to 1 (port P5\_i functions as an output port) and a function should be selected according to Figure 25.8. To use it as an input pin, the PD5\_i bit should be set to 0 (port P5\_i functions as an input port). Figure 25.9 Registers P6\_5S and P6\_7S Port P6\_i does not share a pin with any functions. The P6\_iS register should be set to 00h (I/O port) (i = 5 and 7). #### Notes: - 1. Rewrite these registers after setting the PRC30 bit in the PRCR3 register to 1 (write enabled). - 2. Refer to the following table for each pin setting. | Port | | Setting Value of Bits PSEL2 to PSEL0 | | | | | | | | | |------|------|--------------------------------------|------|---------------------|-------|---------|------|------|--|--| | Foit | 000b | 001b | 010b | 011b | 100b | 101b | 110b | 111b | | | | P7_0 | P7_0 | (3) | (3) | TXD2<br>SDA2 output | (3) | (3) | (3) | (3) | | | | P7_4 | P7_4 | (3) | (3) | SCL2 output | STXD2 | LIN0OUT | (3) | (3) | | | | P7_5 | P7_5 | (3) | (3) | CLK2 output | (3) | (3) | (3) | (3) | | | | P7_6 | P7_6 | (3) | (3) | RTS2 | (3) | CAN0OUT | (3) | (3) | | | <sup>3.</sup> Do not use this combination. Figure 25.10 Registers P7\_0S and P7\_4S to P7\_6S Port P7\_i shares a pin with the serial interface (UART2), LIN module, and CAN module (i = 0 to 7). To use it as an output pin, the PD7\_i bit should be set to 1 (port P7\_i functions as an output port) and a function should be selected according to Figure 25.10. To use it as an input pin, the PD7\_i bit should be set to 0 (port P7\_i functions as an input port). 25. I/O Pins R32C/161 Group #### Notes: - 1. Rewrite these registers after setting the PRC30 bit in the PRCR3 register to 1 (write enabled). - 2. Refer to the following table for each pin setting. | Port | | Setting Value of Bits PSEL2 to PSEL0 | | | | | | | | | |------|------|--------------------------------------|------|------|------|------------------|---------|------|--|--| | Foit | 000b | 001b | 010b | 011b | 100b | 101b | 110b | 111b | | | | P8_2 | P8_2 | (3) | (3) | (3) | (3) | CAN0OUT | CAN1OUT | (3) | | | | P8_3 | P8_3 | (3) | (3) | (3) | (3) | (3) | (3) | (3) | | | | P8_4 | P8_4 | (3) | (3) | (3) | (3) | (3) | (3) | (3) | | | | P8_6 | P8_6 | (3) | (3) | (3) | (3) | (3) | (3) | (3) | | | | P8_7 | P8_7 | (3) | (3) | (3) | (3) | — <sup>(3)</sup> | (3) | (3) | | | <sup>3</sup> Do not use this combination Figure 25.11 Registers P8\_2S to P8\_4S, P8\_6S, and P8\_7S Port P8 i shares a pin with the CAN module and external interrupt input pin (i = 2 to 4, 6, 7). To use it as an output pin, the PD8\_i bit should be set to 1 (port P8\_i functions as an output port) and a function should be selected according to Figure 25.11. To use it as an input pin, the PD8\_i bit should be set to 0 (port P8\_i functions as an input port). #### Notes: - 1. Set the PRC2 bit in the PRCR register to 1 (write enabled) just before rewriting this register. No interrupt handling or DMA transfers should be inserted between these two instructions. - 2. Refer to the following table for each pin setting. | Port | | Setting Value of Bits PSEL2 to PSEL0 | | | | | | | | | |------|------|--------------------------------------|------|------------------|------|------|---------|------|--|--| | Poit | 000b | 001b | 010b | 011b | 100b | 101b | 110b | 111b | | | | P9_3 | P9_3 | (3) | (3) | — <sup>(3)</sup> | (3) | (3) | (3) | (3) | | | | P9_4 | P9_4 | (3) | (3) | RTS4 | (3) | (3) | (3) | (3) | | | | P9_5 | P9_5 | (3) | (3) | CLK4 output | (3) | (3) | (3) | (3) | | | | P9_6 | P9_6 | (3) | (3) | TXD4 | (3) | (3) | CAN1OUT | (3) | | | | P9_7 | P9_7 | (3) | (3) | (3) | (3) | (3) | (3) | (3) | | | <sup>3.</sup> Do not use this combination. Figure 25.12 Registers P9\_3S to P9\_7S Port P9\_i shares a pin with the serial interface (UART4) and CAN module (i = 3 to 7). In particular, port P9\_i also shares a pin with the A/D converter I/O (ANEX0 and ANEX1) pin (i = 5, 6). To use it as the A/D converter pin, the P9\_iS register should be set to 80h and the PD9\_i bit should be set to 0 (port P9\_i functions as an input port) irrespective of the I/O state. To use it as an output pin for functions other than the A/D converter, the PD9\_i bit should be set to 1 (port P9\_i functions as an output port) and a function should be selected according to Figure 25.12. To use it as an input pin of functions other than the A/D converter, the PD9\_i bit should be set to 0 (port P9\_i functions as an input port). # 25.3 Input Function Select Registers When a peripheral input is assigned to multiple pins, these registers select which input pin should be connected to the peripheral. Figures 25.13 to 25.17 show the input function select registers. Figure 25.13 IFS0 Register Figure 25.14 IFS1 Register Figure 25.15 IFS2 Register Figure 25.16 IFS5 Register Figure 25.17 IFS6 Register # 25.4 Pull-up Control Registers 0 to 2 (Registers PUR0 to PUR2) Figures 25.18 to 25.20 show registers PUR0 to PUR2. These registers enable/disable the pull-up resistors for every group of four pins. To enable the pull-up resistors, the corresponding bits in registers PUR0 to PUR2 should be set to 1 (pull-up resistor enabled) and the respective bits in the direction register should be set to 0 (input). Figure 25.18 PUR0 Register Figure 25.19 PUR1 Register Figure 25.20 PUR2 Register # 25.5 Port Control Register (PCR Register) Figure 25.21 shows the PCR register. This register selects an output mode for port P1 between push-pull output and pseudo-N-channel open drain output. When the PCR0 bit is set to 1, the P-channel transistor in the output buffer is turned off. Note that port P1 cannot be a perfect open drain output due to remaining parasitic diode. The absolute maximum rating of the input voltage is, therefore, -0.3 V to VCC + 0.3 V (refer to Figure 25.22). Figure 25.21 PCR Register Figure 25.22 Port P1 Output Buffer Configuration # 25.6 Configuring Unused Pins Table 25.2 and Figure 25.24 show examples of configuring unused pins on the board. Table 25.2 Unused Pin Configuration in Single-chip Mode (1) | Pin Name | Setting | |----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | Ports P0 to P9 (excluding ports P8_5 and P9_1) (2) | Configure as input ports so that each pin is connected to VSS via its own resistor; <sup>(3)</sup> or configure as output ports to leave the pins open | | P9_1 | Connect the pin to VSS via a resistor (3) | | XOUT (4) | Leave pin open | | NMI (P8_5) | Connect the pin to VCC via a resistor (3) | | AVCC | Connect the pin to VCC | | AVSS, VREF | Connect the pin to VSS | | NSD | Connect the pin to VCC via a resistor of 1 to 4.7 $k\Omega$ | #### Notes: - 1. Unused pins should be wired within 2 cm of the MCU. - 2. When configuring the pins as output ports to leave them open, note that ports as inputs remain unchanged from when the reset is released until the mode transition is completed. During this transition, the power supply current may increase due to an undefined voltage level of the pins. In addition, the direction register value may change due to noise or program runaway caused by the noise. To avoid these situations, reconfigure the direction register regularly by software, which may achieve higher program reliability. - 3. Select a resistance value that is appropriate for the system. A range from 10 to 100 $k\Omega$ is recommended - 4. This setting is applicable when an external clock is applied to the XIN pin. #### Pull-up/pull-down resistors The figure shows the equivalent circuit of an input pin. The equivalent input resistors (RP and RN) are calculated using input power current (IIL and IIH). Example: When VCC = 5.0 V, IIH = IIL = 5 $\mu$ A, $$RP = RN = \frac{5.0}{5 \times 10^{-6}} = 1 M\Omega$$ Since the voltage (VIH) defined as high is more than 0.7 VCC, the resistance value R should satisfy the following expression: R//RP : RN = 0.3 : 0.7 That is. $$R = \frac{3RPRN}{7RP - 3RN}$$ Specifically, Example: When VCC = 5.0 V, $IIH = IIL = 5 \mu A$ $$R = \frac{3 \times 10^6 \times 10^6}{7 \times 10^6 - 3 \times 10^6} = 750000$$ The maximum pull-up resistor R is approximately 750 k $\Omega$ . The actual resistance value is the calculated value with some margins. Figure 25.23 Pull-up/Pull-down Resistors Figure 25.24 Unused Pin Configuration # 26. Flash Memory #### 26.1 Overview The flash memory can be programmed in the following three modes: CPU rewrite mode, standard serial I/O mode, and parallel I/O mode. Table 26.1 lists specifications of the flash memory and Table 26.2 shows the overview of each rewrite mode. Table 26.1 Flash Memory Specifications | Item | Specification | |----------------------------------|---------------------------------------------------------------| | Rewrite modes | CPU rewrite mode, standard serial I/O mode, parallel I/O mode | | Structure | Block architecture. Refer to Figure 26.1 | | Program operation | 8-byte basis | | Erase operation | 1-block basis | | Program and erase control method | Software commands | | Protection types | Lock bit protect, ROM code protect, ID code protect | | Software commands | 9 | Table 26.2 Flash Memory Rewrite Mode Overview | Rewrite Mode | CPU Rewrite Mode | Standard Serial I/O Mode | Parallel I/O Mode | |---------------|------------------------------|-------------------------------|-------------------------| | Function | CPU executes a software | A dedicated serial | A dedicated parallel | | | command to rewrite the flash | programmer rewrites the flash | programmer rewrites the | | | memory | memory | flash memory | | | EW0 mode: | Standard serial I/O mode 1: | | | | Rewritable in areas other | Synchronous serial I/O | | | | than the on-chip flash | selected | | | | memory | Standard serial I/O mode 2: | | | | EW1 mode: | UART selected | | | | Rewritable in areas other | | | | | than specified blocks to be | | | | | rewritten | | | | CPU operating | Single-chip mode | Standard serial I/O mode | Parallel I/O mode | | mode | | | | | Programmer | _ | Serial programmer | Parallel programmer | | On-board | Supported | Supported | Not supported | | rewriting | | | | Figure 26.1 shows the on-chip flash memory structure. The on-chip flash memory contains program area to store user programs, and data area/data flash to store the result of user programs. The program area consists of blocks 0 to 5, and data area/data flash consists of blocks A and B. Each block can be individually protected (locked) from programming or erasing by setting the lock bit. Figure 26.1 On-chip Flash Memory Block Diagram # 26.2 Flash Memory Protection There are three types of protection as shown in Table 26.3. Lock bit protection is intended to prevent accidental write or erase by program runaway. ROM code protection and ID code protection are intended to prevent read or write by a third party. **Table 26.3** Protection Types and Characteristics | Protection Type | Lock Bit Protection | ROM Code Protection | ID Code Protection | |---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------------------------------------| | Protected operations | Erase, write | Read, write | Read, erase, write | | Protection available in | CPU rewrite mode<br>Standard serial I/O mode<br>Parallel I/O mode | Parallel I/O mode | Standard serial I/O mode | | Protection available for | Individual blocks | Entire flash memory | Entire flash memory | | Protection settings | Setting 0 to the lock bit of block to be protected | Setting the protect bit of any block to 0 | Writing the program which has set an ID code to specified address | | Protection<br>disabled by | Setting the LBD bit in the FMR register to 1 (lock bit protection disabled), or by erasing the blocks whose lock bits are set to 0 to permanently disable the protection | Erasing all blocks whose protect bits are set to 0 | Sending a proper ID code from the serial programmer | #### 26.2.1 Lock Bit Protection This protection can be used in all three rewrite modes. When the lock bit protection is enabled, all blocks whose lock bits are set to 0 (locked) are protected against programming and erasing. To set the lock bit to 0, the lock bit program command must be issued. To temporarily disable the protection of all protected blocks, disable the lock bit protection itself by setting the LBD bit in the FMR1 register to 1 (lock bit protection disabled). The protection of a protected block is disabled permanently and its lock bit becomes 1 (unlocked) if the block is erased. ## 26.2.2 ROM Code Protection This protection can only be used in parallel I/O mode. When the ROM code protection is enabled, the entire flash memory is protected against reading and writing. To disable the protection, erase all the blocks whose protect bits are set to 0 (protected). Each block has two protect bits. Setting any protect bit to 0 by a software command enables the protection for the entire flash memory. Table 26.4 lists protect bit addresses. | <b>Table 26.4</b> | Protect Bit | Addresses | |-------------------|-------------|-----------| |-------------------|-------------|-----------| | Block | Protect Bit 0 | Protect Bit 1 | |---------|---------------|---------------| | Block B | 00060100h | 00060300h | | Block A | 00061100h | 00061300h | | Block 5 | FFFC0100h | FFFC0300h | | Block 4 | FFFD0100h | FFFD0300h | | Block 3 | FFFE0100h | FFFE0300h | | Block 2 | FFFE8100h | FFFE8300h | | Block 1 | FFFF0100h | FFFF0300h | | Block 0 | FFFF8100h | FFFF8300h | #### 26.2.3 ID Code Protection This protection can only be used in standard serial I/O mode. A command from the serial programmer is to be accepted when the 7-byte ID code sent from the serial programmer matches the ID code programmed in the flash memory. However, when the reset vector is FFFFFFFh, the ID code check is skipped because the flash memory is considered to be blank. When the reset vector is FFFFFFFh and the ROM code protection is enabled, only the block erase command is accepted. The ID codes sent from the serial programmer are consecutively numbered as ID1, ID2, ..., and ID7. ID codes programmed in the flash memory, also numbered as ID1, ID2, ..., and ID7, are assigned to addresses FFFFFE8h, FFFFFE9h, ..., and FFFFFEEh as shown in Figure 26.2. The ID code protection is enabled when a program which has an ID code set in the corresponding address is written to the flash memory. Figure 26.2 Addresses for ID Code Stored #### 26.3 CPU Rewrite Mode In CPU rewrite mode, the CPU executes software commands to rewrite the flash memory. The CPU accesses the flash memory not via the CPU buses, but via the dedicated flash memory rewrite buses (refer to Figure 26.3). Figure 26.3 Flash Memory Access Path in CPU Rewrite Mode Bus setting for flash memory rewrite should be performed by the FEBC register. Refer to 26.3.1 "Flash Memory Rewrite Bus Timing" and 28. "Electrical Characteristics" for the appropriate bus setting. The CPU rewrite mode contains modes EW0 and EW1 as shown in Table 26.5. Table 26.5 EW0 and EW1 Modes | Item | EW0 Mode | EW1 Mode | |------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rewrite program executable spaces | Spaces other than the on-chip flash memory | Internal spaces other than specified blocks to be rewritten, internal RAM | | Restrictions on software commands | None | Do not execute either the program command or the block erase command for blocks where the rewrite control programs are written to Do not execute the enter read status register mode command Execute the enter read lock bit status mode command in RAM Execute the enter read protect bit status mode command in RAM | | Mode after program/ erase operation | Read status register mode | Read array mode | | CPU state during program/erase operation | Operating | In a hold state (I/O ports maintain the state before the command was executed) | | Flash memory state detection by | Reading the FMSR0 register by a program Executing the enter read status register mode command to read data | Reading the FMSR0 register by a program | | Other restrictions | None | The watchdog timer is disabled in count source protect mode Disable interrupts (except NMI) and DMA transfer during program/erase operation | To select CPU rewrite mode, the FEW bit in the FMCR register should be set to 1. Then, EW0 mode/EW1 mode can be selected by setting the EWM bit in the FMR0 register. Registers FMCR and FMR0 are protected by registers PRR and FPR0, respectively. Figures 26.4 to 26.11 show associated registers. Figure 26.4 FMCR Register Figure 26.5 FEBC Register Figure 26.6 FPR0 Register - 1. Set the PR0 bit in the FPR0 register to 1 (write enabled) before rewriting this register. - 2. This register is reset after exiting wait mode or stop mode. - 3. After entering read lock bit status mode, the lock bit status is reflected to bit 6 of read data when reading any even address in the corresponding block. - 4. The LBS bit reflects the lock bit status when issuing the read lock bit status command. Figure 26.7 FMR0 Register Figure 26.8 FMR1 Register Figure 26.9 FMSR0 Register Figure 26.10 FBPM0 Register Figure 26.11 FBPM1 Register # 26.3.1 Flash Memory Rewrite Bus Timing The bus setting for the flash memory rewrite is performed by setting the FEBC register. This section specifically describes the setting of the FEBC register. The reference clock is the base clock set with bits BCD1 and BCD0 in the CCR register. Time duration including tsu, tw, tc, and th are specified by the number of base clock cycles. Tables 26.6 to 26.8 show the correlation of the read cycle and setting of bits MPY1, MPY0, and FWR4 to FWR0, according to peripheral bus clock divide ratios. Tables 26.9 to 26.11 show the correlation of the write cycle and setting of bits MPY1, MPY0, FSUW1, FSUW0, FWW1, and FWW0. Associated read/write timings are illustrated in Figures 26.12 and 26.13, respectively. Read/write cycle timing is selected from the tables below to meet the timing requirements in the CPU rewrite mode described in the electrical characteristics. Figure 26.12 Read Timing Table 26.6 Read Cycle and Bit Settings: MPY1, MPY0, and FWR4 to FWR0, When Peripheral Bus Clock is Divided by 2 (unit: cycles) | | | | a by Z (ai | | -, | | | | | | |--------------|---------|----------|------------|-------|-------|----------|------------|------------|----------|---------| | | | | | | MPY | 1 and MP | Y0 Bit Set | tings | | | | FWR3 to FWR0 | | FWR4 | | 10 | Ob | | 11b | | | | | | ettings | Bit | | тру | · = 3 | | | тру | · = 4 | | | Dit Se | turigs | Settings | tsu(S-R), | tw(D) | toD | th(R-S), | tsu(S-R), | tuv(D) toD | th(R-S), | | | | | | tsu(A-R) | tw(R) | tcR | th(R-A) | tsu(A-R) | tw(R) | tcR | th(R-A) | | 0000b | wr = 1 | 0 | 4 | 3 | 4 | 0 | 6 | 5 | 6 | 0 | | 00000 | W' - 1 | 1 | 6 | 5 | 6 | 0 | 6 | 5 | 6 | 0 | | 0001b | wr = 2 | 0 | 8 | 7 | 8 | 0 | 10 | 9 | 10 | 0 | | 00016 | Wr - Z | 1 | 8 | 7 | 8 | 0 | 10 | 9 | 10 | 0 | | 0101b | wr = 3 | 0 | 10 | 9 | 10 | 0 | 14 | 13 | 14 | 0 | | 01010 | Wr = 3 | 1 | 12 | 11 | 12 | 0 | 14 | 13 | 14 | 0 | | 0110b | wr = 4 | 0 | 14 | 13 | 14 | 0 | 18 | 17 | 18 | 0 | | 01100 | Wr - 4 | 1 | 14 | 13 | 14 | 0 | 18 | 17 | 18 | 0 | | 1010b | wr = 5 | 0 | 16 | 15 | 16 | 0 | 22 | 21 | 22 | 0 | | 10100 | Wr = 3 | 1 | 18 | 17 | 18 | 0 | 22 | 21 | 22 | 0 | | 1011b | wr = 6 | 0 | 20 | 19 | 20 | 0 | 26 | 25 | 26 | 0 | | 10110 | Wr = 0 | | 20 | 19 | 20 | 0 | 26 | 25 | 26 | 0 | | 1111b | wr = 7 | 0 | 22 | 21 | 22 | 0 | 30 | 29 | 30 | 0 | | 11110 | Wr = 7 | 1 | 24 | 23 | 24 | 0 | 30 | 29 | 30 | 0 | Table 26.7 Read Cycle and Bit Settings: MPY1, MPY0, and FWR4 to FWR0, When Peripheral Bus Clock is Divided by 3 (unit: cycles) | | | | | | MPY | 1 and MP | Y0 Bit Set | tings | | | | |--------------|-----------|----------|-----------|-------|-------|----------|------------|-------|------------------|----------|---| | FWR3 to FWR0 | | FWR4 | | 10 | )b | | 11b | | | | | | | ettings | Bit | | тру | y = 3 | | | тру | <sup>,</sup> = 4 | | | | DIL SE | ungs | Settings | tsu(S-R), | tw(D) | tcR | th(R-S), | tsu(S-R), | tw(D) | toD | th(R-S), | | | | | | tsu(A-R) | tw(R) | ICR | th(R-A) | tsu(A-R) | tw(R) | tcR | th(R-A) | | | 0000b | wr = 1 | 0 | 6 | 4.5 | 6 | 0 | 6 | 4.5 | 6 | 0 | | | doodb | Wr - 1 | 1 | 6 | 4.5 | 6 | 0 | 6 | 4.5 | 6 | 0 | | | 0001b | wr = 2 | 0 | 9 | 7.5 | 9 | 0 | 9 | 7.5 | 9 | 0 | | | 00016 | Wr - Z | 1 | 9 | 7.5 | 9 | 0 | 12 | 10.5 | 12 | 0 | | | 0101b | wr = 3 | 0 | 12 | 10.5 | 12 | 0 | 15 | 13.5 | 15 | 0 | | | 01010 | Wr - 3 | WI - 3 | 1 | 12 | 10.5 | 12 | 0 | 15 | 13.5 | 15 | 0 | | 0110b | wr = 4 | 0 | 15 | 13.5 | 15 | 0 | 18 | 16.5 | 18 | 0 | | | 01100 | Wr - 4 | 1 | 15 | 13.5 | 15 | 0 | 18 | 16.5 | 18 | 0 | | | 1010b | wr = 5 | 0 | 18 | 16.5 | 18 | 0 | 21 | 19.5 | 21 | 0 | | | 10100 | WI - S | 1 | 18 | 16.5 | 18 | 0 | 24 | 22.5 | 24 | 0 | | | 1011b | wr = 6 | 0 | 21 | 19.5 | 21 | 0 | 27 | 25.5 | 27 | 0 | | | Wr = 0 | | 1 | 21 | 19.5 | 21 | 0 | 27 | 25.5 | 27 | 0 | | | 1111b | wr = 7 | 0 | 24 | 22.5 | 24 | 0 | 30 | 28.5 | 30 | 0 | | | 11110 | $W_I = I$ | 1 | 24 | 22.5 | 24 | 0 | 30 | 28.5 | 30 | 0 | | Table 26.8 Read Cycle and Bit Settings: MPY1, MPY0, and FWR4 to FWR0, When Peripheral Bus Clock is Divided by 4 (unit: cycles) | | | | | | MPY | 1 and MP | Y0 Bit Set | tings | | | |--------------|--------------|----------|-----------|-------|-----------|----------|------------|-------|------------------|----------| | FWR3 to FWR0 | | FWR4 | | 10 | )b | | 11b | | | | | | ettings | Bit | | тру | y = 3 | | | тру | <sup>,</sup> = 4 | | | Dit Se | turigs | Settings | tsu(S-R), | tw/D) | tw(R) tcR | th(R-S), | tsu(S-R), | tw(R) | tcR | th(R-S), | | | | | tsu(A-R) | tw(R) | ick | th(R-A) | tsu(A-R) | | | th(R-A) | | 0000b | wr = 1 | 0 | 4 | 2 | 4 | 0 | 8 | 6 | 8 | 0 | | 00000 | W/ - 1 | 1 | 8 | 6 | 8 | 0 | 8 | 6 | 8 | 0 | | 0001b | wr = 2 | 0 | 8 | 6 | 8 | 0 | 12 | 10 | 12 | 0 | | 00015 | WI - Z | 1 | 8 | 6 | 8 | 0 | 12 | 10 | 12 | 0 | | 0101b | 0.1b wr = 3 | 0 | 12 | 10 | 12 | 0 | 16 | 14 | 16 | 0 | | 01010 | Wr - 3 | 1 | 12 | 10 | 12 | 0 | 16 | 14 | 16 | 0 | | 0110b | wr = 4 | 0 | 16 | 14 | 16 | 0 | 20 | 18 | 20 | 0 | | 01100 | W/ - 4 | 1 | 16 | 14 | 16 | 0 | 20 | 18 | 20 | 0 | | 1010b | wr = 5 | 0 | 16 | 14 | 16 | 0 | 24 | 22 | 24 | 0 | | 10100 | Wr - 3 | 1 | 20 | 18 | 20 | 0 | 24 | 22 | 24 | 0 | | 1011b | wr = 6 | 0 | 20 | 18 | 20 | 0 | 28 | 26 | 28 | 0 | | 10110 | WI = 0 | 1 | 20 | 18 | 20 | 0 | 28 | 26 | 28 | 0 | | 1111b | wr = 7 | 0 | 24 | 22 | 24 | 0 | 32 | 30 | 32 | 0 | | 11110 | wr = 7 | 1 | 24 | 22 | 24 | 0 | 32 | 30 | 32 | 0 | Figure 26.13 Write Timing Table 26.9 Write Cycle and Bit Settings: MPY1, MPY0, FSUW1, FSUW0, FWW1, and FWW0, When Peripheral Bus Clock is Divided by 2 (unit: cycles) | | | | | | | 1 and MP | Y0 Bit Set | tings | | | | |--------|---------|--------|---------|-----------------------|-------|----------|---------------------|-----------------------|-------|-----|---------------------| | FSUV | V1 and | FWW | /1 and | | 10 | )b | | 11b | | | | | FSU | JW0 | FΝ | /W0 | | тру | = 3 | | | тру | = 4 | | | Bit Se | ettings | Bit Se | ettings | tsu(S-W),<br>tsu(A-W) | tw(W) | tcw | th(W-S),<br>th(W-A) | tsu(S-W),<br>tsu(A-W) | tw(W) | tcw | th(W-S),<br>th(W-A) | | | | 00b | ww = 1 | 1 | 3 | 6 | 2 | 1 | 4 | 6 | 1 | | 00b | suw = 0 | 01b | ww = 2 | 1 | 6 | 8 | 1 | 1 | 8 | 10 | 1 | | 000 | 3uw - 0 | 10b | ww = 3 | 1 | 9 | 12 | 2 | 1 | 12 | 14 | 1 | | | | 11b | ww = 4 | 1 | 12 | 14 | 1 | 1 | 16 | 18 | 1 | | | | 00b | ww = 1 | 4 | 3 | 8 | 1 | 5 | 4 | 10 | 1 | | 01b | suw = 1 | 01b | ww = 2 | 4 | 6 | 12 | 2 | 5 | 8 | 14 | 1 | | 010 | Suw - 1 | 10b | ww = 3 | 4 | 9 | 14 | 1 | 5 | 12 | 18 | 1 | | | | 11b | ww = 4 | 4 | 12 | 18 | 2 | 5 | 16 | 22 | 1 | | | | 00b | ww = 1 | 7 | 3 | 12 | 2 | 9 | 4 | 14 | 1 | | 10b | suw = 2 | 01b | ww = 2 | 7 | 6 | 14 | 1 | 9 | 8 | 18 | 1 | | 100 | Suw 2 | 10b | ww = 3 | 7 | 9 | 18 | 2 | 9 | 12 | 22 | 1 | | | | 11b | ww = 4 | 7 | 12 | 20 | 1 | 9 | 16 | 26 | 1 | | | | 00b | ww = 1 | 10 | 3 | 14 | 1 | 13 | 4 | 18 | 1 | | 11b | suw = 3 | 01b | ww = 2 | 10 | 6 | 18 | 2 | 13 | 8 | 22 | 1 | | 110 | suw - s | 10b | ww = 3 | 10 | 9 | 20 | 1 | 13 | 12 | 26 | 1 | | | | 11b | ww = 4 | 10 | 12 | 24 | 2 | 13 | 16 | 30 | 1 | Table 26.10 Write Cycle and Bit Settings: MPY1, MPY0, FSUW1, FSUW0, FWW1, and FWW0, When Peripheral Bus Clock is Divided by 3 (unit: cycles) | | | | | | | MPY. | 1 and MP | Y0 Bit Set | tings | | | |-----------|----------|--------|---------|-----------------------|-------|------|---------------------|-----------------------|-------|-----|---------------------| | FSUW1 and | | FWW | /1 and | | 10 | )b | | 11b | | | | | FS | SUW0 | FW | /W0 | | тру | = 3 | | | тру | = 4 | | | Bit S | Settings | Bit Se | ettings | tsu(S-W),<br>tsu(A-W) | tw(W) | tcw | th(W-S),<br>th(W-A) | tsu(S-W),<br>tsu(A-W) | tw(W) | tcw | th(W-S),<br>th(W-A) | | | | 00b | ww = 1 | 1 | 3 | 6 | 2 | 1 | 4 | 6 | 1 | | 00b | suw = 0 | 01b | ww = 2 | 1 | 6 | 9 | 2 | 1 | 8 | 12 | 3 | | OOD | Suw - 0 | 10b | ww = 3 | 1 | 9 | 12 | 2 | 1 | 12 | 15 | 2 | | | | 11b | ww = 4 | 1 | 12 | 15 | 2 | 1 | 16 | 18 | 1 | | | | 00b | ww = 1 | 4 | 3 | 9 | 2 | 6 | 3 | 12 | 3 | | 01b | suw = 1 | 01b | ww = 2 | 4 | 6 | 12 | 2 | 6 | 7 | 15 | 2 | | 015 | 3uw-1 | 10b | ww = 3 | 4 | 9 | 15 | 2 | 6 | 11 | 18 | 1 | | | | 11b | ww = 4 | 4 | 12 | 18 | 2 | 6 | 15 | 24 | 3 | | | | 00b | ww = 1 | 7 | 3 | 12 | 2 | 9 | 4 | 15 | 2 | | 10b | suw = 2 | 01b | ww = 2 | 7 | 6 | 15 | 2 | 9 | 8 | 18 | 1 | | 100 | 3uw - 2 | 10b | ww = 3 | 7 | 9 | 18 | 2 | 9 | 12 | 24 | 3 | | | | 11b | ww = 4 | 7 | 12 | 21 | 2 | 9 | 16 | 27 | 2 | | | | 00b | ww = 1 | 10 | 3 | 15 | 2 | 13 | 4 | 18 | 1 | | 11b | suw = 3 | 01b | ww = 2 | 10 | 6 | 18 | 2 | 13 | 8 | 24 | 3 | | 110 | Suw - 3 | 10b | ww = 3 | 10 | 9 | 21 | 2 | 13 | 12 | 27 | 2 | | | | 11b | ww = 4 | 10 | 12 | 24 | 2 | 13 | 16 | 30 | 1 | Table 26.11 Write Cycle and Bit Settings: MPY1, MPY0, FSUW1, FSUW0, FWW1, and FWW0, When Peripheral Bus Clock is Divided by 4 (unit: cycles) | | | | | MPY1 and MPY0 Bit Settings | | | | | | | | | |--------------|----------------|--------------|--------|----------------------------|-------|-----|---------------------|-----------------------|-------|-----|---------------------|---| | FSUW1 and | | FWW1 and | | 10b | | | 11b | | | | | | | FSUW0 | | FWW0 | | mpy = 3 | | | mpy = 4 | | | | | | | Bit Settings | | Bit Settings | | tsu(S-W),<br>tsu(A-W) | tw(W) | tcw | th(W-S),<br>th(W-A) | tsu(S-W),<br>tsu(A-W) | tw(W) | tcw | th(W-S),<br>th(W-A) | | | | 0 | 00b | ww = 1 | 1 | 3 | 8 | 4 | 1 | 4 | 8 | 3 | | | 00b | | 01b | ww = 2 | 1 | 6 | 8 | 1 | 1 | 8 | 12 | 3 | | | 000 | suw = 0 | 10b | ww = 3 | 1 | 9 | 12 | 2 | 1 | 12 | 16 | 3 | | | | | 11b | ww = 4 | 1 | 12 | 16 | 3 | 1 | 16 | 20 | 3 | | | | suw = 1 | | 00b | ww = 1 | 4 | 3 | 8 | 1 | 5 | 4 | 12 | 3 | | 01b | | 01b | ww = 2 | 4 | 6 | 12 | 2 | 5 | 8 | 16 | 3 | | | 010 | | 10b | ww = 3 | 4 | 9 | 16 | 3 | 5 | 12 | 20 | 3 | | | | | 11b | ww = 4 | 4 | 12 | 20 | 4 | 5 | 16 | 24 | 3 | | | | <i>suw</i> = 2 | 00b | ww = 1 | 8 | 2 | 12 | 2 | 9 | 4 | 16 | 3 | | | 10b | | 01b | ww = 2 | 8 | 5 | 16 | 3 | 9 | 8 | 20 | 3 | | | 100 | | 10b | ww = 3 | 8 | 8 | 20 | 4 | 9 | 12 | 24 | 3 | | | | | 11b | ww = 4 | 8 | 11 | 20 | 1 | 9 | 16 | 28 | 3 | | | 11b | <i>suw</i> = 3 | 00b | ww = 1 | 10 | 3 | 16 | 3 | 13 | 4 | 20 | 3 | | | | | 01b | ww = 2 | 10 | 6 | 20 | 4 | 13 | 8 | 24 | 3 | | | | | 10b | ww = 3 | 10 | 9 | 20 | 1 | 13 | 12 | 28 | 3 | | | | | 11b | ww = 4 | 10 | 12 | 24 | 2 | 13 | 16 | 32 | 3 | | #### 26.3.2 Software Commands In CPU rewrite mode, software commands enable rewrite and erase operations for the flash memory. Writing commands and reading/writing data should be performed in 16-bit units. Table 26.12 lists the software commands. Table 26.12 Software Commands | Command | First Command Cycle | | Second Command Cycle | | |----------------------------------------|---------------------|-------|----------------------|-------| | Command | Address | Data | Address | Data | | Enter read array mode | FFFFF800h | 00FFh | _ | _ | | Enter read status register mode (1) | FFFFF800h | 0070h | _ | _ | | Clear status register | FFFFF800h | 0050h | _ | _ | | Program (2) | FFFFF800h | 0043h | WA | WD | | Block erase | FFFFF800h | 0020h | BA | 00D0h | | Lock bit program | FFFFF800h | 0077h | BA | 00D0h | | Read lock bit status | FFFFF800h | 0071h | BA | 00D0h | | Enter read lock bit status mode (3) | FFFFF800h | 0071h | _ | _ | | Protect bit program | FFFFF800h | 0067h | PBA | 00D0h | | Enter read protect bit status mode (3) | FFFFF800h | 0061h | _ | _ | WA: Even address to be written WD: 16-bit data to be written BA: Even address within a specific block PBA: Protect bit address (refer to Table 26.4) #### Notes: - 1. This command cannot be executed in EW1 mode. - 2. The program is performed in 64-bit (4-word) units. A sequence of commands consists of commands from the second to fifth. The upper 29 bits of the address WA should be fixed and the lower 3 bits of respective commands from the second to fifth should be set to 000b, 010b, 100b, and 110b for the addresses 0h, 2h, 4h, and 6h, or 8h, Ah, Ch, and Eh. - 3. This command should be executed in RAM. #### 26.3.3 Mode Transition CPU rewrite mode supports four flash memory operating modes: - · Read array mode - Read status register mode - Read lock bit status mode - Read protect bit status mode When reading the flash memory in these modes, the memory content, the status register content, the state of the lock bit in the read block, and the state of the protect bit are individually read. Details are listed in Tables 26.13 to 26.15. Table 26.13 Status Register | Bit | Bit Symbol | Bit Name | Definition | | | |--------|------------|------------------|------------------------|-------|--| | Dit | Dit Symbol | Dit Name | 0 | 1 | | | b15-b8 | _ | Disabled bit | _ | _ | | | b7 | SR7 | Sequencer status | BUSY | READY | | | b6 | _ | Reserved bit | _ | _ | | | b5 | SR5 | Erase status | Successfully completed | Error | | | b4 | SR4 | Program status | Successfully completed | Error | | | b3 | _ | Reserved bit | _ | _ | | | b2 | _ | Reserved bit | _ | _ | | | b1 | _ | Reserved bit | _ | _ | | | b0 | _ | Reserved bit | _ | _ | | Table 26.14 Lock Bit Status | Bit | Bit Symbol | Bit Name | Definition | | | |--------|------------|-----------------|------------|----------|--| | Dit | Dit Symbol | Dit Name | 0 | 1 | | | b15-b7 | _ | Disabled bit | _ | _ | | | b6 | LBS | Lock bit status | Locked | Unlocked | | | b5-b0 | _ | Disabled bit | _ | _ | | Table 26.15 Protect Bit Status | Bit | Bit Symbol | Bit Name | Definition | | | |--------|------------|--------------------|------------|-------------|--| | Dit | Dit Gymbol | Dit Name | 0 | 1 | | | b15-b7 | _ | Disabled bit | _ | _ | | | b6 | PBS | Protect bit status | Protected | Unprotected | | | b5-b0 | _ | Disabled bit | _ | _ | | In these operating modes, program or erase operation can be performed by software commands. After an operation is completed, the flash memory module automatically enters read array mode (in EW1 mode) or read status register mode (in EW0 mode). # 26.3.4 Issuing Software Commands This section describes how to issue software commands. These commands should be issued while the RDY bit in the FMSR0 register is 1 (ready). # 26.3.4.1 Enter Read Array Mode Command Execute this command to enter read array mode. When 00FFh is written to address FFFF800h, the flash memory enters read array mode. In this mode, the content stored to a given address in memory can be read. In EW1 mode, the flash memory is always in read array mode. ### 26.3.4.2 Enter Read Status Register Mode Execute this command to enter read status register mode. When 0070h is written to address FFFF800h, the status register content is read in any address of the flash memory. Do not issue this command in EW1 mode. #### 26.3.4.3 Clear Status Register Execute this command to reset the status register in the flash memory. When 0050h is written to address FFFFF800h, bits SR5 and SR4 in the status register become 0 (successfully completed) (refer to Table 26.13). Consequently, bits EERR and WERR in the FMSR0 register become 0 (no errors). # 26.3.4.4 Program Command Execute this command to program the flash memory in 8-byte (4-word) units. To start automatic programming (program and program-verify operations), write 0043h to address FFFFF800h, then write data to addresses 8n + 0 to 8n + 6. Verify that the FCA bit in the FMR0 register is 0 just before executing the final command. To monitor the automatic program operation, read the RDY bit in the FMSR0 register. This bit becomes 0 (busy) when the operation is in progress and 1 (ready) when the operation is completed. The operation result can be verified by the WERR bit in the FMSR0 register (refer to 26.3.5 "Status Check"). Do not write additional data to an address that is already programmed. Figure 26.14 Program Command Execution Flowchart #### 26.3.4.5 Block Erase Command Execute this command to erase a specified block in the flash memory. To start automatic erasing of a specified block (erase and erase-verify operations), write 0020h to address FFFF800h, verify that the FCA bit in the FMR0 register is 0, then write 00D0h to an even address in the corresponding block. To monitor the automatic erase operation, read the RDY bit in the FMSR0 register. This bit becomes 0 (busy) when the operation is in progress and 1 (ready) when the operation is completed. The operation result can be verified by the EERR bit in the FMSR0 register (refer to 26.3.5 "Status Check"). Figure 26.15 Block Erase Command Execution Flowchart # 26.3.4.6 Lock Bit Program Command Execute this command to lock a specified block in the flash memory. To lock the block, write 0077h to address FFFFF800h, verify that the FCA bit in the FMR0 register is 0, then write 00D0h to an even address in the corresponding block. Then the lock bit of the block becomes 0 (locked). To monitor the lock bit program, read the RDY bit in the FMSR0 register. This bit becomes 0 (busy) when the operation is in progress and 1 (ready) when the operation is completed. The state of the lock bit can be verified by the read lock bit status command if the LBM bit in the FMR0 register is 1 (read by the LBS bit) (refer to 26.3.4.7 "Read Lock Bit Status Command"). If the LBM bit is 0 (read via data bus), enter read lock bit status mode (refer to 26.3.4.8 "Enter Read Lock Bit Status Mode Command"). Figure 26.16 Lock Bit Program Command Execution Flowchart #### 26.3.4.7 Read Lock Bit Status Command Execute this command to verify if a specified block in the flash memory is locked. This command can be used when the LBM bit in the FMR0 register is 1 (read by the LBS bit). The LBS bit in the FMSR0 register reflects the lock bit status of the specified block when the following is performed: first write 0071h to address FFFF800h and verify that the FCA bit in the FMR0 register becomes 0. Then write 00D0h to an even address of the corresponding block. Read the LBS bit after the RDY bit in the FMSR0 register becomes 1 (ready). Figure 26.17 Read Lock Bit Status Command Execution Flowchart #### 26.3.4.8 Enter Read Lock Bit Status Mode Command Execute this command to enter read lock bit status mode. This command is enabled when the LBM bit in the FMR0 register is 0 (read via data bus). To read the lock bit status of the read block, write 0071h to address FFFFF800h (refer to Table 26.14). The status is read in any address of the flash memory. Execute this command in RAM. # 26.3.4.9 Protect Bit Program Command Execute this command to protect a specific block in the flash memory. ROM code protection is enabled by setting one of the protect bits of the block to 0. To set the protect bit of the designated block to 0 (protected), write 0067h to address FFFF800h, verify that the FCA bit in the FMR0 register is 0, and then write 00D0h to the protect bit of the corresponding block (refer to Table 26.4). To monitor the protect bit program, read the RDY bit in the FMSR0 register. This bit becomes 0 (busy) when the operation is in progress and 1 (ready) when the operation is completed. To verify the state of protect bit, enter read protect bit status mode (refer to 26.3.4.10 "Enter Read Protect Bit Status Mode Command"), then read the flash memory. Figure 26.18 Protect Bit Program Command Execution Flowchart #### 26.3.4.10 Enter Read Protect Bit Status Mode Command Execute this command to enter read protect bit status mode. To read the protect bit status of the read block, write 0061h to address FFFFF800h (refer to Table 26.15). The status is read from any address in the flash memory. Execute this command in RAM. #### 26.3.5 Status Check To verify if a software command is successfully executed, read the EERR or WERR bit in the FMSR0 register, or the SR5 bit or SR4 bit in the status register. Table 26.16 lists status and errors indicated by these bits and Figure 26.19 shows the flowchart of the status check. Table 26.16 Status and Errors | | Register<br>Register) | Error | Source of Error | | | |-----------------------|-----------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | EERR bit<br>(SR5 bit) | WERR bit<br>(SR4 bit) | bit | | | | | 1 | 1 | Command sequence error | <ul> <li>Data other than 00D0h or 00FFh (command to cancel) was written as the last command of two commands</li> <li>An unavailable address was specified by an address specifying command</li> </ul> | | | | 1 | 0 | Erase error | Attempted to erase a locked block Corresponding block was not erased properly | | | | 0 | 1 | Program error | <ul> <li>Attempted to program a locked block</li> <li>Data was not programmed properly</li> <li>Lock bit was not programmed properly</li> <li>Protect bit was not programmed properly</li> </ul> | | | | 0 0 | | No error | | | | Figure 26.19 Status Check Flowchart When an error occurs, execute the clear status register command and then handle the error. If erase errors or program errors occur frequently even though the program is correct, the corresponding block may be disabled. #### 26.4 Standard Serial I/O Mode In standard serial I/O mode, an R32C/161 Group compatible serial programmer can be used to rewrite the flash memory while the MCU is mounted on a board. For further information on the serial programmer, contact your serial programmer manufacturer and refer to the user's manual included with the serial programmer for instructions. As shown in Table 26.17, this mode provides two types of transmit/receive mode: Standard serial I/O mode 1 which uses a synchronous serial interface, and standard serial I/O mode 2 which uses UART. Table 26.17 Standard Serial I/O Mode Specifications | It | em | Standard Serial I/O Mode 1 | Standard Serial I/O Mode 2 | | |------------------|-------------|-----------------------------------------------------------------|-------------------------------------------------|--| | Transmit/receiv | /e mode | Synchronous serial I/O | UART | | | Transmit/receiv | e bit rate | High | Low | | | Serial interface | to be used | UART1 | UART1 | | | Pin settings | CNVSS | High | High | | | | CE (P5_0) | High | High | | | | EPM (P5_5) | Low | Low | | | Pin functions | SCLK (P4_5) | In reset: Low In transmission/reception: Transmit/receive clock | In reset: Low In transmission/reception: Unused | | | | BUSY (P4_4) | BUSY signal | Monitor to check program operation | | | | RXD (P4_6) | Serial data input | Serial data input | | | | TXD (P4_7) | Serial data output | Serial data output | | Table 26.18 lists the pin definitions and functions in standard serial I/O mode. Figures 26.20 and 26.21 show examples of a circuit application in standard serial I/O modes 1 and 2, respectively. Refer to the serial programmer user manual to handle pins controlled by the serial programmer. Table 26.18 Pin Definitions and Functions in Standard Serial I/O Mode | Pin Name | Function | I/O | Description | |----------------------------------------------------------------------------------|------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------| | VCC, VSS | Power supply input | I | Applicable as follows: VCC = guaranteed voltage for program/ erase operations, VSS = 0 V | | VDC1, VDC0 | Connecting pins for decoupling capacitor | _ | A decoupling capacitor for internal voltage should be connected between VDC0 and VDC1 | | CNVSS | CNVSS | I | This pin should be connected to VCC via a resistor | | RESET | Reset input | I | Reset input pin. While the RESET pin is driven low, a clock of 20 cycles or more should be input at the XIN pin | | XIN | Main clock input | - | A ceramic resonator or a crystal oscillator should be connected | | XOUT | Main clock output | 0 | between pins XIN and XOUT. An external clock should be input at XIN while leaving XOUT open | | NSD | Debug port | I/O | This pin should be connected to VCC via a resistor of 1 to 4.7 k $\Omega$ | | AVCC, AVSS | Analog power supply | Ι | AVCC and AVSS should be connected to VCC and VSS, respectively | | VREF | Reference voltage input | I | Reference voltage input for the A/D converter and D/A converter | | 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_3 | Input port | I | High or low should be input, or the ports should be left open | | P4_4 | BUSY output | 0 | Standard serial I/O mode 1: BUSY output pin Standard serial I/O mode 2: Program operation monitor | | P4_5 | SCLK input | I | Standard serial I/O mode 1: Serial clock input pin Standard serial I/O mode 2: Low should be input | | P4_6 | Data input RXD | I | Serial data input pin | | P4_7 | Data output TXD | 0 | Serial data output pin | | P5_0 | CE input | I | High should be input | | P5_1 to P5_4 | Input port | Ι | High or low should be input, or the ports should be left open | | P5_5 | EPM input | Ι | Low should be input | | P5_6, P5_7,<br>P6_5, P6_7 | Input port | I | High or low should be input, or the ports should be left open | | P7_0,<br>P7_4 to P7_6,<br>P8_2 to P8_4 | Input port | I | High or low should be input, or the ports should be left open | | P8_5 | NMI input | I | This pin should be connected to VCC via a resistor | | P8_6, P8_7, P9_1,<br>P9_3 to P9_7 | Input port | I | High or low should be input, or the ports should be left open | Figure 26.20 Circuit Application in Standard Serial I/O Mode 1 Figure 26.21 Circuit Application in Standard Serial I/O Mode 2 #### 26.5 Parallel I/O mode In parallel I/O mode, an R32C/161 Group compatible parallel programmer can be used to rewrite the flash memory. For further information on the parallel programmer, contact your parallel programmer manufacturer and refer to the user's manual included with your parallel programmer for instructions. #### 26.6 Notes on Flash Memory Rewriting #### 26.6.1 Note on Power Supply Keep the supply voltage constant within the range specified in the electrical characteristics while a rewrite operation on the flash memory is in progress. If the supply voltage goes beyond the guaranteed value, the device cannot be guaranteed. #### 26.6.2 Note on Hardware Reset • Do not perform a hardware reset while a rewrite operation on the flash memory is in progress. #### 26.6.3 Note on Flash Memory Protection • If an ID code written in an assigned address has an error, any read/write operation on the flash memory in standard serial I/O mode is disabled. #### 26.6.4 Notes on Programming - Do not set the FEW bit in the FMCR register to 1 (CPU rewrite mode) in low speed mode or low power mode. - When the EWM bit in the E2FM register is 1 (program or erase enabled), do not set the FEW bit in the FMCR register to 1. - The program, block erase, lock bit program, and protect bit program are interrupted by an NMI, a watchdog timer interrupt, an oscillator stop detection interrupt, or a low voltage detection interrupt. If any of the software commands above are interrupted, erase the corresponding block and then execute the same command again. If the block erase command is interrupted, the lock bit and protect bit values become undefined. Therefore, disable the lock bit, and then execute the block erase command again. ### 26.6.5 Notes on Interrupts - EW0 mode - To use interrupts assigned to the relocatable vector table, the vector table should be addressed in RAM space. - When an NMI, watchdog timer interrupt, oscillator stop detection interrupt, or low voltage detection interrupt occurs, the flash memory module automatically enters read array mode. Therefore, these interrupts are enabled even during a rewrite operation. However, the rewrite operation in progress is aborted by the interrupts and registers FMR0 and FRSR0 are reset. When the interrupt handler has ended, set the LBD bit in the FMR1 register to 1 (lock bit protection disabled) to re-execute the rewrite operation. - Instructions BRK, INTO, and UND, which refer to data on the flash memory, cannot be used in this mode. - EW1 mode - Interrupts assigned to the relocatable vector table should not be accepted during program or block erase operation. - The watchdog timer should not be used in count source protect mode. The watchdog timer interrupt should not be generated. - When an NMI, watchdog timer interrupt, oscillator stop detection interrupt, or low voltage detection interrupt occurs, the flash memory module automatically enters read array mode. Therefore, these interrupts are enabled even during a rewrite operation. However, the rewrite operation in progress is aborted by the interrupts and registers FMR0 and FRSR0 are reset. When the interrupt handler has ended, set the EWM bit in the FMR0 register to 1 (EW1 mode) and the LBD bit in the FMR1 register to 1 (lock bit protection disabled) to re-execute the rewrite operation. R32C/161 Group 26. Flash Memory # 26.6.6 Notes on Rewrite Control Program - EW0 mode - If the supply voltage drops during the rewrite operation of blocks having the rewrite control program, the rewrite control program may not be successfully rewritten, and the rewrite operation itself may not be performed. In this case, perform the rewrite operation by serial programmer or parallel programmer. - EW1 mode - Do not rewrite blocks having the rewrite control program. # 26.6.7 Notes on Number of Program/Erase Cycles and Software Command Execution Time • The time to execute software commands (program, block erase, lock bit program, and protect bit program) increases as the number of program/erase cycles increases. If the number of program/erase cycles exceeds the endurance value specified in the electrical characteristics, it may take an unpredictable amount of time to execute the software commands. The wait time for executing software commands should be set much longer than the execution time specified in the electrical characteristics. #### 26.6.8 Other Notes - The minimum values of program/erase cycles specified in the electrical characteristics are the maximum values that can guarantee the initial performance of the flash memory. The program/erase operation may still be performed even if the number of program/erase cycles exceeds the guaranteed values. - Chips repeatedly programmed and erased for debugging should not be used for commercial products. # 27. E<sup>2</sup>PROM Emulation Data Flash #### 27.1 Overview E²PROM emulation data flash (hereafter referred to as E²dataFlash) is an on-chip data flash which has features of serial E²PROMs. It is erasable in much smaller blocks than the other data flash and can be programmed and erased without keeping the CPU away from its operation. Table 27.1 lists the specifications and Figure 27.1 shows the block diagram of the E<sup>2</sup>dataFlash. Table 27.1 E<sup>2</sup>dataFlash Specifications | Item | Specification | | | | |----------------------------------|----------------------|-------------------------|--|--| | item | ECC disabled | ECC enabled | | | | Memory size | 4 Kbytes | 2 Kbytes | | | | Block size | 32 bytes | 16 bytes | | | | Number of blocks | 128 | | | | | Unit to be programmed | 2 bytes | 1 byte | | | | Unit to be erased | 1 block | | | | | Program and erase control method | By software commands | | | | | Software commands | 4 | | | | | Error correction | None | 1-bit error correctable | | | $Figure\ 27.1 \quad E^2 data Flash\ Block\ Diagram$ The CPU indirectly accesses the E<sup>2</sup>dataFlash via registers E2FA, E2FI, and E2FD which are set for SFR space. Figures 27.2 to 27.8 show E<sup>2</sup>dataFlash associated registers. - Notes: - 1. Set the PRC41 bit in the PRCR4 register to 1 (write enabled) before rewriting this register. - 2. Once this bit is set to 1, it should be set to 0 after the RDY bit in the E2FS0 register becomes 1 (ready). - 3. When this bit is set to 1, the module stops ongoing operations to enter its initial state. However, the registers are not initialized. - 4. When the MRS bit in the VRCR register is 1 (main regulator stopped), or when the FEW bit in the FMCR register is 1 (CPU rewrite mode), this bit should not be set to 1. - 5. In this mode, any write access results in the E2FI register being set to 00F3h (read commands). Figure 27.2 E2FM Register Figure 27.3 E2FC Register Figure 27.4 E2FS0 Register Figure 27.5 E2FS1 Register Figure 27.6 E2FA Register Figure 27.7 E2FI Register Figure 27.8 E2FD Register # 27.2 Block Configuration The $E^2$ dataFlash consists of 32 bytes x 128 blocks of flash memory when ECC is disabled, and 16 bytes x 128 blocks when ECC is enabled (refer to Figure 27.9 for details). Figure 27.9 E<sup>2</sup>dataFlash Memory Configuration # 27.3 Operational Procedures Figures 27.10 to 27.13 show the read, program, block erase, and clear status operational procedures. Follow the procedures to operate each. Figure 27.10 Read Operation Figure 27.11 Program Operation Figure 27.12 Block Erase Operation Figure 27.13 Clear Status Operation # 27.4 Note on E<sup>2</sup>dataFlash When the FEW bit in the FMCR register is 1 (CPU rewrite mode), do not set the EWM bit in the E2FM register to 1 (program or erase enabled). # 28. Electrical Characteristics Table 28.1 Absolute Maximum Ratings (1) | Symbol | | Characteristic | Condition | Value | Unit | |------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------------------------|------| | $V_{CC}$ | Supply volta | age | $V_{CC} = AV_{CC}$ | -0.3 to 6.0 | V | | AV <sub>CC</sub> | Analog sup | ply voltage | $V_{CC} = AV_{CC}$ | -0.3 to 6.0 | V | | Vı | Input<br>voltage | XIN, RESET, CNVSS, NSD, V <sub>REF</sub> ,<br>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, P6_5,<br>P6_7, P7_0, P7_4 to P7_6,<br>P8_2 to P8_7, P9_1, P9_3 to P9_7 | | -0.3 to V <sub>CC</sub> + 0.3 | ٧ | | Vo | Output<br>voltage | XOUT, 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | | -0.3 to V <sub>CC</sub> + 0.3 | > | | $P_d$ | Power cons | sumption | T <sub>a</sub> = 25°C | 500 | mW | | _ | Operating t | emperature range | | -40 to 125 | °C | | T <sub>stg</sub> | Storage ten | nperature range | | -65 to 150 | °C | #### Note: 1. Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Table 28.2 Operating Conditions (1/6) (1) | Symbol | | Characteristic | | Value | | Unit | |----------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------|-----------------------|-------| | Symbol | | Characteristic | Min. | Тур. | Max. | Offic | | $V_{CC}$ | Digital supply | voltage | 3.0 | 5.0 | 5.5 | V | | $AV_{CC}$ | Analog suppl | y voltage | | $V_{CC}$ | | V | | $V_{REF}$ | Reference vo | eference voltage | | | V <sub>CC</sub> | V | | $V_{SS}$ | Digital groun | d voltage | | 0 | | V | | $AV_{SS}$ | Analog ground voltage | | | 0 | | V | | dV <sub>CC</sub> /dt | dt V <sub>CC</sub> ramp up rate (V <sub>CC</sub> < 2.0 V) | | 0.05 | | | V/ms | | $V_{IH}$ | High level | XIN, RESET, CNVSS, NSD | 0.8 × V <sub>CC</sub> | | V <sub>CC</sub> | V | | | input<br>voltage | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_7 (2), P9_1, P9_3 to P9_7 | 0.7 × V <sub>CC</sub> | | V <sub>CC</sub> | V | | $V_{IL}$ | Low level | XIN, RESET, CNVSS, NSD | 0 | | 0.2 × V <sub>CC</sub> | V | | | input<br>voltage | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_7 (2), P9_1, P9_3 to P9_7 | 0 | | 0.3 × V <sub>CC</sub> | V | | T <sub>opr</sub> | Operating | J version | -40 | | 85 | °C | | | temperature | L version | -40 | | 105 | °C | | | range | K version | -40 | | 125 | °C | - 1. The device is operationally guaranteed under these operating conditions. - 2. $V_{IH}$ and $V_{IL}$ for P8\_7 are specified for P8\_7 as a programmable port. These values are not applicable for P8\_7 as XCIN. Table 28.3 Operating Conditions (2/6) ( $V_{CC}$ = 3.0 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) <sup>(1)</sup> | Symbol | Characteristic | | V | /alue (2 | 2) | Unit | |------------------|----------------------------------------------|--------------------------|------|----------|------|------| | Oymboi | Onaraciensiio | | Min. | Тур. | Max. | Onic | | C <sub>VDC</sub> | Decoupling capacitance for voltage regulator | Inter-pin voltage: 1.5 V | 2.4 | | 10.0 | μF | - 1. The device is operationally guaranteed under these operating conditions. - 2. This value should be met with due consideration to the following conditions: operating temperature, DC bias, aging, etc. Table 28.4 Operating Conditions (3/6) $(V_{CC} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ (1) | Symbol | | Characteristic | | Value | | Unit | |-----------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------|-------| | Symbol | | Characteristic | Min. | Тур. | Max. | Offic | | I <sub>OH(peak)</sub> | peak<br>output | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | | | -10.0 | mA | | I <sub>OH(avg)</sub> | average<br>output | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | | | -5.0 | mA | | I <sub>OL(peak)</sub> | peak<br>output | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | | | 10.0 | mA | | I <sub>OL(avg)</sub> | average<br>output | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | | | 5.0 | mA | - 1. The device is operationally guaranteed under these operating conditions. - 2. The following conditions should be satisfied: - $\bullet$ The sum of $I_{OL(peak)}$ of ports P0, P1, P2, P8\_6, P8\_7, and P9 is 80 mA or less. - The sum of I<sub>OL(peak)</sub> of ports P3, P4, P5, P6, P7, and P8\_2 to P8\_4 is 80 mA or less. - The sum of I<sub>OH(peak)</sub> of ports P1 and P2 is -40 mA or less. - $\bullet$ The sum of $I_{\mbox{OH(peak)}}$ of ports P0, P9\_6, and P9\_7 is -40 mA or less. - $\bullet$ The sum of $I_{OH(peak)}$ of ports P3, P4, P5, and P6 is -40 mA or less. - $\bullet$ The sum of $I_{OH(peak)}$ of ports P7, P8, and P9\_3 to P9\_5 is -40 mA or less. - 3. Average value within 100 ms. Table 28.5 Operating Conditions (4/6) $(V_{CC} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ (1) | Cumahad | Charactaristic | | Value | | 1.1 | |----------------------|------------------------------------------|-------|--------|------|--------| | Symbol | Characteristic | Min. | Тур. | Max. | - Unit | | $f_{(XIN)}$ | Main clock oscillator frequency | 4 | | 8 | MHz | | f <sub>(XRef)</sub> | Reference clock frequency | 2 | | 4 | MHz | | f <sub>(PLL)</sub> | PLL clock oscillator frequency | 96 | | 144 | MHz | | f <sub>(Base)</sub> | Base clock frequency | | | 48 | MHz | | t <sub>c(Base)</sub> | Base clock cycle time | 20.83 | | | ns | | f <sub>(CPU)</sub> | CPU operating frequency | | | 48 | MHz | | t <sub>C(CPU)</sub> | CPU clock cycle time | 20.83 | | | ns | | f <sub>(BCLK)</sub> | Peripheral bus clock operating frequency | | | 24 | MHz | | t <sub>C(BCLK)</sub> | Peripheral bus clock cycle time | 41.67 | | | ns | | f <sub>(PER)</sub> | Peripheral clock source frequency | | | 24 | MHz | | f <sub>(XCIN)</sub> | Sub clock oscillator frequency | | 32.768 | 50 | kHz | 1. The device is operationally guaranteed under these operating conditions. Figure 28.1 Clock Cycle Time Table 28.6 Operating Conditions (5/6) $(V_{CC} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ (1, 2) | Symbol | | Characteristic | Measurement | | | Unit | | |--------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|------|------|------|-------| | Syllibol | | Characteristic | Condition | Min. | Тур. | Max. | Offic | | I <sub>IC(H)</sub> | High input injection current | 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, P6_5,<br>P6_7, P7_0, P7_4 to P7_6,<br>P8_2 to P8_5, P9_3 to P9_7 | V <sub>I</sub> > V <sub>CC</sub> | | | 2 | mA | | I <sub>IC(L)</sub> | Low input injection current | 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, P6_5,<br>P6_7, P7_0, P7_4 to P7_6,<br>P8_2 to P8_5, P9_3 to P9_7 | V <sub>I</sub> < V <sub>SS</sub> | | | -2 | mA | | $\Sigma I_{IC} $ | Total injection | current | | | | 20 | mA | - 1. The device is operationally guaranteed under these operating conditions. - 2. These conditions are applicable when each port is designated as input. Table 28.7 Operating Conditions (6/6) $(V_{CC} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ (1) | Symbol | Characteristic | | | Value | | | | |--------------------------|----------------------------|-------------------------|------|-------|------|------|--| | Symbol Characteristic | | ouc. | Min. | Тур. | Max. | Unit | | | $V_{r(VCC)}$ | Allowable ripple voltage | V <sub>CC</sub> = 5.0 V | | | 0.5 | Vp-p | | | | | V <sub>CC</sub> = 3.0 V | | | 0.3 | Vp-p | | | dV <sub>r(VCC)</sub> /dt | Ripple voltage gradient | V <sub>CC</sub> = 5.0 V | | | ±0.3 | V/ms | | | | | V <sub>CC</sub> = 3.0 V | | | ±0.3 | V/ms | | | f <sub>r(VCC)</sub> | Allowable ripple frequency | | | | 10 | kHz | | 1. The device is operationally guaranteed under these operating conditions. Figure 28.2 Ripple Waveform Table 28.8 Electrical Characteristics of Flash Memory $(V_{CC} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and Ta} = T_{opr}, \text{ unless otherwise noted})$ | Symbol | Characteristic | | | Value | | Unit | |----------|-------------------------------------|------------------------------|-------|-------|------|--------| | Syllibol | Gnaracteristic | | Min. | Тур. | Max. | Offic | | _ | Program/erase cycles <sup>(1)</sup> | Program area | 1000 | | | Cycles | | | | Data area | 10000 | | | Cycles | | _ | 4-word program time | Program area | | 150 | 900 | μs | | | | Data area | | 300 | 1700 | μs | | _ | Lock bit program time | Program area | | 70 | 500 | μs | | | | Data area | | 140 | 1000 | μs | | _ | Block erasure time | 4-Kbyte block | | 0.12 | 3.0 | S | | | | 32-Kbyte block | | 0.17 | 3.0 | s | | | | 64-Kbyte block | | 0.20 | 3.0 | S | | _ | Data retention <sup>(2)</sup> | $T_a = 55^{\circ}C^{(3, 4)}$ | 20 | | | Years | 1. Program/erase definition This value represents the number of erasures per block. When the number of program/erase cycles is n, each block can be erased n times. For example, if a 4-word write is performed in 512 different addresses in the 4-Kbyte block A and then the block is erased, this is counted as a single program/erase operation. However, the same address cannot be written to more than once per erasure (overwrite disabled). - 2. Data retention includes periods when no supply voltage is applied and no clock is provided. - 3. This data retention includes 3000 hours in $T_a = 125$ °C and 7000 hours in $T_a = 85$ °C. - 4. Contact a Renesas Electronics sales office for data retention times other than the above condition. Table 28.9 Electrical Characteristics of $E^2$ dataFlash ( $V_{CC} = 3.0$ to 5.5 V, $V_{SS} = 0$ V, and $T_a = T_{opr}$ , unless otherwise noted) | Symbol | Characteristic | | | Unit | | | |----------|--------------------------------------------------|-----------------------------|--------|------|------|--------| | Symbol | | | Min. | Тур. | Max. | Offic | | | Program/erase cycles <sup>(1)</sup> | | 100000 | | | Cycles | | | Word program time | | | 100 | 2000 | μs | | | Block erasure time | 32 byte block | | 15 | 200 | ms | | $t_{PS}$ | Flash memory circuit start-up stabilization time | | | 35 | 50 | μs | | | Data retention (2) | $T_a = 55^{\circ}C^{(3,4)}$ | 20 | | | Years | 1. Program/erase definition This value represents the number of erasure per block. When the number of program/erase cycles is n, each block can be erased n times. For example, if a word write is performed in 16 different addresses in a block and then the block is erased, this is counted as a single program/erase operation. However, the same address cannot be written to more than once per erasure (overwrite disabled). - 2. Data retention includes periods when no supply voltage is applied and no clock is provided. - 3. This data retention includes 3000 hours in $T_a = 125^{\circ}C$ and 7000 hours in $T_a = 85^{\circ}C$ . - 4. Contact a Renesas Electronics sales office for data retention times other than the above condition. Table 28.10 Power Supply Circuit Timing Characteristics $(V_{CC} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ | Symbol | Characteristic | Measurement | Value | | | Unit | |----------------|--------------------------------------------------------------------------------------------|-------------|-------|------|------|-------| | | Griaracteristic | Condition | Min. | Тур. | Max. | Offic | | \( \( \) \( \) | Internal power supply start-up stabilization time after the main power supply is turned on | | | | 2 | ms | Figure 28.3 Power Supply Circuit Timing Table 28.11 Electrical Characteristics of Voltage Regulator for Internal Logic ( $V_{CC} = 3.0$ to 5.5 V, $V_{SS} = 0$ V, and $T_a = T_{opr}$ , unless otherwise noted) | Symbol | Characteristics | Measurement | Value | | | Unit | |------------|-----------------|-------------|-------|------|------|-------| | Symbol | Characteristics | Condition | Min. | Тур. | Max. | Offic | | $V_{VDC1}$ | Output voltage | | | 1.5 | | V | Table 28.12 Electrical Characteristics of Low Voltage Detector ( $V_{CC}$ = 4.2 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) | Symbol | Characteristics | Measurement | Value | | | Unit | |---------------------|----------------------------------------|-------------------------------------------------------|-------|------|------|-------| | Symbol | Characteristics | Condition | Min. | Тур. | Max. | Offic | | ∆Vdet | Detected voltage error | | | | ±0.2 | V | | Vdet(R)-Vdet(F) | Hysteresis width | | 0 | | | V | | _ | | V <sub>CC</sub> = 5.0 V, low voltage detector enabled | | 4 | | μΑ | | t <sub>d(E-A)</sub> | Operation start time of low voltage of | detector | | | 150 | μs | Table 28.13 Electrical Characteristics of Oscillator ( $V_{CC} = 3.0$ to 5.5 V, $V_{SS} = 0$ V, and $T_a = T_{opr}$ , unless otherwise noted) | Symbol | Characteristics | Measurement | | Unit | | | |--------------------------|--------------------------------------|---------------------|------|------|------|-------| | Symbol | Characteristics | Condition | Min. | Тур. | Max. | Offic | | f <sub>SO(PLL)</sub> | PLL clock self-oscillation frequency | | 35 | 50 | 80 | MHz | | $ \Delta f_{LOCK} $ | Lock detection <sup>(1)</sup> | | | | 2 | % | | $ \Delta f_{UNLOCK} $ | Unlock detection (1) | | 2 | | | % | | t <sub>LOCK(PLL)</sub> | PLL lock time <sup>(2, 3)</sup> | $f_{(XRef)} = 4MHz$ | | | 1 | ms | | t <sub>jitter(p-p)</sub> | PLL jitter period (p-p) | | | | 2.0 | ns | | f <sub>(OCO)</sub> | On-chip oscillator frequency | | 94 | 125 | 156 | kHz | - 1. This value is the deviation from target frequency. - 2. This value is applicable only when the main clock oscillation is stable. - 3. This value is the time until the PLF1 bit in the PLS register becomes 1. Table 28.14 Electrical Characteristics of Clock Circuitry $(V_{CC} = 3.0 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ | Symbol | Characteristics | Measurement | Value | | | Unit | |------------------------|-------------------------------------------|-------------|-------|------|------|-------| | Syllibol | Characteristics | Condition | Min. | Тур. | Max. | Offic | | t <sub>rec(WAIT)</sub> | Recovery time from wait mode to low power | mode | | | 225 | μs | | t <sub>rec(STOP)</sub> | Recovery time from stop mode (1) | | | | 225 | μs | 1. The stop mode recovery time does not include the main clock oscillation stabilization time. The CPU starts operating before the oscillator is stabilized. Figure 28.4 Clock Circuit Timing # Timing Requirements ( $V_{CC}$ = 3.0 to 5.5 V, $V_{SS}$ = 0 V, and Ta = $T_{opr}$ , unless otherwise noted) Table 28.15 Flash Memory CPU Rewrite Mode Timing | Symbol | Characteristics | Va | lue | Unit | |----------------------|-------------------------------------|------|------|-------| | Symbol | Characteristics | Min. | Max. | Offic | | t <sub>cR</sub> | Read cycle time | 200 | | ns | | t <sub>su(S-R)</sub> | Chip-select setup time before read | 200 | | ns | | t <sub>h(R-S)</sub> | Chip-select hold time after read | 0 | | ns | | t <sub>su(A-R)</sub> | Address setup time before read | 200 | | ns | | t <sub>h(R-A)</sub> | Address hold time after read | 0 | | ns | | t <sub>w(R)</sub> | Read pulse width | 100 | | ns | | t <sub>cW</sub> | Write cycle time | 200 | | ns | | t <sub>su(S-W)</sub> | Chip-select setup time before write | 0 | | ns | | t <sub>h(W-S)</sub> | Chip-select hold time after write | 30 | | ns | | t <sub>su(A-W)</sub> | Address setup time before write | 0 | | ns | | t <sub>h(W-A)</sub> | Address hold time after write | 30 | | ns | | t <sub>w(W)</sub> | Write pulse width | 50 | | ns | Figure 28.5 Flash Memory CPU Rewrite Mode Timing Table 28.16 Electrical Characteristics (1/3) $(V_{CC} = 4.2 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, T_a = T_{opr}, \text{ and } f_{(CPU)} = 48 \text{ MHz}, \text{ unless otherwise noted)}$ | Symbol | | Characteristic Measurement Value | | | | | Unit | |-----------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-----------------------|------|-----------------|-------| | Symbol | | Citatacteristic | Condition | Min. | Тур. | Max. | Offic | | V <sub>OH</sub> | | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | I <sub>OH</sub> = -5 mA | V <sub>CC</sub> - 2.0 | | V <sub>CC</sub> | ٧ | | | | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | Ι <sub>ΟΗ</sub> = -200 μΑ | V <sub>CC</sub> - 0.3 | | V <sub>CC</sub> | ٧ | | V <sub>OL</sub> | Low<br>level<br>output<br>voltage | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | I <sub>OL</sub> = 5 mA | | | 2.0 | ٧ | | | | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | I <sub>OL</sub> = 200 μA | | | 0.45 | V | Table 28.17 Electrical Characteristics (2/3) $(V_{CC} = 4.2 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, T_a = T_{opr}, \text{ and } f_{(CPU)} = 48 \text{ MHz}, \text{ unless otherwise noted)}$ | Cumple al | | Charactaristic | Measurement | | Value | | Unit | |-----------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------|-------|------|------| | Symbol | | Characteristic | Condition | Min. | Тур. | Max. | Unit | | V <sub>T+</sub> - V <sub>T-</sub> | Hysteresis | NMI, INTO to INT5, TA0IN to TA4IN, TA0OUT to TA4OUT, TB0IN to TB5IN, CTS0 to CTS4, CLK0 to CLK4, RXD0 to RXD4, SCL0 to SCL2, SDA0 to SDA2, SS0 to SS2, SRXD0 to SRXD2, ADTRG, IIO0_0 to IIO0_7, UD0A, UD0B, SCS0, SSCK0, SSI0, SSO0, LIN0IN, CAN0IN, CAN1IN, CAN0WU, CAN1WU | | 0.2 | | 1.0 | V | | | | RESET | | 0.2 | | 1.8 | V | | I <sub>IH</sub> | High level input current | XIN, RESET, CNVSS, NSD,<br>P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7,<br>P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7,<br>P6_5, P6_7, P7_0, P7_4 to P7_6,<br>P8_2 to P8_7, P9_1, P9_3 to P9_7 | V <sub>I</sub> = 5 V | | | 1.0 | μΑ | | I <sub>IL</sub> | Low level<br>input<br>current | XIN, RESET, CNVSS, NSD,<br>P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7,<br>P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7,<br>P6_5, P6_7, P7_0, P7_4 to P7_6,<br>P8_2 to P8_7, P9_1, P9_3 to P9_7 | V <sub>I</sub> = 0 V | | | -1.0 | μΑ | | R <sub>PULLUP</sub> | Pull-up<br>resistor | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_1, P9_3 to P9_7 | V <sub>I</sub> = 0 V | 30 | 50 | 170 | kΩ | | R <sub>fXIN</sub> | Feedback resistor | XIN | | | 1.5 | | МΩ | | R <sub>fXCIN</sub> | Feedback resistor | XCIN | | | 15 | | МΩ | Table 28.18 Electrical Characteristics (3/3) $(V_{CC} = 4.2 \text{ to } 5.5 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ | Symbol | Characterist | Mea | surement Condition | | Value | | Unit | |-----------------|----------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|------|------| | | ic | | | Min. | Тур. | Max. | | | I <sub>cc</sub> | Power supply current | In single-chip mode,<br>output pins are left open<br>and others are<br>connected to V <sub>SS</sub> | $f_{(CPU)}$ = 48 MHz, $f_{(BCLK)}$ = 24 MHz,<br>$f_{(XIN)}$ = 8 MHz,<br>Active: XIN, PLL,<br>Stopped: XCIN, OCO | | 31 | 48 | mA | | | | XIN-XOUT<br>Drive strength: low | f <sub>(CPU)</sub> = f <sub>SO(PLL)</sub> /24 MHz,<br>Active: PLL (self-oscillation),<br>Stopped: XIN, XCIN, OCO | | 7 | | mA | | | | XCIN-XCOUT<br>Drive strength: low | $\begin{split} &f_{(CPU)} = f_{(BCLK)} = f_{(XIN)}/256 \text{ MHz}, \\ &f_{(XIN)} = 8 \text{ MHz}, \\ &\text{Active: XIN,} \\ &\text{Stopped: PLL, XCIN, OCO} \end{split}$ | | 1.2 | | mA | | | | | f <sub>(CPU)</sub> = f <sub>(BCLK)</sub> = 32.768 kHz,<br>Active: XCIN,<br>Stopped: XIN, PLL, OCO,<br>Main regulator: shutdown | | 220 | | μΑ | | | | | f <sub>(CPU)</sub> = f <sub>(BCLK)</sub> = f <sub>(OCO)</sub> /4 kHz,<br>Active: OCO,<br>Stopped: XIN, PLL, XCIN,<br>Main regulator: shutdown | | 230 | | μΑ | | | | | $\begin{split} &f_{(CPU)} = f_{(BCLK)} = f_{(XIN)}/256 \text{ MHz}, \\ &f_{(XIN)} = 8 \text{ MHz}, \\ &\text{Active: XIN,} \\ &\text{Stopped: PLL, XCIN, OCO,} \\ &T_a = 25^{\circ}\text{C, Wait mode} \end{split}$ | | 960 | 1600 | μΑ | | | | | f <sub>(CPU)</sub> = f <sub>(BCLK)</sub> = 32.768 kHz,<br>Active: XCIN,<br>Stopped: XIN, PLL, OCO,<br>Main regulator: shutdown,<br>T <sub>a</sub> = 25°C, Wait mode | | 8 | 140 | μΔ | | | | | f <sub>(CPU)</sub> = f <sub>(BCLK)</sub> = f <sub>(OCO)</sub> /4 kHz,<br>Active: OCO,<br>Stopped: XIN, PLL, XCIN,<br>Main regulator: shutdown,<br>T <sub>a</sub> = 25°C, Wait mode | | 10 | 150 | μΔ | | | | | Stopped: all clocks, Main regulator: shutdown, T <sub>a</sub> = 25°C | | 5 | 70 | μΑ | | | | | Stopped: all clocks, Main regulator: shutdown, T <sub>a</sub> = 85°C | | | 400 | μΑ | | | | | Stopped: all clocks,<br>Main regulator: shutdown,<br>T <sub>a</sub> = 105°C | | | 1200 | μΑ | | | | | Stopped: all clocks, Main regulator: shutdown, T <sub>a</sub> = 125°C | | | 2000 | μA | Table 28.19 A/D Conversion Characteristics ( $V_{CC} = AV_{CC} = V_{REF} = 4.2$ to 5.5 V, $V_{SS} = AV_{SS} = 0$ V, $T_a = T_{opr}$ , and $f_{(BCLK)} = 24$ MHz, unless otherwise noted) | 0 | Observato tatta | NA. | | | Value | | | |----------------------|-------------------------------------------------|------------------------------------------|---------------------------------------------------------------------|-------|-------|-----------|------| | Symbol | Characteristic | Measurement Condition | | Min. | Тур. | Max. | Unit | | _ | Resolution | V <sub>REF</sub> = V <sub>CC</sub> | | | | 10 | Bits | | | Absolute error | V <sub>REF</sub> = V <sub>CC</sub> = 5 V | AN_0 to AN_4,<br>AN0_0 to AN0_7,<br>AN2_0 to AN2_7,<br>ANEX0, ANEX1 | | | ±3 | LSB | | | | | External op-amp connection mode | | | ±7 | LSB | | INL | Integral non-linearity error | V <sub>REF</sub> = V <sub>CC</sub> = 5 V | AN_0 to AN_4,<br>AN0_0 to AN0_7,<br>AN2_0 to AN2_7,<br>ANEX0, ANEX1 | | | ±3 | LSB | | | | | External op-amp connection mode | | | ±7 | LSB | | DNL | Differential non-linearity error | | | | | ±1 | LSB | | _ | Offset error | | | | | ±3 | LSB | | _ | Gain error | | | | | ±3 | LSB | | R <sub>LADDER</sub> | Resistor ladder | V <sub>REF</sub> = V <sub>CC</sub> | | 4 | | 20 | kΩ | | t <sub>CONV</sub> | Conversion time (10 bits) | $\phi_{AD}$ = 16 MHz, with function | sample and hold | 2.06 | | | μs | | | | $\phi_{AD}$ = 16 MHz, withoution | out sample and hold | 3.69 | | | μs | | t <sub>CONV</sub> | Conversion time (8 bits) | $\phi_{AD}$ = 16 MHz, with function | sample and hold | 1.75 | | | μs | | | | $\phi_{AD}$ = 16 MHz, withoution | out sample and hold | 3.06 | | | μs | | t <sub>SAMP</sub> | Sampling time | φ <sub>AD</sub> = 16 MHz | | 0.188 | | | μs | | V <sub>IA</sub> | Analog input voltage | | | 0 | | $V_{REF}$ | V | | φ <sub>AD</sub> | Operating clock | Without sample and | hold function | 0.25 | | 16 | MHz | | | frequency | With sample and ho | ld function | 1 | | 16 | MHz | | R <sub>PU(AST)</sub> | Pull-up resistor for open-<br>circuit detection | | | 5 | 10 | 15 | kΩ | | R <sub>PD(AST)</sub> | Pull-down resistor for open-circuit detection | | | 5 | 10 | 15 | kΩ | Timing Requirements ( $V_{CC}$ = 4.2 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.20 External Clock Input | Symbol | Characteristic | Va | Unit | | |---------------------------------|---------------------------------------------|------|------|-------| | Symbol | Characteristic | Min. | Max. | Offic | | $t_{C(X)}$ | External clock input period | 125 | 250 | ns | | t <sub>w(XH)</sub> | External clock input high level pulse width | 50 | | ns | | $t_{w(XL)}$ | External clock input low level pulse width | 50 | | ns | | $t_{r(X)}$ | External clock input rise time | | 5 | ns | | t <sub>f(X)</sub> | External clock input fall time | | 5 | ns | | t <sub>w</sub> / t <sub>c</sub> | External clock input duty | 40 | 60 | % | $$V_{CC} = 5 V$$ # Timing Requirements ( $V_{CC}$ = 4.2 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.21 Timer A Input (counting input in event counter mode) | Symbol | Characteristic | Va | Unit | | |---------------------|------------------------------------|------|------|-------| | Symbol | Characteristic | Min. | Max. | Offic | | t <sub>C(TA)</sub> | TAilN input clock cycle time | 200 | | ns | | t <sub>W(TAH)</sub> | TAilN input high level pulse width | 80 | | ns | | t <sub>W(TAL)</sub> | TAilN input low level pulse width | 80 | | ns | # Table 28.22 Timer A Input (gating input in timer mode) | Symbol | Characteristic | Value | | Unit | |---------------------|------------------------------------|-------|------|-------| | Symbol | Characteristic | Min. | Max. | Offic | | t <sub>C(TA)</sub> | TAilN input clock cycle time | 400 | | ns | | t <sub>w(TAH)</sub> | TAilN input high level pulse width | 180 | | ns | | t <sub>w(TAL)</sub> | TAilN input low level pulse width | 180 | | ns | # Table 28.23 Timer A Input (external trigger input in one-shot timer mode) | Symbol | Characteristic | Va | Value | | |---------------------|------------------------------------|------|-------|------| | Symbol | Characteristic | Min. | Max. | Unit | | t <sub>C(TA)</sub> | TAilN input clock cycle time | 200 | | ns | | t <sub>w(TAH)</sub> | TAilN input high level pulse width | 80 | | ns | | t <sub>w(TAL)</sub> | TAilN input low level pulse width | 80 | | ns | ## Table 28.24 Timer A Input (external trigger input in pulse-width modulation mode) | Symbol Characterist | Characteristic | Value | | Unit | |---------------------|------------------------------------|-------|------|-------| | | Griaracteristic | Min. | Max. | Offic | | t <sub>w(TAH)</sub> | TAilN input high level pulse width | 80 | | ns | | t <sub>w(TAL)</sub> | TAilN input low level pulse width | 80 | | ns | ## Table 28.25 Timer A Input (increment/decrement switching input in event counter mode) | Symbol | Characteristic | Value | | Unit | |-------------------------|-------------------------------------|-------|------|-------| | | Characteristic | Min. | Max. | Offic | | t <sub>C(UP)</sub> | TAiOUT input clock cycle time | 2000 | | ns | | t <sub>W(UPH)</sub> | TAiOUT input high level pulse width | 1000 | | ns | | t <sub>w(UPL)</sub> | TAiOUT input low level pulse width | 1000 | | ns | | t <sub>su(UP-TIN)</sub> | TAiOUT input setup time | 400 | | ns | | t <sub>h(TIN-UP)</sub> | TAiOUT input hold time | 400 | | ns | Timing Requirements ( $V_{CC}$ = 4.2 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.26 Timer B Input (counting input in event counter mode) | Symbol | Symbol Characteristic | | Value | | |---------------------|----------------------------------------------------------|-----|-------|------| | Symbol | | | Max. | Unit | | t <sub>c(TB)</sub> | TBiIN input clock cycle time (one edge counting) | 200 | | ns | | t <sub>W(TBH)</sub> | TBilN input high level pulse width (one edge counting) | 80 | | ns | | t <sub>W(TBL)</sub> | TBilN input low level pulse width (one edge counting) | 80 | | ns | | t <sub>C(TB)</sub> | TBilN input clock cycle time (both edges counting) | 200 | | ns | | t <sub>w(TBH)</sub> | TBilN input high level pulse width (both edges counting) | 80 | | ns | | t <sub>W(TBL)</sub> | TBiIN input low level pulse width (both edges counting) | 80 | | ns | # Table 28.27 Timer B Input (pulse period measure mode) | Symbol | Characteristic | Value | | Unit | |---------------------|------------------------------------|-------|------|------| | | Griaracteristic | Min. | Max. | Oill | | $t_{c(TB)}$ | TBiIN input clock cycle time | 400 | | ns | | t <sub>w(TBH)</sub> | TBilN input high level pulse width | 180 | | ns | | t <sub>W(TBL)</sub> | TBilN input low level pulse width | 180 | | ns | # Table 28.28 Timer B Input (pulse-width measure mode) | Symbol Characteristic | Characteristic | Value | | Linit | |-----------------------|------------------------------------|-------|------|-------| | | Griaracteristic | Min. | Max. | Unit | | t <sub>c(TB)</sub> | TBiIN input clock cycle time | 400 | | ns | | t <sub>W(TBH)</sub> | TBilN input high level pulse width | 180 | | ns | | t <sub>w(TBL)</sub> | TBilN input low level pulse width | 180 | | ns | # Timing Requirements ( $V_{CC}$ = 4.2 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.29 Serial Interface | Currele el | Characteristic | Va | Linit | | |----------------------|-----------------------------------|------|-------|------| | Symbol | Characteristic | Min. | Max. | Unit | | t <sub>C(CK)</sub> | CLKi input clock cycle time | 200 | | ns | | t <sub>w(CKH)</sub> | CLKi input high level pulse width | 80 | | ns | | t <sub>W(CKL)</sub> | CLKi input low level pulse width | 80 | | ns | | t <sub>su(D-C)</sub> | RXDi input setup time | 80 | | ns | | t <sub>h(C-D)</sub> | RXDi input hold time | 90 | | ns | # Table 28.30 A/D Trigger Input | Symbol Characteristic | Characteristic | Value | | Unit | |-----------------------|----------------------------------------------------------------------------------|-----------------------|-------|------| | | Min. | Max. | Offic | | | t <sub>W(ADH)</sub> | ADTRG input high level pulse width Hardware trigger input high level pulse width | $\frac{3}{\phi_{AD}}$ | | ns | | t <sub>W(ADL)</sub> | ADTRG input low level pulse width Hardware trigger input high level pulse width | 125 | | ns | Table 28.31 External Interrupt INTi Input | Symbol Characteristic | | Value | | Unit | | |-----------------------|---------------------------------------|-----------------|---------------------------|------|------| | Symbol | OI CHAI ACTERISTIC | | Min. | Max. | Oill | | t <sub>W(INH)</sub> | INTi input high level pulse width (1) | Edge sensitive | 250 | | ns | | | | Level sensitive | t <sub>C(CPU)</sub> + 200 | | ns | | $t_{W(INL)}$ | INTi input low level pulse width (1) | Edge sensitive | 250 | | ns | | | | Level sensitive | t <sub>C(CPU)</sub> + 200 | | ns | #### Note: 1. The values are applied in case the filtering function is disabled. Timing Requirements ( $V_{CC}$ = 4.2 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.32 Serial Bus Interface | Cy made al | Ob and atomistic | Val | 1.1:4 | | | |---------------------------|------------------------------------|---------------------------|--------------------------|------|--| | Symbol | Characteristic | Min. | Max. | Unit | | | f <sub>(SSCK)</sub> | SSCKi frequency | | 4 | MHz | | | t <sub>c(SSCK)</sub> | SSCKi clock cycle time | 250 | | ns | | | t <sub>w(SSCKH)</sub> | SSCKi input high level pulse width | $0.35 \times t_{c(SSCK)}$ | $0.6 \times t_{c(SSCK)}$ | ns | | | t <sub>w(SSCKL)</sub> | SSCKi input low level pulse width | $0.35 \times t_{c(SSCK)}$ | $0.6 \times t_{c(SSCK)}$ | ns | | | t <sub>r(SSCK)</sub> | SSCKi input rising time | | 1 | μs | | | t <sub>f(SSCK)</sub> | SSCKi input falling time | | 1 | μs | | | t <sub>su(SCS-SSCK)</sub> | SCSi input setup time | t <sub>c(BCLK)</sub> + 50 | | ns | | | t <sub>h(SSCK-SCS)</sub> | SCSi input hold time | t <sub>c(BCLK)</sub> + 50 | | ns | | | t <sub>su(SSI-SSCK)</sub> | SSI input setup time | 80 | | ns | | | t <sub>h(SSCK-SSI)</sub> | SSI input hold time | 10 | | ns | | | t <sub>su(SSO-SSCK)</sub> | SSO input setup time | 80 | | ns | | | t <sub>h(SSCK-SSO)</sub> | SSO input hold time | 20 | | ns | | # Switching Characteristics ( $V_{CC}$ = 4.2 to 5.5 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.33 Serial Interface | Symbol | Characteristic | Measurement<br>Condition | Value | | Unit | |---------------------|------------------------|--------------------------|-------|------|------| | | | | Min. | Max. | Uill | | $t_{d(C-Q)}$ | TXDi output delay time | Refer to | | 80 | ns | | t <sub>h(C-Q)</sub> | TXDi output hold time | Figure 28.6 | 0 | | ns | ## Table 28.34 Serial Bus Interface | Cymbol | Characteristic | Measurement | Value | | | | |---------------------------|----------------------------------------------------------|-------------|---------------------------------|----------------------------------|------|--| | Symbol | Characteristic | Condition | Min. | Max. | Unit | | | t <sub>w(SSCKH)</sub> | SSCKi output high level pulse width | | $0.35 \times t_{c(SSCK)}$ | 0.6 × t <sub>c(SSCK)</sub> | ns | | | t <sub>w(SSCKL)</sub> | SSCKi output low level pulse width | | 0.35 × t <sub>c(SSCK)</sub> | 0.6 × t <sub>c(SSCK)</sub> | ns | | | t <sub>r(SSCK)</sub> | SSCKi output rising time | | | 20 | ns | | | t <sub>f(SSCK)</sub> | SSCKi output falling time | | | 20 | ns | | | t <sub>d(SCS-SSCK)</sub> | SSCKi output delay time for SCSi | | | $0.5 \times t_{c(SSCK)} + 20$ | ns | | | t <sub>d(SSCK-SCS)</sub> | SCSi output delay time for SSCKi | | 0.5 × t <sub>c(SSCK)</sub> - 20 | | ns | | | t <sub>en(SCS-SSO)</sub> | SSOi output enable time | Refer to | | $1.5 \times t_{c(BCLK)} + 100$ | ns | | | t <sub>dis(SCS-SSO)</sub> | SSOi output disable time | Figure 28.6 | | 1.5 × t <sub>c(BCLK)</sub> + 100 | ns | | | t <sub>en(SCS-SSI)</sub> | SSIi output enable time | | | $1.5 \times t_{c(BCLK)} + 100$ | ns | | | t <sub>dis(SCS-SSI)</sub> | SSIi output disable time | | | 1.5 × t <sub>c(BCLK)</sub> + 100 | ns | | | t <sub>d(SSCK-SSO)</sub> | SSOi output delay time for SSCKi | | | 30 | ns | | | t <sub>d(SSCK-SSI)</sub> | SSIi output delay time for SSCKi | | | 85 | ns | | | t <sub>rec(SCS)</sub> | SCSi output high level period in continuous transmission | | | 0.625 × t <sub>c(SSCK)</sub> | ns | | $V_{CC}$ = 3.3 V Table 28.35 Electrical Characteristics (1/3) ( $V_{CC}$ = 3.0 to 3.6 V, $V_{SS}$ = 0 V, $T_a$ = $T_{opr}$ , and $f_{(CPU)}$ = 48 MHz, unless otherwise noted) | Symbol | Characteristic | | Measurement | Value | | | Unit | |-----------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------|------|-----------------|-------| | Symbol | | Characteristic | Condition | Min. | Тур. | Max. | Offic | | V <sub>OH</sub> | _ | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | | V <sub>CC</sub> - 0.6 | | V <sub>CC</sub> | ٧ | | V <sub>OL</sub> | Low<br>level<br>output<br>voltage | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_3 to P9_7 | | | | 0.5 | V | $V_{CC}$ = 3.3 V Table 28.36 Electrical Characteristics (2/3) ( $V_{CC}$ = 3.0 to 3.6 V, $V_{SS}$ = 0 V, $T_a$ = $T_{opr}$ , and $f_{(CPU)}$ = 48 MHz, unless otherwise noted) | Symbol | Characteristic | | Measurement | Value | | | Unit | |-----------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-------|------|------|------| | | | | Condition | Min. | Тур. | Max. | Unit | | V <sub>T+</sub> - V <sub>T-</sub> | Hysteresis | NMI, INTO to INT5, TAOIN to TA4IN, TA0OUT to TA4OUT, TB0IN to TB5IN, CTS0 to CTS4, CLK0 to CLK4, RXD0 to RXD4, SCL0 to SCL2, SDA0 to SDA2, SS0 to SS2, SRXD0 to SRXD2, ADTRG, IIO0_0 to IIO0_7, UD0A, UD0B, SCS0, SSCK0, SSI0, SSO0, LIN0IN, CAN0IN, CAN1IN, CAN0WU, CAN1WU | | 0.2 | | 1.0 | V | | | | RESET | | 0.2 | | 1.8 | V | | l <sub>IH</sub> | High level input current | XIN, RESET, CNVSS, NSD,<br>P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7,<br>P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7,<br>P6_5, P6_7, P7_0, P7_4 to P7_6,<br>P8_2 to P8_7, P9_1, P9_3 to P9_7 | V <sub>I</sub> = 3.3 V | | | 1.0 | μA | | I <sub>IL</sub> | Low level input current | XIN, RESET, CNVSS, NSD,<br>P0_0 to P0_7, P1_0 to P1_7, P2_0 to P2_7,<br>P3_0 to P3_7, P4_0 to P4_7, P5_0 to P5_7,<br>P6_5, P6_7, P7_0, P7_4 to P7_6,<br>P8_2 to P8_7, P9_1, P9_3 to P9_7 | | | | -1.0 | μΑ | | R <sub>PULLUP</sub> | Pull-up<br>resistor | 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_5, P6_7, P7_0, P7_4 to P7_6, P8_2 to P8_4, P8_6, P8_7, P9_1, P9_3 to P9_7 | V <sub>I</sub> = 0 V | 50 | 100 | 500 | kΩ | | R <sub>fXIN</sub> | Feedback resistor | XIN | | | 3 | | МΩ | | R <sub>fXCIN</sub> | Feedback resistor | XCIN | | | 25 | | ΜΩ | $V_{\rm CC}$ = 3.3 V Table 28.37 Electrical Characteristics (3/3) $(V_{CC} = 3.0 \text{ to } 3.6 \text{ V}, V_{SS} = 0 \text{ V}, \text{ and } T_a = T_{opr}, \text{ unless otherwise noted})$ | Symbol | Characte ristic | Measurement Condition | | Value | | | Unit | |--------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|------|------| | | | Measurement Condition | | | Тур. | Max. | UIII | | | | In single-chip mode,<br>output pins are left open<br>and others are<br>connected to V <sub>SS</sub> | $f_{(CPU)}$ = 48 MHz, $f_{(BCLK)}$ = 24 MHz,<br>$f_{(XIN)}$ = 8 MHz,<br>Active: XIN, PLL,<br>Stopped: XCIN, OCO | | 31 | 48 | mA | | | | XIN-XOUT<br>Drive strength: low | f <sub>(CPU)</sub> = f <sub>SO(PLL)</sub> /24 MHz,<br>Active: PLL (self-oscillation),<br>Stopped: XIN, XCIN, OCO | | 7 | | mA | | | XCIN-XCOUT Drive strength: low | $\begin{split} &f_{(CPU)} = f_{(BCLK)} = f_{(XIN)}/256 \text{ MHz}, \\ &f_{(XIN)} = 8 \text{ MHz}, \\ &\text{Active: XIN,} \\ &\text{Stopped: PLL, XCIN, OCO} \end{split}$ | | 670 | | μА | | | | | f <sub>(CPU)</sub> = f <sub>(BCLK)</sub> = 32.768 kHz,<br>Active: XCIN,<br>Stopped: XIN, PLL, OCO,<br>Main regulator: shutdown | | 180 | | μΑ | | | | | f <sub>(CPU)</sub> = f <sub>(BCLK)</sub> = f <sub>(OCO)</sub> /4 kHz,<br>Active: OCO,<br>Stopped: XIN, PLL, XCIN,<br>Main regulator: shutdown | | 190 | | μΑ | | | | | | $\begin{split} f_{(CPU)} &= f_{(BCLK)} = f_{(XIN)}/256 \text{ MHz}, \\ f_{(XIN)} &= 8 \text{ MHz}, \\ \text{Active: XIN,} \\ \text{Stopped: PLL, XCIN, OCO,} \\ T_{a} &= 25^{\circ}\text{C, Wait mode} \end{split}$ | | 500 | 900 | μА | | | | | $\begin{split} &f_{(CPU)} = f_{(BCLK)} = 32.768 \text{ kHz}, \\ &\text{Active: XCIN,} \\ &\text{Stopped: XIN, PLL, OCO,} \\ &\text{Main regulator: shutdown,} \\ &T_a = 25^{\circ}\text{C, Wait mode} \end{split}$ | | 8 | 140 | μΑ | | | | | $f_{(CPU)} = f_{(BCLK)} = f_{(OCO)}/4 \text{ kHz},$<br>Active: OCO,<br>Stopped: XIN, PLL, XCIN,<br>Main regulator: shutdown,<br>$T_a = 25^{\circ}\text{C}$ , Wait mode | | 10 | 150 | μΑ | | | | | Stopped: all clocks,<br>Main regulator: shutdown,<br>T <sub>a</sub> = 25°C | | 5 | 70 | μΑ | | | | | Stopped: all clocks,<br>Main regulator: shutdown,<br>T <sub>a</sub> = 85°C | | | 400 | μΑ | | | | | Stopped: all clocks,<br>Main regulator: shutdown,<br>T <sub>a</sub> = 105°C | | | 1200 | μΑ | | | | | Stopped: all clocks,<br>Main regulator: shutdown,<br>T <sub>a</sub> = 125°C | | | 2000 | μΑ | $V_{CC}$ = 3.3 V Table 28.38 A/D Conversion Characteristics ( $V_{CC}$ = $AV_{CC}$ = $V_{REF}$ = 3.0 to 3.6 V, $V_{SS}$ = $AV_{SS}$ = 0 V, $T_a$ = $T_{opr}$ , and $f_{(BCLK)}$ = 24 MHz, unless otherwise noted) | Cymahal | Ch ava ata viatia | Measurement Condition | | | 1.1:4 | | | |----------------------|----------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------|------|-------|-----------|------| | Symbol | Characteristic | | | Min. | Тур. | Max. | Unit | | _ | Resolution | V <sub>REF</sub> = V <sub>CC</sub> | | | | 10 | Bits | | _ | Absolute error | V <sub>REF</sub> = V <sub>CC</sub> = 3.3 V | AN_0 to AN_4,<br>AN0_0 to AN0_7,<br>AN2_0 to AN2_7,<br>ANEX0, ANEX1 | | | ±5 | LSB | | | | | External op-amp connection mode | | | ±7 | LSB | | INL | Integral non-linearity error | $V_{REF} = V_{CC} = 3.3 V$ | AN_0 to AN_4,<br>AN0_0 to AN0_7,<br>AN2_0 to AN2_7,<br>ANEX0, ANEX1 | | | ±5 | LSB | | | | | External op-amp connection mode | | | ±7 | LSB | | DNL | Differential non-<br>linearity error | $V_{REF} = V_{CC} = 3.3 \text{ V}$ | | | | ±1 | LSB | | _ | Offset error | | | | | ±3 | LSB | | _ | Gain error | | | | | ±3 | LSB | | R <sub>LADDER</sub> | Resistor ladder V <sub>REF</sub> = V <sub>CC</sub> | | | 4 | | 20 | kΩ | | t <sub>CONV</sub> | Conversion time (10 bits) | φ <sub>AD</sub> = 10 MHz,<br>with sample and hold function | | 3.3 | | | μs | | t <sub>CONV</sub> | Conversion time (8 bits) | $\phi_{AD}$ = 10 MHz,<br>with sample and hold function | | 2.8 | | | μs | | t <sub>SAMP</sub> | Sampling time | φ <sub>AD</sub> = 10 MHz | | 0.3 | | | μs | | V <sub>IA</sub> | Analog input voltage | | | 0 | | $V_{REF}$ | V | | φ <sub>AD</sub> | Operating clock | Without sample and hold function With sample and hold function | | 0.25 | | 10 | MHz | | | frequency | | | 1 | | 10 | MHz | | R <sub>PU(AST)</sub> | Pull-up resistor for open-circuit detection | | | 5 | 10 | 15 | kΩ | | R <sub>PD(AST)</sub> | Pull-down resistor for open-circuit detection | | | 5 | 10 | 15 | kΩ | $$V_{CC}$$ = 3.3 $V$ Table 28.39 External Clock Input | Symbol | Characteristic | Value<br>Min. Max. | lue | Unit | |---------------------------------|---------------------------------------------|--------------------|-------|------| | | Characteristic | | Offic | | | $t_{C(X)}$ | External clock input period | 125 | 250 | ns | | t <sub>w(XH)</sub> | External clock input high level pulse width | 50 | | ns | | $t_{w(XL)}$ | External clock input low level pulse width | 50 | | ns | | $t_{r(X)}$ | External clock input rise time | | 5 | ns | | $t_{f(X)}$ | External clock input fall time | | 5 | ns | | t <sub>w</sub> / t <sub>C</sub> | External clock input duty | 40 | 60 | % | $$V_{CC}$$ = 3.3 $V$ Table 28.40 Timer A Input (counting input in event counter mode) | Symbol | Characteristic | Value<br>Min. Max. | Unit | | |---------------------|------------------------------------|--------------------|-------|----| | | Cildiacteristic | | Offic | | | t <sub>c(TA)</sub> | TAilN input clock cycle time | 200 | | ns | | t <sub>w(TAH)</sub> | TAilN input high level pulse width | 80 | | ns | | t <sub>w(TAL)</sub> | TAilN input low level pulse width | 80 | | ns | #### Table 28.41 Timer A Input (gating input in timer mode) | Symbol | Characteristic | Value<br>Min. Max. | Unit | | |---------------------|------------------------------------|--------------------|------|----| | | Gharacteristic | | | | | t <sub>c(TA)</sub> | TAilN input clock cycle time | 400 | | ns | | t <sub>w(TAH)</sub> | TAilN input high level pulse width | 180 | | ns | | t <sub>w(TAL)</sub> | TAilN input low level pulse width | 180 | | ns | #### Table 28.42 Timer A Input (external trigger input in one-shot timer mode) | Symbol | Characteristic | Value<br>Min. Max. | Unit | | |---------------------|------------------------------------|--------------------|------|----| | | Characteristic | | | | | t <sub>c(TA)</sub> | TAilN input clock cycle time | 200 | | ns | | t <sub>w(TAH)</sub> | TAilN input high level pulse width | 80 | | ns | | t <sub>w(TAL)</sub> | TAilN input low level pulse width | 80 | | ns | #### Table 28.43 Timer A Input (external trigger input in pulse-width modulation mode) | Symbol | Characteristic | Value<br>Min. Max. | Unit | | |---------------------|------------------------------------|--------------------|-------|----| | | Griaracteristic | | Offic | | | t <sub>w(TAH)</sub> | TAilN input high level pulse width | 80 | | ns | | t <sub>W(TAL)</sub> | TAilN input low level pulse width | 80 | | ns | #### Table 28.44 Timer A Input (increment/decrement switching input in event counter mode) | Symbol | Characteristic | Value<br>Min. Max. | Unit | | |-------------------------|-------------------------------------|--------------------|------|----| | | Characteristic | | Onit | | | t <sub>c(UP)</sub> | TAiOUT input clock cycle time | 2000 | | ns | | t <sub>w(UPH)</sub> | TAiOUT input high level pulse width | 1000 | | ns | | t <sub>w(UPL)</sub> | TAiOUT input low level pulse width | 1000 | | ns | | t <sub>su(UP-TIN)</sub> | TAiOUT input setup time | 400 | | ns | | t <sub>h(TIN-UP)</sub> | TAiOUT input hold time | 400 | | ns | $$V_{CC}$$ = 3.3 $V$ Table 28.45 Timer B Input (counting input in event counter mode) | Symbol | Characteristic | Value | | Unit | |---------------------|----------------------------------------------------------|-------|------|-------| | | Characteristic | Min. | Max. | Offic | | t <sub>c(TB)</sub> | TBiIN input clock cycle time (one edge counting) | 200 | | ns | | t <sub>w(TBH)</sub> | TBiIN input high level pulse width (one edge counting) | 80 | | ns | | t <sub>w(TBL)</sub> | TBiIN input low level pulse width (one edge counting) | 80 | | ns | | t <sub>c(TB)</sub> | TBilN input clock cycle time (both edges counting) | 200 | | ns | | t <sub>w(TBH)</sub> | TBilN input high level pulse width (both edges counting) | 80 | | ns | | t <sub>w(TBL)</sub> | TBilN input low level pulse width (both edges counting) | 80 | | ns | ## Table 28.46 Timer B Input (pulse period measure mode) | Symbol | Characteristic | Value<br>Min. Max. | Unit | | |---------------------|------------------------------------|--------------------|-------|----| | | Griaracteristic | | Offic | | | $t_{c(TB)}$ | TBiIN input clock cycle time | 400 | | ns | | t <sub>w(TBH)</sub> | TBilN input high level pulse width | 180 | | ns | | t <sub>w(TBL)</sub> | TBiIN input low level pulse width | 180 | | ns | ## Table 28.47 Timer B Input (pulse-width measure mode) | Symbol | Characteristic | Value<br>Min. Max. | Unit | | |---------------------|------------------------------------|--------------------|------|-------| | | Characteristic | | Max. | Offic | | t <sub>c(TB)</sub> | TBiIN input clock cycle time | 400 | | ns | | t <sub>w(TBH)</sub> | TBilN input high level pulse width | 180 | | ns | | t <sub>w(TBL)</sub> | TBiIN input low level pulse width | 180 | | ns | $$V_{CC}$$ = 3.3 $V$ Table 28.48 Serial Interface | Symbol | Characteristic | Value<br>Min. Max. | l lmi4 | | |----------------------|-----------------------------------|--------------------|--------|----| | | Characteristic | | Unit | | | t <sub>c(CK)</sub> | CLKi input clock cycle time | 200 | | ns | | t <sub>w(CKH)</sub> | CLKi input high level pulse width | 80 | | ns | | t <sub>w(CKL)</sub> | CLKi input low level pulse width | 80 | | ns | | t <sub>su(D-C)</sub> | RXDi input setup time | 80 | | ns | | t <sub>h(C-D)</sub> | RXDi input hold time | 90 | | ns | ## Table 28.49 A/D Trigger Input | Symbol | Characteristic | Value | | Unit | |---------------------|------------------------------------------------------------------------------------|--------------------------------|-------|------| | | Characteristic | Min. Max. | Offic | | | t <sub>w(ADH)</sub> | ADTRG input high level pulse width Hardware trigger input high level pulse width | $\frac{3}{\phi_{\mathrm{AD}}}$ | | ns | | t <sub>w(ADL)</sub> | ADTRG input low level pulse width<br>Hardware trigger input high level pulse width | 125 | | ns | ## Table 28.50 External Interrupt INTi Input | Symbol | Characteristic | | Value | | Unit | | |---------------------|---------------------------------------|-----------------|---------------------------|------|-------|--| | Symbol | Symbol | | Min. | Max. | Offic | | | $t_{w(INH)}$ | INTi input high level pulse width (1) | Edge sensitive | 250 | | ns | | | | | Level sensitive | t <sub>C(CPU)</sub> + 200 | | ns | | | t <sub>W(INL)</sub> | INTi input low level pulse width (1) | Edge sensitive | 250 | | ns | | | | | Level sensitive | t <sub>C(CPU)</sub> + 200 | | ns | | #### Note: 1. The values are applied in case filtering function is disabled. $V_{CC}$ = 3.3 V Timing Requirements ( $V_{CC}$ = 3.0 to 3.6 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.51 Serial Bus Interface | Oaab ad | Ob and at a sighting | Va | Value | | | |---------------------------|------------------------------------|---------------------------|--------------------------|------|--| | Symbol | Characteristic | Min. | Max. | Unit | | | f <sub>(SSCK)</sub> | SSCKi frequency | | 4 | MHz | | | t <sub>c(SSCK)</sub> | SSCKi clock cycle time | 250 | | ns | | | t <sub>w(SSCKH)</sub> | SSCKi input high level pulse width | $0.35 \times t_{c(SSCK)}$ | $0.6 \times t_{c(SSCK)}$ | ns | | | t <sub>w(SSCKL)</sub> | SSCKi input low level pulse width | $0.35 \times t_{c(SSCK)}$ | $0.6 \times t_{c(SSCK)}$ | ns | | | t <sub>r(SSCK)</sub> | SSCKi input rising time | | 1 | μs | | | t <sub>f(SSCK)</sub> | SSCKi input falling time | | 1 | μs | | | t <sub>su(SCS-SSCK)</sub> | SCSi input setup time | t <sub>c(BCLK)</sub> + 50 | | ns | | | t <sub>h(SSCK-SCS)</sub> | SCSi input hold time | t <sub>c(BCLK)</sub> + 50 | | ns | | | t <sub>su(SSI-SSCK)</sub> | SSI input setup time | 100 | | ns | | | t <sub>h(SSCK-SSI)</sub> | SSI input hold time | 10 | | ns | | | t <sub>su(SSO-SSCK)</sub> | SSO input setup time | 100 | | ns | | | t <sub>h(SSCK-SSO)</sub> | SSO input hold time | 20 | | ns | | $V_{CC}$ = 3.3 V ## Switching Characteristics ( $V_{CC}$ = 3.0 to 3.6 V, $V_{SS}$ = 0 V, and $T_a$ = $T_{opr}$ , unless otherwise noted) Table 28.52 Serial Interface | Symbol | Characteristic | Measurement | Value | | Unit | |---------------------|------------------------|-------------|-------|------|-------| | Symbol | Characteristic | Condition | Min. | Max. | Offic | | t <sub>d(C-Q)</sub> | TXDi output delay time | Refer to | | 80 | ns | | t <sub>h(C-Q)</sub> | TXDi output hold time | Figure 28.6 | 0 | | ns | #### Table 28.53 Serial Bus Interface | Symbol | Characteristic | Measurement | Value | | | |---------------------------|----------------------------------------------------------|-------------|-------------------------------|--------------------------------|------| | Symbol | Characteristic | Condition | Min. | Max. | Unit | | t <sub>w(SSCKH)</sub> | SSCKi output high level pulse width | | $0.35 \times t_{c(SSCK)}$ | 0.6 × t <sub>c(SSCK)</sub> | ns | | t <sub>w(SSCKL)</sub> | SSCKi output low level pulse width | | $0.35 \times t_{c(SSCK)}$ | 0.6 × t <sub>c(SSCK)</sub> | ns | | t <sub>r(SSCK)</sub> | SSCKi output rising time | | | 35 | ns | | t <sub>f(SSCK)</sub> | SSCKi output falling time | | | 35 | ns | | t <sub>d(SCS-SSCK)</sub> | SSCKi output delay time for SCSi | | | $0.5 \times t_{c(SSCK)} + 40$ | ns | | t <sub>d(SSCK-SCS)</sub> | SCSi output delay time for SSCKi | Refer to | $0.5 \times t_{c(SSCK)} - 40$ | | ns | | t <sub>en(SCS-SSO)</sub> | SSOi output enable time | Figure 28.6 | | $1.5 \times t_{c(BCLK)} + 100$ | ns | | t <sub>dis(SCS-SSO)</sub> | SSOi output disable time | | | $1.5 \times t_{c(BCLK)} + 100$ | ns | | t <sub>en(SCS-SSI)</sub> | SSIi output enable time | | | $1.5 \times t_{c(BCLK)} + 100$ | ns | | t <sub>dis(SCS-SSI)</sub> | SSIi output disable time | | | $1.5 \times t_{c(BCLK)} + 100$ | ns | | $t_{d(SSCK-SSO)}$ | SSOi output delay time for SSCKi | | | 50 | ns | | t <sub>d(SSCK-SSI)</sub> | SSIi output delay time for SSCKi | | | 120 | ns | | t <sub>rec(SCS)</sub> | SCSi output high level period in continuous transmission | | | 0.625 × t <sub>c(SSCK)</sub> | ns | Figure 28.6 Switching Characteristic Measurement Circuit Figure 28.7 External Clock Input Timing Figure 28.8 Timing of Peripherals Figure 28.9 Timing of Serial Bus Interface ## 29. Usage Notes ### 29.1 Notes on Board Designing ## 29.1.1 Power Supply Pins The board should be designed so there is no potential difference between pins with the same name. Note the following points: - Connect all VSS pins to the same GND. Traces for the pins should be as wide as physically possible so the same voltage can be applied to every VSS pin. - Connect all VCC pins to the same power supply. Traces for the pins should be as wide as physically possible so the same voltage can be applied to every VCC pin. Insert a capacitor between each VCC pin and the VSS pin to prevent operation errors due to noise. The capacitor should be beneficially effective at high and low frequencies and should have a capacitance of approximately 0.1 $\mu$ F. The traces for the capacitor and the power supply pins should be as short and wide as physically possible. ## 29.1.2 Supply Voltage The device is operationally guaranteed under operating conditions specified in electrical characteristics. Drive the RESET pin low before the supply voltage becomes lower than the recommended value. ## 29.2 Notes on Register Setting ## 29.2.1 Registers with Write-only Bits Read-modify-write instructions cannot be used when setting a register containing write-only bits. Read-modify-write instructions read a value of an address, modify the value, and write the modified value to the same address. Table 29.1 lists read-modify-write instructions, and Table 29.2 lists registers containing write-only bits. To set a new value by modifying the previous one, write the previous value into RAM as well as to the register, change the contents of the RAM and then transfer the new value to the register by the MOV instruction. Table 29.1 Read-modify-write Instructions | Function | Mnemonic | |--------------------------|------------------------------------------------------------------------------------------------| | Transfer | MOVDir | | Bit processing | BCLR, BM <i>Cnd</i> , BNOT, BSET, BTSTC, and BTSTS | | Shifting | ROLC, RORC, ROT, SHA, and SHL | | Arithmetic operation | ABS, ADC, ADCF, ADD, ADSF, DEC, DIV, DIVU, DIVX, EXTS, EXTZ, INC, MUL, MULU, NEG, SBB, and SUB | | Decimal operation | DADC, DADD, DSBB, and DSUB | | Floating-point operation | ADDF, DIVF, MULF, and SUBF | | Logical operation | AND, NOT, OR, and XOR | Table 29.2 Registers with Write-only Bits | Module | Register | Symbol | Address | |-------------------|-----------------------------------------------------|---------|-------------| | Watchdog timer | Watchdog timer start register | WDTS | 04404Eh | | Timer A | Timer A0 register (1) | TA0 | 0347h-0346h | | | Timer A1 register (1) | TA1 | 0349h-0348h | | | Timer A2 register (1) | TA2 | 034Bh-034Ah | | | Timer A3 register (1) | TA3 | 034Dh-034Ch | | | Timer A4 register (1) | TA4 | 034Fh-034Eh | | | Increment/decrement select register | UDF | 0344h | | Three-phase motor | Timer B2 interrupt generating frequency set counter | ICTB2 | 030Dh | | control timers | Timer A1-1 register | TA11 | 0303h-0302h | | | Timer A2-1 register | TA21 | 0305h-0304h | | | Timer A4-1 register | TA41 | 0307h-0306h | | | Timer A1 mirror register | TA1M | 0221h-0220h | | | Timer A2 mirror register | TA2M | 0225h-0224h | | | Timer A4 mirror register | TA4M | 0229h-0228h | | | Timer A1-1 mirror register | TA11M | 0223h-0222h | | | Timer A2-1 mirror register | TA21M | 0227h-0226h | | | Timer A4-1 mirror register | TA41M | 022Bh-022Ah | | | Dead time timer | DTT | 030Ch | | Serial interface | UART0 bit rate register | U0BRG | 0369h | | | UART1 bit rate register | U1BRG | 02E9h | | | UART2 bit rate register | U2BRG | 0339h | | | UART3 bit rate register | U3BRG | 01E1h | | | UART4 bit rate register | U4BRG | 01E9h | | | UART0 transmit buffer register | U0TB | 036Bh-036Ah | | | UART1 transmit buffer register | U1TB | 02EBh-02EAh | | | UART2 transmit buffer register | U2TB | 033Bh-033Ah | | | UART3 transmit buffer register | U3TB | 01E3h-01E2h | | | UART4 transmit buffer register | U4TB | 01EBh-01EAh | | CAN module | CAN0 receive FIFO pointer control register | C0RFPCR | 047F49h | | | CAN0 transmit FIFO pointer control register | C0TFPCR | 047F4Bh | | | CAN1 receive FIFO pointer control register | C1RFPCR | 047B49h | | | CAN1 transmit FIFO pointer control register | C1TFPCR | 047B4Bh | ## Note: 1. The register has write-only bits in one-shot timer mode and pulse-width modulation mode. #### 29.3 Notes on Clock Generator #### 29.3.1 Sub Clock #### 29.3.1.1 Oscillator Constant Matching The constant matching of the sub clock oscillator should be evaluated in both cases when the drive strength is high and low. Contact the oscillator manufacturer for details on the oscillation circuit constant matching. #### 29.3.2 Power Control Do not switch the base clock source until the oscillation of the clock to be used has stabilized. However, this does not apply to the on-chip oscillator since it starts running immediately after the CM31 bit in the CM3 register is set to 1. To switch the base clock source from the PLL clock to a low speed clock, use the MOV.L or OR.L instruction to set the BCS bit in the CCR register to 1. - Program example in assembly language OR.L #80h, 0004h - Program example in C language asm("OR.L #80h, 0004h"); #### 29.3.2.1 Stop Mode • To exit stop mode using a reset, apply a low signal to the RESET pin until the main clock oscillation stabilizes. ### 29.3.2.2 Suggestions for Power Saving The following are suggestions to reduce power consumption when programming or designing systems. - I/O pins: - If inputs are floating, both transistors may be conducting. Set unassigned pins to input mode and connect each of them to VSS via a resistor, or set them to output mode and leave them open. - A/D converter: - When not performing the A/D conversion, set the VCUT bit in the AD0CON1 register to 0 (VREF disconnected). To perform the A/D conversion, set the VCUT bit to 1 (VREF connected) and wait at least 1 µs before starting conversion. - · Peripheral clock stop: - When entering wait mode, power consumption can be reduced by setting the CM02 bit in the CM0 register to 1 to stop the peripheral clock source. However, this setting does not stop the fC32. #### 29.4 Notes on Interrupts #### 29.4.1 ISP Setting The interrupt stack pointer (ISP) is initialized to 00000000h after a reset. Set a value to the ISP before an interrupt is accepted, otherwise the program may go out of control. A multiple of 4 should be set to the ISP, which enables faster interrupt sequence due to less memory access. When using NMI, in particular, since this interrupt cannot be disabled, set the PM24 bit in the PM2 register to 1 (NMI enabled) after setting the ISP at the beginning of the program. #### 29.4.2 NMI - NMI cannot be disabled once the PM24 bit in the PM2 register is set to 1 (NMI enabled). This bit setting should be done only when using NMI. - When the PM24 bit in the PM2 register is 1 (NMI enabled), the P8\_5 bit in the P8 register is enabled just for monitoring the NMI pin state. It is not enabled as a general port. ## 29.4.3 External Interrupts - The input signal to the INTi pin requires the pulse width specified in the electrical characteristics (i = 0 to 5). If the pulse width is narrower than the specification, an external interrupt may not be accepted. - When the effective level or edge of the INTi pin (i = 0 to 5) is changed by the following bits: bits POL, LVS in the INTiIC register, the IFSR0i bit (i = 0 to 5) in the IFSR0 register, the corresponding IR bit may become 1 (interrupt requested). When setting the above mentioned bits, preset bits ILVL2 to ILVL0 in the INTiIC register to 000b (interrupt disabled). After setting the above mentioned bits, set the corresponding IR bit to 0 (no interrupt requested), then rewrite bits ILVL2 to ILVL0. #### 29.5 Notes on DMAC #### 29.5.1 DMAC-associated Register Settings • Set DMAC-associated registers while bits MDi1 and MDi0 in the DMDi register are 00b (DMA transfer disabled) (i = 0 to 3). Then, set bits MDi1 and MDi0 to 01b (single transfer) or 11b (repeat transfer) at the end of the setup procedure. This procedure also applies when rewriting bits UDAi, USAi, and BWi1 and BWi0 in the DMDi register. - When rewriting the DMAC-associated registers while DMA transfer is enabled, stop the peripherals that can be DMA triggers so that no DMA transfer request is generated, then set bits MDi1 and MDi0 in the DMDi register of the corresponding channel to 00b (DMA transfer disabled). - Once a DMA transfer request is accepted, DMA transfer cannot be disabled even if setting bits MDi1 and MDi0 in the DMDi register to 00b (DMA transfer disabled). Do not change the settings of any DMAC-associated registers other than bits MDi1 and MDi0 until the DMA transfer is completed. - After setting registers DMiSL and DMiSL2, wait at least six peripheral bus clocks to set bits MDi1 and MDi0 in the DMDi register to 01b (single transfer) or 11b (repeat transfer). ## 29.5.2 Reading DMAC-associated Registers Use the following read order to sequentially read registers DMiSL and DMiSL2: DM0SL, DM1SL, DM2SL, and DM3SL DM0SL2, DM1SL2, DM2SL2, and DM3SL2 ## 29.6 Notes on Timers #### 29.6.1 Timer A and Timer B All timers are stopped after a reset. To restart timers, configure parameters such as operating mode, count source, and counter value, then set the TAiS bit or TBjS bit in the TABSR or TBSR register to 1 (count starts) (i = 0 to 4; j = 0 to 5). The following registers and bits should be set while the TAiS bit or TBjS bit is 0 (count stops): - Registers TAiMR and TBiMR - UDF register - Bits TAZIE, TA0TGL, and TA0TGH in the ONSF register - TRGSR register #### 29.6.2 Timer A #### 29.6.2.1 Timer Mode • While the timer counter is running, the TAi register indicates a counter value at any given time. However, FFFFh is read while reloading is in progress. A set value is read if the TAi register is set while the timer counter is stopped. #### 29.6.2.2 Event Counter Mode • While the timer counter is running, the TAi register indicates a counter value at any given time. However, FFFFh is read if the timer counter underflows or 0000h if overflows while reloading is in progress. A set value is read if the TAi register is set while the timer counter is stopped. #### 29.6.2.3 One-shot Timer Mode - If the TAiS bit in the TABSR register is set to 0 (count stops) while the timer counter is running, the following operations are performed: - The timer counter stops and the setting value of the TAi register is reloaded. - A low signal is output at the TAiOUT pin. - The IR bit in the TAilC register becomes 1 (interrupts requested) after one CPU clock cycle. - The one-shot timer is operated by an internal count source. When the trigger is an input to the TAilN pin, the signal is output with a maximum one count source clock delay after a trigger input to the TAilN pin. - The IR bit becomes 1 by any of the settings below. To use the timer Ai interrupt, set the IR bit to 0 after one of the settings below is done: - Select one-shot timer mode after a reset. - Switch operating modes from timer mode to one-shot timer mode. - Switch operating modes from event counter mode to one-shot timer mode. - If a retrigger occurs while counting, the timer counter decrements by one, reloads the setting value of the TAi register, and then continues counting. To generate a retrigger while counting, wait one or more count source cycles after the last trigger is generated. - When an external trigger input is selected to start counting in timer A one-shot mode, do not provide an external retrigger for 300 ns before the timer counter reaches 0000h. Otherwise, it may stop counting. #### 29.6.2.4 Pulse-width Modulation Mode • The IR bit becomes 1 by any of the settings below. To use the timer Ai interrupt, set the IR bit to 0 after one of the settings below is done (i = 0 to 4): - Select pulse-width modulation mode after a reset. - Switch operating modes from timer mode to pulse-width modulation mode. - Switch operating modes from event counter mode to pulse-width modulation mode. - If the TAiS bit in the TABSR register is set to 0 (count stops) while PWM pulse is output, the following operations are performed: - The timer counter stops. - The output level at the TAiOUT pin changes from high to low. The IR bit becomes 1. - When a low signal is output at the TAiOUT pin, it does not change. The IR bit does not change, either. #### 29.6.3 Timer B #### 29.6.3.1 Timer Mode and Event Counter Mode • While the timer counter is running, the TBj register indicates a counter value at any given time (j = 0 to 5). However, FFFFh is read while reloading is in progress. When a value is set to the TBj register while the timer counter is stopped, if the TBj register is read before the count starts, the set value is read. #### 29.6.3.2 Pulse Period/Pulse-width Measure Mode - While the TBjS bit in the TABSR or TBSR register is 1 (start counter), after the MR3 bit becomes 1 (overflow) and at least one count source cycle has elapsed, a write operation to the TBjMR register sets the MR3 bit to 0 (no overflow). - Use the IR bit in the TBjIC register to detect overflow. The MR3 bit is used only to determine an interrupt request source within the interrupt handler. - The counter value is undefined when the timer counter starts. Therefore, the timer counter may overflow before a measured pulse is applied on the initial valid edge and cause a timer Bj interrupt request to be generated. - When the measured pulse is applied on the initial valid edge after the timer counter starts, an undefined value is transferred to the reload register. At this time, a timer Bj interrupt request is not generated. - The IR bit may become 1 (interrupt requested) by changing bits MR1 and MR0 in the TBjMR register after the timer counter starts. However, if the same value is rewritten to bits MR1 and MR0, the IR bit does not change. - Pulse width is continuously measured in pulse-width measure mode. Whether the measurement result is high-level width or not is determined by a program. - When an overflow occurs at the same time a pulse is applied on the valid edge, this pulse is not recognized since an interrupt request is generated only once. Do not let an overflow occur in pulse period measure mode. - In pulse-width measure mode, determine whether an interrupt source is a pulse applied on the valid edge or an overflow by reading the port level in the timer Bj interrupt handler. ## 29.7 Notes on Three-phase Motor Control Timers #### 29.7.1 Shutdown • When a low signal is applied to the $\overline{\text{NMI}}$ pin with the following bit settings, pins TA1OUT, TA2OUT, and TA4OUT become high-impedance: the PM24 bit in the PM2 register is 1 (NMI enabled), the SDE bit in the IOBC register is 1 (shutdown enabled), the INV02 bit in the INVC0 register is 1 (three-phase motor control timers used), and the INV03 bit is 1 (three-phase motor control timer output enabled). ## 29.7.2 Register Setting • Do not write to the TAi1 register before and after timer B2 underflows (i = 1, 2, 4). Before writing to the TAi1 register, read the TB2 register to verify that sufficient time remains until timer B2 underflows. Then, immediately write to the TAi1 register so no interrupt handling is performed during this write procedure. If the TB2 register indicates little time remains until the underflow, write to the TAi1 register after timer B2 underflows. ## 29.8 Notes on Serial Interface ## 29.8.1 Changing the UiBRG Register (i = 0 to 4) Set the UiBRG register after setting bits CLK1 and CLK0 in the UiC0 register. When these bits are changed, the UiBRG register must be set again. • When a clock is input immediately after the UiBRG register is set to 00h, the counter may become FFh. In this case, it requires extra 256 clocks to reload 00h to the register. Once 00h is reloaded, the counter performs the operation without dividing the count source according to the setting. ## 29.8.2 Pin Output When the NCH bit in the U2C0 register is set to 1, pins assigned for TXD2/SDA2 and SCL2 function as N-channel open drain output even if the UART output function is not selected in output function select register. When the NODC bit in the U2SMR3 register is set to 1, CLK2 pins function as N-channel open drain output even if the UART output function is not selected in output function select register. ## 29.8.3 Synchronous Serial Interface Mode #### 29.8.3.1 Selecting an External Clock - If an external clock is selected, the following conditions must be met while the external clock is held high when the CKPOL bit in the UiC0 register is 0 (transmit data output on the falling edge of the transmit/receive clock and receive data input on the rising edge), or while the external clock is held low when the CKPOL bit is 1 (transmit data output on the rising edge of the transmit/receive clock and receive data input on the falling edge) (i = 0 to 4): - The TE bit in the UiC1 register is 1 (transmission enabled). - The RE bit in the UiC1 register is 1 (reception enabled). This bit setting is not required when only transmitting. - The TI bit in the UiC1 register is 0 (data held in the UiTB register). #### 29.8.3.2 Receive Operation - In synchronous serial interface mode, the transmit/receive clock is controlled by the transmit control circuit. Set UARTi-associated registers for a transmit operation, even if the MCU is used only for receive operation (i = 0 to 4). Dummy data is output from the TXDi pin while receiving when the TXDi pin is set to output mode. - When data is received continuously, an overrun error occurs when the RI bit in the UiC1 register is 1 (data held in the UiRB register) and the seventh bit of the next data is received in the UARTi receive shift register. Then, the OER bit in the UiRB register becomes 1 (overrun error occurred). In this case, the UiRB register becomes undefined. If an overrun error occurs, the IR bit in the SiRIC register does not change to 1. ## 29.8.4 Special Mode 1 (I<sup>2</sup>C Mode) • To generate a start condition, stop condition, or restart condition, set the STSPSEL bit in the UiSMR4 register to 0 (i = 0 to 2). Then, wait a half or more clock cycles of the transmit/receive clock to change the condition generate bits (STAREQ, RSTAREQ, or STPREQ bit) from 0 to 1. #### 29.8.5 Reset Procedure on Communication Error Operations which result in communication errors such as rewriting function select registers during transmission/reception should not be performed. Follow the procedure below to reset the internal circuit once the communication error occurs in the following cases: when the operation above is performed by a receiver or transmitter or when a bit slip is caused by noise. #### A. Synchronous Serial Interface Mode - (1) Set the TE bit in the UiC1 register to 0 (transmission disabled) and the RE bit to 0 (reception disabled) (i = 0 to 4). - (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 (synchronous serial interface mode). - (4) Set the TE bit in the UiC1 register to 1 (transmission enabled) and the RE bit to 1 (reception enabled) if necessary. #### B. UART Mode - (1) Set the TE bit in the UiC1 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, 7-bit character length), 101b (UART mode, 8-bit character length), or 110b (UART mode, 9-bit character length). - (4) Set the TE bit in the UiC1 register to 1 (transmission enabled) and the RE bit to 1 (reception enabled) if necessary. #### 29.9 Notes on A/D Converter ## 29.9.1 Notes on Designing Boards • Three capacitors should be placed between the AVSS pin and pins such as AVCC, VREF, and analog inputs (AN\_0 to AN\_4, AN0\_0 to AN0\_7, and AN2\_0 to AN2\_7) to avoid erroneous operations caused by noise or latchup, and to reduce conversion errors. Figure 29.1 shows an example of pin configuration for A/D converter. Figure 29.1 Pin Configuration for the A/D Converter • When AVCC = VREF = VCC, A/D input voltage for pins AN\_0 to AN\_4, AN0\_0 to AN0\_7, AN2\_0 to AN2\_7, ANEX0, and ANEX1 should be VCC or lower. ## 29.9.2 Notes on Programming • The following registers should be written while A/D conversion is stopped. That is, before a trigger occurs: AD0CON0 (except the ADST bit), AD0CON1, AD0CON2, AD0CON3, and AD0CON5. - When the VCUT bit in the AD0CON1 register is changed from 0 (VREF connected) to 1 (VREF disconnected), wait for at least 1 µs before starting A/D conversion. When not performing A/D conversion, set the VCUT bit to 0 to reduce power consumption. - Set the port direction bit for the pin to be used as an analog input pin to 0 (input). Set the ASEL bit of the corresponding port function select register to 1 (port is used as A/D input). - When the TRG bit in the AD0CON0 register is 1 (external trigger or hardware trigger), set the corresponding port direction bit (PD9 7 bit) for the ADTRG pin to 0 (input). - The $\phi$ AD frequency should be 16 MHz or lower when VCC is 4.2 to 5.5 V, and 10 MHz or lower when VCC is 3.0 to 4.2 V. It should be 1 MHz or higher when the sample and hold function is enabled. If not, it should be 250 kHz or higher. - When A/D operating mode (bits MD1 and MD0 in the AD0CON0 register or the MD2 bit in the AD0CON1 register) has been changed, reselect analog input pins by setting bits CH2 to CH0 in the AD0CON0 register or bits SCAN1 and SCAN0 in the AD0CON1 register. - If the AD0i register is read when the A/D converted result is stored to the register, the stored value may have an error (i = 0 to 7). Read the AD0i register after A/D conversion is completed. In one-shot mode or single sweep mode, read the AD0i register after the IR bit in the AD0IC register becomes 1 (interrupt requested). In repeat mode, repeat sweep mode 0, or repeat sweep mode 1, an interrupt request can be generated each time A/D conversion is completed when the DUS bit in the AD0CON3 register is 1 (DMAC operating mode enabled). Similar to the other modes above, read the AD00 register after the IR bit in the AD0IC register becomes 1 (interrupt requested). - When an A/D conversion is halted by setting the ADST bit in the AD0CON0 register to 0, the converted result is undefined. In addition, the unconverted AD0i register may also become undefined. Consequently, the AD0i register should not be used just after A/D conversion is halted. - External triggers cannot be used in DMAC operating mode. When the DMAC is configured to transfer converted results, do not read the AD00 register by a program. - While in single sweep mode, if A/D conversion is halted by setting the ADST bit in the AD0CON0 register to 0 (A/D conversion is stopped), an interrupt request may be generated even though the sweep is not completed. To halt A/D conversion, disable interrupts before setting the ADST bit to 0. #### 29.10 Note on Serial Bus Interface # 29.10.1 Note on Synchronous Serial Communication Mode and 4-wire Serial Bus Mode ## 29.10.1.1 Accessing SBI Associated Registers To read the SBI associated registers (44F06h to 44F0Fh), insert at least three instructions after writing to the registers. • An example of inserting at least three instructions Program example MOV.B #00h, 44F0Bh; Set the SS0ER register to 00h. NOP NOP MOV.B 44F0Bh, R0L #### 29.11 Notes on Flash Memory Rewriting #### 29.11.1 Note on Power Supply • Keep the supply voltage constant within the range specified in the electrical characteristics while a rewrite operation on the flash memory is in progress. If the supply voltage goes beyond the guaranteed value, the device cannot be guaranteed. #### 29.11.2 Note on Hardware Reset • Do not perform a hardware reset while a rewrite operation on the flash memory is in progress. #### 29.11.3 Note on Flash Memory Protection • If an ID code written in an assigned address has an error, any read/write operation on the flash memory in standard serial I/O mode is disabled. #### 29.11.4 Notes on Programming - Do not set the FEW bit in the FMCR register to 1 (CPU rewrite mode) in low speed mode or low power mode. - When the EWM bit in the E2FM register is 1 (program or erase enabled), do not set the FEW bit in the FMCR register to 1. - The program, block erase, lock bit program, and protect bit program are interrupted by an NMI, a watchdog timer interrupt, an oscillator stop detection interrupt, or a low voltage detection interrupt. If any of the software commands above are interrupted, erase the corresponding block and then execute the same command again. If the block erase command is interrupted, the lock bit and protect bit values become undefined. Therefore, disable the lock bit, and then execute the block erase command again. ## 29.11.5 Notes on Interrupts - EW0 mode - To use interrupts assigned to the relocatable vector table, the vector table should be addressed in RAM space. - When an NMI, watchdog timer interrupt, oscillator stop detection interrupt, or low voltage detection interrupt occurs, the flash memory module automatically enters read array mode. Therefore, these interrupts are enabled even during a rewrite operation. However, the rewrite operation in progress is aborted by the interrupts and registers FMR0 and FRSR0 are reset. When the interrupt handler has ended, set the LBD bit in the FMR1 register to 1 (lock bit protection disabled) to re-execute the rewrite operation. - Instructions BRK, INTO, and UND, which refer to data on the flash memory, cannot be used in this mode. - EW1 mode - Interrupts assigned to the relocatable vector table should not be accepted during program or block erase operation. - The watchdog timer should not be used in count source protect mode. The watchdog timer interrupt should not be generated. - When an NMI, watchdog timer interrupt, oscillator stop detection interrupt, or low voltage detection interrupt occurs, the flash memory module automatically enters read array mode. Therefore, these interrupts are enabled even during a rewrite operation. However, the rewrite operation in progress is aborted by the interrupts and registers FMR0 and FRSR0 are reset. When the interrupt handler has ended, set the EWM bit in the FMR0 register to 1 (EW1 mode) and the LBD bit in the FMR1 register to 1 (lock bit protection disabled) to re-execute the rewrite operation. ## 29.11.6 Notes on Rewrite Control Program - EW0 mode - If the supply voltage drops during the rewrite operation of blocks having the rewrite control program, the rewrite control program may not be successfully rewritten, and the rewrite operation itself may not be performed. In this case, perform the rewrite operation by serial programmer or parallel programmer. - EW1 mode - Do not rewrite blocks having the rewrite control program. # 29.11.7 Notes on Number of Program/Erase Cycles and Software Command Execution Time • The time to execute software commands (program, block erase, lock bit program, and protect bit program) increases as the number of program/erase cycles increases. If the number of program/erase cycles exceeds the endurance value specified in the electrical characteristics, it may take an unpredictable amount of time to execute the software commands. The wait time for executing software commands should be set much longer than the execution time specified in the electrical characteristics. #### 29.11.8 Other Notes - The minimum values of program/erase cycles specified in the electrical characteristics are the maximum values that can guarantee the initial performance of the flash memory. The program/erase operation may still be performed even if the number of program/erase cycles exceeds the guaranteed values. - Chips repeatedly programmed and erased for debugging should not be used for commercial products. ## 29.12 Note on E<sup>2</sup>dataFlash When the FEW bit in the FMCR register is 1 (CPU rewrite mode), do not set the EWM bit in the E2FM register to 1 (program or erase enabled). ## **Appendix 1. Package Dimensions** | INDEX | C0RFPCR, C1RFPCR431 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | C0RIC, C1RIC128 | | Numariaa | C0STR, C1STR435 | | Numerics | C0TCR, C1TCR453 | | | C0TECR, C1TECR449 | | 4-wire Serial Bus Mode | C0TFCR, C1TFCR432 | | | C0TFPCR, C1TFPCR434 | | Α | C0TIC, C1TIC | | | C0TSR, C1TSR | | A0 13 | COWIC, C1WIC | | A1 13 | C1FIDCR0, C1FIDCR1417 | | A2 13 | C1MB0 to C1MB31421 | | A3 13 | C1MCTL0 to C1MCTL31 | | AD00 to AD07 | | | AD0CON0 | C1MKR0 to C1MKR7416 | | AD0CON1 | Carry Flag | | AD0CON2 | CCR83 | | AD0CON2 | CM084 | | | CM185 | | AD0CON5 | CM285 | | ADOIC | CM386 | | Address Register13 | CPSRF87 | | | CRCD295 | | В | CRCIN296 | | B Flag14 | D | | BCN0IC to BCN2IC | | | BRK Instruction Interrupt | D. Flor: 12 | | BRK2 Instruction Interrupt | D Flag | | Braz mondon mondpt | Data Register | | С | DCR0 to DCR3 | | C | DCT0 to DCT3 | | | DDA0 to DDA3 | | C Flag 13 | 111100 to 111103 15 155 | | | DDR0 to DDR3 | | C0AFSR, C1AFSR 442 | Debug Flag13 | | C0AFSR, C1AFSR | Debug Flag | | C0AFSR, C1AFSR 442 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 | | C0AFSR, C1AFSR | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 | | C0AFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 | | C0AFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 | | C0AFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 | | C0AFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 C0ECSR, C1ECSR 450 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 | | COAFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 C0ECSR, C1ECSR 450 C0EIC, C1EIC 128 | Debug Flag | | COAFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 C0ECSR, C1ECSR 450 C0EIC, C1EIC 128 C0EIER, C1EIER 443 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 DMA Mode Register 15 DMA Source Address Register 15 | | COAFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 C0ECSR, C1ECSR 450 C0EIC, C1EIC 128 C0EIER, C1EIER 443 C0EIFR, C1EIFR 445 | Debug Flag | | COAFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 C0ECSR, C1ECSR 450 C0EIC, C1EIC 128 C0EIER, C1EIER 443 C0EIFR, C1EIFR 445 C0FIDCR0, C0FIDCR1 417 C0FRIC, C1FRIC 128 | Debug Flag | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 C0ECSR, C1ECSR 450 C0EIC, C1EIC 128 C0EIER, C1EIER 443 C0EIFR, C1EIFR 445 C0FIDCR0, C0FIDCR1 417 C0FRIC, C1FRIC 128 C0FTIC, C1FTIC 128 | Debug Flag | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 C0ECSR, C1ECSR 450 C0EIC, C1EIC 128 C0EIER, C1EIER 443 C0EIFR, C1EIFR 445 C0FIDCR0, C0FIDCR1 417 C0FRIC, C1FRIC 128 C0FTIC, C1FTIC 128 C0MB0 to C0MB31 421 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Source Address Reload Register 15 DMA Terminal Count Register 15 DMA Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 COECSR, C1ECSR 450 COEIC, C1EIC 128 COEIER, C1EIER 443 COEIFR, C1EIFR 445 COFIDCRO, C0FIDCR1 417 C0FRIC, C1FRIC 128 COFTIC, C1FTIC 128 COMB0 to C0MB31 421 C0MCTL0 to C0MCTL31 425 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Source Address Reload Register 15 DMA Terminal Count Register 15 DMA Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 DSA0 to DSA3 15, 154 | | COAFSR, C1AFSR 442 C0BCR, C1BCR 414 C0CLKR, C1CLKR 413 C0CSSR, C1CSSR 441 C0CTLR, C1CTLR 409 C0ECSR, C1ECSR 450 C0EIC, C1EIC 128 C0EIER, C1EIER 443 C0EIFR, C1EIFR 445 C0FIDCRO, C0FIDCR1 417 C0FRIC, C1FRIC 128 C0FTIC, C1FTIC 128 C0MB0 to C0MB31 421 C0MCTL0 to C0MCTL31 425 C0MIER, C1MIER 424 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Source Address Reload Register 15 DMA Terminal Count Register 15 DMA Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 DSA0 to DSA3 15, 154 DSR0 to DSR3 15, 155 | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 COECSR, C1ECSR 450 COEIC, C1EIC 128 COEIER, C1EIER 443 COEIFR, C1EIFR 445 COFIDCRO, C0FIDCR1 417 C0FRIC, C1FRIC 128 C0FTIC, C1FTIC 128 C0MB0 to C0MB31 421 C0MCTL0 to C0MCTL31 425 C0MIER, C1MIER 424 C0MKIVLR, C1MKIVLR 419 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Source Address Reload Register 15 DMA Terminal Count Register 15 DMD Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 DSA0 to DSA3 15, 154 DSR0 to DSR3 15, 155 DTT 222 | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 COECSR, C1ECSR 450 COEIC, C1EIC 128 COEIER, C1EIER 443 COEIFR, C1EIFR 445 COFIDCRO, C0FIDCR1 417 COFRIC, C1FRIC 128 COFTIC, C1FTIC 128 COMB0 to C0MB31 421 C0MCTL0 to C0MCTL31 425 C0MIER, C1MIER 424 C0MKIVLR, C1MKIVLR 419 C0MKR0 to C0MKR7 416 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Source Address Reload Register 15 DMA Terminal Count Register 15 DMA Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 DSA0 to DSA3 15, 154 DSR0 to DSR3 15, 155 | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 COECSR, C1ECSR 450 COEIC, C1EIC 128 COEIER, C1EIER 443 COEIFR, C1EIFR 445 COFIDCRO, C0FIDCR1 417 C0FRIC, C1FRIC 128 COFTIC, C1FTIC 128 COMB0 to C0MB31 421 C0MCTL0 to C0MCTL31 425 C0MIER, C1MIER 424 C0MKR0 to C0MKR7 416 C0MSMR, C1MSMR 438 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Terminal Count Register 15 DMA Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 DSA0 to DSA3 15, 154 DSR0 to DSR3 15, 155 DTT 222 DVCR 78 | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 COECSR, C1ECSR 450 COEIC, C1EIC 128 COEIER, C1EIER 443 COEIFR, C1EIFR 445 COFIDCRO, C0FIDCR1 417 C0FRIC, C1FRIC 128 COFTIC, C1FTIC 128 COMB0 to C0MB31 421 C0MCTL0 to C0MCTL31 425 C0MIER, C1MIER 424 C0MKIVLR, C1MKIVLR 419 C0MKR0 to C0MKR7 416 C0MSMR, C1MSMR 438 C0MSSR, C1MSSR 439 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Source Address Reload Register 15 DMA Terminal Count Register 15 DMD Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 DSA0 to DSA3 15, 154 DSR0 to DSR3 15, 155 DTT 222 | | COAFSR, C1AFSR 442 COBCR, C1BCR 414 COCLKR, C1CLKR 413 COCSSR, C1CSSR 441 COCTLR, C1CTLR 409 COECSR, C1ECSR 450 COEIC, C1EIC 128 COEIER, C1EIER 443 COEIFR, C1EIFR 445 COFIDCRO, C0FIDCR1 417 C0FRIC, C1FRIC 128 COFTIC, C1FTIC 128 COMB0 to C0MB31 421 C0MCTL0 to C0MCTL31 425 C0MIER, C1MIER 424 C0MKR0 to C0MKR7 416 C0MSMR, C1MSMR 438 | Debug Flag 13 DM0IC to DM3IC 128 DM0SL to DM3SL 149 DM0SL2 to DM3SL2 150 DMA Destination Address Register 15 DMA Destination Address Reload Register 15 15 DMA Mode Register 15 DMA Source Address Register 15 DMA Terminal Count Register 15 DMA Terminal Count Reload Register 15 DMD0 to DMD3 15, 153 DP Bit 14 DSA0 to DSA3 15, 154 DSR0 to DSR3 15, 155 DTT 222 DVCR 78 | | E2FC | 526 | IC07DDR | 334 | |-------------------------------|-----|--------------------------------------|--------| | E2FD | 528 | ICTB2 | 213 | | E2FI | 528 | IDB0, IDB1 | 212 | | E2FIC | 128 | IFS0 | 487 | | E2FM | 526 | IFS1 | 487 | | E2FS0 | 527 | IFS2 | 488 | | E2FS1 | 527 | IFS5 | 489 | | | | IFS6 | 489 | | F | | IFSR0 | 137 | | - | | IIO0IC to IIO11IC | 128 | | Fast Interrupt | 121 | IIO0IE to IIO11IE | | | FB | | IIO0IR to IIO11IR | 140 | | FBPM0 | | INT Instruction Interrupt | | | FBPM1 | | INTOIC to INT5IC | | | FEBC | | INTB | | | | | Interrupt Control Register | | | Fixed-point Designation Bit | | Interrupt Enable Flag | | | Flag Register | | Interrupt request level | | | FLG | | Interrupt Response Time | | | Floating-point Overflow Flag | | Interrupt Sequence | | | Floating-point Rounding Mode | | Interrupt Stack Pointer | | | Floating-point Underflow Flag | | Interrupt Types | | | FMCR | | Interrupt Vector Table Base Register | | | FMR0 | | INTFO | | | FMR1 | | | | | FMSR0 | | INTF1 | | | FO Flag | | INVC0 | | | FPR0 | | INVC1 | | | Frame Base Register | 13 | IOBC | | | FU Flag | 14 | IPL1 | • | | | | ISP | 13 | | G | | | | | | | L | | | G0BCR0 | 305 | 1.010 | 400 | | G0BCR1 | 306 | LOIC | | | G0BT | | LBRG | | | G0FE | 313 | LBRK | | | G0FS | 312 | LBRP0 | | | G0PO0 to G0PO7 | 310 | LBRP1 | | | G0POCR0 to G0POCR7 | 309 | LCW | | | G0PSCR | 311 | LDB1 to LDB8 | | | G0SDR | 310 | LEST | 386 | | G0TM0 to G0TM7 | 308 | LIDB | 383 | | G0TMCR0 to G0TMCR7 | 307 | LLDIC | 128 | | G0TPR6, G0TPR7 | 307 | LMD0 | 377 | | , | | LMD1 | 378 | | н | | Low Voltage Detection Interrupt 79 | 9, 120 | | • • | | Low Voltage Detector | 76 | | Hardwara Interrupt | 120 | LRFC | 382 | | Hardware Interrupt | 120 | LSC | 383 | | | | LSPC | 381 | | l | | LST | 385 | | | | LTC | | | I Flag | 14 | LVDC | | | LWUP | 379 | PUR0 | | |-------------------------------------|---------|---------------------------------|--------------| | | | PUR1 | | | M | | PUR2 | 491 | | | | <b>D</b> | | | Maskable Interrupt | | R | | | MOD | 166 | | | | | | R2R0 | 13 | | N | | R3R1 | 13 | | | | R6R4 | 13 | | NMI (Non Maskable Interrupt) | 120 | R7R5 | 13 | | Non-maskable Interrupt | | Register Bank Select Flag | 14 | | Tron madicable interrupt | 110 | Register Saving | 134 | | 0 | | RIPL1, RIPL2 | | | O | | RND | | | 0.51 | 4.4 | | | | O Flag | | S | | | OFS | | • | | | ONSF | | 0.51 | 40 | | Oscillator Stop Detection Interrupt | 120 | S Flag | | | Overflow Flag | 14 | S0RIC to S4RIC | | | Overflow Interrupt | 119 | S0TIC to S4TIC | | | · | | Save Flag Register | 15 | | P | | Save PC Register | 15 | | • | | SB | 13 | | D0 t- D0 | 470 | Serial Bus Interface | 336 | | P0 to P9 | | Sign Flag | 13 | | P0_0S to P0_7S | | Single-step Interrupt | | | P1_0S to P1_7S | | Software Interrupt | | | P2_0S to P2_7S | | SP | | | P3_0S to P3_7S | 480 | Special Interrupt | | | P4_0S to P4_7S | 481 | SSOCRH | | | P5_0S to P5_7S | 482 | | | | P6_5S, P6_7S | 483 | SSOCRL | | | P7 0S, P7 4S to P7 6S | | SS0ER | | | P8_2S to P8_4S, P8_6S, P8_7S | | SS0IC | | | P9_3S to P9_7S | | SS0MR | | | PBC | | SS0MR2 | 347 | | PC | | SS0RDR | 348 | | PCR | | SS0SR | 346 | | PD0 to PD9 | | SS0TDR | 348 | | | | Stack Pointer | 13 | | Peripheral Interrupt | | Stack Pointer Select Flag | 14 | | PLC0 | | Static Base Register | 13 | | PLC1 | | SVF | | | PLS | | SVP | | | PM0 | | Synchronous Serial Communicati | | | PM2 | | Cyricine near Conai Communicati | 511 MOGO 000 | | PM3 | 89 | т | | | PRCR | 114 | • | | | PRCR2 | 115 | | | | PRCR3 | 115 | TA0 to TA4 | | | PRCR4 | 116 | TA0IC to TA4IC | | | Processor Interrupt Priority Level | 14, 127 | TA0MR to TA4MR 178, 184, 18 | | | Program Counter | | TA1, TA2, TA4, TA11, TA21, TA41 | 217 | | PRR | | TA1M, TA11M, TA2M, TA21M, TA | 4M, TA41M | | | | | 218 | | TA1MR, TA2MR, TA4MR | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TRGSR 181, 220 | | U | | U Flag 14 U0BRG to U4BRG 237 U0C0 to U2C0 231 U0C1 to U2C1 233 U0MR to U2MR 229 U0RB to U2RB 238 U0SMR to U2SMR 234 U0SMR2 to U2SMR2 235 U0SMR3 to U2SMR3 236 U0SMR4 to U2SMR4 237 U0TB to U4TB 238 U3CO, U4CO 234 U3C1, U4C1 233 U3RB, U4MR 230 U3RB, U4RB 239 UDF 179 Undefined Instruction Interrupt 119 User Stack Pointer 13 USP 13 | | V | | VCT 15 Vector Register 15 VRCR 74 | | W | | Watchdog Timer Interrupt 120 WDC 144 WDK 145 WDTS 145 | | X | | X0R to X15R | | XYC | 298 | |-------------|----------| | | Υ | | Y0R to Y15R | 299 | | | Z | | | 13<br>13 | | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |------------------|----------------------------------------| | | • | | Rev. | Date | Description | | |------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TCV. | Date | Page | Summary | | 0.51 | Dec 24, 2008 | | Initial release | | 1.02 | Feb 26, 2010 | | Second edition released | | | | | This manual in general | | | | _ | <ul> <li>Changed the following expressions: "erase/program" to "program/ erase" (under Chapters 1, 26, 27, and 29); "ID code check" to "ID code protect" (under Chapters 1 and 26); "sample &amp; hold" to "sample and hold" (under Chapters 1, 18, and 28); "reset operation" to "reset" (under Chapters 7, 8, 10, 11, and 29); and "Start/Stop Condition" to "Start Condition/Stop Condition" (under Chapters 4, 10, and 17)</li> <li>Added a question mark to the sentence in diamond-shaped boxes of flowcharts (under Chapters 22, 26, and 27)</li> <li>Modified descriptions for notes in some figures (under Chapters 6, 7, 8, 11, 12, 17, and 26)</li> </ul> | | | | | About This Manual | | | | _ | <ul> <li>Made minor text modifications to this section</li> <li>Deleted "Shortsheet" row from 1. Purpose and Target User</li> <li>Revised illustration in 3. Registers</li> </ul> | | | | | Chapter 1. Overview | | | 3 | • Changed the following expressions in <b>Table 1.2</b> : "Read protection" to "Security protection" and "on-board flash reprogramming" to "on-board flash programming" | | | | 4 | Completed "under development" phase of part number R5F64610JFP in <b>Table 1.3</b> | | | | | | Chapter 2. Central Processing Unit | | | | _ | Made minor text modifications to this chapter | | | | | Chapter 3. Memory | | | | | Made minor text modifications to this chapter | | | | | Chapter 4. Special Function Registers | | | | 17 | • Changed hexadecimal format of reset values for registers CCR and FMCR in <b>Table 4.1</b> to binary | | | | 24 | <ul> <li>Changed reset values "XXXX XXXXb" and "XXXX 000Xb" for<br/>registers U3RB and U4RB in Table 4.8 to "XXXXh"</li> </ul> | | | | 26 | • Changed expression of register name "Xi Register Yi Register" and symbol "XiR, YiR" in <b>Table 4.10</b> to "Xi Register/Yi Register" and to "XiR/YiR", respectively | | | | 35, 36 | <ul> <li>Modified register name "Port Pi_j Port Function Select Register" in<br/>Table 4.19 and 4.20 to "Port Pi_j Function Select Register"</li> </ul> | | | | 38 | Modified register name "DMAi Request Source Select Register 1" in Table 4.22 to "DMAi Request Source Select Register" | | | | 39 | Modified "X" in reset values for unassigned bits to "0" for the following registers in <b>Table 4.23</b> : LCW, LBRG, LMD0, LBRK, LSPC, LRFC, LSC, LTC, LST, and LEST | | | | 55, 69 | Modified reset value "00h" for C1CLKR in <b>Table 4.39</b> and C0CLKR in <b>Table 4.53</b> to "000X 0000b" | | REVISION HISTORY R32 | C/161 Group User's Manual: Hardware | |----------------------|-------------------------------------| |----------------------|-------------------------------------| | | Description | | | |------|-------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | | Chapter 5. Resets | | | | _ | Made minor text modifications to this chapter | | | | 71 | Deleted the arrow indicating period from when the RESET signal | | | | | becomes high to when address data is output from Figure 5.2 | | | | 73 | Modified Figure 5.5 | | | | | Chapter 6. Power Management | | | | 76 | Corrected the following bit symbols "LVDEN" and "LVEIEN" in Figure 6.3 to "VDEN" and "LVDIEN", respectively; Corrected register symbol "LVDCR" to "LVDC" | | | | | Chapter 7. Clock Generator | | | | _ | Made minor text modifications to this chapter | | | | | <ul> <li>Modified expression: "peripheral clock" to "peripheral clock source"<br/>when it means a peripheral clock source</li> </ul> | | | | 81 | • Modified reference figure number "Figure 7.3" in <b>7.1</b> to "Figure 7.2" | | | | 82 | <ul> <li>Changed the following bit symbols in Figure 7.1: "CM06 to CM00" to "CM00 to CM02, CM04, and CM05", "CM27 to CM20" to "CM20", "CM31 and CM30" to "CM30 and CM31", and "PM27 to PM20" to "PM26"</li> </ul> | | | | 83 | • Corrected a typo "Aah" in Note 1 for CCR register of <b>Figure 7.2</b> to "AAh" | | | | 84 | • Added "and f2n whose clock source is the main clock" to Note 3 for CM0 register in <b>Figure 7.3</b> | | | | 85 | Modified description for Note 3 of CM1 register in Figure 7.4 | | | | 88 | Modified "Bus clock" in "Function" of PM22 bit in <b>Figure 7.9</b> to "Peripheral bus clock" | | | | 92 | Added register name "PLC1" for SEO bit in Figure 7.13 | | | | 92, 93 | Added description associated with interrupt and DMA transfer to Note 1 for registers PLC0 and PLC1 in Figures 7.14 and 7.15 Changed frequency of PLL frequency synthesizer "50MH-7" in line 3. | | | | 94 | • Changed frequency of PLL frequency synthesizer "50MHz" in line 3 of the third paragraph above <b>Table 7.2</b> to "t <sub>SO</sub> (PLL)"; Deleted | | | | | description associated with frequency from line 14; Modified "t <sub>ocs</sub> (PLL)" to "t <sub>Lock</sub> (PLL)" | | | | 96 | • Deleted description "with the frequency of approximately 8MHz" from line 2 of <b>7.3</b> ; Corrected a typo "fc" in line 4 to "fC" | | | | 97 | <ul> <li>Deleted description associated with frequency from line 2 of 7.4;</li> <li>Added "the serial bus interface" to line 6</li> <li>Added "whose clock source is the peripheral clock source" to line 5</li> </ul> | | | | | of (1) in <b>7.5</b> | | | | 100-102 | • Added definitions for the following bit symbols in <b>Figures 7.18 to 7.20</b> : BCS, CM04, CM05, CM10, CM20, CM30, and CM31 | | | | 104, 107 | <ul> <li>Revised procedures and descriptions for entering wait mode in<br/>7.7.2.2 and for entering stop mode in 7.7.3.1</li> </ul> | | | | 105 | • Changed "the peripheral clock" in line 9 of <b>7.7.2.4</b> , to "f1, f8, f32, f2n (when the clock source is the peripheral clock source), or fAD"; Added description "with the software interrupt numbers 0 to 63" to line 11 to specify peripheral clocks | | D | Date | Description | | |------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | | Page | Summary | | | | 106 | <ul> <li>Added "Watchdog timer interrupt" and the related specifications to<br/>Table 7.5</li> </ul> | | | | 108 | <ul> <li>Moved Table 7.6 to under 7.7.3.3 as Table 7.7 and previous Table 7.7 becomes Table 7.6; Made related modifications due to the changes</li> </ul> | | | | 110 | • Deleted entire section of "Wait Mode" from <b>7.9.2.1</b> and the first bullet point for "Stop Mode" from previous <b>7.9.2.2</b> (current <b>7.9.2.1</b> ) | | | | | Chapter 8. Bus | | | | _ | Made minor text modifications to this chapter | | | | 112 | • Modified bus width "16-bit" in <b>8.2</b> to "16-/32-bit"; Added description for maximum operating frequency to lines 1 and 2 | | | | | Chapter 9. Protection | | | | _ | Made minor text modifications to this chapter | | | | 113 | Added IOBC to PRC1 bit as writable register in Figure 9.1 | | | | | Chapter 10. Interrupts | | | | _ | Made major text modifications to this chapter | | | | 117 | Added "MULX" as instruction to (2) of 10.2 | | | | 118 | Modified number of interrupts "seven" in 10.3.1 to "five" | | | | 121-124 | <ul> <li>Added reference chapter and section numbers to "Reference" in<br/>Tables 10.2 to 10.5</li> </ul> | | | | 126, 127 | <ul> <li>Changed IR bit name "Interrupt Request Bit" in Figures 10.3 and<br/>10.4 to "Interrupt Request Flag"</li> </ul> | | | | 131 | Modified number of cycles for some interrupts in Table 10.7 | | | | 133 | Changed priority order of hardware interrupts in 10.8 | | | | 134 | <ul> <li>Modified "Bits RLVL02 to RLVL00" and "Bits RLVL12 to RLVL10" in<br/>Figure 10.8 to "Bits RLVL2 to RLVL0 in the RIPL1 register" and "Bits<br/>RLVL2 to RLVL0 in the RIPL2 register", respectively</li> </ul> | | | | 137 | • Moved "(i = 0 to 11)" in <b>Figure 10.12</b> to the title | | | | 138, 139 | • Corrected the following register names: "Intelligent I/O Interrupt Request Register" in <b>Figure 10.13</b> to "Intelligent I/O Interrupt Request Register i (i = 0 to 11)" and "Intelligent I/O Interrupt Enable Register" in <b>Figure 10.14</b> to "Intelligent I/O Interrupt Enable Register i (i = 0 to 11)"; Changed variable "j" for definitions of bits to "y" in <b>Figures 10.13 and 10.14</b> ; Added expression "channel" to descriptions for TM0yR, PO0yR, TM0yE, and PO0yE | | | | 140 | • Corrected typos "PR2 register" in <b>10.13.1</b> and "INTi (i = 0 to 5) pin" in <b>10.13.3</b> to "PM2 register" and "INTi pin (i = 0 to 5)", respectively | | | | | Chapter 11. Watchdog Timer | | | | _ | <ul><li>Revised this chapter entirely</li><li>Modified expression "bus clock" to "peripheral bus clock"</li></ul> | | | | 142 | <ul> <li>Changed upper prescaler section in Figure 11.1; Added definitions<br/>to the following bit symbols: PM22, WDK2, and WDK3</li> </ul> | | | | 143 | <ul> <li>Changed bit name "Count Source Protect Mode Prescaler Select<br/>Bit" for WDK2 and WDK3 in Figure 11.3 to "On-chip Oscillator<br/>Prescaler Select Bit"</li> </ul> | | Rev. | Date | Description | | | |------|------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | rev. | | Page | Summary | | | | | 144 | • Changed bit name "Watchdog Timer Prescaler Select Bit" for WPSC1 and WPSC0 in <b>Figure 11.5</b> to "Watchdog Timer On-chip Oscillator Prescaler Select Bit"; Added note symbol "(2)" to WDTON bit; Changed "RW" section for each bit to "(1)" as note symbol; Added description "in the PM2 register" to Note 2 | | | | | | Chapter 12. DMAC | | | | | | Made minor text modifications to this chapter | | | | | 146 | Changed the following expressions in <b>Table 12.1</b> : "transfer unit" to "transfer size", "destination address" to "addressing mode", "forward" to "incrementing addressing", and "fixed" to "non-incrementing addressing" | | | | | 147 | <ul> <li>Modified description "registers DMiSL and DMiSL2" in line 3 of a<br/>paragraph above Figure 12.2 to "DMiSL register, and in bits<br/>DSEL24 to DSEL20 in the DMiSL2 register"</li> </ul> | | | | | 148 | <ul> <li>Modified register name "DMiSL Register 2 (i = 0 to 3) Function" for<br/>DSEL20 to DSEL24 in Figure 12.3 to "DMiSL2 Register (i = 0 to 3)<br/>Function"; Modified "DSEL4 to DSEL0" in Note 1 to "DSEL24 to<br/>DSEL20"</li> </ul> | | | | | 151 | <ul> <li>Changed bit names for USAi and UDAi of DMDi register in Figure 12.4 and modified descriptions for their functions; Deleted the second sentence of Note 2; Added Note 3; Changed the following expressions of function descriptions: "Not updated" to "Non-incrementing addressing" and "Updated with each transfer" to "Incrementing addressing"</li> <li>Modified description for Note 2 of DCTi register in Figure 12.5; Deleted Note 3</li> </ul> | | | | | 154 | • Added "(i = 0 to 3)" to DSAi in line 3 of <b>12.1</b> | | | | | 159 | <ul> <li>Modified description "channel i" in line 1 of the first bullet point of 12.4.1 to "DMDi register"; Deleted whole description of the second and third bullet points; Added two new paragraphs</li> <li>Modified description "peripheral clocks" in the fourth bullet point of 12.4.2 to "peripheral bus clocks"</li> </ul> | | | | | Chapter 13. DMAC II | | | | | | _ | <ul> <li>Revised this chapter entirely</li> <li>Changed the following expressions: "transfer data" to "transfer type", "transfer data unit" to "transfer size", "transfer space" to "transfer memory space", "transfer direction" to "addressing mode", "fixed address" to "non-incrementing/constant addressing", "forward address" to "incrementing addressing", "end-of-transfer interrupt" to "DMA II transfer complete interrupt", "chained transfer address" for CADR to "chained transfer base address", "transfer source address" for SADR to "source address", "transfer destination address" for</li> </ul> | | | | | | DADR to "destination address" | | | Rev. | Date | | Description | |------|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 160 | <ul> <li>Corrected typos "64-Kbyte space" and "0000000h to 01FFFFFh" in Table 13.1 to "64-Mbyte space" and "00000000h to 01FFFFFh", respectively; Added "multiple transfer" and its description to "transfer modes"; Deleted "multiple transfer" from item column</li> <li>Modified description "The relocatable vector table" in line 1 of 13.1</li> </ul> | | | | 1.22 | to "The relocatable vector" | | | | 162 | • Corrected a typo "BASE + 6" in <b>Figure 13.2</b> to "BASE + 8" | | | | 164 | <ul> <li>Revised Figure 13.3; Modified function "No register bits" for b14 to<br/>b8 to "Reserved"</li> </ul> | | | | 165 | • Corrected a typo "FE00000000h" in line 3 of <b>13.3</b> to "FE000000h" | | | | 167 | Modified descriptions in Figure 13.4 | | | | | Chapter 15. Timers | | | | _ | Made minor text modifications to this chapter | | | | 172 | • Corrected the following typos: "TTA0TGL", "TAiGH", and "TAiGL" in | | | | 474 | Figure 15.1 to "TA0TGL", "TAiTGH", and "TAiTGL", respectively | | | | 174 | <ul> <li>Corrected a typo "TBiS bit" in Figure 15.3 to "TAiS"; Added<br/>description "Event/trigger selection"</li> </ul> | | | | 189 | Corrected a typo "FEh" as a value of m for "8-bit PWM" in <b>Table</b> | | | | 100 | 15.5 to "FFh" | | | | 190 | Modified reset value "0000 000b" for TAiMR register in Figure 15.10 to "0000 0000b" | | | | 192 | Changed "TBiS bit" in Figure 15.19 to "TBiS" | | | | 193 | • Corrected a typo "TM5MR" in the title of <b>Figure 15.21</b> to "TB5MR" | | | | 201 | <ul> <li>Moved note symbol "(1)" from "Function" in Figure 15.27 to "Bit<br/>Name"</li> </ul> | | | | 203, 204 | • Deleted "(i = 0 to 4)" from line 1 of the first bullet point of <b>15.3.2.3</b> and the second bullet point of <b>15.3.2.4</b> | | | | 204 | • Added "(i = 0 to 4)" to line 1 of the first bullet point of 15.3.2.4 | | | | 205 | • Replaced variable "i" with "j" in <b>15.3.3.1 and 15.3.3.2</b> ; Added "(j = 0 | | | | | to 5)" to the first bullet point of <b>15.3.3.1</b> | | | | | Chapter 16. Three-phase Motor Control Timers | | | | _ | <ul> <li>Made minor text modifications to this chapter</li> <li>Changed expression "timer B2 counter" to "timer B2"</li> </ul> | | | | 208 | Modified "RW" for INV05 bit in <b>Figure 16.2</b> to "RO" | | | | 210 | <ul> <li>Modified reset value "0011 111b" for IDBi register in Figure 16.5 to "XX11 1111b"; Changed status of bits 7 and 6 from reserved to unassigned</li> </ul> | | | | 213 | <ul> <li>Modified reset value "0010 0000b" for TB2MR register in Figure<br/>16.8 to "00XX 0000b"</li> </ul> | | | | 214, 218 | Changed titles of Figures 16.9 and 16.14 | | | | 220 | <ul> <li>Changed expression "high side- and low side- transistors" in Figure<br/>16.16 to "high-side and low-side transistors"</li> </ul> | | | | 221 | Corrected a typo "TA4-1" in <b>Figure 16.18</b> to "TA41"; Changed expression "Refer to Figure 16.1" in Note 1 to "Refer to the block diagram of three-phase motor control timers" | | | | 222 | <ul> <li>Modified description "The three motor control timer is applicable" in<br/>Figure 16.19 to "This bit setting is applicable"</li> </ul> | | Davi | Dete | | Description | |------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | | Chapter 17. Serial Interface | | | | _ | Made minor text modifications to this chapter | | | | | Changed expression "UART transmit/UART receive interrupt" to | | | | | "transmit/receive interrupt" | | | | 225, 226 | • Deleted "CRS" from list of bits in UiC0 register in <b>Figures 17.1 and 17.2</b> | | | | 228 | <ul> <li>Modified expression of bit symbol "SMD1" (the second one of the<br/>two) for UiMR register in Figure 17.4 to "SMD2"; Changed<br/>expression "i-bit transfer data" to "i-bit character length"</li> </ul> | | | | 230 | • Corrected a typo "synchronous serialb interface mode" in Note 1 for UiC0 register in <b>Figure 17.6</b> to "synchronous serial interface mode" | | | | 233, 235 | Modified descriptions "SCL" and "SDA" in Figure 17.11 and 17.13 to "SCLi" and "SDAi", respectively | | | | 234 | <ul> <li>Modified description "To set the SS" for Note 2 of UiSMR3 in Figure<br/>17.12 to "To use the SS function"; Corrected a typo "UiCO register"<br/>to "UiC0 register"</li> </ul> | | | | 236 | <ul> <li>Deleted description "and read as undefined value" from "b15-b9" of<br/>UiTB register in Figure 17.15</li> <li>Added addresses "033Fh-033Eh" to UiRB register in Figure 17.16</li> </ul> | | | | 238 | Modified description "(i = 0 to 2)" for "Transmit/receive clock" in Table 17.2 to "(i = 0 to 4)" | | | | 239 | • Corrected typos "000h" for bits "7 to 4" and "000h" for bits "2 to 0" for UiSM3 register in <b>Table 17.3</b> to "0000b" and "000b", respectively | | | | 243, 252 | • Deleted description "(i = 0 to 4)" from subsection B in 17.1.1 and 17.2.2 | | | | 243, 244 | • Changed variable "j" for descriptions of bits in <b>Figures 17.20 and 17.21</b> to "i"; Deleted "(j = 0 to 6)" from Notes 2 and 4 in <b>Figure 17.20</b> and from Notes 1 and 2 in <b>Figure 17.21</b> | | | | 246 | • Specified number of stop bits for "Overrun error" in <b>Table 17.5</b> ;<br>Changed expression "n stop bit(s)" for "Error detection" to "n stop bit length" | | | | 248 | Corrected a typo "SUM0" for UiRB register in <b>Table 17.7</b> to "SUM" | | | | 256 | Added bits ACKC and ACKD and their definitions to Figure 17.29 | | | | 257 | Changed bits "7 to 4" for UiC1 register in <b>Table 17.10</b> to "7 to 5" and corrected "0000b" to "000b"; Added UilRS bit and its function to UiC1 register; Changed description "fix a low output" for bits SWC and SWC9 to "hold a low output" | | | | 258 | Added description " to the line of "Default output value at the SDAi pin" in <b>Table 17.11</b> to "by output function select registers" | | | | 268 | • Corrected a typo "SS pin" in title of Figure 17.35 to "SSi pin" | | | | 271 | • Deleted whole description from the third bullet point of previous 17.5.2.2 (current <b>17.5.3.2</b> ) | | | | | Chapter 18. A/D Converter | | | | _ | Made minor text modifications to this chapter | | | | | Modified numbers of sections and figures due to the deletes throughout the chapter | | 1020/1010 Managar Haraware | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |----------------------------|------------------|----------------------------------------| |----------------------------|------------------|----------------------------------------| | Page Deleted second and third sentences from Note 3 for AE register in Figure 18.3; Added Note 4 Modified description for Note 4 of AD0CON3 register in Figure Do Control Register, Changed "Ro" for unassigned bit to "RW" and changed function for unassigned bits b7 ar Added bit symbol boxes for AD0i register in Figure 18. function for unassigned bits b7 ar Added bit symbol boxes for AD0i register in Figure 18. function for unassigned bits b15 to b10; Modified descr Notes 1 and 4 280-284 Revised description for Tables 18.2 to 18.6; Corrected D00" for "Reading of A/D conversion result" to "AD00" Added Note 1 to Tables 18.4 to 18.6 285 Changed expression "AD0j" in 18.2.1 to "AD0i"; Modified "TRG0 bit in the AD0CON2 register" in 18.2.3 to "bits TRG0 in the AD0CON2 register" in last line of the se point in 18.3.2 to "AD00 register" in last line of the se point in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth bit Chapter 19. CRC Calculator Made minor text modifications to this chapter Chapter 20. X-Y Conversion Made minor text modifications to this chapter Chapter 21. Intelligent I/O Made minor text modifications to this chapter Chapter 21. Intelligent I/O Made minor text modifications to this chapter Chapter 21. Intelligent I/O Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title. Changed expression "IIOO_j pin function" to "IIOO_function" Moved "j = 0 to 7" in Figure 21.18 and 21.19 to the title 319 Moved "j = 0 to 7" in Figure 21.20 to the title Moved "j = 0 to 7" in Figure 21.20 to the title Changed expression "IIOO_j pin function" in Table 21.7 output pin function Changed expression "IIOO_j pin function" in Table 21.7 output pin function Changed expression "IIOO_j pin function" output)" in Ta and 21.9 to "IIOO_j output pin function" Changed expression "IIOO_j pin function" output)" in Ta and 21.9 to "IIOO_j output pin function" Changed expressions "For and output Polar Polar Polar Polar Polar Polar Polar Polar Polar | Rev. Date | | Description | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | register in Figure 18.3; Added Note 4 278 | Nev. Date | Page | Summary | | **Modified description for Note 4 of ADOCON3 register in **Modified register name "ADO Control Register" in *Figure Do Control Register"; Changed "RO" for unassigned bits to "RV" and changed function for unassigned bits b7 ar **Added bit symbol boxes for AD0i register in *Figure 18.* function for unassigned bits b7 ar **Added bit symbol boxes for AD0i register in *Figure 18.* function for unassigned bits b15 to b10; Modified descr Notes 1 and 4 | | 276 | Deleted second and third sentences from Note 3 for AD0CON1 register in Figure 18.3: Added Note 4. | | • Modified register name "AD0 Control Register" in Figur D0 Control Register"; Changed "RO" for unassigned bits b7 ar • Added bit symbol boxes for AD0i register in Figure 18. function for unassigned bits b15 to b10; Modified descr Notes 1 and 4 280-284 • Revised description for Tables 18.2 to 18.6; Corrected D00" for "Reading of A/D conversion result" to "AD00" • Added Note 1 to Tables 18.4 to 18.6 • Changed expression "AD0]" in 18.2.1 to "AD01"; Modified "TRG0 bit in the AD0CON2 register" in 18.2.3 to "bits T TRG0 in the AD0CON2 register" in 18.2.3 to "bits T TRG0 bit in the AD0CON2 register" 286 • Added description of reference table to line 2 of 18.2.5 • Changed description "AD0i register" in last line of the se point in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth bit Chapter 19. CRC Calculator — Made minor text modifications to this chapter Chapter 20. X-Y Conversion — Made minor text modifications to this chapter Chapter 21. Intelligent I/O — Made minor text modifications to this chapter Chapter 21. Intelligent I/O — Made minor text modifications to this chapter Chapter 21. Intelligent I/O — Made minor text modifications to this chapter Chapter 21. Intelligent I/O — Made minor text modifications to this chapter Chapter 21. Intelligent I/O — Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added destroped and the file of the service | | 270 | | | D0 Control Register"; Changed "RO" for unassigned bits to "RW" and changed function for unassigned bits b7 ar Added bit symbol boxes for AD0i register in Figure 18; function for unassigned bits b15 to b10; Modified descr Notes 1 and 4 280-284 | | | , | | to "RW" and changed function for unassigned bits b7 ar | | 219 | | | - Added bit symbol boxes for AD0i register in Figure 18. function for unassigned bits b15 to b10; Modified descr Notes 1 and 4 280-284 - Revised description for Tables 18.2 to 18.6; Corrected D00" for "Reading of A/D conversion result" to "AD00" - Added Note 1 to Tables 18.4 to 18.6 - Changed expression "AD0j" in 18.2.1 to "AD0i"; Modified "TRG0 bit in the AD0CON2 register" in 18.2.3 to "bits TTRG0 in the AD0CON2 register" in 18.2.3 to "bits TTRG0 in the AD0CON2 register" in last line of the sepoint in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth bit bullet point; Added description to the ninth bit chapter 19. CRC Calculator - Made minor text modifications to this chapter - Chapter 20. X-Y Conversion - Made minor text modifications to this chapter - Chapter 21. Intelligent I/O - Made minor text modifications to this chapter - Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BT0R bit - Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIO0_j pin function" to "IIO0_function" - Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title - Moved "j = 0 to 7" in Figure 21.20 to the title - Moved "j = 0 to 7" in Figure 21.20 to the title - Moved "j = 0 to 7" in Table 21.6 to the title - Moved "j = 0 to 7" in Table 21.6 to the title - Changed expression "IIO0_j pin function" in Table 21.7 output pin function" - Changed expression "IIO0_j pin function (output)" in Talle 21.7 output pin function" - Changed expression "IIO0_j pin function (output)" in Talle 21.7 output pin function" - Deleted "j = 0 to 7" from Case 2 in Figure 21.25 - Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | | | | function for unassigned bits b15 to b10; Modified descr Notes 1 and 4 280-284 • Revised description for Tables 18.2 to 18.6; Corrected D00" for "Reading of A/D conversion result" to "AD00" 282-284 • Added Note 1 to Tables 18.4 to 18.6 285 • Changed expression "AD0]" in 18.2.1 to "AD01"; Modified "TRG0 bit in the AD0CON2 register" in 18.2.3 to "bits T TRG0 in the AD0CON2 register" in 18.2.3 to "bits T TRG0 in the AD0CON2 register" in last line of the se point in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth bit chapter 19. CRC Calculator • Made minor text modifications to this chapter Chapter 20. X-Y Conversion • Made minor text modifications to this chapter Chapter 21. Intelligent I/O • Made minor text modifications to this chapter Chapter 21. Intelligent I/O • Made minor text modifications to this chapter Chapter 21. Intelligent I/O • Made minor text modifications to this chapter 300 • Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIOO_j pin function" to "IIOO_function" • Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title 317, 318 • Moved "j = 0 to 7" in Tigure 21.10 to the title 320 • Moved "j = 0 to 7" in Tigure 21.20 to the title 321 • Changed expression "IIOO_j pin function" in Table 21.7 output pin function" 323, 325 • Changed expression "IIOO_j pin function (output)" in Tallor and 21.9 to "IIOO_j output pin function" 330 • Deleted "j = 0 to 7" from Case 2 in Figure 21.25 • Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | | | | **Revised description for Tables 18.2 to 18.6; Corrected D00" for "Reading of A/D conversion result" to "AD00" 4dded Note 1 to Tables 18.4 to 18.6 285 **Changed expression "AD0j" in 18.2.1 to "AD0j"; Modified "TRG0 bit in the AD0CON2 register" in 18.2.3 to "bits TTRG0 in the AD0CON2 register" in 18.2.3 to "bits TTRG0 in the AD0CON2 register" in last line of the sepoint in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth but text modifications to this chapter Chapter 21. Intelligent I/O Made minor text modifications to this chapter Chapter 21. Intelligent I/O Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added description but but but title; Changed expression "IIO0_j pin function" to "IIO0_function" Moved "j = 0 to 7," in Figures 21.18 and 21.19 to the title 317, 318 Moved "j = 0 to 7" in Figure 21.20 to the title Changed expression "IIO0_j pin function (output)" in Table 21.9 to "IIO0_j output pin function" Changed expression "IIO0_j pin function (output)" in Ta and 21.9 to "IIO0_j output pin function" Deleted "j = 0 to 7" from Case 2 in Figure 21.25 Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | | function for unassigned bits b15 to b10; Modified description for | | **Added Note 1 to Tables 18.4 to 18.6 **Changed expression "AD0j" in 18.2.1 to "AD0i"; Modified "TRG0 bit in the AD0CON2 register" in 18.2.3 to "bits TTRG0 in the AD0CON2 register" in 18.2.3 to "bits TTRG0 in the AD0CON2 register" in 18.2.5 to "Added description of reference table to line 2 of 18.2.5 expoint in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the text modifications to this chapter Chapter 21. Intelligent I/O | | 280-284 | • Revised description for <b>Tables 18.2 to 18.6</b> ; Corrected a typo "A/ | | **Changed expression "ADOj" in 18.2.1 to "ADOi"; Modified "TRG0 bit in the AD0CON2 register" in 18.2.3 to "bits T TRG0 in the AD0CON2 register" in 18.2.5 to "bits T TRG0 in the AD0CON2 register" in last line of the se point in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth but eighth bullet point; Added description to the ninth but eighth bullet point; Added description to the ninth but eighth bullet point; Added description to the ninth but eighth bullet point; Added description to the ninth but eighth bullet point; Added description to the ninth but eighth bullet point; Added description to the ninth but eighth bullet point; Added description to the ninth but eighth bullet point; Added description to this chapter Chapter 20. X-Y Conversion - Made minor text modifications to this chapter Chapter 21. Intelligent I/O - Made minor text modifications to this chapter - Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added description to the ninth but eighth bullet in the state of the second sec | | 282-284 | 1 | | *Added description of reference table to line 2 of 18.2.5 *Changed description "AD0i register" in last line of the se point in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" for the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to this chapter **Chapter 20. X-Y Conversion** **Made minor text modifications to this chapter** **Chapter 21. Intelligent I/O** **Made minor text modifications to this chapter of the eight point in eight point in the eight point in the eight point in the eight point in the eight point in the eight point in the eight point | | | • Changed expression "AD0j" in <b>18.2.1</b> to "AD0i"; Modified description "TRG0 bit in the AD0CON2 register" in <b>18.2.3</b> to "bits TRG1 and | | • Changed description "AD0i register" in last line of the se point in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" from the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to this chapter Chapter 20. X-Y Conversion • Made minor text modifications to this chapter Chapter 21. Intelligent I/O • Made minor text modifications to this chapter • Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added description to the point of t | | 286 | | | point in 18.3.2 to "AD00 register"; Deleted "(i=0 to 7)" frequency the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the eighth bullet point; Added description to the ninth but the ninth but the eighth bullet point; Added description to this chapter 20. X-Y Conversion | | | · | | the eighth bullet point; Added description to the ninth buton Chapter 19. CRC Calculator - Made minor text modifications to this chapter Chapter 20. X-Y Conversion - Made minor text modifications to this chapter Chapter 21. Intelligent I/O - Made minor text modifications to this chapter Chapter 21. Intelligent I/O - Made minor text modifications to this chapter Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BTOR bit 317 Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIOO_j pin function" to "IIOO_function" Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title 317, 318 Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title 320 Moved "j = 0, 7" in Figure 21.20 to the title 321 Changed expression "IIOO_j pin function" in Table 21.7 output pin function" 323, 325 Changed expression "IIOO_j pin function (output)" in Talle 21.9 to "IIOO_j output pin function" 324, 325 Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | 231 | | | Chapter 19. CRC Calculator * Made minor text modifications to this chapter Chapter 20. X-Y Conversion * Made minor text modifications to this chapter Chapter 21. Intelligent I/O * Made minor text modifications to this chapter 300 * Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BTOR bit 317 * Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIOO_j pin function" to "IIOO_function" * Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title 317, 318 * Moved "j = 0 to 7" in Figures 21.20 to the title 320 * Moved "j = 0 to 7" in Table 21.6 to the title 321 * Changed expression "IIOO_j pin function" in Table 21.7 output pin function" 323, 325 * Changed expression "IIOO_j pin function (output)" in Talle 21.9 to "IIOO_j output pin function" 330 * Deleted "j = 0 to 7" from Case 2 in Figure 21.25 * Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | | the eighth bullet point; Added description to the ninth bullet point | | Chapter 20. X-Y Conversion • Made minor text modifications to this chapter Chapter 21. Intelligent I/O • Made minor text modifications to this chapter 300 • Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BTOR bit 317 • Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIOO_j pin function" • Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title 317, 318 • Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title 319 • Moved "j = 6, 7" in Figure 21.20 to the title 320 • Moved "j = 0 to 7" in Table 21.6 to the title 321 • Changed expression "IIOO_j pin function" in Table 21.7 output pin function" 323, 325 • Changed expression "IIOO_j pin function (output)" in Ta and 21.9 to "IIOO_j output pin function" 330 • Deleted "j = 0 to 7" from Case 2 in Figure 21.25 • Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | | | | Chapter 20. X-Y Conversion • Made minor text modifications to this chapter Chapter 21. Intelligent I/O • Made minor text modifications to this chapter 300 • Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BTOR bit 317 • Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIOO_j pin function" • Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title 317, 318 • Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title 319 • Moved "j = 6, 7" in Figure 21.20 to the title 320 • Moved "j = 0 to 7" in Table 21.6 to the title 321 • Changed expression "IIOO_j pin function" in Table 21.7 output pin function" 323, 325 • Changed expression "IIOO_j pin function (output)" in Ta and 21.9 to "IIOO_j output pin function" 330 • Deleted "j = 0 to 7" from Case 2 in Figure 21.25 • Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | | Made minor text modifications to this chapter | | Chapter 21. Intelligent I/O • Made minor text modifications to this chapter • Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BTOR bit • Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIO0_j pin function" to "IIO0_function" • Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title 317, 318 • Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title 319 • Moved "j = 6, 7" in Figure 21.20 to the title 320 • Moved "j = 0 to 7" in Table 21.6 to the title 321 • Changed expression "IIO0_j pin function" in Table 21.7 output pin function" 323, 325 • Changed expression "IIO0_j pin function (output)" in Talle 21.9 to "IIO0_j output pin function" 330 • Deleted "j = 0 to 7" from Case 2 in Figure 21.25 • Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | | | | <ul> <li>• Made minor text modifications to this chapter</li> <li>• Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BT0R bit</li> <li>• Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIO0_j pin function" to "IIO0_function"</li> <li>• Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title</li> <li>317, 318</li> <li>• Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title</li> <li>319</li> <li>• Moved "j = 6, 7" in Figure 21.20 to the title</li> <li>320</li> <li>• Moved "j = 0 to 7" in Table 21.6 to the title</li> <li>321</li> <li>• Changed expression "IIO0_j pin function" in Table 21.7 output pin function"</li> <li>323, 325</li> <li>• Changed expression "IIO0_j pin function (output)" in Taand 21.9 to "IIO0_j output pin function"</li> <li>330</li> <li>• Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>• Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | _ | Made minor text modifications to this chapter | | <ul> <li>Moved "(j = 0 to 7)" in Figure 21.1 to the title; Added de BTOR bit</li> <li>Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIOO_j pin function" title; Changed expression "IIOO_j pin function" to "IIOO_function"</li> <li>Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title</li> <li>Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title</li> <li>Moved "j = 6, 7" in Figure 21.20 to the title</li> <li>Moved "j = 0 to 7" in Table 21.6 to the title</li> <li>Changed expression "IIOO_j pin function" in Table 21.7 output pin function"</li> <li>Changed expression "IIOO_j pin function (output)" in Talle 21.9 to "IIOO_j output pin function"</li> <li>Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | | Chapter 21. Intelligent I/O | | <ul> <li>BTOR bit</li> <li>Moved "(j = 0 to 7)" for "Trigger input polarity" in Table 2 title; Changed expression "IIOO_j pin function" to "IIOO_function"</li> <li>Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title</li> <li>Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title</li> <li>Moved "j = 6, 7" in Figure 21.20 to the title</li> <li>Moved "j = 0 to 7" in Table 21.6 to the title</li> <li>Moved "j = 0 to 7" in Table 21.6 to the title</li> <li>Changed expression "IIOO_j pin function" in Table 21.7 output pin function"</li> <li>Changed expression "IIOO_j pin function (output)" in Ta and 21.9 to "IIOO_j output pin function"</li> <li>Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | _ | Made minor text modifications to this chapter | | title; Changed expression "IIO0_j pin function" to "IIO0_function" • Moved "j = 0 to 7; k = 6, 7" below Table 21.5 to the title • Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title • Moved "j = 6, 7" in Figure 21.20 to the title • Moved "j = 0 to 7" in Table 21.6 to the title • Changed expression "IIO0_j pin function" in Table 21.7 output pin function" • Changed expression "IIO0_j pin function (output)" in Ta and 21.9 to "IIO0_j output pin function" • Deleted "j = 0 to 7" from Case 2 in Figure 21.25 • Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | 300 | • Moved "(j = 0 to 7)" in <b>Figure 21.1</b> to the title; Added definition to BT0R bit | | <ul> <li>• Moved "j = 0 to 7" in Figures 21.18 and 21.19 to the title</li> <li>• Moved "j = 6, 7" in Figure 21.20 to the title</li> <li>• Moved "j = 0 to 7" in Table 21.6 to the title</li> <li>• Changed expression "IIOO_j pin function" in Table 21.7 output pin function"</li> <li>• Changed expression "IIOO_j pin function (output)" in Ta and 21.9 to "IIOO_j output pin function"</li> <li>• Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>• Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | 317 | | | <ul> <li>• Moved "j = 6, 7" in Figure 21.20 to the title</li> <li>• Moved "j = 0 to 7" in Table 21.6 to the title</li> <li>• Changed expression "IIOO_j pin function" in Table 21.7 output pin function"</li> <li>• Changed expression "IIOO_j pin function (output)" in Ta and 21.9 to "IIOO_j output pin function"</li> <li>• Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>• Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | 317 318 | 1 | | <ul> <li>Moved "j = 0 to 7" in Table 21.6 to the title</li> <li>Changed expression "IIO0_j pin function" in Table 21.7 output pin function"</li> <li>Changed expression "IIO0_j pin function (output)" in Ta and 21.9 to "IIO0_j output pin function"</li> <li>Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | | , | | <ul> <li>Changed expression "IIO0_j pin function" in Table 21.7 output pin function"</li> <li>Changed expression "IIO0_j pin function (output)" in Ta and 21.9 to "IIO0_j output pin function"</li> <li>Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | | 1 | | <ul> <li>and 21.9 to "IIO0_j output pin function"</li> <li>Deleted "j = 0 to 7" from Case 2 in Figure 21.25</li> <li>Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively</li> </ul> | | | • Changed expression "IIO0_j pin function" in <b>Table 21.7</b> to "IIO0_j | | • Modified expressions "read out" and "low pulse long" in 21.27 to "read" and "low pulse width", respectively | | 323, 325 | Changed expression "IIO0_j pin function (output)" in <b>Tables 21.8</b> and 21.9 to "IIO0_j output pin function" | | 21.27 to "read" and "low pulse width", respectively | | 330 | • Deleted "j = 0 to 7" from Case 2 in <b>Figure 21.25</b> | | Chanter 22 Serial Rus Interface | | 332 | Modified expressions "read out" and "low pulse long" in Figure 21.27 to "read" and "low pulse width", respectively | | Onapter 22. Ochai Das interiace | | | Chapter 22. Serial Bus Interface | | Made minor text modifications to this chapter | | _ | Made minor text modifications to this chapter | | | | 339 | Corrected a typo "SS0L" in <b>Figure 22.4</b> to "SS0"; Modified description "Output pin level remains changed" for "Function" of SOLD hit to "Output pin level remains were benefit." | | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |------------------|----------------------------------------| |------------------|----------------------------------------| | Rev. | Date | | Description | |---------|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 (G V. | Date | Page | Summary | | | | 343 | • Modified expression "undefined value" for b1 in <b>Figure 22.8</b> to "0"; Moved note symbol "(3)" for ORER bit from function description to bit name; Switched function of "0" and "1" for TDRE bit | | | | 350 | • Modified figure number to refer "Figure 22.15" in last line of <b>22.1.3</b> to "Figure 22.14" | | | | 351 | <ul> <li>Deleted "Abbreviation" column from Table 22.3 and added the abbreviations to each interrupt request source; Added note symbols "(1)" and "(2)" to "Generating Condition for Interrupt Requests", and "CE" bit to Note 2</li> <li>Modified table number to refer "Table 22.4" in line 1 of the second paragraph in 22.1.4 to "Table 22.3"</li> </ul> | | | | 352 | Corrected a typo "SBIMS" in <b>Table 22.4</b> to "SSUMS" | | | | 353 | <ul> <li>Modified figure number to refer "Figure 22.16" in line 1 of 22.1.6.1 to "Figure 22.15"</li> </ul> | | | | 359 | • Added "RE" bit to (5) in Figure 22.20 | | | | 366 | <ul> <li>Modified section number for "SCSi Pin Control and Arbitration"</li> <li>22.1.8 to 22.1.7.4</li> </ul> | | | | 367 | Modified addresses of program example in 22.2.1.1 | | | | | Chapter 23. LIN Module | | | | _ | <ul> <li>Made minor text modifications to this chapter</li> <li>Modified read values for unassigned bits from "undefined value" to "0", and "X" in reset values for unassigned bits to "0"</li> </ul> | | | | 372 | <ul> <li>Modified bit symbol "FLSRC" for LBRG register in Figure 23.4 to<br/>"FLNS"</li> </ul> | | | | 379 | Modified register name "LIN Status Control Command Register" in<br>Figure 23.14 to "LIN Status Control Register" | | | | 382 | Corrected a typo: "LDB0" in the title of Figure 23.18 to "LDB1" | | | | 386, 387 | <ul> <li>Corrected the following typos in (4) and (6) of Table 23.4 and (5) of<br/>Table 23.5: "LiEST register" to "LEST register" and "LiTC register"s<br/>to "LTC register"s, respectively</li> </ul> | | | | 388 | Added Note 3 to Figure 23.23 | | | | 394 | Corrected a typo "LiEST" in line 7 of 23.7.1.1 to "LEST" | | | | 396 | • Revised whole section of 23.8 including Figure 23.30 | | | | 400 | <ul> <li>Modified descriptions "Frame transmit completion flag" and "Frame<br/>receive completion flag" in Figure 23.32 to "Frame/wake-up<br/>transmit completion flag" and "Frame/wake-up receive completion<br/>flag", respectively</li> </ul> | | | | | Chapter 24. CAN Module | | | | _ | <ul> <li>Made minor text modifications to this chapter</li> <li>Modified read values for unassigned bits from "undefined value" to "0"</li> </ul> | | | | 403 | Changed expression "XIN" in Figure 24.1 to "Main clock" | | | | 409 | <ul> <li>Modified reset value "00h" for CiCKLR register in Figure 24.3 to<br/>"000X 0000b"; Changed b4 to undefined value</li> </ul> | | | | 410 | <ul> <li>Corrected a typo "b23-22" for CiBCR register in Figure 24.4 to "b23-b22"; Added description "from CAN reset mode" to Note 1</li> </ul> | | Rev. | Date | | Description | |-----------------|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 <b>\</b> C V. | Date | Page | Summary | | | | 412 | Corrected a typo "47A13h-47E10h" for address of C1MKR4 in Figure 24.5 to "47A13h-47A10h" | | | | 412, 413 | <ul> <li>Changed function for b31 to b29 for CiMKRk in Figure 24.5 and b29 for CiFIDCRn in Figure 24.6 to "Reserved"</li> </ul> | | | | 416 | Changed "*" as multiplication sign in <b>Table 24.4</b> to "x" | | | | 417 | • Changed functions of b29, b32 to b39, and b44 to b47 for CiMBj in <b>Figure 24.8</b> to "Reserved"; Added "b28", "b18", and "b17" to respective bit field box; Corrected a typo "00" for setting values of "DATA0 to DATA7", "TSL", and "TSH" to "00h" | | | | 419 | Changed expression "-" in Table 24.6 to "X" | | | | 421 | <ul> <li>Modified register name "CANi Message Control Register" in the title<br/>of 24.1.9 to "CANi Message Control Register j"</li> </ul> | | | | 423 | • Deleted a part of description in lines 7 and 8 of <b>24.1.9.9</b> | | | | 428 | <ul> <li>Changed "0" for bit field b4 of CiTFCR in Figure 24.14 to "X"</li> <li>Modified a part of description in 24.1.12.2</li> </ul> | | | | 430 | <ul> <li>Corrected a typo "TFE bit in the CiTFPCR register" in line 3 of<br/>24.1.13 to "TFE bit in the CiTFCR register"</li> </ul> | | | | 437 | <ul> <li>Modified "0" for bit fields b3 and b4 of 4th read of CiMSSR register<br/>in Figure 24.21 to "X"</li> </ul> | | | | 438 | • Modified register name "CAFSR" in line 2 of <b>24.1.18</b> to "CiAFSR" | | | | 444, 445 | <ul> <li>Deleted "(8 bits)" from function description for CiRECR and CiTECF<br/>in Figures 24.26 and 24.27</li> </ul> | | | | 452 | Added description "set" to Note 2 for Figure 24.34 | | | | 458 | <ul> <li>Deleted BPR bit from Figure 24.36; Added "P = 0 to 1023" to<br/>definition of setting value P</li> </ul> | | | | 469 | <ul> <li>Moved "CANi wakeup interrupt" from interrupt sources to list of CAN interrupts in 24.7</li> </ul> | | | | | Chapter 25. I/O Pins | | | | _ | Made minor text modifications to this chapter | | | | 472 | Added "b" to all values in <b>Table 25.1</b> | | | | 474, 477 | <ul> <li>Modified description "Serial bus k output" for bits PSEL2 to PSEL0<br/>in Figures 25.4 and 25.7 to "SBIk output"</li> </ul> | | | | 474, 478 | <ul> <li>Modified description "IIOi_j output" for bits PSEL2 to PSEL0 in<br/>Figures 25.4 and 25.8 to "IIOi output"</li> </ul> | | | | 482 | <ul> <li>Corrected a typo: "PD_9i bit" in line 7 below Figure 25.12 to "PD9_<br/>bit"</li> </ul> | | | | 485 | <ul> <li>Changed bit name "Serial Bus i Input Pin Switch Bit" in Figure 25.10 to "SBIi Input Pin Switch Bit" and the description for Note 1</li> <li>Modified description "Do not use this communication" in Figure</li> </ul> | | | | | 25.17 to "Do not use this combination" | | | | | Chapter 26. Flash Memory | | | | _ | <ul> <li>Made major text modifications to this chapter</li> <li>Changed expressions "write" and "rewrite" to "program" when this word is used in combination with "erase"</li> </ul> | | | | | Corrected a typo "read allay" to "read array" | | Boy | Data | | Description | |------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 491 | <ul> <li>Changed the following expressions in Table 26.1: "Operating modes" to "Rewrite modes", "Block formation" to "Structure", "Unit to be programmed" to "Program operation", "Unit to be erased" to "Erase operation", "How to control program and erase" to "Program erase controlled by", and "Protect types" to "Protection types"; Modified specifications; Specified protection types; Deleted row "ROM code protection"</li> </ul> | | | | 493, 494 | • Revised sections 26.2 through 26.2.3 and Table 26.3 | | | | 495 | Changed expressions "Flash rewrite address bus" and "Flash rewrite data bus" in <b>Figure 26.3</b> to "Flash memory rewrite address bus" and "Flash memory rewrite data bus", respectively | | | | 496 | • Revised <b>Table 26.5</b> | | | | 497 | • Added note symbol "(2)" to FEW bit in <b>Figure 26.4</b> ; Changed description "erase/write enable mode" in Note 2 to "program/erase enabled" | | | | 499 | Changed FCA bit names and their function descriptions in <b>Figure</b> 26.7 | | | | 500 | • Corrected a typo "b7-4" for FMR1 register in Figure 26.8 to "b7-b4" | | | | 506 | • Added note symbol "(3)" to "Enter read protect bit status mode" in <b>Table 26.12</b> | | | | 507 | <ul> <li>Modified descriptions "Read lock bit mode" and "Read protect bit mode" in 26.3.3 to "Read lock bit status mode" and "Read protect bit status mode", respectively</li> <li>Corrected a typo "b5-0" in Tables 26.14 and 26.15 to "b5-b0"</li> </ul> | | | | 509 | Changed decision timing of FCA bit in <b>Figure 26.14</b> | | | | 509-513 | • Changed logical value "1" for decision in <b>Figures 26.14 to 26.18</b> to "0" | | | | | • Added description for FCA bit to 26.3.4.4 to 26.3.4.7 and 26.3.4.9 | | | | 510<br>511 | <ul> <li>Corrected a typo "FFFF800h" in line 3 of 26.3.4.5 to "FFFF800h"</li> <li>Corrected a typo "00D0h" in line 2 of 26.3.4.6 to "0077h"; Specified "FFFF800h" as even address</li> </ul> | | | | 514 | <ul> <li>Modified expressions "Status/Error" and "Status check" in Table</li> <li>26.16 and Figure 26.19 to "Error" and "Check status", respectively</li> </ul> | | | | 516 | • Deleted column "Power Supply" from <b>Table 26.18</b> ; Modified "I/O port" for P0_0 to P4_3 to "Input port"; Modified description "P9_0 to P9_7" as input ports to "P9_1, P9_3 to P9_7" | | | | 519 | Changed description "erase/write enable mode" in the second bulled point of 26.6.4 to "program or erase enabled" | | | | | <ul> <li>Modified description "erase operation" in the first bullet point of EW1 mode in 26.6.5 to "block erase operation"</li> <li>Corrected a typo "FMR1 register" in line 5 of the third bullet point of EW1 mode to "FMR0 register"</li> </ul> | | | | | Chapter 27. E <sup>2</sup> PROM Emulation data Flash | | | | _ | <ul> <li>Made minor text modifications to this chapter</li> <li>Changed expressions "write" and "rewrite" to "program" when this word is used in combination with "erase"</li> </ul> | | 1020/1010 Managar Haraware | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |----------------------------|------------------|----------------------------------------| |----------------------------|------------------|----------------------------------------| | Day | Dete | | Description | |------|------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 523 | • Modified setting range "00062000h to 00062FFFh" in <b>Figure 27.6</b> to "00062000h to 00062FFEh" | | | | 524 | Corrected a typo "F2FI Register" in the title of <b>Figure 27.7</b> to "E2FI Register" | | | | 526-528 | Changed Figures 27.10 through 27.13 | | | | 529 | Changed description "erase/write enable mode" in line 2 of 27.4 to "program or erase enabled" | | | | | Chapter 28. Electrical Characteristics | | | | _ | Made minor text modifications to this chapter | | | | 532 | Added description about values as Note 2 and its note symbol to "Value" in Table 28.3 | | | | 533 | Corrected a typo "pots" in the first bullet point in Note 2 for <b>Table</b> 28.4 to "ports" | | | | 535 | • Modified "P9_6" in <b>Table 28.6</b> to "P9_7" | | | | 538 | <ul> <li>Corrected a typo "32 Kbyte block" in Table 28.9 to "32 byte block"</li> <li>Deleted description "the following 10000 hours" from Note 3 for Table 28.9</li> </ul> | | | | | • Deleted "V <sub>CC</sub> = 3.0 to 5.5 V" from "measurement condition" in <b>Table 28.10</b> | | | | 539 | • Changed maximum value for f <sub>SO(PLL)</sub> in <b>Table 28.13</b> from "65" to "80"; Added two measurement conditions | | | | 540 | Changed the order of description of t <sub>rec(STOP)</sub> and t <sub>rec(WAIT)</sub> in <b>Table</b> 28.14 and Figure 28.4 | | | | 544, 554 | Added "XIN" as "Active" to the first, third, and sixth rows of <b>Tables</b> 28.18 and 28.37 | | | | 545 | Modified expression "Sample time" for "Characteristics" in <b>Table</b> 28.19 to "Sampling time" | | | | 549, 559 | • Changed minimum value for "t <sub>W</sub> (ADH)" "2/\$\phi_{AD}\$" in <b>Table 28.30 and</b> 28.49 to "3/\$\phi_{AD}\$" | | | | 549, 560 | Corrected a typo "SSCKI input falling time" in <b>Tables 28.33 and 28.51</b> to "SSCKi input falling time" | | | | 551, 561 | • Modified expression "TXDi hold time" in <b>Tables 28.33 and 28.52</b> to "TXDi output hold time" | | | | 555 | Modified expression "Differential non-linearity" in <b>Table 28.38</b> to "Differential non-linearity error" | | | | 556 | • Corrected the following typos in <b>Table 28.39</b> : "t <sub>W</sub> (H)", "t <sub>W</sub> (L)", "t <sub>r</sub> ", and "t <sub>f</sub> " to "t <sub>W</sub> (XH)", "t <sub>W</sub> (XL)", "t <sub>r</sub> (X)", and "t <sub>f</sub> (X)", respectively | | | | | Chapter 29. Usage Notes | | | | _ | Made minor text modifications to this chapter | | | | 566 | Modified description for 29.2 as 29.2.1 | | | | 567 | Modified addresses of registers from TA1M to TA41M in <b>Table 29.2</b> ; Deleted part of the last rows for C0CSSR and C1CSSR for CAN module | | Davi | Data | | Description | |------|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 568 | <ul> <li>Deleted entire section of "Wait Mode" from 29.3.2.1 and the first<br/>bullet point for "Stop Mode" from previous 29.3.2.2 (current<br/>29.3.2.1)</li> </ul> | | | | 569 | • Corrected typos "PR2 register" in <b>29.4.1</b> and "INTi (i = 0 to 5) pin" in <b>29.4.3</b> to "PM2 register" and "INTi pin (i = 0 to 5)", respectively | | | | 570 | <ul> <li>Modified description "channel i" in line 1 of the first bullet point of 29.5.1 to "DMDi register"; Deleted whole description of the second and third bullet points; Added two new paragraphs</li> <li>Modified description "peripheral clocks" in the fourth bullet point of 29.5.2 to "peripheral bus clocks"</li> </ul> | | | | 571, 572 | • Deleted "(i = 0 to 4)" from line 1 of the first bullet point of 29.6.2.3 and the second bullet point of 29.6.2.4 | | | | 572 | • Added "(i = 0 to 4)" to line 1 of the first bullet point of 29.6.2.4 | | | | 573 | • Replaced variable "i" with "j" in <b>29.6.3.1 and 29.6.3.2</b> ; Added "(j = 0 to 5)" to the first bullet point of <b>29.6.3.1</b> | | | | 575 | Deleted whole description from the third bullet point of 29.8.3.2 | | | | 577 | • Changed description "AD0i register" in last line of the seventh bullet point in <b>29.9.2</b> to "AD00 register"; Deleted "(i=0 to 7)" from line 2 of the eighth bullet point; Added description to the ninth bullet point | | | | 578 | Modified addresses of program example in 29.10.1.1 | | | | 579 | Changed description "erase/write enable mode" in the second bullet point of 29.11.4 to "program or erase enabled" | | | | | <ul> <li>Modified description "erase operation" in the first bullet point of EW1 mode in 29.11.5 to "block erase operation"</li> <li>Corrected a typo "FMR1 register" in line 5 of the third bullet point of</li> </ul> | | | | 581 | EW1 mode to "FMR0 register" • Changed description "erase/write enable mode" in line 2 of <b>29.12</b> to | | | | 301 | "program or erase enabled" | | 1.20 | Jul 04, 2012 | | Third edition released | | | | | This manual in general | | | | _ | Applied new Renesas templates and formats to the manual | | | | | Changed company name to "Renesas Electronics Corporation" and changed related descriptions due to business merger of Renesas Technology Corporation and NEC Electronic Corporation Changed document number "REJ09B0517-0102" to | | | | | "R01UH0226EJ0120" • Modified the following expressions: "version J", "version L", and | | | | | "version K" to "J version", "L version", and "K version", respectively (under Chapters 1 and 28) | | | | | Modified expressions "a write" to "a write operation", "calculation transfer" to "calculation result transfer", and "chained transfer" to "chain transfer" | | | | | Chapter 1. Overview | | | | _ | Modified wording and enhanced description in this chapter | | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |------------------|----------------------------------------| |------------------|----------------------------------------| | Rev. | Data | | Description | |------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 2 | <ul> <li>Modified expressions "Main clock oscillator stop/re-oscillation<br/>detection", "calculation transfer", "chained transfer", and "inputs/<br/>outputs" in Table 1.1 to "Main clock oscillator stop/restart detection",<br/>"calculation result transfer", "chain transfer", and "I/O ports",<br/>respectively</li> </ul> | | | | 4 | Completed all "under development" phases in Table 1.3 | | | | 7 | Changed order of signals in Figure 1.3 | | | | 9 | • Changed order of timer pins "TA4IN/Ū/TB1IN" in <b>Table 1.5</b> to "TA4IN/TB1IN/Ū" | | | | 10 | Modified expression "fC" in <b>Table 1.6</b> to "low speed clocks" | | | | | Chapter 2. CPU | | | | | Modified wording and enhanced description in this chapter | | | | 13 | • Corrected a typo "R3R0" in line 3 of <b>2.1.1</b> to "R3R1" | | | | | Chapter 3. Memory | | | | | Modified wording and enhanced description in this chapter | | | | | Chapter 4. SFRs | | | | _ | Made minor text modifications to this chapter | | | | 23 | Changed hexadecimal format of reset value for G0BCR0 register in | | | | | <b>Table 4.7</b> to binary; Changed register name "Group 0 Timer Measurement Prescaler Register" to "Group 0 Time Measurement Prescaler Register" | | | | 26 | Modified expression "XY Control Register" in <b>Table 4.10</b> to "X-Y Control Register" | | | | 28 | Changed register names "UART2 Transmission/Receive Mode<br>Register" and "Increment/Decrement Counting Select Register" in<br>Table 4.12 to "UART2 Transmit/Receive Mode Register" and<br>"Increment/Decrement Select Register", respectively; Changed<br>hexadecimal format of reset values for registers TABSR, ONSF, and<br>TRGSR to binary | | | | 35 | Corrected reset value "X000 X000b" for IFS0 register in <b>Table 4.19</b> to "X0X0 X000b" | | | | 38 | Changed register name "External Interrupt Source Select Register 0" in <b>Table 4.22</b> to "External Interrupt Request Source Select Register 0" | | | | 52, 53, 66, | Changed register name "CANi Acceptance Mask Register k" in | | | | 67 | <b>Tables 4.36, 4.37, 4.50, and 4.51</b> to "CANi Mask Register k" | | | | 55, 69 | <ul> <li>Changed register names "CANi Reception Error Count Register" and "CANi Transmission Error Count Register" in Tables 4.39 and 4.53 to "CANi Receive Error Count Register" and "CANi Transmit Error Count Register", respectively; Corrected reset value "XXXX XX00b" for CiMSMR register to "0000 0000b"</li> </ul> | | | | | Chapter 5. Resets | | | | _ | Modified wording and enhanced description in this chapter | | | | 70 | <ul> <li>Changed expression "operating level" in (2) of B in 5.1 to "operating voltage"</li> </ul> | | | | | Chapter 6. Power Management | | | | | Modified wording and enhanced description in this chapter | | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |------------------|----------------------------------------| |------------------|----------------------------------------| | Rev. | Date | | Description | |-------|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IXEV. | Date | Page | Summary | | | | 74<br>77 | <ul> <li>Modified descriptions "main clock oscillator active" and "PLL clock oscillator active" in Note 2 of Figure 6.2 to "main clock oscillator enabled" and "PLL oscillator enabled"</li> <li>Modified VDEN bit name in Figure 6.4 to "Low Voltage Detector</li> </ul> | | | | | Enable Bit"; Modified its function descriptions "low voltage detection disabled" and "low voltage detection enabled" to "low voltage detector disabled" and "low voltage detector enabled", respectively | | | | | Chapter 7. Clock Generator | | | | _ | <ul> <li>Modified wording and enhanced description in this chapter</li> <li>Modified function descriptions of bits CM05 and CM10 to the following: "main clock oscillator enabled", "main clock oscillator disabled", "PLL oscillator enabled", and "PLL oscillator disabled"</li> </ul> | | | | 82 | <ul> <li>Modified expression "fC" in Figure 7.1 to "Low speed clock"; Added<br/>BCS bit</li> </ul> | | | | 83 | <ul> <li>Deleted the last sentence from Note 2 in Figure 7.2; Added<br/>description for bit settings to Note 6</li> </ul> | | | | 84 | <ul> <li>Changed expression "fC" in Figure 7.3 to "a low speed clock";</li> <li>Added Note 7</li> </ul> | | | | 85 | <ul> <li>Modified CM10 and CM15 bit names "PLL Clock Oscillator Stop Bit"<br/>and "XIN-XOUT Drive Power Select Bit" in Figure 7.4 to "PLL<br/>Oscillator Stop Bit" and "XIN-XOUT Drive Strength Select Bit";<br/>Modified description of Note 2; Added Note 4</li> </ul> | | | | | <ul> <li>Modified function descriptions of CM20 bit in Figure 7.5 to "Disable<br/>oscillator stop detection" when it is 0 and "Enable oscillator stop<br/>detection" when it is 1; Corrected "CM02 bit" in Note 3 to "CM20 bit"</li> </ul> | | | | 86 | Modified description of Note 1 in Figure 7.6 | | | | 88 | <ul> <li>Modified the following descriptions in Note 3 in Figure 7.9: "start<br/>main clock oscillator running" for CM05 bit to "main clock oscillator<br/>enabled/disabled" and "start PLL clock oscillator running" for CM10<br/>bit to "PLL oscillator enabled/disabled"; Added Note 6</li> </ul> | | | | 89 | Added description to Note 1 in Figure 7.10 | | | | 93 | <ul> <li>Changed SEO bit name and its function description in Figure 7.15</li> <li>Added Note 1 to Figure 7.16</li> </ul> | | | | 95 | Modified the last sentence in 7.1.4 | | | | 96 | <ul> <li>Deleted the last sentence in parenthesis in 7.2</li> <li>Added description of stopping main clock to lines 6 to 7 of 7.2.1</li> </ul> | | | | 98, 106, 109 | • Modified expression "fC" in line 1 of <b>7.6</b> to "Low speed clocks" and "fC" in <b>Tables 7.3</b> , <b>7.4</b> , <b>and 7.6</b> to "a low speed clock" | | | | 99 | Revised the entire paragraph of 7.7 | | | | 100 | • Revised 7.7.1 entirely | | | | 102-104 | • Moved Figures 7.18 to 7.20 into 7.7.1 | | | | 102 | <ul> <li>Corrected a typo "f(XPLL)" in the third row of Figure 7.18 to<br/>"f(PLL)"; Deleted Note 4</li> </ul> | | | | 103 | • Corrected a typo "CM0 = 1" in the fifth row of <b>Figure 7.19</b> to "CM05 = 1"; Deleted Note 3 | | 1020/1010 Managar Haraware | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |----------------------------|------------------|----------------------------------------| |----------------------------|------------------|----------------------------------------| | | D ( | | Description | |------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 104 | Corrected "CM31 = 1" in the first row and "CM10 = 0" for "Low | | | | | speed mode" in the second row of Figure 7.20 to "CM31 = 0" and | | | | | "CM10 = 1", respectively; Deleted Note 3 | | | | 105 | Modified descriptions in lines 1 to 3 of 7.7.2 | | | | | Added description "in wait mode" to line 3 of 7.7.2.1 | | | | 106 | • Revised <b>7.7.2.4</b> | | | | 108 | Modified description of line 1 of 7.7.3 | | | | 109 | Added interrupt numbers from 0 to 63 to line 2 of 7.7.3.3 as factors | | | | | of exiting stop mode | | | | | Chapter 8. Bus | | | | | Made minor text modifications to this chapter | | | | | Chapter 9. Protection | | | | _ | Modified wording and enhanced description in this chapter | | | | | Changed title of each section in this chapter | | | | | Chapter 10. Interrupts | | | | _ | Modified wording and enhanced description in this chapter | | | | 118 | Modified description of Note 1 in Figure 10.1 | | | | 119 | Modified descriptions in the second paragraph in (5) of 10.2 | | | | 121, 122, | Modified description of jump operation in 10.5, Table 10.1, and | | | | 129 | below Figure 10.4 | | | | 132 | Moved description of Note 1 to (2) of 10.6.4 | | | | 133 | Modified description of Note 1 of Table 10.7 | | | | 136 | • Changed expression "Serial bus 0" in Figure 10.8 to "Serial bus | | | | | interface 0"; Deleted "Bits RLVL2 to RLVL0 in the RIPL2 register" | | | | | and associated signal lines; Changed expression "DMAC II" to "DMA II transfer complete" | | | | 139 | Corrected register symbol "IIOiE" in 10.12 to "IIOiIE" | | | | 140 | <ul> <li>Changed function description of b0 in Figure 10.13; Modified<br/>description in Note 3</li> </ul> | | | | | Chapter 11. Watchdog Timer | | | | _ | Modified wording and enhanced description in this chapter | | | | 143 | • Modified description of lines 4 to 5 in 11. Watchdog Timer; | | | | | Corrected register symbol "WKD" in line 9 to "WDK"; Modified CPU clock frequency to "48 MHz" and watchdog timer period to "21.8 ms" | | | | 144 | • Added Notes 1 and 2 to Figure 11.2 | | | | 145 | • Added Note 2 to Figure 11.3 | | | | 146 | Added Note 3 to Figure 11.5 | | | | | Chapter 12. DMAC | | | | - | Modified wording and enhanced description in this chapter | | | | 148 | Modified descriptions of timer- and UART-associated interrupt | | | | | requests in "DMA request sources" in Table 12.1; Modified | | | | | expression "DMA transfer startup" to "DMA transfer start-up"; | | | | | Modified description "more than 00000001h" in "DMA transfer start- | | | | 450 | up" to "other than 00000000h" | | | | 156 | Modified descriptions in 12.1 | | 1020/1010 Managar Haraware | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |----------------------------|------------------|----------------------------------------| |----------------------------|------------------|----------------------------------------| | Rev. | Date | | Description | |-------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1164. | Date | Page | Summary | | | | | Chapter 13. DMAC II | | | | _ | Modified wording and enhanced description in this chapter | | | | 162 | <ul> <li>Corrected source address "FFFFFFh" in Note 1 of Table 13.1 to<br/>"FFFFFFFh"</li> </ul> | | | | | • Corrected bit symbol "IIRLT" in the fifth bullet point of <b>13.1</b> to "IRLT" | | | | 164, 165 | <ul> <li>Changed expression "DMA II transfer complete interrupt vector<br/>address" in lines 3 to 4 and the seventh bullet point of 13.1.2 and<br/>Figure 13.2 to "jump address for the DMA II transfer complete<br/>interrupt handler"</li> </ul> | | | | 164, 167 | <ul> <li>Modified expression "interrupt vector" in Figure 13.2 and line 1 of<br/>13.1.4 to "interrupt vector space"</li> </ul> | | | | 165 | <ul> <li>Changed description "jump address" in the seventh bullet point of<br/>13.1.2 to "start address"</li> </ul> | | | | 166 | Changed bit names of OPER bit and bits CNT2 to CNT0 in <b>Figure</b> 13.3 to "Calculation Result Transfer Select Bit" and "Number of Transfers Setting Bit", respectively | | | | 170 | Modified descriptions in Figure 13.5 | | | | | Chapter 14. Programmable I/O Ports | | | | | Modified wording and enhanced description in this chapter | | | | | Chapter 15. Timers | | | | | Modified wording and enhanced description in this chapter | | | | 175 | Separated signal for overflow or underflow from interrupt signal in Figure 15.2 | | | | 179 | • Deleted "Counting" from UDF register name and bit names of bits TA4UD to TA0UD in <b>Figure 15.7</b> | | | | 187 | Changed MR2 bit name "Increment/Decrement Count Switching Source Select Bit" in <b>Figure 15.12</b> to "Increment/Decrement Switching Source Select Bit"; Corrected bit symbols "TAiTGH and TAiTGL" in Note 5 to "TAjTGH and TAjTGL" | | | | 189 | • Corrected a typo "TA4NR" in line 3 of <b>15.1.3</b> to "TA4MR" | | | | 207 | Modified description in 15.3.3.1 | | | | | • Modified description "TBjS bit" in the first bullet point of <b>15.3.3.2</b> to "TBjS bit in the TABSR or TBSR register"; Modified "TBj" in the Eighth bullet point to "timer Bj" | | | | | Chapter 16. Three-phase Motor Control Timers | | | | _ | Modified wording and enhanced description in this chapter | | | | 211 | • Changed function descriptions "Timer A reload control signal is 0" and "Timer A reload control signal is 1" for INV13 bit in <b>Figure 16.3</b> to "Timer A1 reload control signal is 0" and "Timer A1 reload control signal is 1", respectively; Modified Note 1 | | | | 215 | Changed bit functions of bits MR2 and MR3 for TB2MR register in Figure 16.8 | | | | 216 | Changed function description of PWCON bit for TB2SC register in Figure 16.9 | | | | 217 | • Deleted description in lines 8 to 9 of <b>16.3</b> ; Added "TA4M" to line 10 | | | | 222 | • Corrected bit symbol "INV06" in Note 3 of Figure 16.16 to "INV16" | | 1020/1010 Managar Haraware | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |----------------------------|------------------|----------------------------------------| |----------------------------|------------------|----------------------------------------| | Day | Data | | Description | |------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 223 | Corrected register symbol "INV1" in Note 2 of <b>Figure 16.18</b> to "INVC1" | | | | 225 | Added description of SDE bit to 16.6.1; Modified text representation | | | | | Modified "overflow" in 16.6.2 to "underflow" | | | | | Chapter 17. Serial Interface | | | | _ | Modified wording and enhanced description in this chapter | | | | 231, 232 | Modified CRD bit name in <b>Figures 17.5 and 17.6</b> to "CTS Function Disable Bit"; Modified their function descriptions | | | | 231 | Deleted Note 1 from Figure 17.5 | | | | 233 | • Modified bit description of UiIRS bit when it is 0 in <b>Figure 17.7</b> to "Transmit buffer is empty (TI = 1)"; Modified bit name of UiLCH bit to "Logic Inversion Select Bit" | | | | 235 | Modified CSC bit name in <b>Figure 17.11</b> to "Clock Synchronization<br>Bit"; Deleted "of the SCLi" from function description of SWC bit | | | | 236 | • Corrected "UiBRG count source" in function description of bits DL2 to DL0 in <b>Figure 17.12</b> to "baud rate generator count source" | | | | 237 | <ul> <li>Deleted "of the SCLi" from function description of SWC9 bit in<br/>Figure 17.13</li> </ul> | | | | 237, 263 | • Corrected a typo "STARREQ" in Note 3 of <b>Figure 17.13</b> and in line 1 of <b>17.3.2</b> to "STAREQ" | | | | 243 | <ul> <li>Modified "TXEPT flag" in Figure 17.18 to "TXEPT bit"; Corrected bit<br/>symbol "UiRS" in the fourth dash to "UilRS"</li> </ul> | | | | 251, 252 | Corrected bit functions of UiIRS bit in the fourth dash in Figures 17.23 and 17.24 | | | | 255, 256 | Changed expression "Transmit/receive clock" in Figures 17.27 and 17.28 to "CLKi" | | | | 260, 261 | • Divided Table 17.11 into Tables 17.11 and 17.12 | | | | 273 | Moved description in the fourth dash in 17.5.3.1 to the second dash | | | | 274 | Added a new paragraph for "Reset Procedure on Communication<br>Error" as 17.5.5 | | | | | Chapter 18. A/D Converter | | | | _ | Modified wording and enhanced description in this chapter | | | | 280 | Modified expression "sample & hold function" in function description of SMP bit in <b>Figure 18.4</b> to "sample and hold function" | | | | 282 | Modified "DMA" in Note 4 of Figure 18.7 to "DMAC" | | | | 284, 286, | Modified "DMA" in the first bullet point in "Reading A/D converted | | | | 287 | result" of <b>Tables 18.3, 18.5, and 18.6</b> to "DMAC" | | | | 287 | <ul> <li>Modified description of the number of prioritized pins in line 1 of<br/>18.1.5 and "Function" in Table 18.6</li> </ul> | | | | 289 | • Deleted description "(AN0 to AN7, ANEX0, ANEX1 as analog input port)" from line 10 of <b>18.2.6</b> | | | | 294 | Corrected "AD0i" in the ninth bullet point of 18.3.2 to "AD00" | | | | | Chapter 19. CRC Calculator | | | | _ | Made minor text modifications to this chapter | | | | 295 | Corrected a typo "CRC_CCITT" in line 2 of 19. CRC Calculator to "CRC-CCITT" | | D | Data | | Description | |------|------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | 295 | Modified Figure 19.1 | | | | | Chapter 20. X-Y Conversion | | | | _ | Made minor text modifications to this chapter | | | | | Chapter 21. Intelligent I/O | | | | _ | Modified wording and enhanced description in this chapter | | | | 303 | • Changed expression "the $\overline{\text{INT0}}$ pin" in <b>Figure 21.1</b> to "the $\overline{\text{INT0}}$ pin or the $\overline{\text{INT1}}$ pin" | | | | 306 | Changed expression "INT0 pin" in Figure 21.4 to "INT0/INT1 pin";<br>Changed bit name of bits UD1 and UD0 "Increment/Decrement<br>Counting Control Bit" to "Increment/Decrement Control Bit"; Added Note 2 | | | | 307 | Deleted Note 3 from Figure 21.5 | | | | 314 | <ul> <li>Modified descriptions of "Reset Conditions" in Table 21.2; Changed<br/>description of the timer counter to start decrementing in the first<br/>bullet point of "Other functions"</li> </ul> | | | | 315 | • Changed expression "INTO pin" in Figure 21.14 to "INTO/INT1 pin" | | | | 318 | • Changed expression "INT0" in Figure 21.17 to "INT0/INT1" | | | | 322 | • Moved "k = 4, 5" in <b>Figure 21.20</b> to its figure title | | | | 325, 327,<br>330 | • Modified "Input to the IIO0_j pin" in <b>Figures 21.21 to 21.23</b> to "IIO0_j pin" | | | | 328, 329 | Divided Table 21.9 into Tables 21.9 and 21.10 | | | | | Chapter 22. Serial Bus Interface | | | | _ | Modified wording and enhanced description in this chapter | | | | 336 | Corrected a typo "SBUMS bit" in 22. Serial Bus Interface to "SSUMS bit" | | | | 337, 339 | Corrected typos "SS0CK pin" and "SS0RDR register" in <b>Tables 22.1</b> and <b>22.2</b> to "SSCK0 pin" and "SS0TDR register", respectively | | | | 339 | • Modified "SSI0 (I): Data input pin" and "SSO0 (O): Data output pin" in <b>Table 22.2</b> to "SSI0 (I/O): Data I/O pin" and "SSO0 (I/O): Data I/O pin", respectively | | | | 341 | • Corrected "b6 b5 b4" in "Function" of bits CKS2 to CKS0 in <b>Figure 22.3</b> to "b2 b1 b0" | | | | 343 | <ul> <li>Added description "Bits left during transmission/reception" to<br/>"Function" of bits BC2 to BC0 in Figure 22.5</li> </ul> | | | | 347 | Modified expressions "input/output pin" and "Input/output pin" in<br>Figure 22.9 to "I/O pin" | | | | 363 | <ul> <li>Corrected bit symbol "MSL" in line 14 of 22.1.7 to "MLS"</li> <li>Modified "flags RDRF and ORER" in line 5 of 22.1.7.1 to "bits RDRF and ORER"</li> </ul> | | | | | Chapter 23. LIN Module | | | | _ | Modified wording and enhanced description in this chapter | | | | 371 | Modified descriptions "Break dominant" and "Break delimiter" in<br>Table 23.1 to "Transmit break length" and "Transmit break delimiter<br>length", respectively | | | | 372 | Modified pin names "LINOUT" and "LININ" in Figure 23.1 to "LINOUT" and "LINOIN", respectively | | | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |--|------------------|----------------------------------------| |--|------------------|----------------------------------------| | Rev. | Date | Description | | |------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Rev. | | Page | Summary | | | | 375 | Added Note 1 to Figure 23.3 | | | | 377 | Changed Note 4 in Figure 23.7 | | | | 380 | <ul> <li>Modified bit names for bits BLT3 to BLT0 and bits BDT1 and BDT0<br/>in Figure 23.10 to "Transmit Break (Low) Length Setting Bit" and</li> </ul> | | | | 383 | <ul> <li>"Transmit Break Delimiter (High) Length Setting Bit", respectively</li> <li>Corrected reset value of LSC register in Figure 23.14 to "0000 0000b"; Changed bit name of bits OM1 and OM0 to "Operating Mode Select Bit"; Modified function description of b7 to b2</li> </ul> | | | | 385 | <ul> <li>Changed bit name of bits OMM1 and OMM0 in Figure 23.16 to<br/>"Operating Mode Monitor Flag"; Added description to Note 1; Added<br/>Note 3</li> </ul> | | | | 386 | Added description to Note 1 in Figure 23.17 | | | | 389 | • Modified description of the third bullet point in <b>Table 23.3</b> ; Modified bit symbols "BFTL3 to BFTL0" and "BFTD1 and BFTD0" to "BLT3 to BLT0" and "BDT1 and BDT0", respectively | | | | 390, 391 | Changed (4) for "LIN Module Processing" in Tables 23.4 and 23.5 | | | | 393 | Corrected a typo "BPR0" in Note 1 of <b>Table 23.6</b> to "BRP0" | | | | 400 | • Revised Figure 23.30 | | | | 401 | <ul> <li>Added detecting condition to "Input signal low detection" in Table</li> <li>23.8</li> </ul> | | | | 404 | Added description to lines 9 to 10 in 23.11 | | | | | Modified Figures 23.32 and 23.33 | | | | | Chapter 24. CAN Module | | | | _ | Modified wording and enhanced description in this chapter | | | | | Changed expression "8/3 encoder" to "8-to-3 priority encoder" | | | | 405 | • Modified "Table 24.1" in line 5 of <b>24. CAN Module</b> to "Tables 24.1 and 24.2" | | | | 409 | • Modified RBOC bit name in <b>Figure 24.2</b> to "Forced Recovery From Bus-off Bit"; Modified its function description | | | | 417 | Modified Note 2 in Figure 24.6 | | | | 421 | Modified Note 4 in Figure 24.8 | | | | 426 | Corrected "fCAN (CAN system clock)" in line 4 of 24.1.9.5 to "the peripheral bus clock" | | | | 428 | Changed description of Note 2 in Figure 24.11 | | | | 429 | • Corrected "fCAN" in line 5 of <b>24.1.10.3</b> to "the peripheral bus clock" | | | | 435 | • Changed function description of b7 in <b>Figure 24.17</b> to "No register bit; this bit is read as 0" | | | | 442 | • Changed expression "3/8 decoder" in <b>Figure 24.23</b> to "3-to-8 decoder"; Moved "(j = 0 to 31)" to its figure title | | | | 450 | Moved footnote "(4)" from "Bit Name" to "Function" in Figure 24.28 | | | | 459 | • Changed expression "MCU hardware reset or software reset" in line 2 of <b>24.2.3</b> to "a MCU reset" | | | | 460 | Corrected a typo "CiSTR" in the third bullet point of the third paragraph of 24.2.4 to "CiTCR" | | | | 462 | • Corrected q value in <b>Figure 24.36</b> to "q = 2, 3, 4" | | Boy | Date | Description | | | |------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Rev. | | Page | Summary | | | | | 468 | • Moved "(j = 0 to 31)" and "(k = 0 to 7)" in <b>Figure 24.42</b> to its figure | | | | | | title | | | | | 470-472 | • Moved "(j = 0 to 31)" in <b>Figures 24.43 to 24.45</b> to their figure titles | | | | | | Chapter 25. I/O Pins | | | | | _ | Modified wording and enhanced description in this chapter | | | | | 474 | • Deleted ASEL from a factor of pull-up resistor being separated from peripheral functions in 25. I/O Pins and Figure 25.1 | | | | | | <ul> <li>Modified descriptions "has neither the bit 5 of the function select<br/>register nor the PDi register" in lines 10 to 11 and "The bit 1 of the<br/>function select register and the PDi register" in lines 11 to 12 below<br/>Figure 25.1 to "has no function select register or bit 5 in the PD8</li> </ul> | | | | | | register" and "The function select register and bit 1 in the PD9 register", respectively | | | | | 478 | <ul> <li>Corrected reset values of registers P1_0S to P1_4S "XXXX X000b" in Figure 25.4 to "0XXX X000b"</li> </ul> | | | | | 478, 482 | Changed expression "IIO0 output" in Figures 25.4 and 25.8 to "IIO0_i output" | | | | | 480 | • Corrected description "PD3_i register" in line 4 below <b>Figure 25.6</b> to "PD3_i bit" | | | | | 484 | • Corrected addresses of registers P7_4S to P7_6S in <b>Figure 25.10</b> to "400D9h", "400DBh", "400DDh" | | | | | 489 | Modified expression "serial bus 0" in function description for IFS50 bit in Figure 25.16 to "SBI0" | | | | | | Chapter 26. Flash Memory | | | | | _ | Modified wording and enhanced description in this chapter | | | | | 497 | • Deleted descriptions "erase" and "by using the serial programmer" from "ROM Code Protection" in <b>Table 26.3</b> ; Added "erase" to "ID Code Protection" | | | | | | <ul> <li>Deleted description "use the serial programmer" from line 3 of<br/>26.2.2</li> </ul> | | | | | 498 | Assigned "OFS" to the reserved ID code area in address FFFFFEFh in <b>Figure 26.2</b> ; Added Note 1 | | | | | 500 | Changed the following expressions in <b>Table 26.5</b> : "the program or the block erase command" to "the program command or the block erase command" and "the read status register command" and "the ready status register command" to "the enter read status register mode command" | | | | | 506, 508 | Changed expressions "CS0" and "A23 to A0, BC3 to BC0" in Figures 26.12 and 26.13 to "Chip select" and "Address", respectively | | | | | 524 | • Modified descriptions of the first bullet points in 26.6.7 and 26.6.8 | | | | | | Chapter 27. E <sup>2</sup> PROM Emulation Data Flash | | | | | _ | Modified wording and enhanced description in this chapter | | | | | 526 | <ul> <li>Added description to Note 3 of Figure 27.2; Deleted description<br/>from Note 5</li> </ul> | | | | | 532 | • Modified description for EERR bit setting in <b>Figure 27.12</b> to "EERR bit in the E2FS0 register is 0?" | | | REVISION HISTORY | R32C/161 Group User's Manual: Hardware | |------------------|----------------------------------------| |------------------|----------------------------------------| | Dov | Data | Description | | |------|------|-------------|------------------------------------------------------------------------------------------------------| | Rev. | Date | Page | Summary | | | | | Chapter 28. Electrical Characteristics | | | | _ | Modified wording and enhanced description in this chapter | | | | | Changed expression "clock period" to "clock cycle time" | | | | 541, 542 | Changed expression "Programming and erasure endurance" in | | | | | Tables 28.8 and 28.9 to "Program/erase cycles"; Changed its unit | | | | | "times" to "Cycles" | | | | 545 | • Changed expressions "CS0" and "A23 to A0, BC0 to BC3" in Figure | | | | | 28.5 to "Chip select" and "Address", respectively | | | | 547, 557 | Modified "LININ" in Tables 28.17 and 28.36 to "LIN0IN" | | | | 553, 563 | Corrected "INTi" in the title of <b>Tables 28.31 and 28.50</b> to "INTi" | | | | | Chapter 29. Usage Notes | | | | _ | Modified wording and enhanced description in this chapter | | | | 570, 571 | Changed orders of Tables 29.1 and 29.2 | | | | 577 | Modified description in 29.6.3.1 | | | | | Modified description "TBjS bit" in the first bullet point of 29.6.3.2 to | | | | | "TBjS bit in the TABSR or TBSR register"; Modified "TBj" in the | | | | | Eighth bullet point to "timer Bj" | | | | 578 | • Added description of SDE bit to 29.7.1; Modified text representation | | | | | Modified "overflow" in 29.7.2 to "underflow" | | | | 579 | Moved description the fourth dash in 29.8.3.1 to the second dash | | | | 580 | <ul> <li>Added a new paragraph for "Reset Procedure on Communication<br/>Error" as 29.8.5</li> </ul> | | | | 582 | Corrected "AD0i" in the ninth bullet point of 29.9.2 to "AD00" | | | | 585 | • Modified descriptions of the first bullet points in 29.11.7 and 29.11.8 | | | | | Appendix 1. Package Dimensions | | | | 587 | Added a seating plane to the drawing of package dimension | R32C/161 Group User's Manual: Hardware Publication Date: Rev.0.51 Dec 24, 2008 Rev.1.20 Jul 04, 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 R32C/161 Group