# Hitachi Single-Chip Microcomputer # H8/3664 Series H8/3664 HD6433664 H8/3663 HD6433663 H8/3662 HD6433662 H8/3661 HD6433661 H8/3660 HD6433660 H8/3664F-ZTAT<sup>TM</sup> Hardware Manual ADE-602-202A Rev. 2.0 9/25/00 Hitachi, Ltd. #### **Cautions** - Hitachi neither warrants nor grants licenses of any rights of Hitachi's or any third party's patent, copyright, trademark, or other intellectual property rights for information contained in this document. Hitachi bears no responsibility for problems that may arise with third party's rights, including intellectual property rights, in connection with use of the information contained in this document. - Products and product specifications may be subject to change without notice. Confirm that you have received the latest product standards or specifications before final design, purchase or use. - 3. Hitachi makes every attempt to ensure that its products are of high quality and reliability. However, contact Hitachi's sales office before using the product in an application that demands especially high quality and reliability or where its failure or malfunction may directly threaten human life or cause risk of bodily injury, such as aerospace, aeronautics, nuclear power, combustion control, transportation, traffic, safety equipment or medical equipment for life support. - 4. Design your application so that the product is used within the ranges guaranteed by Hitachi particularly for maximum rating, operating supply voltage range, heat radiation characteristics, installation conditions and other characteristics. Hitachi bears no responsibility for failure or damage when used beyond the guaranteed ranges. Even within the guaranteed ranges, consider normally foreseeable failure rates or failure modes in semiconductor devices and employ systemic measures such as fail-safes, so that the equipment incorporating Hitachi product does not cause bodily injury, fire or other consequential damage due to operation of - 5. This product is not designed to be radiation resistant. the Hitachi product. - 6. No one is permitted to reproduce or duplicate, in any form, the whole or part of this document without written approval from Hitachi. - 7. Contact Hitachi's sales office for any questions regarding this document or Hitachi semiconductor products. ### **Preface** The H8/3664 Series of single-chip microcomputers has the high-speed H8/300H CPU at its core, with many necessary peripheral functions on-chip. The H8/300H CPU instruction set is compatible with the H8/300 CPU. The H8/3664 Series includes such peripheral functions as four timers, an I<sup>2</sup>C bus interface, a serial communication interface, and a 10-bit A/D converter, so that they can be used as an embedded microcomputer for a sophisticated control system. This manual describes the hardware of the H8/3664 Series. For details on the H8/3664 Series instruction set, refer to the H8/300H Series Programming Manual. #### Notes: When using an on-chip emulator (E10T) for H8/3664 program development and debugging, the following restrictions must be noted. - 1. The $\overline{\text{NMI}}$ pin is reserved for the E10T, and cannot be used. - 2. Pins P85, P86, and P87 cannot be used. (In order to use these pins, additional hardware must be provided on the user board.) - 3. Area H'7000 to H'7FFF is used by the E10T, and is not available to the user. - 4. Area H'F780 to H'FB7F must on no account be accessed. - 5. When the E10T is used, address breaks can be set as available to the user, or for use by the E10T. If address breaks are set as being used by the E10T, the address break control registers must not be accessed. - 6. When the E10T is used, $\overline{\text{NMI}}$ is an input/output pin (open-drain in output mode), P85 and P87 are input pins, and P86 is an output pin. # Main Revisions and Additions in this Edition | Page | Item | Description | |--------|--------------------------------------------------------------------------------------------|----------------------------------------| | 4 | Figure 1.1 Block Diagram | TEST pin is amended to TEST pin | | 43 | 2.9.2 Notes on Bit Manipulation | Example 1 description added | | 54 | 3.4.2 Interrupt Edge Select Register 2 (IEGR2) | Bit 5 description amended | | 79 | Figure 5.9 Pin Connection when not Using Subclock | Figure amended | | 88 | Table 6.3 Transition Mode after the SLEEP Instruction Execution and Interrupt Handling | *1 description changed | | 102 | Figure 7.4 User Program Mode | Figure amended | | 122 | 7.9 Flash Memory and Power-Down States | Description amended | | | Table 7.10 Flash Memory Operating States | | | 179 | Figure 11.2 Increment Timing with Internal Clock | Figure amended | | 281 | 14.5.1 Data Transfer Format | 1st line, reference figure No. amended | | 322 | Figure 15.5 I <sup>2</sup> C Bus Timing | R/W is amended to $R/\overline{W}$ | | 322 to | 15.3.2 Master Transmit Operation | Description changed | | 324 | Figure 15.6 Example of Master Transmit Mode Operation Timing (MLS = WAIT = 0) | Figure amended | | 324 to | 15.3.3 Master Receive Operation | Description changed | | 326 | Figure 15.7 Example of Master Receive Mode Operation Timing (1) (NLS = ACKB = 0, WAIT = 1) | Figure amended | | | Figure 15.7 Example of Master Receive Mode Operation Timing (2) (NLS = ACKB = 0, WAIT = 1) | | | 326 | 15.3.4 Slave Receive Operation | R/W is amended to R/ $\overline{W}$ | | 327 | Figure 15.8 Example of Slave Receive Mode Operation Timing (1) (MLS = ACKB = 0) | R/W is amended to R/W | | 328 | 15.3.5 Slave Transmit Operation | Description amended | | 329 | Figure 15.10 Example of Slave Transmit Mode Operation Timing (MLS = 0) | R/W is amended to R/W | | 332 | Figure 15.13 Flowchart for Master Transmit Mode (Example) | Flowchart changed | | 333 | Figure 15.14 Flowchart for Master Receive Mode (Example) | Flowchart changed | | Page | Item | Description | |---------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | 339, | 15.4 Usage Notes | Description added | | 340 | <ul> <li>Notes on Start Condition Issuance for<br/>Retransmission</li> </ul> | | | | Figure 15.17 Flowchart and Timing of Start Condition Instruction Issuance for Retransmission | | | 348 | 16.2.3 A/D Control Register (ADCR) | Bit 7 Note added | | 367 | Table 18.2 DC Characteristics (2) | Conditions changed | | 370 | Table 18.4 I <sup>2</sup> C Bus Interface Timing | Symbol in SCL and SDA output fall time amended | | 372,<br>373 | Table 18.6 A/D Converter Characteristics | Min Value in AVcc amended<br>Test Condition of Conversion time<br>(single mode) amended | | 373 | Table 18.7 Watchdog Timer Characteristics | Unit amended | | 376 to<br>388 | 18.3 Electrical Characteristics (Mask ROM Version) | Added | | 411 to<br>417 | A.3 Number of Execution States | Added | | 423 | B.2 Register Bits | Bit name in ABRKSR amended | # Contents | Sect | ion 1 | Overview | 1 | |------|----------|----------------------------------------------|----------| | 1.1 | Feature | S | 1 | | 1.2 | Internal | Block Diagram | 4 | | 1.3 | Pin Arr | angement | 5 | | 1.4 | Pin Fun | actions | 7 | | Sect | ion 2 | CPU | 11 | | 2.1 | Feature | S | 11 | | 2.2 | Address | s Space and Memory Map | 12 | | 2.3 | | r Configuration | 15 | | | 2.3.1 | General Registers | 16 | | | 2.3.2 | Program Counter (PC) | 17 | | | 2.3.3 | Condition Code Register (CCR) | 17 | | 2.4 | Data Fo | ormats | 19 | | | 2.4.1 | General Register Data Formats | 19 | | | 2.4.2 | Memory Data Formats | 21 | | 2.5 | | ion Set | 22 | | | 2.5.1 | Instruction Set Overview | 22 | | | 2.5.2 | Basic Instruction Formats. | | | 2.6 | | sing Modes and Effective Address Calculation | | | | 2.6.1 | Addressing Modes | 33 | | | 2.6.2 | Effective Address Calculation | 35 | | 2.7 | | Bus Cycle | 39 | | | 2.7.1 | Access to On-Chip Memory (RAM, ROM) | 39 | | | 2.7.2 | Access to On-Chip Peripheral Modules | 40 | | 2.8 | | ates | 41 | | 2.0 | 2.8.1 | Overview | 41 | | 2.9 | | ation Notes | 42 | | 2.7 | 2.9.1 | Notes on Data Access to Empty Areas. | 42 | | | 2.9.2 | Notes on Bit Manipulation | 43 | | | 2.9.3 | Notes on Use of the EEPMOV Instruction | 48 | | Sect | ion 3 | Exception Handling | 49 | | 3.1 | | ew | | | ٥.1 | 3.1.1 | Exception Handling Types | 49 | | 3.2 | | Exception Handling Types | 49 | | 3.2 | 3.2.1 | | 49<br>49 | | | 3.2.1 | Reset Sequence | | | | 3.2.2 | Interrupt Immediately after Reset | | | | 3.4.3 | menupi miniculately after Keset | 20 | | 3.3 | Interru | pts | 51 | |-------|---------|------------------------------------------|-----| | | 3.3.1 | Interrupt and Vector Address | 51 | | 3.4 | Interru | pt Control Registers | 53 | | | 3.4.1 | Interrupt Edge Select Register 1 (IEGR1) | 53 | | | 3.4.2 | Interrupt Edge Select Register 2 (IEGR2) | 54 | | | 3.4.3 | Interrupt Enable Register 1 (IENR1) | 55 | | | 3.4.4 | Interrupt Flag Register 1 (IRR1) | 56 | | | 3.4.5 | Wakeup Interrupt Flag Register (IWPR) | 57 | | 3.5 | Interru | pt Sources | 58 | | | 3.5.1 | External Interrupts | 58 | | | 3.5.2 | Internal Interrupts | 58 | | | 3.5.3 | Interrupt Operations | | | | 3.5.4 | Interrupt Response Time | 62 | | 3.6 | Trap Ir | struction | | | 3.7 | Applic | ation Notes | 62 | | | 3.7.1 | Notes on Stack Area Use | | | | 3.7.2 | Notes on Rewriting Port Mode Registers | | | | | | | | Secti | on 4 | Address Break | 67 | | 4.1 | Overvi | ew | 67 | | | 4.1.1 | Block Diagram | | | | 4.1.2 | Register Configuration | | | 4.2 | Registe | er Descriptions | | | | 4.2.1 | Address Break Control Register (ABRKCR) | | | | 4.2.2 | Address Break Status Register (ABRKSR) | | | | 4.2.3 | Break Address Registers (BARH, BARL) | | | | 4.2.4 | Break Data Registers (BDRH, BDRL) | | | 4.3 | | ion | 72 | | | - F | | . – | | Secti | on 5 | Clock Pulse Generators | 75 | | 5.1 | | ew | | | 0.1 | 5.1.1 | Block Diagram | | | | 5.1.2 | System Clock and Subclock | | | 5.2 | | 1 Clock Generator | | | 5.3 | • | ck Generator | 78 | | 5.4 | | lers | 79 | | 5.5 | | Notes | 80 | | 3.3 | 5.5.1 | Note on Oscillators | 80 | | | 5.5.2 | Notes on Board Design | 80 | | | J.J.L | Notes on Bould Design | 30 | | Secti | on 6 | Power-down Modes | 81 | | 6.1 | | ew | 81 | | 0.1 | 6.1.1 | Register Configuration | 81 | | | 0.1.1 | Negrowi Comiguration | 01 | | | ister Descriptions | 02 | |----------------|----------------------------------------------|------------| | 6.2. | System Control Register 1 (SYSCR1) | 82 | | 6.2. | 2 System Control Register 2 (SYSCR2) | 83 | | 6.2. | Module Standby Control Register 1 (MSTCR1) | 85 | | 6.3 Mod | le Transition Conditions | 87 | | 6.4 Slee | p Mode | 90 | | 6.4. | 1 Transition to the Sleep Mode | 90 | | 6.4. | 2 Clearing the Sleep Mode | 90 | | 6.5 Star | dby Mode | 90 | | 6.5. | 1 Transition to the Standby Mode | 90 | | 6.5. | 2 Clearing the Standby Mode | 91 | | 6.5. | | | | 6.6 Sub | sleep Mode | 92 | | 6.6. | | | | 6.6. | • | | | 6.7 Sub | active Mode | | | 6.7. | | | | 6.7. | | | | 6.8 Acti | ve Mode | | | 6.8. | | | | 6.8. | | | | 6.8. | | | | | ect Transition | | | 6.9. | | | | | lule Standby Mode | | | | | | | Section 7 | | | | 7.1 Feat | ures | | | 7.2 Ove | rview | 98 | | 7.2. | | | | 7.2. | 2 On-board Programming Mode | 99 | | 7.2. | Block Configuration | 103 | | 7.2. | 4 Pin Configuration | 103 | | 7.2. | 5 Register Configuration | 104 | | 7.3 Reg | ister Descriptions | 104 | | 7.3. | Flash Memory Control Register 1 (FLMCR1) | 104 | | 7.3. | Flash Memory Control Register 2 (FLMCR2) | 106 | | 7.3. | Brase Block Register 1 (EBR1) | 107 | | 7.3.4 | Flash Memory Power Control Register (FLPWCR) | 108 | | 1.5. | Flash Memory Enable Register (FENR) | 108 | | 7.3. | | | | 7.3. | t Mode | | | 7.3. | | 109 | | 7.3<br>7.4 Boo | 1 Automatic SCI Bit Rate Adjustment | 109<br>111 | | 7.6 Programming/Erasing Flash Memory 113 7.6.1 Program/Program-Verify 114 7.6.2 Erase/Erase-Verify 117 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 120 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 | 7.6. Programming/Erasing Flash Memory 113 7.6.1 Program/Program-Verify 114 7.6.2 Erase/Erase-Verify 117 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 120 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Block Diagram< | | 7.4.3 | Notes on Use of Boot Mode | 112 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|----------------------------------------------------|-----| | 7.6.1 Program/Program-Verify 114 7.6.2 Erase/Erase-Verify 117 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 119 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Frase Mode 131 7.10.6 Status Read Mode 131 7.10.7 Status Read Mode 133 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview <td>7.6.1 Program/Program-Verify 114 7.6.2 Erase/Erase-Verify 117 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Program Mode 129 7.10.6 Status Read Mode 131 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 139 9.1 Overview</td> <td>7.5</td> <td>User Pr</td> <td>ogram Mode</td> <td>112</td> | 7.6.1 Program/Program-Verify 114 7.6.2 Erase/Erase-Verify 117 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Program Mode 129 7.10.6 Status Read Mode 131 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 139 9.1 Overview | 7.5 | User Pr | ogram Mode | 112 | | 7.6.2 Erase/Erase-Verify 117 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 119 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10.1 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Block Diagram 137 8.1.1 Block Diagram | 7.6.2 Erase/Erase-Verify 117 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 120 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 139 9.1 Overview 139 </td <td>7.6</td> <td>Prograi</td> <td>mming/Erasing Flash Memory</td> <td>113</td> | 7.6 | Prograi | mming/Erasing Flash Memory | 113 | | 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection 119 7.7.1 Hardware Protection 119 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) | 7.6.3 Interrupts during Flash Memory Programming/Erasing 117 7.7 Protection | | 7.6.1 | Program/Program-Verify | 114 | | 7.7 Protection 119 7.7.1 Hardware Protection 120 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 131 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 140 9.2.1 <td>7.7 Protection</td> <td></td> <td>7.6.2</td> <td>Erase/Erase-Verify</td> <td>117</td> | 7.7 Protection | | 7.6.2 | Erase/Erase-Verify | 117 | | 7.7.1 Hardware Protection 119 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Block Diagram 137 8.1.1 Block Diagram 139 9.2 Port 1 140 9.2.1 Overview 139 9.2.1 Overview 139 9.2.2 | 7.7.1 Hardware Protection 120 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 139 9.1 Overview 139 9.2 Port I 140 9.2.1 Overview 139 9.2.2 Register Configuration and Description 140 | | 7.6.3 | Interrupts during Flash Memory Programming/Erasing | 117 | | 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 139 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 | 7.7.2 Software Protection 120 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Block Diagram 137 8.1.1 Block Diagram 137 8.1.2 Overview 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 139 9.2.2 Register Configuration and Description 140 9.2.3< | 7.7 | Protect | ion | 119 | | 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 139 9.2 Port 1 140 9.2.1 Overview 139 9.2 Port 1 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 | 7.7.3 Error Protection 120 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 8.2 Port I 140 9.2 Port I 140 9.2.1 Overview 139 9.2 Port Data Register I (PDR1) 141 9.2.4 Port Control Register I (PDR1) 141 9.2 | | 7.7.1 | Hardware Protection | 119 | | 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 | 7.8 Interrupt Handling when Programming/Erasing Flash Memory 121 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram. 123 7.10.2 Programmer Mode Operation. 125 7.10.3 Memory Read Mode. 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 141 9.2.4 Port Data Register 1 (PCR1) 141 </td <td></td> <td>7.7.2</td> <td>Software Protection</td> <td>120</td> | | 7.7.2 | Software Protection | 120 | | 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 139 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 < | 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Co | | 7.7.3 | Error Protection | 120 | | 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 139 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 < | 7.9 Flash Memory and Power-Down States 122 7.10 Flash Memory Programmer Mode 122 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Co | 7.8 | Interru | ot Handling when Programming/Erasing Flash Memory | 121 | | 7.10.1 Socket Adapter Pin Correspondence Diagram. 123 7.10.2 Programmer Mode Operation. 125 7.10.3 Memory Read Mode. 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode. 131 7.10.6 Status Read Mode. 133 7.10.7 Status Polling. 134 7.10.8 Programmer Mode Transition Time. 134 7.10.9 Notes on Memory Programming. 135 Section 8 RAM. 137 8.1 Overview. 137 8.1.1 Block Diagram. 137 Section 9 I/O Ports. 139 9.1 Overview. 139 9.2 Port 1 140 9.2.1 Overview. 140 9.2.2 Register Configuration and Description. 140 9.2.3 Port Data Register 1 (PDR1). 141 9.2.4 Port Control Register 1 (PCR1). 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1). 141 9.2.6 Port Mode Register 1 (PMR1). 142 | 7.10.1 Socket Adapter Pin Correspondence Diagram 123 7.10.2 Programmer Mode Operation 125 7.10.3 Memory Read Mode 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 | 7.9 | | | | | 7.10.2 Programmer Mode Operation. 125 7.10.3 Memory Read Mode. 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode. 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time. 134 7.10.9 Notes on Memory Programming. 135 Section 8 RAM. 137 8.1 Overview. 137 8.1.1 Block Diagram. 137 Section 9 I/O Ports 139 9.1 Overview. 139 9.2 Port 1 140 9.2.1 Overview. 140 9.2.2 Register Configuration and Description. 140 9.2.3 Port Data Register 1 (PDR1). 141 9.2.4 Port Control Register 1 (PCR1). 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1). 141 9.2.6 Port Mode Register 1 (PMR1). 142 | 7.10.2 Programmer Mode Operation. 125 7.10.3 Memory Read Mode. 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode. 131 7.10.6 Status Read Mode. 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time. 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM. 137 8.1 Overview. 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview. 139 9.2 Port 1 140 9.2.1 Overview. 140 9.2.2 Register Configuration and Description. 140 9.2.3 Port Data Register 1 (PDR1). 141 9.2.4 Port Control Register 1 (PCR1). 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.3.1 Overvie | 7.10 | Flash N | Memory Programmer Mode | 122 | | 7.10.3 Memory Read Mode | 7.10.3 Memory Read Mode. 126 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode. 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time. 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.3.1 Overview 146 9.3.2 Register Configuration and Descrip | | 7.10.1 | Socket Adapter Pin Correspondence Diagram | 123 | | 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 7.10.4 Auto-Program Mode 129 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 <td></td> <td>7.10.2</td> <td>Programmer Mode Operation</td> <td>125</td> | | 7.10.2 | Programmer Mode Operation | 125 | | 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 7.10.5 Auto-Erase Mode 131 7.10.6 Status Read Mode 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description <t< td=""><td></td><td>7.10.3</td><td>Memory Read Mode</td><td>126</td></t<> | | 7.10.3 | Memory Read Mode | 126 | | 7.10.6 Status Read Mode | 7.10.6 Status Read Mode. 133 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time. 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2)< | | 7.10.4 | Auto-Program Mode | 129 | | 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 7.10.7 Status Polling 134 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 7.10.5 | Auto-Erase Mode | 131 | | 7.10.8 Programmer Mode Transition Time 134 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 7.10.8 Programmer Mode Transition Time | | 7.10.6 | Status Read Mode | 133 | | 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 7.10.9 Notes on Memory Programming 135 Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 7.10.7 | Status Polling | 134 | | Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | Section 8 RAM 137 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 7.10.8 | Programmer Mode Transition Time | 134 | | 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 8.1 Overview 137 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 7.10.9 | Notes on Memory Programming | 135 | | 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 8.1.1 Block Diagram 137 Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | Secti | on 8 | RAM | 137 | | Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | Section 9 I/O Ports 139 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | 8.1 | Overvi | ew | 137 | | 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 8.1.1 | Block Diagram | 137 | | 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 9.1 Overview 139 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | Secti | on 9 | I/O Ports | 139 | | 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 9.2 Port 1 140 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | 9.1 | Overvi | | | | 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 9.2.1 Overview 140 9.2.2 Register Configuration and Description 140 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | | | | | 9.2.2 Register Configuration and Description. 140 9.2.3 Port Data Register 1 (PDR1). 141 9.2.4 Port Control Register 1 (PCR1). 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1). 141 9.2.6 Port Mode Register 1 (PMR1). 142 | 9.2.2 Register Configuration and Description | | | | | | 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 9.2.3 Port Data Register 1 (PDR1) 141 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 9.2.2 | | | | 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 | 9.2.4 Port Control Register 1 (PCR1) 141 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 9.2.3 | · · | | | 9.2.5 Port Pull-Up Control Register 1 (PUCR1) | 9.2.5 Port Pull-Up Control Register 1 (PUCR1) 141 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 9.2.4 | | | | 9.2.6 Port Mode Register 1 (PMR1) | 9.2.6 Port Mode Register 1 (PMR1) 142 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 9.2.5 | | | | | 9.2.7 Pin Functions 144 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | | | | | | 9.2.8 MOS Input Pull-Up 145 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | | | | | 9.2.8 MOS Input Pull-Up | 9.3 Port 2 146 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | | 9.2.8 | MOS Input Pull-Up | 145 | | • | 9.3.1 Overview 146 9.3.2 Register Configuration and Description 146 9.3.3 Port Data Register 2 (PDR2) 146 9.3.4 Port Control Register 2 (PCR2) 147 | 9.3 | | - | | | | 9.3.2Register Configuration and Description.1469.3.3Port Data Register 2 (PDR2).1469.3.4Port Control Register 2 (PCR2)147 | | | | | | | 9.3.3 Port Data Register 2 (PDR2) 146<br>9.3.4 Port Control Register 2 (PCR2) 147 | | | | | | · · · · · · · · · · · · · · · · · · · | 9.3.4 Port Control Register 2 (PCR2) | | | • | | | | | | | | | | | | iv. | | | | | | ·· | iv | - ·-· | | | | | 9.3.5 | Pin Functions | . 148 | |------|---------|-----------------------------------------|-------| | 9.4 | Port 5. | | . 149 | | | 9.4.1 | Overview | . 149 | | | 9.4.2 | Register Configuration and Description | . 149 | | | 9.4.3 | Port Data Register 5 (PDR5) | . 150 | | | 9.4.4 | Port Control Register 5 (PCR5) | . 150 | | | 9.4.5 | Port Pull-Up Control Register 5 (PUCR5) | . 15 | | | 9.4.6 | Port Mode Register 5 (PMR5) | . 15 | | | 9.4.7 | Pin Functions | . 152 | | | 9.4.8 | MOS Input Pull-Up | . 15. | | 9.5 | Port 7. | | . 154 | | | 9.5.1 | Overview | . 154 | | | 9.5.2 | Register Configuration and Description. | . 154 | | | 9.5.3 | Port Data Register 7 (PDR7) | . 154 | | | 9.5.4 | Port Control Register 7 (PCR7) | . 15: | | | 9.5.5 | Pin Functions | . 15: | | 9.6 | Port 8. | | . 150 | | | 9.6.1 | Overview | . 150 | | | 9.6.2 | Register Configuration and Description. | . 150 | | | 9.6.3 | Port Data Register 8 (PDR8) | . 15′ | | | 9.6.4 | Port Control Register 8 (PCR8) | . 15′ | | | 9.6.5 | Pin Functions | . 15 | | 9.7 | Port B. | | . 16 | | | 9.7.1 | Overview | . 16 | | | 9.7.2 | Register Configuration and Description. | . 16 | | | 9.7.3 | Port Data Register B (PDRB) | . 16 | | | 9.7.4 | Pin Functions | . 162 | | Sect | ion 10 | Timer A | . 16. | | 10.1 | Overvi | ew | . 16. | | | 10.1.1 | Features | . 16. | | | 10.1.2 | Block Diagram | . 164 | | | 10.1.3 | Pin Configuration | . 164 | | | 10.1.4 | Register Configuration | . 16: | | 10.2 | Registe | er Descriptions | . 16: | | | 10.2.1 | Timer Mode Register A (TMA) | . 16: | | | 10.2.2 | Timer Counter A (TCA) | . 16 | | 10.3 | Timer | Operation | . 16 | | | 10.3.1 | Interval Timer Operation | . 16 | | | 10.3.2 | Clock Time Base Operation | . 16 | | | 10.3.3 | Clock Output | . 16 | | 10.4 | Timer. | A Operation States | . 16 | | | | | | | | | | | | Secti | ion 11 | Timer V | . 16 | |-------|---------|------------------------------------------------|-------| | 11.1 | Overvi | ew | . 16 | | | 11.1.1 | Features | . 169 | | | 11.1.2 | Block Diagram | . 17 | | | 11.1.3 | Pin Configuration | . 17 | | | 11.1.4 | Register Configuration | . 17 | | 11.2 | Registe | er Descriptions | . 17 | | | 11.2.1 | Timer Counter V (TCNTV) | . 17 | | | 11.2.2 | Time Constant Registers A and B (TCORA, TCORB) | . 17 | | | 11.2.3 | Timer Control Register V0 (TCRV0) | . 17 | | | 11.2.4 | Timer Control/Status Register V (TCSRV) | . 17 | | | 11.2.5 | Timer Control Register V1 (TCRV1) | . 17 | | 11.3 | Timer | Operation | . 17 | | | 11.3.1 | Timer V Operation Modes | . 182 | | | 11.3.2 | Interrupt Sources | . 182 | | | 11.3.3 | Application Examples | . 18 | | | | Application Notes | | | Cont | ion 10 | Timor W | 10 | | | | Timer W | | | 12.1 | | ew | | | | | Features | | | | | Block Diagrams | | | | | Input/Output Pins | | | 10.0 | | Register Configuration | | | 12.2 | - | er Description | | | | 12.2.1 | | | | | | Timer Control Register W (TCRW) | | | | | Timer Interrupt Enable Register W (TIERW) | | | | | Timer Status Register W (TSRW) | | | | 12.2.5 | E \ \ | | | | 12.2.6 | Timer I/O Control Register 1 (TIOR1) | | | | 12.2.7 | | | | | | General Registers A to D (GRA to GRD) | | | 12.3 | | nterface | | | | | 16-Bit Registers | | | | | 8-Bit Registers | | | 12.4 | - | ion | | | | | Overview | | | | 12.4.2 | Operation Timing | . 22 | | 12.5 | Usage | Notes | . 22 | | | | | | | | | | | | 13.1 | Overvi | ew | 237 | |-------|---------|--------------------------------------------------|-----| | | 13.1.1 | Features | 237 | | | 13.1.2 | Block Diagram | 237 | | | 13.1.3 | Register Configuration | 238 | | 13.2 | Registe | er Descriptions | 238 | | | 13.2.1 | Timer Control/Status Register WD (TCSRWD) | 238 | | | 13.2.2 | Timer Counter WD (TCWD) | 240 | | | 13.2.3 | Timer Mode Register WD (TMWD) | 241 | | 13.3 | | on | | | | 13.3.1 | Watchdog Timer Operating Modes | 243 | | Secti | on 14 | Serial Communication Interface 3 | 245 | | 14.1 | Overvi | ew | 245 | | | 14.1.1 | Features | 245 | | | 14.1.2 | Block Diagram | 247 | | | 14.1.3 | Pin Configuration | 248 | | | 14.1.4 | Register Configuration | 248 | | 14.2 | Registe | er Descriptions | 249 | | | | Receive Shift Register (RSR) | | | | 14.2.2 | Receive Data Register (RDR) | 249 | | | 14.2.3 | Transmit Shift Register (TSR) | 250 | | | | Transmit Data Register (TDR) | | | | 14.2.5 | 2 \ / | | | | | Serial Control Register 3 (SCR3) | | | | | Serial Status Register (SSR) | | | | 14.2.8 | Bit Rate Register (BRR) | 260 | | 14.3 | Operati | on | | | | 14.3.1 | Asynchronous Mode | 267 | | | | Synchronous Mode | | | | | Interrupts and Continuous Transmission/Reception | | | 14.4 | - | ion in Asynchronous Mode | | | | | Data Transfer Format | | | | | Clock | | | | | Data Transfer Operations | | | 14.5 | _ | ion in Synchronous Mode | | | | | Data Transfer Format | | | | | Clock | | | | | Data Transfer Operations | | | 14.6 | - | rocessor Communication Function | | | 14.7 | | pts | | | 14.8 | _ | Notes | | | | 1/1 & 1 | Relation between Writes to TDR and Rit TDRF | 295 | vii | | 14.8.2 | Operation when a Number of Receive Errors Occur Simultaneously | 295 | |------|---------|----------------------------------------------------------------------|-------| | | 14.8.3 | Break Detection and Processing. | 296 | | | 14.8.4 | Mark State and Break Detection | 296 | | | 14.8.5 | Receive Error Flags and Transmit Operation (Synchronous Mode Only) | 296 | | | 14.8.6 | Receive Data Sampling Timing and Receive Margin in Asynchronous Mode | 296 | | | 14.8.7 | Relation between RDR Reads and Bit RDRF | 298 | | Sect | ion 15 | I <sup>2</sup> C Bus Interface (IIC) | 299 | | 15.1 | | ew | | | | 15.1.1 | Features | 299 | | | 15.1.2 | Block Diagram | 300 | | | 15.1.3 | Pin Configuration | 301 | | | 15.1.4 | Register Configuration | 302 | | 15.2 | Registe | er Descriptions | 303 | | | _ | I <sup>2</sup> C Bus Data Register (ICDR) | | | | | Slave Address Register (SAR) | | | | | Second Slave Address Register (SARX) | | | | | I <sup>2</sup> C Bus Mode Register (ICMR) | | | | | I <sup>2</sup> C Bus Control Register (ICCR) | | | | | I <sup>2</sup> C Bus Status Register (ICSR) | | | | | Timer Serial Control Register (TSCR) | | | 15.3 | | ion | | | | - | I <sup>2</sup> C Bus Data Format | | | | | Master Transmit Operation | | | | | Master Receive Operation | | | | | Slave Receive Operation | | | | | Slave Transmit Operation | | | | | IRIC Setting Timing and SCL Control | | | | | Noise Canceler | | | | 15.3.8 | | | | 15.4 | | Notes | | | 13.4 | Osage | Notes | . 550 | | Sect | ion 16 | A/D Converter | 341 | | 16.1 | Overvi | ew | 341 | | | 16.1.1 | Features | 341 | | | 16.1.2 | Block Diagram | 342 | | | 16.1.3 | Input Pins | 343 | | | 16.1.4 | Register Configuration | 344 | | 16.2 | | er Descriptions | | | | | A/D Data Registers A to D (ADDRA to ADDRD) | | | | | A/D Control/Status Register (ADCSR) | | | | | A/D Control Register (ADCR) | | | 16.3 | | nterface | | | viii | | | | | | | | | | 16.4 | Operati | ion | 350 | |-------|----------|-------------------------------------------------------|-----| | | 16.4.1 | Single Mode (SCAN = 0) | 350 | | | 16.4.2 | Scan Mode (SCAN = 1) | 352 | | | 16.4.3 | Input Sampling and A/D Conversion Time | 354 | | | 16.4.4 | External Trigger Input Timing | 355 | | 16.5 | Interru | pts | 356 | | 16.6 | Usage 2 | Notes | 356 | | Secti | on 17 | Power Supply Circuit | 359 | | 17.1 | | ew | | | 17.2 | | Using the Internal Power Supply Step-Down Circuit | | | 17.3 | | Not Using the Internal Power Supply Step-Down Circuit | | | | | | | | Secti | on 18 | Electrical Characteristics | 361 | | 18.1 | | te Maximum Ratings | | | 18.2 | | cal Characteristics (F-ZTAT <sup>TM</sup> Version) | | | | | Power Supply Voltage and Operating Ranges | | | | 18.2.2 | DC Characteristics | 363 | | | 18.2.3 | AC Characteristics | 368 | | | 18.2.4 | A/D Converter Characteristics | 372 | | | 18.2.5 | Watchdog Timer | 373 | | | 18.2.6 | Flash Memory Characteristics (Preliminary) | 374 | | 18.3 | Electric | cal Characteristics (Mask ROM Version) | 376 | | | | Power Supply Voltage and Operating Ranges | | | | 18.3.2 | DC Characteristics | 378 | | | 18.3.3 | AC Characteristics | 383 | | | 18.3.4 | A/D Converter Characteristics | 387 | | | 18.3.5 | Watchdog Timer | 388 | | 18.4 | Operati | ion Timing | 389 | | 18.5 | Output | Load Circuit | 392 | | | 1. 4 | | ••• | | 1.1 | | A Instruction Set | | | A.1 | | tion List | | | A.2 | - | ion Code Map | | | A.3 | | er of Execution States | | | A.4 | Combi | nations of Instructions and Addressing Modes | 418 | | App | endix E | 3 Internal I/O Registers | 419 | | B.1 | | er Addresses | | | B.2 | _ | er Bits | | | Anne | endix C | C I/O Port Block Diagrams | 425 | | PP' | | 2 0 1 010 010 010 010 010 010 010 010 01 | | | Appendix D | Port States in the Different Processing States | 442 | |------------|------------------------------------------------|-----| | Appendix E | Model Names | 443 | | Annendix F | Package Dimensions | 444 | # Section 1 Overview ## 1.1 Features ### Table 1.1 Features | Item | Description | | | | | |-------------|------------------------------------------------------------------------------------------|--|--|--|--| | CPU | H8/300H CPU (upward compatibility with H8/300 CPU at object level) | | | | | | | General-register machine | | | | | | | <ul> <li>Sixteen 16-bit registers (also usable as eight 16-bit registers plus</li> </ul> | | | | | | | sixteen 8-bit registers or eight 32-bit registers) | | | | | | | High-speed operation | | | | | | | <ul> <li>Max. operation speed: 16 MHz</li> </ul> | | | | | | | <ul><li>— Add/subtract: 0.125 μs</li></ul> | | | | | | | <ul><li>— Multiply/divide: 0.875 μs</li></ul> | | | | | | | Address space: 64 kbytes | | | | | | | Instruction features | | | | | | | <ul> <li>8/16/32-bit data transfer, arithmetic, and logic instructions</li> </ul> | | | | | | | <ul> <li>— Signed and unsigned multiply instructions</li> </ul> | | | | | | | (8 bits $\times$ 8 bits, 16 bits $\times$ 16 bits) | | | | | | | <ul> <li>— Signed and unsigned divide instructions</li> </ul> | | | | | | | (16 bits ÷ 8 bits, 32 bits ÷ 16 bits) | | | | | | | Bit accumulator function | | | | | | | — Bit manipulation instructions with register-indirect specification of bit | | | | | | | positions | | | | | | Interrupts | <ul> <li>11 external interrupt sources (NMI, IRQ3 to IRQ0, WKP5 to WKP0)</li> </ul> | | | | | | | 20 internal interrupt sources | | | | | | Clock pulse | System clock pulse generator: 1 to 16 MHz | | | | | | generators | Sub-system clock pulse generator: 32.768 kHz (for watch) | | | | | | Power-down | Transition possible between five modes | | | | | | modes | Active mode | | | | | | | Sleep mode | | | | | | | Standby mode | | | | | | | Subsleep mode | | | | | | | Subactive mode | | | | | | | Gear function | | | | | | | Module standby function | | | | | | | | | | | | | Item | Description | | | | | | | |-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------------------|-------------------------------|--|--|--| | Memory | | | | | | | | | | Type No. | | ROM | RAM | | | | | | HD64F3664 | (Flash memory version) | 32 kbytes | 2,048 bytes | | | | | | HD6433664 | (Mask ROM version) | 32 kbytes | 1,024 bytes | | | | | | HD6433663 | (Mask ROM version) | 24 kbytes | 1,024 bytes | | | | | | HD6433662 | (Mask ROM version) | 16 kbytes | 512 bytes | | | | | | HD6433661 | (Mask ROM version) | 12 kbytes | 512 bytes | | | | | | HD6433660 | (Mask ROM version) | 8 kbytes | 512 bytes | | | | | I/O ports | • 29 I/O pins, | including 8 large current | ports (I <sub>OL</sub> = 20 m | nA, @ V <sub>OL</sub> = 1.5 V | | | | | | 8 input pins | (also used for analog inp | out) | | | | | | Timers | Timer A: 8-b | oit timer | | | | | | | | Count-up timer with selection of eight internal clock signals divided from the system clock and four clock signals divided from the watch sub-clock | | | | | | | | | Timer V: 8-bit timer | | | | | | | | | <ul> <li>Count-up timer with selection of six internal clock signals or event input<br/>from external pin</li> </ul> | | | | | | | | | Compare-match waveform output | | | | | | | | | Externally triggerable | | | | | | | | | Timer W: 16-bit timer | | | | | | | | | <ul> <li>Counts any of four internal clock signals or external events</li> </ul> | | | | | | | | | <ul> <li>Maximum of four types of pulses can be input or output and processed</li> </ul> | | | | | | | | | <ul><li>Output of</li></ul> | compare/input capture (4 | output pins) | | | | | | | <ul> <li>Output compare/input capture operation can be buffered</li> </ul> | | | | | | | | | <ul> <li>PWM mode can be set (maximum of three synchronous outputs)</li> </ul> | | | | | | | | | Watchdog timer: 8-bit timer | | | | | | | | | — Reset si | gnal generated by counte | er overflow | | | | | | | — Operate | s independent from syste | m clock by inter | nal oscillation circuit | | | | | Serial | Selectable to | etween asynchronous m | ode or 8-bit cloc | ck synchronous mode | | | | | communication interface | <ul> <li>Incorporate</li> </ul> | baud rate generator | | | | | | | | Multi-proces | ssor communication funct | ion (asynchrono | ous) | | | | | Item | Description | | | | | | |----------------------|----------------------------------------------------------------------------|------------------|-----------|--|--|--| | I <sup>2</sup> C bus | Conforms to I <sup>2</sup> C bus interface proposed by Philips Electronics | | | | | | | interface | Selectable between single master mode and slave mode | | | | | | | | <ul> <li>Supports two slave</li> </ul> | addresses | | | | | | A/D converter | 10-bit resolution | | | | | | | | 8-channel analog input pins (selectable between single mode and scan mode) | | | | | | | | <ul> <li>Conversion time: 7 μs</li> </ul> | | | | | | | | Sample and hold fur | nction | | | | | | Package | | | | | | | | | Code | <b>Body Size</b> | Pin Pitch | | | | | | QFP-64 (FP-64E) | 10.0 × 10.0 mm | 0.5 mm | | | | | | QFP-64 (FP-64A) | 14.0 × 14.0 mm | 0.8 mm | | | | | | SDIP-42 (DP-42S) | 14.0 × 37.3 mm | 1.78 mm | | | | ## 1.2 Internal Block Diagram Figure 1.1 Block Diagram ### 1.3 Pin Arrangement Figure 1.2 Pin Arrangement (FP-64E, FP-64A) Figure 1.3 Pin Arrangement (DP-42S) ## 1.4 Pin Functions **Table 1.2 Pin Functions** | | | Р | in No. | | | |-------------------|------------------|------------------|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Туре | Symbol | FP-64E<br>FP-64A | DP-42S | <br>I/O | Name and Functions | | Power source pins | V <sub>cc</sub> | 12 | 14 | Input | <b>Power supply:</b> All $V_{cc}$ pins should be connected to the user system $V_{cc}$ . | | | V <sub>ss</sub> | 9 | 11 | Input | <b>Ground:</b> All V <sub>ss</sub> pins should be connected to the user system GND (0 V). | | | AV <sub>cc</sub> | 3 | 5 | Input | Analog power supply: This is the power supply pin for the A/D converter. When the A/D converter is not used, connect this pin to the user system V <sub>cc</sub> . | | | V <sub>CL</sub> | 6 | 8 | Input | Internal step-down power supply: Connect a capacitor of around 0.1 µF between this pin and the V <sub>ss</sub> pin for stabilization. | | Clock pins | OSC1 | 11 | 13 | Input | System clock: These pins connect to a crystal or ceramic oscillator, or can be used to input an external clock. | | | OSC2 | 10 | 12 | Output | See section 5, Clock Pulse Generators, for a typical connection diagram. | | | X1 | 5 | 7 | Input | <b>Subclock:</b> These pins connect to a 32.768-kHz crystal oscillator. | | | X2 | 4 | 6 | Output | See section 5, Clock Pulse Generators, for a typical connection diagram. | | System control | RES | 7 | 9 | Input | Reset: When this pin is driven low, the chip is reset. | | | TEST | 8 | 10 | Input | <b>Test:</b> This is a test pin, not for use in application systems. It should be connected to $V_{\rm ss}$ . | | | | Pi | in No. | | | |-------------------------------|-------------------|---------------------|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------| | Туре | Symbol | FP-64E<br>FP-64A | DP-42S | <br>I/O | Name and Functions | | Interrupt<br>pins | NMI | 35 | 27 | Input | Non-maskable interrupt request input pin | | | IRQ0 to<br>IRQ3 | 51 to 54 | 39 to 42 | Input | IRQ interrupt request 0 to 3: These are input pins for edge- sensitive external interrupts, with a selection of rising or falling edge. | | | WKP0 to WKP5 | 13, 14,<br>19 to 22 | 15 to 20 | Input | WKP interrupt request 0 to 5: These are input pins for edgesensitive external interrupts, with a selection of rising or falling edge. | | Timer A | TMOW | 23 | 21 | Output | Clock output: This is an output pin for waveforms generated by the timer A output circuit. | | Timer V | TMOV | 30 | 26 | Output | <b>Timer V output:</b> This is an output pin for waveforms generated by the timer V output compare function. | | | TMCIV | 29 | 25 | Input | <b>Timer V event input:</b> This is an event input pin for input to the timer V counter. | | | TMRIV | 28 | 24 | Input | Timer V counter reset: This is a counter reset input pin for timer V. | | | TRGV | 54 | 42 | Input | Timer V counter trigger input: This is a trigger input pin for the timer V counter. | | Timer W | FTCI | 36 | 28 | Input | <b>Timer W clock input:</b> This is an external clock input pin for input to the timer X counter. | | | FTIOA to<br>FTIOD | 37 to 40 | 29 to 32 | I/O | Timer W output compare A/input capture/PWM output pin | | I <sup>2</sup> C bus inerface | SDA | 26 | 22 | I/O | I <sup>2</sup> C data I/O: Can directly drive a bus by NMOS open-drain output. | | | SCL | 27 | 23 | I/O | I <sup>2</sup> C clock I/O: Can directly drive a bus by NMOS open-drain output. | | | | Pi | n No. | | | |---------------------------|---------------------------|--------------------------------|---------------------|---------|-------------------------------------------------------------------------------------------| | Туре | Symbol | FP-64E<br>FP-64A | DP-42S | <br>I/O | Name and Functions | | Serial com-<br>munication | TXD | 46 | 38 | Output | SCI3 transmit data output: This is the data output pin. | | interface<br>(SCI) | RXD | 45 | 37 | Input | SCI3 receive data input: This is the data input pin. | | | SCK3 | 44 | 36 | Output | SCI3 clock I/O: This is the clock I/O pin. | | A/D<br>converter | AN7 to AN0 | 55 to 62 | 1 to 4 | Input | Analog input channels 7 to 0: These are analog data input channels to the A/D converter. | | | ADTRG | 22 | 20 | Input | A/D converter trigger input: This is the external trigger input pin to the A/D converter. | | I/O ports | PB7 to PB0 | 55 to 62 | 1 to 4 | Input | Port B: This is an 8-bit input port. | | | P17 to P14,<br>P12 to P10 | 51 to 54,<br>23 to 25 | 39 to 42,<br>21 | I/O | Port 1: This is a 7-bit I/O port. | | | P22 to P20 | 44 to 46 | 36 to 38 | I/O | Port 2: This is a 3-bit I/O port. | | | P57 to P50 | 13, 14,<br>19 to 22,<br>26, 27 | 15 to 20,<br>22, 23 | I/O | Port 5: This is an 8-bit I/O port. | | | P76 to P74 | 28 to 30 | 24 to 26 | I/O | Port 7: This is a 3-bit I/O port. | | | P87 to P80 | 36 to 43 | 28 to 35 | I/O | Port 8: This is an 8-bit I/O port. | | Other | NC | | | | Non-connected pins: These pins must be left unconnected. | ### Section 2 CPU #### 2.1 Features The H8/3664 Series has an H8/300H CPU with an internal 32-bit architecture that is upward-compatible with the H8/300 CPU, and supports only normal mode, which has a 64-kbyte address space. The H8/300H CPU has the following features. - Upward compatibility with H8/300 CPU - Can execute H8/300 Series object programs - Additional eight 16-bit extended registers - 32-bit transfer and arithmetic and logic instructions are added - Signed multiply and divide instructions are added - · General registers - Sixteen 16-bit general registers (also usable as sixteen 8-bit registers and eight 16-bit registers or eight 32-bit registers) - Sixty-two basic instructions - 8/16/32-bit data transfer and arithmetic and logic instructions - Multiply and divide instructions - Powerful bit-manipulation instructions - Eight addressing modes - Register direct [Rn] - Register indirect [@ERn] - Register indirect with displacement [@(d:16, ERn) or @(d:24, ERn)] - Register indirect with post-increment or pre-decrement [@ERn+ or @-ERn] - Absolute address [@aa:8, @aa:16, or @aa:24] - Immediate [#xx:8, #xx:16, or #xx:32] - Program-counter relative [@(d:8, PC) or @(d:16, PC)] - Memory indirect [@@aa:8] - 64-kbyte address space - High-speed operation - All frequently-used instructions execute in two to four states - Maximum clock frequency: 16 MHz - 8/16/32-bit register-register add/subtract: 2 states - $16 \div 8$ -bit register-register divide: 14 states - $16 \times 16$ -bit register-register multiply: 22 states - $32 \div 16$ -bit register-register divide: 22 states • Low-power mode Transition to low-power state by SLEEP instruction ## 2.2 Address Space and Memory Map The address space of the H8/3664 Series CPU is 64 kbytes, which includes the program area and the data area. Figures 2.1 and 2.2 show the memory map. Figure 2.1 Memory Map (1) Figure 2.2 Memory Map (2) ## 2.3 Register Configuration The H8/300H CPU has the internal registers shown in figure 2.3. There are two types of registers: general registers and control registers. Control registers are 24-bit program counter (PC) and 8-bit condition code register (CCR). | 15 | | 0 | 7 | 0 7 | 0 | |--------------------------------------|--------------------------------------------------------|----|--------|-----|----------------------------| | ER0 | E0 | | R0H | | R0L | | ER1 | E1 | | R1H | | R1L | | ER2 | E2 | | R2H | | R2L | | ER3 | E3 | | R3H | | R3L | | ER4 | E4 | | R4H | | R4L | | ER5 | E5 | | R5H | | R5L | | ER6 | E6 | | R6H | | R6L | | ER7 | E7 | (S | P) R7H | | R7L | | | | | | | 5 4 3 2 1 0<br>H U N Z V C | | Legend<br>SP: Stack p<br>PC: Prograr | ointer<br>n counter<br>on code register<br>ot mask bit | | | | | Figure 2.3 CPU Internal Registers #### 2.3.1 General Registers The H8/300H CPU has eight 32-bit general registers. These general registers are all functionally alike and can be used without distinction between data registers and address registers. When a general register is used as a data register, it can be accessed as a 32-bit, 16-bit, or 8-bit register. When the general registers are used as 32-bit registers or as address registers, they are designated by the letters ER (ER0 to ER7). The ER registers divide into 16-bit general registers designated by the letters E (E0 to E7) and R (R0 to R7). These registers are functionally equivalent, providing a maximum sixteen 16-bit registers. The E registers (E0 to E7) are also referred to as extended registers. The R registers divide into 8-bit general registers designated by the letters RH (R0H to R7H) and RL (R0L to R7L). These registers are functionally equivalent, providing a maximum of sixteen 8-bit registers. Figure 2.4 illustrates the usage of the general registers. The usage of each register can be selected independently. Figure 2.4 Usage of General Registers General register ER7 has the function of stack pointer (SP) in addition to its general-register function, and is used implicitly in exception handling and subroutine calls. Figure 2.5 shows the stack. Figure 2.5 Relationship between Stack Pointer and Stack Area #### 2.3.2 Program Counter (PC) This 24-bit counter indicates the address of the next instruction the CPU will execute. The length of all CPU instructions is 2 bytes (one word) or a multiple of 2 bytes, so the least significant PC bit is ignored. When an instruction is fetched, the least significant PC bit is regarded as 0. The PC is initialized when the start address is loaded by the vector address generated during reset exception-handling sequence. ### 2.3.3 Condition Code Register (CCR) This 8-bit register contains internal CPU status information, including the interrupt mask bit (I) and half-carry (H), negative (N), zero (Z), overflow (V), and carry (C) flags. The I bit is initialized to 1 by reset exception-handling sequence, but other bits are not initialized. **Bit 7—Interrupt Mask Bit (I):** Masks interrupts other than NMI when set to 1. NMI is accepted regardless of the I bit setting. **Bit 6—User Bit (UI):** Can be written and read by software using the LDC, STC, ANDC, ORC, and XORC instructions. **Bit 5—Half-Carry Flag (H):** When the ADD.B, ADDX.B, SUB.B, SUBX.B, CMP.B, or NEG.B instruction is executed, this flag is set to 1 if there is a carry or borrow at bit 3, and cleared to 0 otherwise. When the ADD.W, SUB.W, CMP.W, or NEG.W instruction is executed, the H flag is set to 1 if there is a carry or borrow at bit 11, and cleared to 0 otherwise. When the ADD.L, SUB.L, CMP.L, or NEG.L instruction is executed, the H flag is set to 1 if there is a carry or borrow at bit 27, and cleared to 0 otherwise. **Bit 4—User Bit (U):** Can be written and read by software using the LDC, STC, ANDC, ORC, and XORC instructions. Bit 3—Negative Flag (N): Indicates the most significant bit (sign bit) of data. Bit 2—Zero Flag (Z): Set to 1 to indicate zero data, and cleared to 0 to indicate non-zero data. **Bit 1—Overflow Flag (V):** Set to 1 when an arithmetic overflow occurs, and cleared to 0 at other times. Bit 0—Carry Flag (C): Set to 1 when a carry occurs, and cleared to 0 otherwise. Used by: - Add instructions, to indicate a carry - Subtract instructions, to indicate a borrow - Shift and rotate instructions, to store the value shifted out of the end bit The carry flag is also used as a bit accumulator by bit manipulation instructions. Some instructions leave flag bits unchanged. Operations can be performed on CCR by the LDC, STC, ANDC, ORC, and XORC instructions. The N, Z, V, and C flags are used by conditional branch (Bcc) instructions. For the action of each instruction on the flag bits, see appendix A.1, Instruction List. ### 2.4 Data Formats The H8/300H CPU can process 1-bit, 4-bit (BCD), 8-bit (byte), 16-bit (word), and 32-bit (longword) data. Bit-manipulation instructions operate on 1-bit data by accessing bit n (n = 0, 1, 2, ..., 7) of byte operand data. The DAA and DAS decimal-adjust instructions treat byte data as two digits of 4-bit BCD data. ### 2.4.1 General Register Data Formats Figures 2.6 and 2.7 show the data formats in general registers. | Data Type | General<br>Register | Data Format | |----------------|---------------------|--------------------------------------------| | 1-bit data | RnH | 7 0<br>7 6 5 4 3 2 1 0 Don't care | | 1-bit data | RnL | Don't care 7 6 5 4 3 2 1 0 | | 4-bit BCD data | RnH | 7 4 3 0 Upper digit Lower digit Don't care | | 4-bit BCD data | RnL | Don't care Upper digit Lower digit | | Byte data | RnH | 7 0 Don't care MSB LSB | | Byte data | RnL | 7 0 Don't care | Figure 2.6 General Register Data Formats (1) Figure 2.7 General Register Data Formats (2) #### 2.4.2 Memory Data Formats Figure 2.8 shows the data formats on memory. The H8/300H CPU can access word data and longword data on memory, but word or longword data must begin at an even address. If an attempt is made to access word or longword data at an odd address, no address error occurs but the least significant bit of the address is regarded as 0, so the access starts at the preceding address. This also applies to instruction fetches. When ER7 (SP) is used as an address register to access the stack, the operand size should be word size or longword size. Figure 2.8 Memory Data Formats ## 2.5 Instruction Set #### 2.5.1 Instruction Set Overview The H8/300H CPU has 62 types of instructions. Tables 2.1 to 2.8 summarize the instructions in each functional category. The operation notation used in these tables is defined next. ## **Operation Notation** | Rd | General register (destination)* | | |---------------|--------------------------------------------------------|--| | Rs | General register (source)* | | | Rn | General register* | | | ERn | General register (32-bit register or address register) | | | (EAd) | Destination operand | | | (EAs) | Source operand | | | CCR | Condition code register | | | N | N (negative) flag of CCR | | | Z | Z (zero) flag of CCR | | | V | V (overflow) flag of CCR | | | С | C (carry) flag of CCR | | | PC | Program counter | | | SP | Stack pointer | | | #IMM | Immediate data | | | disp | Displacement | | | + | Addition | | | _ | Subtraction | | | × | Multiplication | | | ÷ | Division | | | ٨ | AND logical | | | | OR logical | | | $\oplus$ | Exclusive OR logical | | | $\rightarrow$ | Move | | | 7 | NOT (logical complement) | | | :3/:8/:16/:24 | 3-, 8-, 16-, or 24-bit length | | Note: \* General registers include 8-bit registers (R0H to R7H, R0L to R7L), 16-bit registers (R0 to R7, E0 to E7), and 32-bit data or address registers (ER0 to ER7). **Table 2.1 Data Transfer Instructions** | Instruction | Size* | Function | | |-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------|--| | MOV | B/W/L | $(EAs) \rightarrow Rd, Rs \rightarrow (EAd)$ | | | | | Moves data between two general registers or between a general register and memory, or moves immediate data to a general register. | | | MOVFPE | В | (EAs) o Rd | | | | | Cannot be used in the H8/3664 Series. | | | MOVTPE | В | $Rs \rightarrow (EAs)$ | | | | | Cannot be used in the H8/3664 Series. | | | POP | W/L | $@SP+ \rightarrow Rn$ | | | | | Pops a general register from the stack. POP.W Rn is identical to MOV.W @SP+, Rn. Similarly, POP.L ERn is identical to MOV.L @SP+, ERn. | | | PUSH | W/L | $Rn \rightarrow @-SP$ | | | | | Pushes a general register onto the stack. PUSH.W Rn is identical to MOV.W Rn, @-SP. Similarly, PUSH.L ERn is identical to MOV.L ERn, @-SP. | | B: Byte W: Word L: Longword **Table 2.2** Arithmetic Operation Instructions | | • | • | | |-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Instruction | Size* | Function | | | ADD, SUB | B/W/L | $Rd \pm Rs \to Rd, Rd \pm \#IMM \to Rd$ | | | | | Performs addition or subtraction on data in two general registers, or on immediate data and data in a general register. (Immediate byte data cannot be subtracted from data in a general register. Use the SUBX or ADD instruction.) | | | ADDX, SUBX | В | $Rd \pm Rs \pm C \rightarrow Rd, Rd \pm \#IMM \pm C \rightarrow Rd$ | | | | | Performs addition or subtraction with carry or borrow on data in two general registers, or on immediate data and data in a general register. | | | INC, DEC | B/W/L | $Rd \pm 1 \rightarrow Rd, Rd \pm 2 \rightarrow Rd$ | | | | | Increments or decrements a general register by 1 or 2. (Byte operands can be incremented or decremented by 1 only.) | | | ADDS, SUBS | L | $Rd \pm 1 \rightarrow Rd, Rd \pm 2 \rightarrow Rd, Rd \pm 4 \rightarrow Rd$ | | | | | Adds or subtracts the value 1, 2, or 4 to or from data in a 32-bit register. | | | DAA, DAS | В | $Rd \; decimal \; adjust \to Rd$ | | | | | Decimal-adjusts an addition or subtraction result in a general register by referring to CCR to produce 4-bit BCD data. | | | MULXU | B/W | $Rd \times Rs \rightarrow Rd$ | | | | | Performs unsigned multiplication on data in two general registers: either 8 bits $\times$ 8 bits $\rightarrow$ 16 bits or 16 bits $\times$ 16 bits $\rightarrow$ 32 bits. | | | MULXS | B/W | $Rd \times Rs \rightarrow Rd$ | | | | | Performs signed multiplication on data in two general registers: either 8 bits $\times$ 8 bits $\rightarrow$ 16 bits or 16 bits $\times$ 16 bits $\rightarrow$ 32 bits. | | | DIVXU | B/W | $Rd \div Rs \rightarrow Rd$ | | | | | Performs unsigned division on data in two general registers: either 16 bits $\div$ 8 bits $\rightarrow$ 8-bit quotient and 8-bit remainder or 32 bits $\div$ 16 bits $\rightarrow$ 16-bit quotient and 16-bit remainder. | | | DIVXS | B/W | $Rd \div Rs \rightarrow Rd$ | | | | | Performs signed division on data in two general registers: either 16 bits $\div$ 8 bits $\rightarrow$ 8-bit quotient and 8-bit remainder, or 32 bits $\div$ 16 bits $\rightarrow$ 16-bit quotient and 16-bit remainder. | | | CMP | B/W/L | Rd – Rs, Rd – #IMM | | | | | Compares data in a general register with data in another general register or with immediate data, and sets CCR according to the result. | | | Instruction | Size* | Function | | |-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | NEG | B/W/L | $0 - Rd \rightarrow Rd$ | | | | | Takes the two's complement (arithmetic complement) of data in a general register. | | | EXTS | W/L | Rd (sign extension) → Rd | | | | | Extends byte data in the lower 8 bits of a 16-bit register to word data, or extends word data in the lower 16 bits of a 32-bit register to longword data, by extending the sign bit. | | | EXTU | W/L | $Rd\ (zero\ extension) o Rd$ | | | | | Extends byte data in the lower 8 bits of a 16-bit register to word data, or extends word data in the lower 16 bits of a 32-bit register to longword data, by padding with zeros. | | B: ByteW: WordL: Longword **Table 2.3** Logic Operation Instructions | Instruction | Size* | Function | | |-------------|-------|-----------------------------------------------------------------------------------------------------------------|--| | AND | B/W/L | $Rd \wedge Rs \rightarrow Rd, Rd \wedge \#IMM \rightarrow Rd$ | | | | | Performs a logical AND operation on a general register and another general register or immediate data. | | | OR | B/W/L | $Rd \lor Rs \rightarrow Rd, Rd \lor \#IMM \rightarrow Rd$ | | | | | Performs a logical OR operation on a general register and another general register or immediate data. | | | XOR | B/W/L | $Rd \oplus Rs \rightarrow Rd, Rd \oplus \#IMM \rightarrow Rd$ | | | | | Performs a logical exclusive OR operation on a general register and another general register or immediate data. | | | NOT | B/W/L | $\neg Rd \rightarrow Rd$ | | | | | Takes the one's complement of general register contents. | | B: Byte W: Word L: Longword **Table 2.4** Shift Instructions | Instruction | Size* | Function | |-------------|-------|------------------------------------------------------------| | SHAL, | B/W/L | $Rd (shift) \rightarrow Rd$ | | SHAR | | Performs an arithmetic shift on general register contents. | | SHLL, | B/W/L | $Rd ext{ (shift)} o Rd$ | | SHLR | | Performs a logical shift on general register contents. | | ROTL, | B/W/L | Rd (rotate) → Rd | | ROTR | | Rotates general register contents. | | ROTXL, | B/W/L | Rd (rotate) → Rd | | ROTXR | | Rotates general register contents through the carry bit. | Note: \* Size refers to the operand size. B: Byte W: Word L: Longword **Table 2.5** Bit Manipulation Instructions | Instruction | Size* | Function | | |-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | BSET | В | $1 \rightarrow (\text{sbit-No.} > \text{of } < \text{EAd} >)$ | | | | | Sets a specified bit in a general register or memory operand to 1. The bit number is specified by 3-bit immediate data or the lower 3 bits of a general register. | | | BCLR | В | $0 \rightarrow (\text{sbit-No.> of } \text{EAd>})$ | | | | | Clears a specified bit in a general register or memory operand to 0. The bit number is specified by 3-bit immediate data or the lower 3 bits of a general register. | | | BNOT | В | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> (<bit-no.> of <ead>)</ead></bit-no.></ead></bit-no.> | | | | | Inverts a specified bit in a general register or memory operand. The bit number is specified by 3-bit immediate data or the lower 3 bits of a general register. | | | BTST | В | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> Z</ead></bit-no.> | | | | | Tests a specified bit in a general register or memory operand and sets or clears the Z flag accordingly. The bit number is specified by 3-bit immediate data or the lower 3 bits of a general register. | | | BAND | В | $C \land ($ < bit-No.> of < EAd> $) \rightarrow C$ | | | | | ANDs the carry flag with a specified bit in a general register or memory operand and stores the result in the carry flag. | | | BIAND | В | $C \wedge [\neg \ (sbit\text{-No.}>\ of\ )] \to C$ | | | | | ANDs the carry flag with the inverse of a specified bit in a general register or memory operand and stores the result in the carry flag. | | | | | The bit number is specified by 3-bit immediate data. | | | BOR | В | $C \lor (\ of\ ) \to C$ | | | | | ORs the carry flag with a specified bit in a general register or memory operand and stores the result in the carry flag. | | | BIOR | В | $C \vee [\neg \ ( of } )] \to C$ | | | | | ORs the carry flag with the inverse of a specified bit in a general register or memory operand and stores the result in the carry flag. | | | | | The bit number is specified by 3-bit immediate data. | | | Instruction | Size* | Function | | |-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|--| | BXOR | В | $C \oplus (\;of\;) \to C$ | | | | | Exclusive-ORs the carry flag with a specified bit in a general registe or memory operand and stores the result in the carry flag. | | | BIXOR | В | $C \oplus [\neg \ (\text{\rm of })] \to C$ | | | | | Exclusive-ORs the carry flag with the inverse of a specified bit in a general register or memory operand and stores the result in the carry flag. | | | | | The bit number is specified by 3-bit immediate data. | | | BLD | В | $($<br>bit-No.> of <ead><math>) \rightarrow C</math></ead> | | | | | Transfers a specified bit in a general register or memory operand to the carry flag. | | | BILD | В | $\neg \; (}\;of\;) \to C$ | | | | | Transfers the inverse of a specified bit in a general register or memory operand to the carry flag. | | | | | The bit number is specified by 3-bit immediate data. | | | BST | В | $C \rightarrow (\text{sbit-No.> of } \text{EAd>})$ | | | | | Transfers the carry flag value to a specified bit in a general register or memory operand. | | | BIST | В | $C \rightarrow \neg$ ( <bit-no.> of <ead>)</ead></bit-no.> | | | | | Transfers the inverse of the carry flag value to a specified bit in a general register or memory operand. | | | | | The bit number is specified by 3-bit immediate data. | | B: Byte **Table 2.6 Branching Instructions** | Bcc* | _ | | Branches to a specified address if a specified condition is true. The branching conditions are listed below. | | | |------|---|----------------|--------------------------------------------------------------------------------------------------------------|---------------------------|--| | | | Mnemonic | Description | Condition | | | | | BRA (BT) | Always (true) | Always | | | | | BRN (BF) | Never (false) | Never | | | | | BHI | High | $C \lor Z = 0$ | | | | | BLS | Low or same | C ∨ Z = 1 | | | | | Bcc (BHS) | Carry clear (high or same) | C = 0 | | | | | BCS (BLO) | Carry set (low) | C = 1 | | | | | BNE | Not equal | Z = 0 | | | | | BEQ | Equal | Z = 1 | | | | | BVC | Overflow clear | V = 0 | | | | | BVS | Overflow set | V = 1 | | | | | BPL | Plus | N = 0 | | | | | ВМІ | Minus | N = 1 | | | | | BGE | Greater or equal | N ⊕ V = 0 | | | | | BLT | Less than | N ⊕ V = 1 | | | | | BGT | Greater than | $Z \vee (N \oplus V) = 0$ | | | | | BLE | Less or equal | $Z \vee (N \oplus V) = 1$ | | | | | | | | | | JMP | | Branches unco | onditionally to a specified addres | SS | | | BSR | _ | Branches to a | subroutine at a specified addres | ss | | | JSR | | Branches to a | subroutine at a specified addres | SS | | | RTS | _ | Returns from a | subroutine | | | Note: \* Conditional branch instructions are generally called the Bcc instructions. **Table 2.7 System Control Instructions** | Instruction | Size* | Function | | |-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | TRAPA | _ | Starts trap-instruction exception handling | | | RTE | _ | Returns from an exception-handling routine | | | SLEEP | _ | Causes a transition to the power-down state | | | LDC | B/W | (EAs) o CCR | | | | | Moves the source operand contents to the condition code register. The condition code register size is one byte, but in transfer from memory, data is read by word access. | | | STC | B/W | $CCR \to (EAd)$ | | | | | Transfers the CCR contents to a destination location. The condition code register size is one byte, but in transfer to memory, data is written by word access. | | | ANDC | В | $CCR \land \#IMM \rightarrow CCR$ | | | | | Logically ANDs the condition code register with immediate data. | | | ORC | В | CCR ∨ #IMM → CCR | | | | | Logically ORs the condition code register with immediate data. | | | XORC | В | $CCR \oplus \#IMM \rightarrow CCR$ | | | | | Logically exclusive-ORs the condition code register with immediate data. | | | NOP | _ | $PC + 2 \rightarrow PC$ | | | | | Only increments the program counter. | | B: Byte W: Word **Table 2.8** Block Transfer Instruction | Instruction | Size | Function | | |-------------|------|--------------------------------------------------------------------------------------------------|--| | EEPMOV.B | _ | if R4L ≠ 0 then | | | | | repeat @ER5+ $\rightarrow$ @ER6+, R4L – 1 $\rightarrow$ R4L until R4L = 0 | | | | | else next; | | | EEPMOV.W | _ | if R4 ≠ 0 then | | | | | repeat @ER5+ $\rightarrow$ @ER6+, R4 – 1 $\rightarrow$ R4 until R4 = 0 | | | | | else next; | | | | | Transfers a data block according to parameters set in general registers R4L or R4, ER5, and ER6. | | | | | R4L or R4: Size of block (bytes) ER5: Starting source address ER6: Starting destination address | | | | | Execution of the next instruction begins as soon as the transfer is completed. | | #### 2.5.2 Basic Instruction Formats The H8/300H instructions consist of 2-byte (1-word) units. An instruction consists of an operation field (OP field), a register field (r field), an effective address extension (EA field), and a condition field (cc field). **Operation Field:** Indicates the function of the instruction, the addressing mode, and the operation to be carried out on the operand. The operation field always includes the first 4 bits of the instruction. Some instructions have two operation fields. **Register Field:** Specifies a general register. Address registers are specified by 3 bits, data registers by 3 bits or 4 bits. Some instructions have two register fields. Some have no register field. **Effective Address Extension:** 8, 16, or 32 bits specifying immediate data, an absolute address, or a displacement. A 24-bit address or displacement is treated as 32-bit data in which the first 8 bits are 0 (H'00). **Condition Field:** Specifies the branching condition of Bcc instructions. Figure 2.9 shows examples of instruction formats. Figure 2.9 Instruction Formats # 2.6 Addressing Modes and Effective Address Calculation The following describes the H8/300H CPU. In the H8/3664 Series, the upper eight bits are ignored in the generated 24-bit address, so the effective address is 16 bits. #### 2.6.1 Addressing Modes The H8/300H CPU supports the eight addressing modes listed in table 2.9. Each instruction uses a subset of these addressing modes. Addressing modes that can be used differ depending on the instruction. For details, refer to appendix A, CPU Instruction Set. Arithmetic and logic instructions can use the register direct and immediate modes. Data transfer instructions can use all addressing modes except program-counter relative and memory indirect. Bit manipulation instructions use register direct, register indirect, or absolute (@aa:8) addressing mode to specify an operand, and register direct (BSET, BCLR, BNOT, and BTST instructions) or immediate (3-bit) addressing mode to specify a bit number in the operand. **Table 2.9 Addressing Modes** | No. | Addressing Mode | Symbol | |-----|---------------------------------------|---------------------------| | 1 | Register direct | Rn | | 2 | Register indirect | @ERn | | 3 | Register indirect with displacement | @(d:16, ERn)/@(d:24, ERn) | | 4 | Register indirect with post-increment | @ERn+ | | | Register indirect with pre-decrement | @-ERn | | 5 | Absolute address | @aa:8/@aa:16/@aa:24 | | 6 | Immediate | #xx:8/#xx:16/#xx:32 | | 7 | Program-counter relative | @(d:8, PC)/@(d:16, PC) | | 8 | Memory indirect | @@aa:8 | - **1 Register Direct—Rn:** The register field of the instruction code specifies an 8-, 16-, or 32-bit register containing the operand. R0H to R7H and R0L to R7L can be specified as 8-bit registers. R0 to R7 and E0 to E7 can be specified as 16-bit registers. ER0 to ER7 can be specified as 32-bit registers. - **2 Register Indirect**—@**ERn:** The register field of the instruction code specifies an address register (ERn), the lower 24 bits of which contain the address of the operand. - 3 Register Indirect with Displacement—@(d:16, ERn) or @(d:24, ERn): A 16-bit or 24-bit displacement contained in the instruction code is added to the contents of an address register (ERn) specified by the register field of the instruction, and the lower 24 bits of the sum specify the address of a memory operand. A 16-bit displacement is sign-extended when added. #### 4 Register Indirect with Post-Increment or Pre-Decrement—@ERn+ or @-ERn: - Register indirect with post-increment—@ERn+ The register field of the instruction code specifies an address register (ERn) the lower 24 bits of which contain the address of a memory operand. After the operand is accessed, 1, 2, or 4 is added to the address register contents (32 bits) and the sum is stored in the address register. The value added is 1 for byte access, 2 for word access, or 4 for longword access. For word or longword access, the register value should be even. - Register indirect with pre-decrement—@-ERn The value 1, 2, or 4 is subtracted from an address register (ERn) specified by the register field in the instruction code, and the lower 24 bits of the result become the address of a memory operand. The result is also stored in the address register. The value subtracted is 1 for byte access, 2 for word access, or 4 for longword access. For word or longword access, the resulting register value should be even. - **5 Absolute Address**—@aa:8, @aa:16, or @aa:24: The instruction code contains the absolute address of a memory operand. The absolute address may be 8 bits long (@aa:8), 16 bits long (@aa:16), or 24 bits long (@aa:24). For an 8-bit absolute address, the upper 16 bits are all assumed to be 1 (H'FFFF). For a 16-bit absolute address the upper 8 bits are a sign extension. A 24-bit absolute address can access the entire address space. Table 2.10 indicates the accessible address ranges. Table 2.10 Absolute Address Access Ranges | Absolute Address | Access Range | |------------------|------------------| | 8 bits (@aa:8) | H'FF00 to H'FFFF | | 16 bits (@aa:16) | H'0000 to H'FFFF | | 24 bits (@aa:24) | H'0000 to H'FFFF | **6 Immediate—#xx:8, #xx:16, or #xx:32:** The instruction code contains 8-bit (#xx:8), 16-bit (#xx:16), or 32-bit (#xx:32) immediate data as an operand. The instruction codes of the ADDS, SUBS, INC, and DEC instructions contain immediate data implicitly. The instruction codes of some bit manipulation instructions contain 3-bit immediate data specifying a bit number. The TRAPA instruction code contains 2-bit immediate data specifying a vector address. - **7 Program-Counter Relative**—@(**d:8, PC**) **or** @(**d:16, PC**): This mode is used in the Bcc and BSR instructions. An 8-bit or 16-bit displacement contained in the instruction code is sign-extended to 24 bits and added to the 24-bit PC contents to generate a 24-bit branch address. The PC value to which the displacement is added is the address of the first byte of the next instruction, so the possible branching range is –126 to +128 bytes (–63 to +64 words) or –32766 to +32768 bytes (–16383 to +16384 words) from the branch instruction. The resulting value should be an even number. - **8 Memory Indirect**—@@aa:8: This mode can be used by the JMP and JSR instructions. The instruction code contains an 8-bit absolute address specifying a memory operand. This memory operand contains a branch address. The memory operand is accessed by longword access. The first byte of the memory operand is ignored, generating a 24-bit branch address. See figure 2.10. The upper bits of the 8-bit absolute address are assumed to be 0 (H'0000), so the address range is 0 to 255 (H'0000 to H'00FF). Note that the first part of this range is also the exception vector area. Figure 2.10 Memory-Indirect Branch Address Specification #### 2.6.2 Effective Address Calculation Table 2.11 explains how an effective address (EA) is calculated in each addressing mode. In the H8/3664 Series, the upper 8 bits of the calculated address are ignored in order to generate a 16-bit effective address. Table 2.11 Effective Address Calculation 8 Memory indirect @@aa:8 ## Legend: r, rm, rn: Register field op: Operation field disp: Displacement IMM: Immediate data abs: Absolute address Note: In the H8/3664 Series, the upper 8 bits of the calculation result are ignored. ## 2.7 Basic Bus Cycle CPU operation is synchronized by a system clock $(\emptyset)$ or a subclock $(\emptyset_{SUB})$ . For details on these clock signals see section 4, Clock Pulse Generators. The period from a rising edge of $\emptyset$ or $\emptyset_{SUB}$ to the next rising edge is called one state. A bus cycle consists of two states or three states. The cycle differs depending on whether access is to on-chip memory or to on-chip peripheral modules. #### 2.7.1 Access to On-Chip Memory (RAM, ROM) Access to on-chip memory takes place in two states. The data bus width is 16 bits, allowing access in byte or word size. Figure 2.11 shows the on-chip memory access cycle. Figure 2.11 On-Chip Memory Access Cycle #### 2.7.2 Access to On-Chip Peripheral Modules On-chip peripheral modules are accessed in two states or three states. The data bus width is 8 bits or 16 bits depending on the register. For description on the data bus width of each register, refer to appendix B, Internal I/O Registers. Registers with 16-bit data bus width can be accessed by word size only. Registers with 8-bit data bus width can be accessed by byte or word size. When a register with 8-bit data bus width is accessed by word size, access is completed in two cycles. In two-state access, the operation timing is the same as that for on-chip memory. Figure 2.12 shows the operation timing in the case of three-state access to an on-chip peripheral module. Figure 2.12 On-Chip Peripheral Module Access Cycle (3-State Access) #### 2.8 CPU States #### 2.8.1 Overview There are four CPU states: the reset state, program execution state, program halt state, and exception-handling state. The program execution state includes active mode and subactive mode. In the program halt state there are a sleep mode, standby mode, and sub-sleep mode. These states are shown in figure 2.13. Figure 2.14 shows the state transitions. For details on program execution state and program halt state, refer to section 6, Power-Down Modes. For details on exception processing, refer to section 3, Exception Handling. Figure 2.13 CPU Operation States Figure 2.14 State Transitions # 2.9 Application Notes #### 2.9.1 Notes on Data Access to Empty Areas The address space of the H8/3664 Series CPU includes empty areas in addition to the RAM, registers, and ROM areas available to the user. If these empty areas are mistakenly accessed by an application program, the following results will occur. - Data transfer from CPU to empty area The transferred data will be lost. This action may also cause the CPU to misoperate. - Data transfer from empty area to CPU Unpredictable data is transferred. #### 2.9.2 Notes on Bit Manipulation The BSET, BCLR, BNOT, BST, and BIST instructions read one byte of data, modify the data, then write the data byte again. Special care is required when using these instructions in cases where two registers are assigned to the same address, in the case of registers that include write-only bits, and when the instruction accesses an I/O port. | Order of Operation | | Operation | | | | |-------------------------------------------------|--------|-------------------------------------------------------|--|--|--| | 1 Read Read byte data at the designated address | | | | | | | 2 | Modify | Modify a designated bit in the read data | | | | | 3 | Write | Write the altered byte data to the designated address | | | | ## Bit Manipulation in Two Registers Assigned to the Same Address **Example 1:** Timer load register and timer counter (This applies to timers B and C. It does not apply to the H8/3664 Series.) Figure 2.15 shows an example in which two timer registers share the same address. When a bit manipulation instruction accesses the timer load register and timer counter of a reloadable timer, since these two registers share the same address, the following operations take place. | Order of Operation | | Operation | | | | |----------------------------------------------|--------|-------------------------------------------------------------------------|--|--|--| | 1 Read Timer counter data is read (one byte) | | | | | | | 2 | Modify | The CPU modifies (sets or resets) the designated bit in the instruction | | | | | 3 | Write | The altered byte data is written to the timer load register | | | | The timer counter is counting, so the value read is not necessarily the same as the value in the timer load register. As a result, bits other than the intended bit in the timer load register may be modified to the timer counter value. Figure 2.15 Timer Configuration Example ### Example 2: BSET instruction executed designating port 5 $P5_7$ and $P5_6$ are designated as input pins, with a low-level signal input at $P5_7$ and a high-level signal input at $P5_6$ . The remaining pins, $P5_5$ to $P5_0$ , are output pins and output low-level signals. In this example, the BSET instruction is used to change pin $P5_0$ to high-level output. #### [A: Prior to executing BSET] | | P5 <sub>7</sub> | P5 <sub>6</sub> | P5 <sub>5</sub> | P5 <sub>4</sub> | P5 <sub>3</sub> | P5 <sub>2</sub> | P5 <sub>1</sub> | P5 <sub>0</sub> | |--------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low<br>level | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | | PCR5 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | PDR5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### [B: BSET instruction executed] | BSET | #0, | @PDR5 | |------|-----|-------| | | | | The BSET instruction is executed designating port 5. #### [C: After executing BSET] | | P5 <sub>7</sub> | P5 <sub>6</sub> | P5 <sub>5</sub> | P5 <sub>4</sub> | P5 <sub>3</sub> | P5 <sub>2</sub> | P5 <sub>1</sub> | P5 <sub>0</sub> | |--------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low<br>level | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | High<br>level | | PCR5 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | PDR5 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | ## [D: Explanation of how BSET operates] When the BSET instruction is executed, first the CPU reads port 5. Since P5<sub>7</sub> and P5<sub>6</sub> are input pins, the CPU reads the pin states (low-level and high-level input). P5<sub>5</sub> to P5<sub>0</sub> are output pins, so the CPU reads the value in PDR5. In this example PDR5 has a value of H'80, but the value read by the CPU is H'40. Next, the CPU sets bit 0 of the read data to 1, changing the PDR5 data to H'41. Finally, the CPU writes this value (H'41) to PDR5, completing execution of BSET. As a result of this operation, bit 0 in PDR5 becomes 1, and $P5_0$ outputs a high-level signal. However, bits 7 and 6 of PDR5 end up with different values. To avoid this problem, store a copy of the PDR5 data in a work area in memory. Perform the bit manipulation on the data in the work area, then write this data to PDR5. ## [A: Prior to executing BSET] | MOV.B | #80, | ROL | |-------|------|-------| | MOV.B | ROL, | @RAM0 | | MOV.B | ROL, | @PDR5 | The PDR5 value (H'80) is written to a work area in memory (RAM0) as well as to PDR5. | | P5 <sub>7</sub> | P5 <sub>6</sub> | P5 <sub>5</sub> | P5 <sub>4</sub> | P5 <sub>3</sub> | P5 <sub>2</sub> | P5 <sub>1</sub> | P5 <sub>0</sub> | |--------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low<br>level | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | | PCR5 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | PDR5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | RAM0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## [B: BSET instruction executed] | BSET | #0, | @RAM0 | |------|-----|-------| |------|-----|-------| The BSET instruction is executed designating the PDR5 work area (RAM0). ## [C: After executing BSET] | MOV.B | @RAM0, ROL | |-------|------------| | MOV.B | ROL, @PDR5 | The work area (RAM0) value is written to PDR5. | | P5, | P5 <sub>6</sub> | P5 <sub>5</sub> | P5₄ | P5 <sub>3</sub> | P5 <sub>2</sub> | P5 <sub>1</sub> | P5 <sub>0</sub> | |--------------|-------|-----------------|-----------------|--------------|-----------------|-----------------|-----------------|-----------------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | High<br>level | | PCR5 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | PDR5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | RAM0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ### Bit Manipulation in a Register Containing a Write-Only Bit #### **Example 3:** BCLR instruction executed designating port 5 control register PCR5 As in the examples above, $P5_7$ and $P5_6$ are input pins, with a low-level signal input at $P5_7$ and a high-level signal input at $P5_6$ . The remaining pins, $P5_5$ to $P5_0$ , are output pins that output low-level signals. In this example, the BCLR instruction is used to change pin $P5_0$ to an input port. It is assumed that a high-level signal will be input to this input pin. #### [A: Prior to executing BCLR] | | P5 <sub>7</sub> | P5 <sub>6</sub> | P5₅ | P5₄ | P5 <sub>3</sub> | P5 <sub>2</sub> | P5₁ | P5 <sub>0</sub> | |--------------|-----------------|-----------------|--------------|--------------|-----------------|-----------------|--------------|-----------------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low<br>level | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | | PCR5 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | PDR5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### [B: BCLR instruction executed] | BCLR | #0, | @PCR5 | T | |------|-----|-------|---| | | | | | The BCLR instruction is executed designating PCR5. ### [C: After executing BCLR] | | P5 <sub>7</sub> | P5 <sub>6</sub> | P5 <sub>5</sub> | P5 <sub>4</sub> | P5 <sub>3</sub> | P5 <sub>2</sub> | P5 <sub>1</sub> | P5 <sub>0</sub> | |--------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------| | Input/output | Output Input | | Pin state | Low<br>level | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | High<br>level | | PCR5 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | PDR5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## [D: Explanation of how BCLR operates] When the BCLR instruction is executed, first the CPU reads PCR5. Since PCR5 is a write-only register, the CPU reads a value of H'FF, even though the PCR5 value is actually H'3F. Next, the CPU clears bit 0 in the read data to 0, changing the data to HFE. Finally, this value (HFE) is written to PCR5 and BCLR instruction execution ends. As a result of this operation, bit 0 in PCR5 becomes 0, making $P5_0$ an input port. However, bits 7 and 6 in PCR5 change to 1, so that $P5_7$ and $P5_6$ change from input pins to output pins. To avoid this problem, store a copy of the PCR5 data in a work area in memory. Perform the bit manipulation on the data in the work area, then write this data to PCR5. ## [A: Prior to executing BCLR] | MOV.B | #3F, | R0L | |-------|------|-------| | MOV.B | ROL, | @RAM0 | | MOV.B | ROL, | @PCR5 | The PCR5 value (H'3F) is written to a work area in memory (RAM0) as well as to PCR5. | | P5 <sub>7</sub> | P5 <sub>6</sub> | <b>P5</b> ₅ | P5₄ | P5 <sub>3</sub> | P5 <sub>2</sub> | P5 <sub>1</sub> | P5 <sub>0</sub> | |--------------|-----------------|-----------------|--------------|--------------|-----------------|-----------------|-----------------|-----------------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low<br>level | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | | PCR5 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | PDR5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | RAM0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | ## [B: BCLR instruction executed] | BCLR #0, @RAM0 | |----------------| |----------------| The BCLR instruction is executed designating the PCR5 work area (RAM0). ## [C: After executing BCLR] | MOV.B | @RAMO, ROL | |-------|------------| | MOV.B | ROL, @PCR5 | The work area (RAM0) value is written to PCR5. | | P5 <sub>7</sub> | P5 <sub>6</sub> | P5 <sub>5</sub> | P5₄ | P5 <sub>3</sub> | P5 <sub>2</sub> | P5₁ | P5 <sub>0</sub> | |--------------|-----------------|-----------------|-----------------|--------------|-----------------|-----------------|--------------|-----------------| | Input/output | Input | Input | Output | Output | Output | Output | Output | Output | | Pin state | Low | High<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | Low<br>level | High<br>level | | PCR5 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | | PDR5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | RAM0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | #### 2.9.3 Notes on Use of the EEPMOV Instruction • The EEPMOV instruction is a block data transfer instruction. It moves the number of bytes specified by R4L from the address specified by R5 to the address specified by R6. When setting R4L and R6, make sure that the final destination address (R6 + R4L) does not exceed H'FFFF. The value in R6 must not change from H'FFFF to H'0000 during execution of the instruction. # Section 3 Exception Handling #### 3.1 Overview #### 3.1.1 Exception Handling Types Exception handling is performed in the H8/3664 Series when a reset, interrupt, or trap instruction occurs. Table 3.1 shows these three types of exception handling. A trap instruction can always be accepted when the program is being executed. Table 3.1 Exception Handling Types | Exception Source | Time of Start of Exception Handling | | | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Reset | Exception handling starts as soon as the reset state is cleared | | | | | | Interrupt | When an interrupt is requested, exception handling starts after the present instruction or the exception handling in progress is completed | | | | | | Trap instruction | Execution handling starts up when a TRAP instruction is executed | | | | | #### 3.2 Reset As soon as the $\overline{RES}$ pin is set to low, all processing is stopped and the chip enters the reset state. The internal state of the CPU and the registers of the on-chip peripheral modules are initialized by the reset. To make sure the chip is reset properly, when turning the power on, the $\overline{RES}$ pin should be held at low until the clock pulse generator output stabilizes. When resetting during operation, the $\overline{RES}$ pin should be held at low for at least 10 system clock cycles. Reset exception handling begins when the $\overline{RES}$ pin is held at low for a given period, then returned to the high level. ## 3.2.1 Reset Sequence A reset is the highest-priority exception handling. The sequence of the reset exception handling takes place as follows. - 1. Set the I bit of the condition code register (CCR). - 2. The CPU generates the reset exception handling vector address (H'0000 to H'0001), and transfers the address to PC as a start address. Then a program starts executing from the address indicated in PC. Figure 3.1 shows the reset sequence. ### 3.2.2 Reset by Watchdog Timer When the watchdog timer overflows, the chip enters the reset state and reset exception handling begins. The same reset exception handling is carried out as for input at the $\overline{RES}$ pin. For details on the watchdog timer, see section 13, Watchdog Timer. #### 3.2.3 Interrupt Immediately after Reset After a reset, if the CPU was to accept an interrupt before the stack pointer (SP) was initialized, PC and CCR would not be pushed onto the stack correctly, resulting in control over the program being lost. To prevent this, immediately after reset exception handling all interrupts including $\overline{\text{NMI}}$ are masked. For this reason, the initial program instruction is always executed immediately after a reset. This instruction should initialize the stack pointer (e.g. MOV.W #xx: 16, SP). Figure 3.1 Reset Sequence ## 3.3 Interrupts #### 3.3.1 Interrupt and Vector Address The interrupt sources that start the interrupt exception handling include 11 external interrupts and 20 internal interrupts. Table 3.2 shows the interrupts, their priorities, and their vector addresses. When more than one interrupt is requested, handling is performed from the interrupt with the highest priority. $\overline{\text{NMI}}$ is the highest-priority interrupt, and cannot be masked by the I bit in CCR. All other external interrupts excluding $\overline{\text{NMI}}$ and internal interrupts excluding address break are masked by the I bit in CCR, and kept masked while the I bit is set to 1. **Table 3.2** Interrupt Priorities and Their Vector Addresses | Interrupt Source | Interrupt | Vector Number | Vector Address | Priority | |----------------------------|----------------------------|---------------|------------------|------------------| | RES<br>Watchdog timer | Reset | 0 | H'0000 to H'0001 | High<br><b>Å</b> | | (Reserved by | (Reserved by system) | 1 | H'0002 to H'0003 | | | system) | | 2 | H'0004 to H'0005 | _ | | | | 3 | H'0006 to H'0007 | _ | | | | 4 | H'0008 to H'0009 | _ | | | | 5 | H'000A to H'000B | _ | | | | 6 | H'000C to H'000D | _ | | External pin | NMI | 7 | H'000E to H'000F | _ | | Trap instruction | Trap instruction #0 | 8 | H'0010 to H'0011 | _ | | executed | Trap instruction #1 | 9 | H'0012 to H'0013 | _ | | | Trap instruction #2 | 10 | H'0014 to H'0015 | _ | | | Trap instruction #3 | 11 | H'0016 to H'0017 | _ | | Address break | Break conditions satisfied | 12 | H'0018 to H'0019 | _ | | Sleep instruction executed | Transferred directly | 13 | H'001A to H'001B | - | | External pin | IRQ0 | 14 | H'001C to H'001D | _ | | | IRQ1 | 15 | H'001E to H'001F | _ | | | IRQ2 | 16 | H'0020 to H'0021 | | | | IRQ3 | 17 | H'0022 to H'0023 | | | | WKP5 | 18 | H'0024 to H'0025 | _ \ | | Timer A | Timer A overflow | 19 | H'0026 to H'0027 | Low | | Interrupt Source | Interrupt | <b>Vector Number</b> | Vector Address | Priority | | |------------------------------|-----------------------------------|----------------------|------------------|----------|--| | (Reserved by system) system) | | 20 | H'0028 to H'0029 | High | | | Timer W | Input capture A / compare match A | 21 | H'002A to H'002B | _ | | | | Input capture B / compare match B | | | | | | | Input capture C / compare match C | | | | | | | Input capture D / compare match D | | | | | | | Timer W overflow | | | | | | Timer V | Timer V compare match A | 22 | H'002C to H'002D | - | | | | Timer V compare match B | | | | | | | Timer V overflow | | | | | | SCI3 | SCI3 transmit end | 23 | H'002E to H'002F | _ | | | | SCI3 transmit data empty | | | | | | | SCI3 receive data full | | | | | | | SCI3 overrun error | | | | | | | SCI3 framing error | | | | | | | SCI3 parity error | | | | | | IIC | Data transfer end | 24 | H'0030 to H'0031 | - | | | | Address inequality | | | | | | | Stop conditions detected | | | <b>V</b> | | | A/D converter | A/D conversion end | 25 | H'0032 to H'0033 | Low | | # 3.4 Interrupt Control Registers Table 3.3 lists the registers that control interrupts. **Table 3.3** Interrupt Control Registers | Name | Abbreviation | R/W | Initial Value | Address | |----------------------------------|--------------|------|---------------|---------| | Interrupt edge select register 1 | IEGR1 | R/W | H'70 | H'FFF2 | | Interrupt edge select register 2 | IEGR2 | R/W | H'C0 | H'FFF3 | | Interrupt enable register 1 | IENR1 | R/W | H'10 | H'FFF4 | | Interrupt flag register 1 | IRR1 | R/W* | H'30 | H'FFF6 | | Wakeup interrupt flag register | IWPR | R/W* | H'C0 | H'FFF8 | Note: \* Write is enabled only for writing of 0 to clear a flag. #### 3.4.1 Interrupt Edge Select Register 1 (IEGR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|---|---|---|------|------|------|------| | | NMIEG | _ | _ | _ | IEG3 | IEG2 | IEG1 | IEG0 | | Initial value | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/W | | _ | _ | R/W | R/W | R/W | R/W | IEGR1 is an 8-bit read/write register used to designate whether pins $\overline{NMI}$ and $\overline{IRQ3}$ to $\overline{IRQ0}$ are set to rising edge sensing or falling edge sensing. Upon reset, IEGR1 is initialized to H'70. Bit 7—NMI Edge Select (NMIEG): Bit 7 selects the input sensing of pin NMI. | Bit 7: NMIEG | Description | | |--------------|-------------------------------------------|-----------------| | 0 | Falling edge of NMI pin input is detected | (initial value) | | 1 | Rising edge of NMI pin input is detected | | **Bits 6 to 4—Reserved Bits:** Bits 6 to 4 are reserved; they are always read as 1, and cannot be modified. Bit 3—IRQ<sub>3</sub> Edge Select (IEG3): Bit 3 selects the input sensing of pin $\overline{\text{IRQ3}}$ . | Bit 3: IEG3 | Description | | |-------------|--------------------------------------------|-----------------| | 0 | Falling edge of IRQ3 pin input is detected | (initial value) | | 1 | Rising edge of IRQ3 pin input is detected | | Bit 2—IRQ<sub>2</sub> Edge Select (IEG2): Bit 2 selects the input sensing of pin IRQ2. | Bit 2: IEG2 | Description | | |-------------|--------------------------------------------|-----------------| | 0 | Falling edge of IRQ2 pin input is detected | (initial value) | | 1 | Rising edge of IRQ2 pin input is detected | | Bit 1—IRQ<sub>1</sub> Edge Select (IEG1): Bit 1 selects the input sensing of pin IRQ1. | Bit 1: IEG1 | Description | | |-------------|--------------------------------------------|-----------------| | 0 | Falling edge of IRQ1 pin input is detected | (initial value) | | 1 | Rising edge of IRQ1 pin input is detected | | Bit 0—IRQ<sub>0</sub> Edge Select (IEG0): Bit 0 selects the input sensing of pin $\overline{\text{IRQ0}}$ . | Bit 0: IEG0 | Description | | |-------------|--------------------------------------------|-----------------| | 0 | Falling edge of IRQ0 pin input is detected | (initial value) | | 1 | Rising edge of IRQ0 pin input is detected | | ## 3.4.2 Interrupt Edge Select Register 2 (IEGR2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|-------|-------|-------|-------|-------|-------| | | _ | _ | WPEG5 | WPEG4 | WPEG3 | WPEG2 | WPEG1 | WPEG0 | | Initial value | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | _ | R/W | R/W | R/W | R/W | R/W | R/W | IEGR2 is an 8-bit read/write register used to designate whether pins $\overline{WKP5}$ to $\overline{WKP0}$ are set to rising edge sensing or falling edge sensing. Upon reset, IEGR2 is initialized to H'C0. **Bits 7 and 6—Reserved Bits:** Bits 7 and 6 are reserved; they are always read as 1, and cannot be modified. Bit 5—WKP<sub>5</sub> Edge Select (WPEG5): Bit 5 selects the input sensing of pins $\overline{WKP5}$ and $\overline{ADTRG}$ . | Bit 5: WPEG5 | Description | | |--------------|----------------------------------------------------|-----------------| | 0 | Falling edge of WKP5 (ADTRG) pin input is detected | (initial value) | | 1 | Rising edge of WKP5 (ADTRG) pin input is detected | | Bits 4 to 0—WKP<sub>4</sub> to WKP<sub>0</sub> Edge Select (WPEG4 to WPEG0): Bits 4 to 0 select the input sensing of pins $\overline{WKP4}$ to $\overline{WKP0}$ . | Bit n: WPEGn | Description | | |--------------|--------------------------------------------|-----------------| | 0 | Falling edge of WKPn pin input is detected | (initial value) | | 1 | Rising edge of WKPn pin input is detected | | | | | (n = 4 to 0) | ## 3.4.3 Interrupt Enable Register 1 (IENR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|---|------|------|------|------| | | IENDT | IENTA | IENWP | _ | IEN3 | IEN2 | IEN1 | IEN0 | | Initial value | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/W | R/W | R/W | _ | R/W | R/W | R/W | R/W | IENR1 is an 8-bit read/write register that enables or disables interrupt requests. Upon reset, IENR1 is initialized to H'10. **Bit 7—Direct Transfer Interrupt Enable (IENDT):** Bit 7 enables or disables direct transfer interrupt requests. | Bit 7: IENDT | Description | | |--------------|---------------------------------------------|-----------------| | 0 | Disables direct transfer interrupt requests | (initial value) | | 1 | Enables direct transfer interrupt requests | | **Bit 6—Timer A Interrupt Enable (IENTA):** Bit 6 enables or disables timer A overflow interrupt requests. | Bit 6: IENTA | Description | | |--------------|-------------------------------------|-----------------| | 0 | Disables timer A interrupt requests | (initial value) | | 1 | Enables timer A interrupt requests | | **Bit 5—Wakeup Interrupt Enable (IENWP):** Bit 5 enables or disables $\overline{WKP5}$ to $\overline{WKP0}$ interrupt requests. | Bit 5: IENWP | Description | | |--------------|--------------------------------------------------------------------------------------------|-----------------| | 0 | Disables interrupt requests from pins $\overline{\text{WKP5}}$ to $\overline{\text{WKP0}}$ | (initial value) | | 1 | Enables interrupt requests from pins WKP5 to WKP0 | | Bit 4—Reserved Bit: Bit 4 is reserved; it is always read as 1, and cannot be modified. **Bits 3 to 0—IRQ3 to IRQ0 Interrupt Enable (IEN3 to IEN0):** Bits 3 to 0 enable or disable IRO3 to IRO0 interrupt requests. | Bit n: IENn | Description | | |-------------|-------------------------------------------|-----------------| | 0 | Disables interrupt requests from pin IRQn | (initial value) | | 1 | Enables interrupt requests from pin IRQn | | | | | (n = 3 to 0) | ### 3.4.4 Interrupt Flag Register 1 (IRR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|---|---|-------|-------|-------|-------| | | IRRDT | IRRTA | _ | _ | IRRI3 | IRRI2 | IRRI1 | IRRI0 | | Initial value | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/W | R/W | _ | _ | R/W | R/W | R/W | R/W | IRR1 is an 8-bit read/write register, in which a corresponding flag is set to 1 when a direct transfer, a timer A, or IRQ3 to IRQ0 interrupt is requested. The flags are not cleared automatically when an interrupt is accepted. It is necessary to write 0 to clear each flag. Upon reset, IRR1 is initialized to H'30. ## Bit 7—Direct Transfer Interrupt Request Flag (IRRDT) | Bit 7: IRRDT | Description | | |--------------|--------------------------------------------------------------------------------------------------|-----------------| | 0 | Clearing conditions: When IRRDT = 1, it is cleared by writing 0 | (initial value) | | 1 | Setting conditions: When a direct transfer is made by executing a SLEEP instructio = 1 in SYSCR2 | n while DTON | # Bit 6—Timer A Interrupt Request Flag (IRRTA) | Bit 6: IRRTA | Description | | |--------------|--------------------------------------------------------------------------------|-----------------| | 0 | Clearing conditions: When IRRTA = 1, it is cleared by writing 0 | (initial value) | | 1 | Setting conditions: When the timer A counter value overflows from H'FF to H'00 | | **Bits 5 and 4—Reserved Bits:** Bits 5 and 4 are reserved: they are always read as 1 and cannot be modified. Bit 4—Reserved Bit: Bit 4 is reserved; it is always read as 1, and cannot be modified. ### Bits 3 to 0—IRQ3 to IRQ0 Interrupt Request Flags (IRRI3 to IRRI0) | Bit n: IRRIn | Description | |--------------|---------------------------------------------------------------------------------------------------------------------------| | 0 | Clearing conditions: (initial value) When IRRIn = 1, it is cleared by writing 0 | | 1 | Setting conditions: When pin $\overline{IRQ}_n$ is designated for interrupt input and the designated signal edge is input | | | (n = 3 to 0) | ## 3.4.5 Wakeup Interrupt Flag Register (IWPR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|-------|-------|-------|-------|-------|-------| | | _ | _ | IWPF5 | IWPF4 | IWPF3 | IWPF2 | IWPF1 | IWPF0 | | Initial value | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | _ | R/W | R/W | R/W | R/W | R/W | R/W | IWPR is an 8-bit read/write register, in which a corresponding flag is set to 1 when the designated signal edge is input at pin $\overline{WKP5}$ to $\overline{WKP0}$ . The flags are not cleared automatically when an interrupt is accepted. It is necessary to write 0 to clear each flag. Upon reset, IWPR is initialized to H'C0. Bits 7 and 6—Bits 7 and 6 are reserved; they are always read as 1, and cannot be modified. # Bits 5 to 0—WKP5 to WKP0 Interrupt Request Flags (IWPF5 to IWPF0) | Bit n: IWPFn | Description | |--------------|--------------------------------------------------------------------------------------------------------------------------| | 0 | Clearing conditions: (initial value) When IWPFn = 1, it is cleared by writing 0 | | 1 | Setting conditions: When pin $\overline{WKPn}$ is designated for interrupt input and the designated signal edge is input | | | (n = 5 to 0) | # 3.5 Interrupt Sources #### 3.5.1 External Interrupts There are 11 external interrupts: NMI, IRQ3 to IRQ0, and WKP5 to WKP0. #### NMI Interrupt NMI interrupt is requested by input signal to pin $\overline{\text{NMI}}$ . This interrupt is detected by either rising edge sensing or falling edge sensing, depending on the setting of bit NMIEG in IEGR1. NMI is the highest-priority interrupt, and can always be accepted without depending on the I bit value in CCR. When NMI interrupt exception handling is accepted, the I bit is set to 1 in CCR. #### • IRQ3 to IRQ0 Interrupts IRQ3 to IRQ0 interrupts are requested by input signals to pins $\overline{IRQ3}$ to $\overline{IRQ0}$ . These four interrupts are given different vector addresses, and are detected individually by either rising edge sensing or falling edge sensing, depending on the settings of bits IEG3 to IEG0 in IEGR1. When pins $\overline{IRQ3}$ to $\overline{IRQ0}$ are designated for interrupt input in PMR1 and the designated signal edge is input, the corresponding bit in IRR1 is set to 1, requesting the CPU of an interrupt. When IRQ3 to IRQ0 interrupt is accepted, the I bit is set to 1 in CCR. These interrupts can be masked by setting bits IEN3 to IEN0 in IENR1. #### • WKP5 to WKP0 Interrupts WKP5 to WKP0 interrupts are requested by input signals to pins $\overline{\text{WKP}}$ 5 to $\overline{\text{WKP}}$ 0. These six interrupts have the same vector addresses, and are detected individually by either rising edge sensing or falling edge sensing, depending on the settings of bits WPEG5 to WPEG0 in IEGR2. When pins $\overline{WKP5}$ to $\overline{WKP0}$ are designated for interrupt input in PMR5 and the designated signal edge is input, the corresponding bit in IWPR is set to 1, requesting the CPU of an interrupt. When a WKP5 to WKP0 interrupt is accepted, the I bit is set to 1 in CCR. These interrupts can be masked by setting bit IENWP in IENR1. # 3.5.2 Internal Interrupts There are 20 internal interrupts that can be requested by the on-chip peripheral modules. Each on-chip peripheral module has a flag to show the interrupt request status and the enable bit to enable or disable the interrupt. For timer A interrupt requests and direct transfer interrupt requests generated by execution of a SLEEP instruction, this function is included in IRR1 and IENR1. Table 3.2 shows the order of priority of interrupts and their vector addresses. When an on-chip peripheral module requests an interrupt, the corresponding interrupt request status flag is set to 1, requesting the CPU of an interrupt. When this interrupt is accepted, the I bit is set to 1 in CCR. These interrupts can be masked by writing 0 to clear the corresponding enable bit. ### 3.5.3 Interrupt Operations Interrupts are controlled by an interrupt controller. Interrupt operation is described as follows. - 1. If an interrupt occurs while the NMI or interrupt enable bit is set to 1, an interrupt request signal is sent to the interrupt controller. - 2. From among the interrupts with interrupt request flags set to 1, the interrupt controller selects the interrupt request with the highest priority and holds the others pending. (Refer to table 3.2 for a list of interrupt priorities.) - 3. The CPU accepts the NMI and address break without depending on the I bit value. Other interrupt requests are accepted, if the I bit is cleared to 0 in CCR; if the I bit is set to 1, the interrupt request is held pending. - 4. If the CPU accepts the interrupt after processing of the current instruction is completed, interrupt exception handling will begin. First, both PC and CCR are pushed onto the stack. The state of the stack at this time is shown in figure 3.2. The PC value pushed onto the stack is the address of the first instruction to be executed upon return from interrupt handling. - 5. Then, the I bit of CCR is set to 1, masking further interrupts excluding the NMI and address break. Upon return from interrupt handling, the values of I bit and other bits in CCR will be restored and returned to the values prior to the start of interrupt exception handling. - 6. Next, the CPU generates the vector address corresponding to the accepted interrupt, and transfers the address to PC as a start address of the interrupt handling-routine. Then a program starts executing from the address indicated in PC. - Figure 3.3 shows a typical interrupt sequence where the program area is in the on-chip ROM and the stack area is in the on-chip RAM. - Notes: 1. When disabling interrupts by clearing bits in an interrupt enable register, or when clearing bits in an interrupt flag register, always do so while interrupts are masked (I = 1). - 2. If the above clear operations are performed while I = 0, and as a result a conflict arises between the clear instruction and an interrupt request, exception handling for the interrupt will be executed after the clear instruction has been executed. CCR: Condition code register Stack pointer SP: Notes: 1. PC shows the address of the first instruction to be executed upon return from the interrupt handling routine. 2. Register contents must always be saved and restored by word length, starting from an even-numbered address. 3. Ignored when returning from the interrupt handling routine. Figure 3.2 Stack State after Completion of Interrupt Exception Handling Figure 3.3 Interrupt Sequence #### 3.5.4 Interrupt Response Time Table 3.4 shows the number of wait states after an interrupt request flag is set until the first instruction of the interrupt handling-routine is executed. **Table 3.4** Interrupt Wait States | Item | States | |-------------------------------------------------------|----------| | Waiting time for completion of executing instruction* | 1 to 13 | | Saving of PC and CCR to stack | 4 | | Vector fetch | 2 | | Instruction fetch | 4 | | Internal processing | 4 | | Total | 15 to 27 | Note: \* Not including EEPMOV instruction. ## 3.6 Trap Instruction When a TRAP instruction is executed, trap instruction exception handling starts up. A TRAP instruction generates vector addresses corresponding to the vector numbers 0 to 3 designated in the instruction code. ## 3.7 Application Notes #### 3.7.1 Notes on Stack Area Use When word data is accessed in the H8/3664 Series, the least significant bit of the address is regarded as 0. Access to the stack always takes place in word size, so the stack pointer (SP: R7) should never indicate an odd address. Use PUSH Rn (MOV.W Rn, @-SP) or POP Rn (MOV.W @SP+, Rn) to save or restore register values. Setting an odd address in SP may cause a program to crash. An example is shown in figure 3.4. Figure 3.4 Operation when Odd Address is Set in SP When CCR contents are saved to the stack during interrupt exception handling or restored when RTE is executed, this also takes place in word size. Both the upper and lower bytes of word data are saved to the stack; on return, the even address contents are restored to CCR while the odd address contents are ignored. ## 3.7.2 Notes on Rewriting Port Mode Registers When a port mode register is rewritten to switch the functions of external interrupt pins, the following points should be observed. When an external interrupt pin function is switched by rewriting the port mode register that controls pins $\overline{IRQ}_3$ to $\overline{IRQ}_1$ , and $\overline{WKP}_5$ to $\overline{WKP}_0$ , the interrupt request flag may be set to 1 at the time the pin function is switched, even if no valid interrupt is input at the pin. Table 3.5 shows the conditions under which interrupt request flags are set to 1 in this way. Table 3.5 Conditions under which Interrupt Request Flag is Set to 1 | Interrup<br>Flags Se | t Request<br>et to 1 | Conditions | |----------------------|----------------------|--------------------------------------------------------------------------------------------------------------------| | IRR1 | IRRI3 | When bit IRQ3 in PMR1 is changed from 0 to 1 while pin $\overline{IRQ}_3$ is low and bit IEG3 in IEGR1 = 0. | | | | When bit IRQ3 in PMR1 is changed from 1 to 0 while pin $\overline{\text{IRQ}}_3$ is low and bit IEG3 in IEGR1 = 1. | | | IRRI2 | When bit IRQ2 in PMR1 is changed from 0 to 1 while pin $\overline{\text{IRQ}}_2$ is low and bit IEG2 in IEGR1 = 0. | | | | When bit IRQ2 in PMR1 is changed from 1 to 0 while pin $\overline{\text{IRQ}}_2$ is low and bit IEG2 in IEGR1 = 1. | | | IRRI1 | When bit IRQ1 in PMR1 is changed from 0 to 1 while pin $\overline{IRQ}_1$ is low and bit IEG1 in IEGR1 = 0. | | | | When bit IRQ1 in PMR1 is changed from 1 to 0 while pin $\overline{IRQ}_1$ is low and bit IEG1 in IEGR1 = 1. | | | IRRI0 | When bit IRQ0 in PMR1 is changed from 0 to 1 while pin $\overline{IRQ}_0$ is low and bit IEG0 in IEGR1 = 0. | | | | When bit IRQ0 in PMR1 is changed from 1 to 0 while pin $\overline{IRQ}_0$ is low and bit IEG0 in IEGR1 = 1. | | IWPR | IWPF5 | When bit WKP5 in PMR5 is changed from 0 to 1 while pin $\overline{WKP}_5$ is low and bit WPEG5 in IEGR2 = 0. | | | | When bit WKP5 in PMR5 is changed from 1 to 0 while pin $\overline{WKP}_5$ is low and bit WPEG5 in IEGR2 = 1. | | | IWPF4 | When bit WKP4 in PMR5 is changed from 0 to 1 while pin $\overline{WKP}_4$ is low and bit WPEG4 in IEGR2 = 0. | | | | When bit WKP4 in PMR5 is changed from 1 to 0 while pin $\overline{WKP}_4$ is low and bit WPEG4 in IEGR2 = 1. | | | IWPF3 | When bit WKP3 in PMR5 is changed from 0 to 1 while pin $\overline{WKP}_3$ is low and bit WPEG3 in IEGR2 = 0. | | | | When bit WKP3 in PMR5 is changed from 1 to 0 while pin $\overline{WKP}_3$ is low and bit WPEG3 in IEGR2 = 1. | | | IWPF2 | When bit WKP2 in PMR5 is changed from 0 to 1 while pin $\overline{WKP}_2$ is low and bit WPEG2 in IEGR2 = 0. | | | | When bit WKP2 in PMR5 is changed from 1 to 0 while pin $\overline{WKP}_2$ is low and bit WPEG2 in IEGR2 = 1. | | | IWPF1 | When bit WKP1 in PMR5 is changed from 0 to 1 while pin $\overline{WKP}_1$ is low and bit WPEG1 in IEGR2 = 0. | | | | When bit WKP1 in PMR5 is changed from 1 to 0 while pin $\overline{WKP}_1$ is low and bit WPEG1 in IEGR2 = 1. | | | IWPF0 | When bit WKP0 in PMR5 is changed from 0 to 1 while pin $\overline{WKP}_0$ is low and bit WPEG0 in IEGR2 = 0. | | | | When bit WKP0 in PMR5 is changed from 1 to 0 while pin $\overline{WKP}_0$ is low and bit WPEG0 in IEGR2 = 1. | Figure 3.5 shows the procedure for setting a bit in a port mode register and clearing the interrupt request flag. When switching a pin function, mask the interrupt before setting the bit in the port mode register. After accessing the port mode register, execute at least one instruction (e.g., NOP), then clear the interrupt request flag from 1 to 0. If the instruction to clear the flag is executed immediately after the port mode register access without executing an intervening instruction, the flag will not be cleared. An alternative method to avoid the setting of interrupt request flags when pin functions are switched is to keep the pins at the high level so that the conditions in table 3.5 do not occur. Figure 3.5 Port Mode Register Setting and Interrupt Request Flag Clearing Procedure # Section 4 Address Break #### 4.1 Overview The address break simplifies on-board program debugging. It requests an address break interrupt when the set break condition is satisfied. The interrupt request is not affected by the I bit of CCR. Break conditions that can be set include instruction execution at a specific address and a combination of access and data at a specific address. With the address break function, the execution start point of a program containing a bug is detected and execution is branched to the correcting program. #### 4.1.1 Block Diagram Figure 4.1 shows a block diagram of the address break. Figure 4.1 Block Diagram of an Address Break ## 4.1.2 Register Configuration Table 4.1 shows the address break register configuration. Table 4.1 Address Break Registers | Name | Abbrev. | R/W | Initial Value | Address | |--------------------------------|---------|-----|---------------|---------| | Address break control register | ABRKCR | R/W | H'80 | H'FFC8 | | Address break status register | ABRKSR | R/W | H'3F | H'FFC9 | | Break address register (H) | BARH | R/W | H'FF | H'FFCA | | Break address register (L) | BARL | R/W | H'FF | H'FFCB | | Break data register (H) | BDRH | R/W | Undefined | H'FFCC | | Break data register (L) | BDRL | R/W | Undefined | H'FFCD | # 4.2 Register Descriptions ## 4.2.1 Address Break Control Register (ABRKCR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|-------|-------|-------|-------|-------|-------|-------| | | RTINTE | CSEL1 | CSEL0 | ACMP2 | ACMP1 | ACMP0 | DCMP1 | DCMP0 | | Initial value | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W ABRKCR is an 8-bit read/write register that sets address break conditions. **Bit 7—RTE Interrupt Enable (RTINTE):** Bit 7 enables or disables an interrupt after RTE instruction execution. | Bit 7: RTINTE | Description | | |---------------|---------------------------------------------------------------------------|-----------------| | 0 | Disables an interrupt after RTE instruction execution (one inst executed) | ruction is | | 1 | Enables an interrupt after RTE instruction execution | (Initial value) | **Bits 6 and 5—Condition Select (CSEL1, CSEL0):** Bits 6 and 5 set address break conditions. When CSEL1=0 and CSEL0=0, data is not compared regardless of the values of DCMP1 and DCMP0. | Bit 6: CSEL1 | Bit 5: CSEL0 | Description | | |--------------|--------------|-----------------------------|-----------------| | 0 | 0 | Instruction execution cycle | (Initial value) | | | 1 | CPU data read cycle | | | 1 | 0 | CPU data write cycle | | | | 1 | CPU data read/write cycle | | **Bits 4 to 2—Address Compare Condition Select (ACMP2 to ACMP0):** Bits 4 to 2 set comparison condition between the address set in BAR and the internal address bus. | Bit 4:<br>ACMP2 | Bit 3:<br>ACMP1 | Bit 2:<br>ACMP0 | Description | | |-----------------|-----------------|-----------------|---------------------------------|-----------------| | 0 | 0 | 0 | Compare 16-bit addresses | (Initial value) | | | | 1 | Compares upper 12-bit addresses | | | | 1 | 0 | Compares upper 8-bit addresses | | | | | 1 | Compares upper 4-bit addresses | | | 1 | * | * | Reserved | | Note: \* Don't care. **Bits 1 and 0—Data Compare Condition Select (DCMP1, DCMP0):** Bits 1 and 0 set the comparison condition between the data set in BDR and the internal data bus. | Bit 1: DCMP1 | Bit 0: DCMP0 | Description | | |--------------|--------------|----------------------------------------|-----------------| | 0 | 0 | No data comparison | (Initial value) | | | 1 | Compares lower 8-bit data between BDRL | and data bus | | 1 | 0 | Compares upper 8-bit data between BDRH | l and data bus | | | 1 | Compares 16-bit data between BDR and d | ata bus | When an address break is set in the data read cycle or data write cycle, the data bus used will depend on the combination of the byte/word access and address. Table 4.2 shows the access and data bus used. Table 4.2 Access and Data Bus Used | | Word A | Access | Byte Access | | | |-------------------------------------------------|---------------|---------------|--------------|--------------|--| | | Even Address | Odd Address | Even Address | Odd Address | | | ROM space | Upper 8 bits | Lower 8 bits | Upper 8 bits | Upper 8 bits | | | RAM space | Upper 8 bits | Lower 8 bits | Upper 8 bits | Upper 8 bits | | | I/O register space<br>(except H'FF86 to H'FF8F) | Upper 8 bits* | Upper 8 bits* | Upper 8 bits | Upper 8 bits | | | I/O register space<br>(H'FF86 to H'FF8F) | Upper 8 bits | Lower 8 bits | _ | _ | | Note: \* When the I/O register space, except H'FF86 to H'FF8F, is accessed by word, byte access occurs twice. ## 4.2.2 Address Break Status Register (ABRKSR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------|------|------|---|---|---|---|---|---|---| | | ABIF | ABIE | _ | _ | _ | _ | _ | _ | | | Initial value | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | - | | Read/Write | R/W | R/W | | | | | | _ | | ABRKSR is an 8-bit read/write register that consists of the address break interrupt flag and the address break interrupt enable bit. Bit 7—Address Break Interrupt Flag (ABIF): Bit 7 indicates an address break interrupt. | Bit 7: ABIF | Description | | |-------------|-----------------------------------------------------|-----------------| | 0 | An address break interrupt request is not generated | | | | [Clearing condition] | | | | When 0 is written after ABIF=1 is read | (Initial value) | | 1 | An address break interrupt request is generated | | | | [Set condition] | | | | When the condition set in ABRKCR is satisfied | | **Bit 6—Address Break Interrupt Enable (ABIE):** Bit 6 enables or disables an address break interrupt. | Bit 6: ABIE | Description | | |-------------|---------------------------------------------|-----------------| | 0 | Disables an address break interrupt request | (Initial value) | | 1 | Enables an address break interrupt request | | **Bits 5 to 0—Reserved Bits:** Bits 5 to 0 are reserved; they are always read as 1 and cannot be modified. ## 4.2.3 Break Address Registers (BARH, BARL) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | | BARH7 | BARH6 | BARH5 | BARH4 | BARH3 | BARH2 | BARH1 | BARH0 | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BARL7 | BARL6 | BARL5 | BARL4 | BARL3 | BARL2 | BARL1 | BARL0 | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W BAR (BARH, BARL) is a 16-bit read/write register that sets the address for generating an address break interrupt. When setting the address break condition to the instruction execution cycle, set the first byte address of the instruction. #### 4.2.4 Break Data Registers (BDRH, BDRL) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | BDRH7 | BDRH6 | BDRH5 | BDRH4 | BDRH3 | BDRH2 | BDRH1 | BDRH0 | | Initial value | Undefined | Read/Write | R/W | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BDRL7 | BDRL6 | BDRL5 | BDRL4 | BDRL3 | BDRL2 | BDRL1 | BDRL0 | | Initial value | Undefined | Read/Write | R/W BDR (BDRH, BDRL) is a 16-bit read/write register that sets the data for generating an address break interrupt. BDRH is compared with the upper 8-bit data bus. BDRL is compared with the lower 8-bit data bus. When memory or registers are accessed by byte, the upper 8-bit data bus is used for even and odd addresses in the data transmission. Therefore, comparison data must be set in BDRH for byte access. For word access, the data bus used depends on the address. See section 4.2.1, Address Break Control Register, for details. # 4.3 Operation When the ABIE bit in ABRKSR is set to 1, if the ABIF bit in ABRKSR is set to 1 by the combination of the address set in BAR, the data set in BDR, and the conditions set in ABRKCR, the address break function generates an interrupt request to the CPU. When the interrupt request is accepted, interrupt exception handling starts after the instruction being executed ends. The address break interrupt is not masked because of the I bit in CCR of the CPU. Figures 4.2 to 4.4 show the operation examples of the address break interrupt setting. Figure 4.2 Address Break Interrupt Operation Example (1) Figure 4.3 Address Break Interrupt Operation Example (2) Figure 4.4 Address Break Interrupt Operation Example (3) # Section 5 Clock Pulse Generators #### 5.1 Overview Clock oscillator circuitry (CPG: clock pulse generator) is provided on-chip, including both a system clock pulse generator and a subclock pulse generator. The system clock pulse generator consists of a system clock oscillator and system clock dividers. The subclock pulse generator consists of a subclock oscillator circuit and a subclock divider. #### 5.1.1 Block Diagram Figure 5.1 shows a block diagram of the clock pulse generators. Figure 5.1 Block Diagram of Clock Pulse Generators ## 5.1.2 System Clock and Subclock The basic clock signals that drive the CPU and on-chip peripheral modules are $\emptyset$ and $\emptyset_{SUB}$ . Four of the clock signals have names: $\emptyset$ is the system clock, $\emptyset_{SUB}$ is the subclock, $\emptyset_{OSC}$ is the oscillator clock, and $\emptyset_{W}$ is the watch clock. The clock signals available for use by peripheral modules are $\emptyset/2$ , $\emptyset/4$ , $\emptyset/8$ , $\emptyset/16$ , $\emptyset/32$ , $\emptyset/64$ , $\emptyset/128$ , $\emptyset/256$ , $\emptyset/512$ , $\emptyset/1024$ , $\emptyset/2048$ , $\emptyset/4096$ , $\emptyset/8192$ , $\emptyset_W/8$ , $\emptyset_W/16$ , $\emptyset_W/32$ , $\emptyset_W/64$ , and $\emptyset_W/128$ . The clock requirements differ from one module to another. # 5.2 System Clock Generator Clock pulses can be supplied to the system clock divider either by connecting a crystal or ceramic oscillator, or by providing external clock input. **Connecting a Crystal Oscillator:** Figure 5.2 shows a typical method of connecting a crystal oscillator. An AT-cut parallel-resonance crystal resonator should be used. Figure 5.2 Typical Connection to Crystal Oscillator Figure 5.3 shows the equivalent circuit of a crystal oscillator. An oscillator having the characteristics given in table 5.1 should be used. Figure 5.3 Equivalent Circuit of Crystal Oscillator **Table 5.1** Crystal Oscillator Parameters | Frequency | 2 MHz | 4 MHz | 8 MHz | 10 MHz | 16 MHz | |----------------------|-------|-------|-------|--------|--------| | R <sub>s</sub> (max) | 500 Ω | 120 Ω | 80 Ω | 60 Ω | 50 Ω | | C <sub>0</sub> (max) | 7 pF | 7 pF | 7 pF | 7 pF | 7 pF | **Connecting a Ceramic Oscillator:** Figure 5.4 shows a typical method of connecting a ceramic oscillator. Figure 5.4 Typical Connection to Ceramic Oscillator **Notes on Board Design:** When generating clock pulses by connecting a crystal or ceramic oscillator, pay careful attention to the following points. Avoid running signal lines close to the oscillator circuit, since the oscillator may be adversely affected by induction currents. (See figure 5.5.) The board should be designed so that the oscillator and load capacitors are located as close as possible to pins OSC<sub>1</sub> and OSC<sub>2</sub>. Figure 5.5 Board Design of Oscillator Circuit **External Clock Input Method:** Connect an external clock signal to pin $OSC_1$ , and leave pin $OSC_2$ open. Figure 5.6 shows a typical connection. The duty cycle of the external clock signal must be 45 to 55%. Figure 5.6 Example of External Clock Input ## 5.3 Subclock Generator **Connecting a 32.768-kHz Crystal Oscillator:** Clock pulses can be supplied to the subclock divider by connecting a 32.768-kHz crystal oscillator, as shown in figure 5.7. Follow the same precautions as noted under 5.2 Notes on Board Design. Figure 5.7 Typical Connection to 32.768-kHz Crystal Oscillator Figure 5.8 shows the equivalent circuit of the 32.768-kHz crystal oscillator. Figure 5.8 Equivalent Circuit of 32.768-kHz Crystal Oscillator **Pin Connection when Not Using Subclock:** When the subclock is not used, connect pin $X_1$ to $V_{CL}$ or $V_{SS}$ and leave pin $X_2$ open, as shown in figure 5.9. Figure 5.9 Pin Connection when not Using Subclock ### 5.4 Prescalers This LSI is equipped with two on-chip prescalers having different input clocks (prescaler S and prescaler W). Prescaler S is a 13-bit counter using the system clock ( $\emptyset$ ) as its input clock. Its prescaled outputs provide internal clock signals for on-chip peripheral modules. Prescaler W is a 5-bit counter using a 32.768-kHz signal divided by 4 ( $\emptyset_W/4$ ) as its input clock. Its prescaled outputs are used by timer A as a time base for timekeeping. **Prescaler S (PSS):** Prescaler S is a 13-bit counter using the system clock (Ø) as its input clock. It is incremented once per clock period. Prescaler S is initialized to H'0000 by a reset, and starts counting on exit from the reset state. In standby mode, subactive mode, and subsleep mode, the system clock pulse generator stops. Prescaler S also stops and is initialized to H'0000. The CPU cannot read or write prescaler S. The output from prescaler S is shared by the on-chip peripheral modules. The divider ratio can be set separately for each on-chip peripheral function. In active (medium-speed) mode the clock input to prescaler S is determined by the division factor designated by MA1 and MA0 in SYSCR1. **Prescaler W** (**PSW**): Prescaler W is a 5-bit counter using a 32.768 kHz signal divided by 4 ( $\phi_W/4$ ) as its input clock. Prescaler W is initialized to H'00 by a reset, and starts counting on exit from the reset state. Even in standby mode, subactive mode, or subsleep mode, prescaler W continues functioning so long as clock signals are supplied to pins $X_1$ and $X_2$ . Prescaler W can be reset by setting 1s in bits TMA3 and TMA2 of timer mode register A (TMA). Output from prescaler W can be used to drive timer A, in which case timer A functions as a time base for timekeeping. # 5.5 Usage Notes #### **5.5.1** Note on Oscillators Oscillator characteristics are closely related to board design and should be carefully evaluated by the user, referring to the examples shown in this section. Oscillator circuit constants will differ depending on the oscillator element, stray capacitance in its interconnecting circuit, and other factors. Suitable constants should be determined in consultation with the oscillator element manufacturer. Design the circuit so that the oscillator element never receives voltages exceeding its maximum rating. #### 5.5.2 Notes on Board Design When using a crystal resonator (ceramic resonator), place the resonator and its load capacitors as close as possible to the OSC1 and OSC2 pins. Other signal lines should be routed away from the oscillator circuit to prevent induction from interfering with correct oscillation (see figure 5.10). Figure 5.10 Example of Incorrect Board Design # Section 6 Power-down Modes ### 6.1 Overview This LSI has six modes of operation after a reset. These include a normal active mode and four power-down modes, in which power dissipation is significantly reduced. The module standby mode reduces power dissipation by selectively halting on-chip module functions. Table 6.1 summarizes the six operating modes. **Table 6.1 Operating Modes** | Operating Mode | Description | |---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Active mode | The CPU and all on-chip peripheral modules are operable on the system clock. The system clock frequency can be selected from øosc, øosc/8, øosc/16, øosc/32, and øosc/64. For details, see 6.2.2, System Control Register 2. | | Subactive mode | The CPU and all on-chip peripheral modules are operable on the subclock. The subclock frequency can be selected from øw/2, øw/4, and øw/8. | | Sleep mode | The CPU halts. On-chip peripheral functions are operable on the system clock. | | Subsleep mode | The CPU halts. On-chip peripheral functions are operable on the subclock. | | Standby mode | The CPU and all on-chip peripheral modules halt. When the clock time-base function is selcted, timer A is operable. | | Module standby mode | The on-chip peripheral modules specified by software stop operating. For details, see 6.2.3, Module Standby Control Register 1. | ## 6.1.1 Register Configuration Table 6.2 shows the power-down mode register configuration. Table 6.2 Power-down Mode Registers | Name | Abbreviation | R/W | Initial Value | Address | |-----------------------------------|--------------|-----|---------------|---------| | System control register 1 | SYSCR1 | R/W | H'00 | H'FFF0 | | System control register 2 | SYSCR2 | R/W | H'00 | H'FFF1 | | Module standby control register 1 | MSTCR1 | R/W | H'00 | H'FFF9 | # **6.2** Register Descriptions ## **6.2.1** System Control Register 1 (SYSCR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|------|-------|---|---|---| | | SSBY | STS2 | STS1 | STS0 | NESEL | _ | _ | _ | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W | R/W | R/W | R/W | R/W | _ | _ | _ | SYSCR1 is an 8-bit read/write register for control of the power-down modes. Upon reset, SYSCR1 is initialized to H'00. **Bit 7—Software Standby (SSBY):** This bit designates the transition to the sleep mode, subsleep mode, or standby mode. | Bit 7: SSBY | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------| | 0 | When a SLEEP instruction is executed in the active mode, a transition is made to the sleep mode or subsleep mode. (Initial value) | | 1 | When a SLEEP instruction is executed in the active mode, a transition is made to the standby mode. | **Bits 6 to 4—Standby Timer Select 2 to 0 (STS2 to STS0):** These bits designate the time the CPU and peripheral modules wait for stable clock operation after exiting from the standby mode, subactive mode, or subsleep mode to the active mode or sleep mode due to an interrupt. The designation should be made according to the clock frequency so that the waiting time is at least 10 ms. | Bit 6: STS2 | Bit 5: STS1 | Bit 4: STS0 | Description | | |-------------|-------------|-------------|----------------------------|-----------------| | 0 | 0 | 0 | Wait time = 8,192 states | (Initial value) | | | | 1 | Wait time = 16,384 states | | | | 1 | 0 | Wait time = 32,768 states | | | | | 1 | Wait time = 65,536 states | | | 1 | 0 | 0 | Wait time = 131,072 states | | | | | 1 | Wait time = 1,024 states | | | | 1 | 0 | Wait time = 128 states | | | | | 1 | Wait time = 16 states | | Bit 3—Noise Elimination Sampling Frequency Select (NESEL): This bit selects the frequency at which the watch clock signal ( $\phi_w$ ) generated by the subclock pulse generator is sampled, in relation to the oscillator clock ( $\phi_{OSC}$ ) generated by the system clock pulse generator. When $\phi_{OSC} = 2$ to 10 MHz, clear NESEL to 0. | Bit 3: NESEL | Description | | |--------------|---------------------------------------|-----------------| | 0 | Sampling rate is ø <sub>osc</sub> /16 | (Initial value) | | 1 | Sampling rate is ø <sub>osc</sub> /4 | | **Bits 2 to 0—Reserved Bits:** Bits 2 to 0 are reserved: they are always read as 0 and cannot be modified. ## 6.2.2 System Control Register 2 (SYSCR2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|------|------|-----|-----|-----|-----|-----| | | SMSEL | LSON | DTON | MA2 | MA1 | MA0 | SA1 | SA0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W SYSCR2 is an 8-bit read/write register for power-down mode control. Upon reset, SYSCR2 is initialized to H'00. **Bit 7—Sleep Mode Selection (SMSEL):** This bit chooses the transition to the sleep mode or subsleep mode when the SLEEP instruction is executed. The transition after the SLEEP instruction is executed depends on a combination of this and other control bits. | Bit 7: SMSEL | Description | | |--------------|----------------------------------------|-----------------| | 0 | A transition is made to sleep mode. | (Initial value) | | 1 | A transition is made to subsleep mode. | | Bit 6—Low Speed on Flag (LSON): This bit chooses the system clock ( $\emptyset$ ) or subclock ( $\emptyset$ <sub>SUB</sub>) as the CPU operating clock. The resulting operation mode after the SLEEP instruction is executed depends on the combination of other control bits. | Bit 6: LSON | Description | | |-------------|-----------------------------------------------------------------|-----------------| | 0 | The CPU operates on the system clock (ø) | (Initial value) | | 1 | The CPU operates on the subclock ( $\varnothing_{\text{SUB}}$ ) | | **Bit 5—Direct Transfer on Flag (DTON):** This bit designates whether to make direct transitions between the active and subactive modes when a SLEEP instruction is executed. The mode to which the transition is made after the SLEEP instruction is executed depends on a combination of this and other control bits | Bit 5: DTON | Description | |-------------|---------------------------------------------------------------------------------------------------------------------------------------| | 0 | When a SLEEP instruction is executed, a transition is made to standby mode, sleep mode, or subsleep mode. (Initial value) | | 1 | When a SLEEP instruction is executed, a direct transition is made to active mode if LSON = $0$ , or to subactive mode if LSON = $1$ . | Bits 4 to 2—Active Mode Clock Select (MA2 to MA0): These bits select the operating clock frequency in the active and sleep modes. The operating clock frequency changes to the set frequency after the SLEEP instruction is executed. | Bit 4: MA2 | Bit 3: MA1 | Bit 2: MA0 | Description | | |------------|------------|------------|----------------------|-----------------| | 0 | * | * | Ø <sub>osc</sub> | (Initial value) | | 1 | 0 | 0 | ø <sub>osc</sub> /8 | | | | | 1 | ø <sub>osc</sub> /16 | | | | 1 | 0 | ø <sub>osc</sub> /32 | | | | | 1 | ø <sub>osc</sub> /64 | | Note: \* Don't care Bits 1 and 0— Subactive Mode Clock Select (SA1, SA0): These bits select the operating clock frequency in the subactive and subsleep modes. The operating clock frequency changes to the set frequency after the SLEEP instruction is executed. | Bit 1: SA1 | Bit 0: SA0 | Description | | |------------|------------|-------------------|-----------------| | 0 | 0 | ø <sub>W</sub> /8 | (Initial value) | | | 1 | ø <sub>W</sub> /4 | | | 1 | * | ø <sub>W</sub> /2 | | Note: \* Don't care ## 6.2.3 Module Standby Control Register 1 (MSTCR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|--------|-------|-------|-------|-------|-------|-------| | | _ | MSTIIC | MSTS3 | MSTAD | MSTWD | MSTTW | MSTTV | MSTTA | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | R/W MSTCR1 is an 8-bit read/write register that enables each on-chip peripheral module to enter the standby state. Upon reset, MSTCR1 is initialized to H'00. Bit 7—Reserved Bit: This bit is reserved: it is always read as 0 and cannot be modified. Bit 6—IIC Module Standby (MSTIIC): This bit enables IIC to enter the standby state. | Bit 6: MSTIIC | Description | | |---------------|-----------------------------------|-----------------| | 0 | The IIC operates normally. | (Initial value) | | 1 | The IIC enters the standby state. | | Bit 5—SCI3 Module Standby (MSTS3): This bit enables SCI3 to enter the standby state. | Bit 5: MSTS3 | Description | | |--------------|------------------------------------|-----------------| | 0 | The SCI3 operates normally. | (Initial value) | | 1 | The SCI3 enters the standby state. | | **Bit 4—A/D Converter Module Standby (MSTAD):** This bit enables the A/D converter to enter the standby state. | Bit 4: MSTAD | Description | | |--------------|---------------------------------------------|-----------------| | 0 | The A/D converter operates normally. | (Initial value) | | 1 | The A/D converter enters the standby state. | | **Bit 3—Watchdog Timer Module Standby (MSTWD):** This bit enables the watchdog timer to enter the standby state. When the internal oscillator is selected for the watchdog timer clock, the watchdog timer operates regardless of the setting of this bit. | Bit 3: MSTWD | Description | | |--------------|----------------------------------------------|-----------------| | 0 | The watchdog timer operates normally. | (Initial value) | | 1 | The watchdog timer enters the standby state. | | Bit 2—Timer W Module Standby (MSTTW): This bit enables timer W to enter the standby state. | Bit 2: MSTTW | Description | | |--------------|-----------------------------------|-----------------| | 0 | Timer W operates normally. | (Initial value) | | 1 | Timer W enters the standby state. | | Bit 1—Timer V Module Standby (MSTTV): This bit enables timer V to enter the standby state. | Bit 1: MSTTV | Description | | | | |--------------|-----------------------------------|-----------------|--|--| | 0 | Timer V operates normally. | (Initial value) | | | | 1 | Timer V enters the standby state. | | | | Bit 0—Timer A Module Standby (MSTTA): This bit enables timer A to enter the standby state. | Bit 0: MSTTA | Description | | | |--------------|-----------------------------------|-----------------|--| | 0 | Timer A operates normally. | (Initial value) | | | 1 | Timer A enters the standby state. | | | ## **6.3** Mode Transition Conditions Figure 6.1 shows the transitions among these operation modes. Table 6.3 shows the transition mode after the SLEEP instruction is executed and when an interrupt occurs. Table 6.4 indicates the internal states in each mode. Figure 6.1 Mode Transition Diagram Table 6.3 Transition Mode after the SLEEP Instruction Execution and Interrupt Handling | DTON | SSBY | SMSEL | LSON | Transition Mode after<br>SLEEP Instruction<br>Execution | Transition Mode due to<br>Interrupt | | | |------|------|-------|------|---------------------------------------------------------|-------------------------------------|--|--| | 0 | 0 | 0 | 0 | Sleep mode | Active mode | | | | | | | 1 | | Subactive mode | | | | | | 1 | 0 | Subsleep mode | Active mode | | | | | | | 1 | | Subactive mode | | | | | 1 | * | * | Standby mode | Active mode | | | | 1 | * | 0*1 | 0 | Active mode | <del></del> | | | | | * | * | 1 | Subactive mode | | | | Notes: \* Don't care 1. When state transition is performed while SMSEL is 1, timer V, SCI3, and the A/D converter are reset, and all registers are set to their initial values. To use these after entering active mode, reset the registers. **Table 6.4** Internal State in Each Operating Mode | Function | | Active Mode | Sleep Mode | Subactive<br>Mode | Subsleep<br>Mode | Standby Mode | | |-------------------------|---------------------|-------------|--------------------|-------------------|------------------|--------------|--| | System clock oscillator | | Functions | Functions | Halted | Halted | Halted | | | Subclock osc | Subclock oscillator | | Functions | Functions | Functions | Functions | | | CPU operations | Instructions | Functions | Halted<br>Retained | Functions | Halted | Halted | | | | Registers | _ | | | Retained | Retained | | | RAM | | | | | | | | | IO ports | | | | | | Retained*1 | | | External | IRQ <sub>0</sub> | Functions | Functions | Functions | Functions | Functions | | | interrupts | IRQ <sub>1</sub> | | | | | | | | | $IRQ_2$ | | | | | | | | | IRQ <sub>3</sub> | | | | | | | | | WKP <sub>0</sub> | Functions | Functions | Functions | Functions | Functions | | | | WKP <sub>1</sub> | | | | | | | | | WKP <sub>2</sub> | _ | | | | | | | | WKP <sub>3</sub> | | | | | | | | | WKP <sub>4</sub> | | | | | | | | | WKP <sub>5</sub> | | | | | | | | Peripheral functions*3 | Timer A | Functions | Functions | Functions*2 | Functions*2 | Functions*2 | | | | Timer V | _ | | Reset | Reset | Reset | | | | Timer W | _ | | Retained*4*6 | Retained*4 | Retained | | | | Watchdog<br>timer | | | Retained*5*6 | Retained*5 | Retained*5 | | | | SCI3 | | | Reset | Reset | Reset | | | | IIC | <u> </u> | | Retained*6 | Retained | Retained | | | | A/D converter | | | Reset | Reset | Reset | | Notes: 1. Register contents are retained, but output is the high-impedance state. - 2. Functions if the timekeeping time-base function is selected, and retained if not selected. Retained in the module standby mode regardless of time-base function selection. - 3. Peripheral functions can be in the standby state in each mode by setting module standby control register 1 (MSTCR1). - 4. If internal clock $\emptyset$ is selected as a count clock, the counter is incremented by a subclock. - 5. Functions if the internal oscillator is selected as a count clock. - 6. Registers can be read or written. # 6.4 Sleep Mode #### 6.4.1 Transition to the Sleep Mode The system goes from the active mode to the sleep mode when a SLEEP instruction is executed while the SSBY bit in SYSCR1 and the DTON and SMSEL bits in SYSCR2 are all cleared to 0. In the sleep mode, CPU operation is halted but the on-chip peripheral modules function at the clock frequency set by the MA2, MA1, and MA0 bits in SYSCR2. CPU register contents are retained ### 6.4.2 Clearing the Sleep Mode The sleep mode is cleared by any interrupt or by input at the $\overline{RES}$ pin. · Clearing by interrupt When an interrupt is requested, the sleep mode is cleared and interrupt exception handling starts. The sleep mode is not cleared if the I bit of the condition code register (CCR) is set to 1 or the requested interrupt is disabled in the interrupt enable register. After the sleep mode is cleared, a transition is made to active mode when the LSON bit in SYSCR2 is 0, and a transition is made to subactive mode when the bit is 1. When the $\overline{RES}$ pin goes low, the CPU goes into the reset state and the sleep mode is cleared. ## 6.5 Standby Mode ## 6.5.1 Transition to the Standby Mode The system goes from the active mode to the standby mode when a SLEEP instruction is executed while the SSBY bit in SYSCR1 is set to 1 and the DTON bit in SYSCR1 is cleared to 0. In the standby mode, the clock pulse generator stops, so the CPU and on-chip peripheral modules stop functioning. However, as long as the rated voltage is supplied, the contents of CPU registers, on-chip RAM, and some on-chip peripheral module registers are retained. On-chip RAM contents will be further retained down to a minimum RAM data retention voltage. The I/O ports go to the high-impedance state. ## 6.5.2 Clearing the Standby Mode The standby mode is cleared by an interrupt or by input at the $\overline{RES}$ pin. ### • Clearing by interrupt When an interrupt is requested, the system clock pulse generator starts. After the time set in bits STS2–STS0 in SYSCR1 has elapsed, a stable system clock signal is supplied to the entire chip, the standby mode is cleared, and interrupt exception handling starts. The standby mode is not cleared if the I bit of CCR is set to 1 or the requested interrupt is disabled in the interrupt enable register. ## • Clearing by RES input When the $\overline{RES}$ pin goes low, the system clock pulse generator starts. After the pulse generator output has stabilized, the CPU starts reset exception handling if the $\overline{RES}$ pin is driven high. Since system clock signals are supplied to the entire chip as soon as the system clock pulse generator starts functioning, the $\overline{RES}$ pin must be kept low until the pulse generator output stabilizes. #### 6.5.3 Oscillator Settling Time after the Standby Mode is Cleared ## • When a crystal oscillator is used Table 6.5 lists the settings for various operating frequencies. Bits STS2 to STS0 in SYSCR1 must be set so that the waiting time is longer than the oscillator settling time. Table 6.5 Operating Frequency and Waiting Time ( $\emptyset = \emptyset$ osc) | STS2 | STS1 | STS0 | Waiting Time | 10 MHz | 8 MHz | 4 MHz | 2 MHz | 1 MHz | 0.5 MHz | |------|------|------|----------------|--------|-------|-------|-------|-------|---------| | 0 | 0 | 0 | 8,192 states | 8.0 | 1.6 | 2.0 | 4.1 | 8.1 | 16.4 | | | | 1 | 16,384 states | 1.6 | 2.0 | 4.1 | 8.2 | 16.4 | 32.8 | | | 1 | 0 | 32,768 states | 3.3 | 4.1 | 8.2 | 16.4 | 32.8 | 65.5 | | | | 1 | 65,536 states | 6.6 | 8.2 | 16.4 | 32.8 | 65.5 | 131.1 | | 1 | 0 | 0 | 131,072 states | 13.1 | 16.4 | 32.8 | 65.5 | 131.1 | 262.1 | | | | 1 | 1,024 states | 0.10 | 0.13 | 0.26 | 0.51 | 1.02 | 2.05 | | | 1 | 0 | 128 states | 0.01 | 0.02 | 0.03 | 0.06 | 0.13 | 0.26 | | | | 1 | 16 states | 0.00 | 0.00 | 0.00 | 0.01 | 0.02 | 0.03 | | - | | | | | | | | | | (Unit: ms) ### • When an external clock is used Any values can be set. Normally the minimum time (STS2 = STS1 = STS0 = 1) should be set. # 6.6 Subsleep Mode ### **6.6.1** Transition to the Subsleep Mode The system goes from the active or subactive mode to the subsleep mode when a SLEEP instruction is executed while the SSBY bit in SYSCR1 is cleared to 0, the DTON bit in SYSCR2 is cleared to 0, and the SMSEL bit in SYSCR2 is set to 1. In the subsleep mode, operation of the CPU and on-chip peripheral modules other than timer A is halted. As long as a minimum required voltage is applied, the contents of CPU registers, the on-chip RAM, and some registers of the on-chip peripheral modules are retained. I/O ports keep the same states as before the transition. ## 6.6.2 Clearing the Subsleep Mode The subsleep mode is cleared by an interrupt or by input at the $\overline{RES}$ pin. - · Clearing by interrupt - When an interrupt is requested, the subsleep mode is cleared and interrupt exception handling starts. The subsleep mode is not cleared if the I bit of CCR is set to 1 or the requested interrupt is disabled in the interrupt enable register. After the subsleep mode is cleared, a transition is made to the active mode when the LSON bit in SYSCR2 is 0, and a transition is made to the subactive mode when the bit is 1. - Clearing by RES input - When the $\overline{RES}$ pin goes low, the system clock pulse generator starts. After the pulse generator output has stabilized, the CPU starts reset exception handling if the $\overline{RES}$ pin is driven high. Since system clock signals are supplied to the entire chip as soon as the system clock pulse generator starts functioning, the $\overline{RES}$ pin must be kept low until the pulse generator output stabilizes. ## 6.7 Subactive Mode #### 6.7.1 Transition to the Subactive Mode The subactive mode is entered from the sleep or subsleep mode if an interrupt is requested while the LSON bit in SYSCR2 is set to 1. The operating frequency of the subactive mode is selected from $\phi_{\rm W}/2$ , $\phi_{\rm W}/4$ , and $\phi_{\rm W}/8$ by the SA1 and SA0 bits in SYSCR2. The operating frequency changes to the set frequency after SLEEP instruction execution. A transition to the subactive mode does not take place if the I bit of CCR is set to 1 or the requested interrupt is disabled in the interrupt enable register. The subactive mode can be directly entered from the active mode. See section 6.9, Direct Transition, for details. ## 6.7.2 Clearing the Subactive Mode The subactive mode is cleared by a SLEEP instruction or by input at the $\overline{RES}$ pin. ### Clearing by SLEEP instruction If a SLEEP instruction is executed in the subactive mode, the subactive mode is cleared and another mode is entered. If the SSBY bit in SYSCR1 and the DTON and SMSEL bits in SYSCR2 are cleared to 0, the sleep mode is entered; if the SSBY bit in SYSCR1, the DTON bit in SYSCR2 are cleared to 0, and the SMSEL bit is set to 1, the subsleep mode is entered; if the SSBY bit in SYSCR1 is set to 1 and the DTON bit in SYSCR2 is cleared to 0, the standby mode is entered; if the DTON bit in SYSCR2 is set to 1 and the LSON bit is cleared to 0, the active mode is directly entered. For direct transition to the active mode, see section 6.9, Direct Transition. # Clearing by RES pin When the $\overline{RES}$ pin goes low, the system clock pulse generator starts. After the pulse generator output has stabilized, the CPU starts reset exception handling if the $\overline{RES}$ pin is driven high. Since system clock signals are supplied to the entire chip as soon as the system clock pulse generator starts functioning, the $\overline{RES}$ pin must be kept low until the pulse generator output stabilizes. #### 6.8 Active Mode #### **6.8.1** Transition to the Active Mode The active mode is entered from the standby, sleep, or subsleep mode if an interrupt is requested while the LSON bit in SYSCR2 is cleared to 0. The system directly goes to the active mode when a SLEEP instruction is executed while the DTON bit in SYSCR2 is set to 1 and the LSON bit in SYSCR2 is cleared to 0. The operating frequency changes to the set frequency after SLEEP instruction execution. A transition to the active mode does not take place if the I bit of CCR is set to 1 or the requested interrupt is disabled in the interrupt enable register. In the active mode, the CPU and on-chip peripheral modules function at the clock frequency set by the MA2, MA1, and MA0 bits in SYSCR2. #### 6.8.2 Transition from the Active Mode to Other Modes A transition from the active mode to the standby mode takes place if the SLEEP instruction is executed while the SSBY bit in SYSCR1 is set to 1 and the DTON bit in SYSCR1 is cleared to 0. If the SLEEP instruction is executed while SSBY is cleared to 0 and the DTON and SMSEL bits in SYSCR2 are cleared to 0, the sleep mode is entered. If the SLEEP instruction is executed while SSBY is cleared to 0, the DTON bit is cleared to 0, and the SMSEL bit is set to 1, the subsleep mode is entered. Direct transition from the active mode to the subactive mode is also possible. See section 6.9, Direct Transition, for details. ## **6.8.3** Operating Frequency in the Active Mode Operation in the active mode is clocked at the frequency designated by the MA1 and MA0 bits in SYSCR1. The operating frequency changes to the set frequency after SLEEP instruction execution. #### **6.9** Direct Transition The CPU can execute programs in two modes: active and subactive mode. A direct transition is a transition between these two modes without stopping program execution. A direct transition can be made by executing a SLEEP instruction while the DTON bit in SYSCR2 is set to 1. The direct transition also enables operating frequency modification in the active or subactive mode. After the mode transition, direct transition interrupt exception handling starts. If the direct transition interrupt is disabled in interrupt enable register 1, a transition is made instead to the sleep or subsleep mode. Note that if a direct transition is attempted while the I bit in CCR is set to 1, the sleep or subsleep mode will be entered, and the resulting mode cannot be cleared by means of an interrupt. - Direct transition from the active mode to the subactive mode When a SLEEP instruction is executed in the active mode while the DTON and LSON bits in SYSCR2 are set to 1, a transition is made to the subactive mode. - Direct transition from the subactive mode to the active mode When a SLEEP instruction is executed in the subactive mode while the DTON bit in SYSCR2 is set to 1 and the LSON bit in SYSCR2 is cleared to 0, a direct transition is made to the active mode after the waiting time set in SYSCR1 bits STS2 to STS0 has elapsed. #### 6.9.1 Direct Transition Time When a SLEEP instruction is executed in the active mode while the DTON and LSON bits in SYSCR2 are set to 1, a transition is made to the subactive mode. The time from the start of SLEEP instruction execution to the end of interrupt exception handling (the direct transition time) is calculated by equation (1). ## [Example] Direct transition time = $(2 + 1) \times tosc + 14 \times 8tw = 3tosc + 112tw$ (when the CPU operating clock of $\phi$ osc $\rightarrow \phi$ w/8 is selected) Direct transition from the active mode to the subactive mode <Symbols> tosc: OSC clock cycle time tw: watch clock cycle time tcyc: system clock (ø) cycle time tsubcyc: subclock (øSUB) cycle time • Direct transition from the subactive mode to the active mode When a SLEEP instruction is executed in the subactive mode while the DTON bit in SYSCR2 is set to 1 and the LSON bit in SYSCR2 is cleared to 0, a direct transition is made from the subactive mode to the active mode. The time from the start of SLEEP instruction execution to the end of interrupt exception handling (the direct transition time) is calculated by equation (2). ### [Example] Direct transition time = $(2 + 1) \times 8$ tw + $(8192 + 14) \times$ tosc = 24tw + 8206tosc (when the CPU operating clock of $\phi$ w/8 $\rightarrow$ $\phi$ osc and a waiting time of 8192 states are selected) <Symbols> tosc: OSC clock cycle time tw: watch clock cycle time tcyc: system clock (ø) cycle time tsubcyc: subclock (øSUB) cycle time ## 6.10 Module Standby Mode The module standby mode can be set to any peripheral module. In the module standby mode, the clock supply to modules and the module functions stop much like the states in the standby mode. Therefore, power consumption can be reduced. The module standby mode can be specified by setting each bit of module standby control register 1 (MSTCR1) to 1. The module standby mode can be canceled by clearing each bit of module standby control register 1 (MSTCR1) to 0. # Section 7 ROM #### 7.1 Features The HD64F3664 has 32 kbytes of on-chip flash memory. The features of the flash memory are summarized below. - Four flash memory operating modes - Program mode - Erase mode - Program-verify mode - Erase-verify mode - Programming/erase methods The flash memory is programmed 128 bytes at a time. The flash memory includes four 1-kB blocks and one 28-kB block. To erase the entire flash memory, each block must be erased in turn. Reprogramming capability The flash memory can be reprogrammed up to 100 times. On-board programming modes There are two modes in which flash memory can be programmed/erased/verified on-board: - Boot mode - User program mode - Automatic bit rate adjustment With data transfer in boot mode, the LSI's bit rate can be automatically adjusted to match the transfer bit rate of the host. Protect modes The software protect mode is available in which protected status is designated for flash memory program/erase/verify operations. • Programmer mode Flash memory can be programmed/erased in programmer mode, using a PROM programmer, as well as in on-board programming mode. • Power-down mode In the sub-active mode, data is read in the power-down mode by stopping the operation of part of the power supply circuit. ## 7.2 Overview ## 7.2.1 Block Diagram Figure 7.1 Block Diagram of Flash Memory ## 7.2.2 On-board Programming Mode For flash memory program/erase mode, boot mode and user program mode, in which on-board program/erase is performed, and programmer mode, in which program/erase is performed using a PROM programmer, are available. When the HD64F3664 is activated from the reset state, the HD64F3664 enters different operating modes, depending on the state of the TEST pin, the $\overline{\text{NMI}}$ pin, and the port input level as shown in figure 7.2. The input level of the TEST pin and $\overline{\text{NMI}}$ pin must be stabilized at least four states before reset cancellation. **Figure 7.2 Flash Memory State Transitions** When the boot mode is entered, the boot program built in the LSI is activated. The boot mode is shown in figure 7.3. In this mode, the programming control program prepared in the host is received via SCI3, and is serially transmitted to the programming control program area of the on-chip RAM. The old data in the flash memory is entirely erased, the program branches to the start address of the programming control program area, and the execution of the programming control program is started. Prepare the programming control program according to section 7.6, Programming/erasing Flash Memory Program. In user program mode, control branches from the user mode to the programming control program prepared by the user; desired blocks can be erased and programmed in this mode. The user must set the branch condition and prepare the means for providing on-board programming data. Since the flash memory cannot be read during program/erase, execute the programming control program after transmitting the program to the on-chip RAM, as in boot mode. Figure 7.4 shows an example of user program mode. #### 1. Initial state The old program version or data remains written in the flash memory. The user should prepare the programming control program and new application program beforehand in the host. 3. Flash memory initialization The erase program in the boot program area (in RAM) is executed, and the flash memory is initialized (to H'FF). In boot mode, the entire flash memory area is erased, without regard to blocks. Programming control program transfer When boot mode is entered, the boot program in the H8/3664 (originally incorporated in the chip) is started and the programming control program in the host is transferred to RAM via SCI communication. The boot program required for flash memory erasing is automatically transferred to the RAM boot program area. Writing new application program The programming control program transferred from the host to RAM is executed, and the new application program in the host is written into the flash memory. Figure 7.3 Boot Mode 1. Initial state The means for entering the user program mode has been prepared, and the program that will transfer the programming/erase control program from flash memory to on-chip RAM should be written into the flash memory by the user beforehand. The programming/erase control program should be prepared in the host or in the flash memory. Flash memory initialization The programming/erase program in RAM is executed, and the flash memory is initialized (to H'FF). Erasing can be performed in block units, but not in byte units. Programming/erase control program transfer When user program mode is entered, user software confirms this fact, executes transfer program in the flash memory, and transfers the programming/erase control program to RAM. Writing new application program Next, the new application program in the host is written into the erased flash memory blocks. Do not write to unerased blocks. Figure 7.4 User Program Mode ## 7.2.3 Block Configuration The flash memory is divided into four 1-kbyte blocks and one 28-kbyte block. Erasure is performed in this unit. ### 7.2.4 Pin Configuration The flash memory is controlled by means of the pins shown in table 7.1. **Table 7.1 Pin Configuration** | Pin Name | Abbreviation | I/O | Function | |---------------|--------------|--------|---------------------------------------| | Reset | RES | Input | Reset | | Mode | TEST | Input | Sets LSI operating mode | | Port PB0 | PB0 | Input | Sets LSI operating mode when TEST = 1 | | Port PB1 | PB1 | Input | Sets LSI operating mode when TEST = 1 | | Port PB2 | PB2 | Input | Sets LSI operating mode when TEST = 1 | | Transmit data | TxD | Output | Serial transmit data output | | Receive data | RxD | Input | Serial receive data input | ### 7.2.5 Register Configuration The registers used to control the on-chip flash memory when enabled are shown in table 7.2. **Table 7.2** Register Configuration | Register Name | Abbreviation | R/W | Initial Value | Address | |-------------------------------------|--------------|-------|---------------|---------| | Flash memory control register 1 | FLMCR1 | R/W*1 | H'00 | H'FF90 | | Flash memory control register 2 | FLMCR2 | R*1 | H'00 | H'FF91 | | Erase block register 1 | EBR1 | R/W*1 | H'00*2 | H'FF93 | | Flash memory power control register | FLPWCR | R/W*1 | H'00*2 | H'FF92 | | Flash memory enable register | FENR | R/W | H'00 | H'FF9B | Notes: 1. To access these registers, set the FLSHE bit to 1 in the flash memory enable register. 2. When the SWE bit of FLMCR1 is not set, these registers are initialized to H'00. # 7.3 Register Descriptions #### 7.3.1 Flash Memory Control Register 1 (FLMCR1) FLMCR1 is an 8-bit register used for flash memory operating mode control. Program-verify mode or erase-verify mode is entered by setting the SWE bit to 1, then setting the PV or EV bit. Program mode is entered by setting the SWE bit to 1, then setting the PSU bit, and finally setting the P bit. Erase mode is entered by setting the SWE bit to 1, then setting the ESU bit, and finally setting the E bit. FLMCR1 is initialized to H'00 by a power-on reset, or is initialized in standby mode. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|-----|-----|-----|-----|-----|-----|-----| | | _ | SWE | ESU | PSU | EV | PV | Е | Р | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | R/W **Bit 7—Reserved:** This bit always reads 0. Bit 6—Software Write Enable Bit (SWE): Enables or disables flash memory programming and erasing. Set this bit before setting bits 5 to 0 of this register and bits 4 to 0 of EBR1. | Bit 6: SWE | Description | _ | |------------|----------------|-----------------| | 0 | Write disabled | (Initial value) | | 1 | Write enabled | | **Bit 5—Erase Setup Bit (ESU):** Prepares for a transition to erase mode. Set this bit to 1 before setting the E bit in FLMCR1 to 1. Do not set the SWE, PSU, EV, PV, E, or P bit at the same time. | Bit 5: ESU | Description | | |------------|---------------------|-----------------| | 0 | Erase setup cleared | (Initial value) | | 1 | Erase setup | | | | [Setting condition] | | | | When SWE = 1 | | **Bit 4—Program Setup Bit (PSU):** Prepares for a transition to program mode. Set this bit to 1 before setting the P bit in FLMCR1 to 1. Do not set the SWE, ESU, EV, PV, E, or P bit at the same time. | Bit 4: PSU | Description | | |------------|-----------------------|-----------------| | 0 | Program setup cleared | (Initial value) | | 1 | Program setup | | | | [Setting condition] | | | | When SWE = 1 | | **Bit 3—Erase-Verify (EV):** Selects erase-verify mode transition or clearing. Do not set the SWE, ESU, PSU, PV, E, or P bit at the same time. | Bit 3: EV | Description | | |-----------|---------------------------------|-----------------| | 0 | Erase-verify mode cleared | (Initial value) | | 1 | Transition to erase-verify mode | | | | [Setting condition] | | | | When SWE = 1 | | **Bit 2—Program-Verify (PV):** Selects program-verify mode transition or clearing. Do not set the SWE, ESU, PSU, EV, E, or P bit at the same time. | Bit 2: PV | Description | | |-----------|-----------------------------------|-----------------| | 0 | Program-verify mode cleared | (Initial value) | | 1 | Transition to program-verify mode | | | | [Setting condition] | | | | When SWE = 1 | | **Bit 1—Erase (E):** Selects erase mode transition or clearing. Do not set the SWE, ESU, PSU, EV, PV, or P bit at the same time. | Bit 1: E | Description | | |----------|--------------------------|-----------------| | 0 | Erase mode cleared | (Initial value) | | 1 | Transition to erase mode | | | | [Setting condition] | | | | When SWE = 1 and ESU = 1 | | **Bit 0—Program (P):** Selects program mode transition or clearing. Do not set the SWE, PSU, ESU, EV, PV, or E bit at the same time. | Bit 0: P | Description | | |----------|----------------------------|-----------------| | 0 | Program mode cleared | (Initial value) | | 1 | Transition to program mode | | | | [Setting condition] | | | | When SWE = 1 and PSU = 1 | | ## 7.3.2 Flash Memory Control Register 2 (FLMCR2) FLMCR2 is an 8-bit register used for indicating flash memory program/erase status. FLMCR2 is initialized to H'00 by a power-on reset or is initialized in standby mode. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|---|---|---|---|---|---|---| | | FLER | | _ | _ | _ | _ | _ | _ | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R | R | R | R | R | R | R | Note: FLMCR2 is a read-only register, and must not be written to. **Bit 7—Flash Memory Error (FLER):** Indicates that an error has occurred during an operation on flash memory (programming or erasing). When FLER is set to 1, flash memory goes to the error-protection state. | Bit 7: FLER | Description | | | | | | |-------------|----------------------------------------------------------------------|-----------------|--|--|--|--| | 0 | Flash memory is operating normally | (Initial value) | | | | | | | Flash memory program/erase protection (error protection) is disabled | | | | | | | | [Clearing condition] | | | | | | | | Power-on reset or standby mode | | | | | | | 1 | An error has occurred during flash memory programming/erasing | | | | | | | | Flash memory program/erase protection (error protection) is enabled | | | | | | | | [Setting condition] | | | | | | | | See section 7.7.3, Error Protection | | | | | | | | | | | | | | Bits 6 to 0—Reserved: These bits always read 0. ### 7.3.3 Erase Block Register 1 (EBR1) EBR1 is an 8-bit register that specifies the flash memory erase area block by block. EBR1 is initialized to H'00 by a power-on reset, or in standby mode, or when the SWE bit in FLMCR1 is 0. When a bit in EBR1 is set to 1, the corresponding block can be erased. Other blocks are erase-protected. Do not set more than one bit, as this will cause all the bits in EBR1 to be automatically cleared to 0. The flash memory erase blocks are shown in table 7.3. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | _ | _ | _ | EB4 | EB3 | EB2 | EB1 | EB0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W **Table 7.3** Flash Memory Erase Blocks | Block (Size) | Addresses | | |-----------------|---------------|--| | EB0 (1 kbyte) | H'0000-H'03FF | | | EB1 (1 kbyte) | H'0400-H'07FF | | | EB2 (1 kbyte) | H'0800-H'0BFF | | | EB3 (1 kbyte) | H'0C00-H'0FFF | | | EB4 (28 kbytes) | H'1000–H'7FFF | | ## 7.3.4 Flash Memory Power Control Register (FLPWCR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|---|---|---|---|---|---|---| | | PDWND | _ | _ | _ | _ | _ | _ | _ | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W | R | R | R | R | R | R | R | FLPWCR enables or disables a transition to the flash memory power-down mode when the LSI switches to subactive mode. **Bit 7—Power-Down Disable (PDWND):** Enables or disables a transition to the flash memory power-down mode when the LSI switches to subactive mode. | Bit 7: PDWND | Description | | |--------------|-----------------------------------------------------|-----------------| | 0 | Transition to flash memory power-down mode enabled | (Initial value) | | 1 | Transition to flash memory power-down mode disabled | | Bits 6 to 0—Reserved: These bits always read 0. ## 7.3.5 Flash Memory Enable Register (FENR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|---|---|---|---|---|---|---| | | FLSHE | _ | _ | _ | _ | _ | _ | _ | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W | _ | _ | _ | _ | _ | _ | _ | FENR is an 8-bit readable/writable register that controls on-chip flash memory. FENR is initialized to H'00 by a reset or in standby mode. **Bit 7—Flash Memory Control Register Enable (FLSHE):** Controls CPU access to the flash memory control registers (FLMCR1, FLMCR2, EBR1, and FLPWCR). Setting the FLSHE bit to 1 enables read/write access to the flash memory control registers. If FLSHE is cleared to 0, the flash memory control registers cannot be accessed. In this case, the flash memory control register contents are retained. | Bit 7: FLSHE | Description | |--------------|--------------------------------------------------------------------------------------------| | 0 | Flash memory control registers in area H'FF90 to H'FF93 cannot be accessed (Initial value) | | 1 | Flash memory control registers in area H'FF90 to H'FF93 can be accessed | Bits 6 to 0—Reserved: Write 0 when writing. #### 7.4 Boot Mode When boot mode is used, the flash memory programming control program must be prepared in the host beforehand. The SCI3 to be used is set to asynchronous mode. The transmission/receive format is 8-bit data, 1 stop-bit, and no parity. When the boot program built into the LSI is activated, the bit rate of SCI3 is set according to the host bit rate. Next, the programming control program prepared in the host is received via SCI3, and is serially transmitted to the programming control program area of the on-chip RAM. The old data in the flash memory is entirely erased, the program branches to the start address of the programming control program area, and the execution of the programming control program is started. When the control branches to the programming control program, SCI3 terminates the transmission/receive operation (RE and TE of SCR are 0). However, since the bit rate of SCI3 that has been set is retained, SCI3 can be used continuously for transmission/receive of programming data or verify data. The TxD pin is in the high-level output state (PCR22 = PDR22 = 1). The values of the general-purpose registers of the CPU immediately after the branch to the programming control program are undefined. In particular, since the stack pointer (SP) is used for subroutine calls, specify the stack area at the beginning of the programming control program. The system configuration in boot mode is shown in figure 7.5, and the boot mode execution procedure is shown in figure 7.6. Figure 7.5 System Configuration in Boot Mode Note: If a memory cell does not operate normally and cannot be erased, one H'FF byte is transmitted as an erase error, and the erase operation and subsequent operations are halted. Figure 7.6 Boot Mode Execution Procedure ### 7.4.1 Automatic SCI Bit Rate Adjustment When the boot program is initiated, the boot program measures the low period of the asynchronous SCI communication data (H'00) transmitted continuously from the host. After the reset ends, it takes approximately 100 states before the chip is ready to measure the low-level period. The boot program adjusts the bit rate of the SCI3 to the bit rate of the transmission from the host and transmits one H'00 byte to the host to indicate the end of bit rate adjustment. The host should confirm that this adjustment end indication (H'00) has been received normally, and transmit one H'55 byte to the LSI. If reception cannot be performed normally, initiate boot mode again (reset), and repeat the above operations. Depending on the host's transmission bit rate and the LSI's system clock frequency, there will be a discrepancy between the bit rates of the host and the LSI. Set the host transfer bit rate and the system clock frequencies within the range shown in Table 7.4 Table 7.4 shows host transfer bit rates and system clock frequencies for which automatic adjustment of the LSI bit rate is possible. Table 7.4 System Clock Frequencies for which Automatic Adjustment of LSI Bit Rate is Possible | Host Bit Rate | System Clock Frequency for Which Automatic Adjustment of LSI Bit Rate is Possible | |---------------|-----------------------------------------------------------------------------------| | 19200 bps | 16 MHz | | 9600 bps | 8 to 16 MHz | | 4800 bps | 4 to 16 MHz | | 2400 bps | 2 to 16 MHz | # 7.4.2 Programming Control Program Area In boot mode, a part of the RAM area is used by the boot program. An area to which the programming control program is transferred is shown in figure 7.7. The boot program area cannot be used until the execution state in boot mode switches to the programming control program transferred from the host. Note: The boot program area cannot be used until a transition is made to the execution state for the programming control program transferred to RAM. Note also that the boot program remains in this area of the on-chip RAM even after control branches to the programming control program. Figure 7.7 RAM Areas in Boot Mode #### 7.4.3 Notes on Use of Boot Mode - 1. When the boot program is initiated, it measures the low-level period of the input at the SCI3's RxD pin. The reset should end with RxD high. The RxD and TxD pins should be pulled up on the board if necessary. - 2. Do not change input levels of the TEST pin and the $\overline{\text{NMI}}$ pin in boot mode. - 3. Boot mode can be cleared by driving the reset pin low, waiting at least 20 states, then setting the TEST pin and NMI pin, and executing reset release. Boot mode can also be cleared by a WDT overflow reset. - 4. If the TEST pin input levels are changed (for example, from low to high) during a reset, the state of ports will change according to the change in the microcomputer's operating mode\*. Therefore, care must be taken to make pin settings to prevent these pins from becoming output signal pins during a reset, or to prevent collision with signals outside the microcomputer. Note: \* See appendix D, Pin States in the Different Processing States. # 7.5 User Program Mode The on-board reprogramming of the on-chip flash memory in user program mode can be carried out by providing on-board means for supplying programming data, and by storing a program/erase control program or a program to supply it from outside in part of the flash memory as necessary. In this mode, peripheral functions other than flash memory operate as they normally would in user mode. The flash memory itself cannot be read while the SWE bit is set to 1 to perform programming or erasing, so the control program that performs programming and erasing should be run in on-chip RAM. Figure 7.8 shows the procedure for executing the program/erase control program when transferred to on-chip RAM. Figure 7.8 User Program Mode Execution Procedure # 7.6 Programming/Erasing Flash Memory A software method, using the CPU, is employed to program and erase flash memory in the on-board programming modes. There are flash memory operating modes: program mode, program-verify mode, erase mode, and erase-verify mode. Transitions to these modes are made by setting FLMCR1. The programming control program and the program/erase control program in on-board programming mode are used by combining these operating modes. The programming into the flash memory should be followed by "7.6.1 Program/Program-Verify Mode" and the erasing of the flash memory should be followed by "7.6.2 Erase/Erase-Verify Mode". Notes: 1. Operation is not guaranteed if bits SWE, ESU, PSU, EV, PV, E, and P of FLMCR1 are set/reset by a program in flash memory in the corresponding address areas. ### 7.6.1 Program/Program-Verify To write to flash memory, follow the program/program-verify flowchart shown in figure 7.9. Performing programming operations according to this flowchart will enable flash memory to be programmed without subjecting the device to voltage stress or sacrificing data reliability. - 1. Perform programming in the erased state. Do not reprogram addresses that have already been programmed. - 2. The unit for one programming operation is 128 bytes. A 128-byte data transfer must be performed even if writing fewer than 128 bytes of data; in this case, write H'FF data to addresses that do not need to be programmed. - 3. Provide a 128-byte program data area, 128-byte reprogram data area, and 128-byte additional-program data area in RAM. Refer to tables 7.5 and 7.6 for reprogram data and additional-program data computation. - 4. Write 128 bytes successively in byte units from the reprogram data area or additional-program data area to flash memory. The program address and 128-byte data are latched in the flash memory. The lower 8 bits of the flash memory start address must be H'00 or H'80. - 5. The time during which the P bit is set is the programming time. Set the programming time according to table 7.7. - 6. A watchdog timer setting is made to prevent overprogramming due to program runaway, etc. Set an overflow period of around 6.6 ms. - 7. For the dummy write to verify addresses, write one H'FF byte to addresses with b'00 in the lower 2 bits. Verify data can be read in longword format from the address on which the dummy write was executed. - 8. Do not repeat the program/program-verify sequence more than 1,000 times on the same bit. Figure 7.9 Program/Program-Verify Flowchart **Table 7.5 Reprogram Data Computation Table** | Program Data | Verify Data | Reprogram Data | Comments | |--------------|-------------|----------------|-------------------------| | 0 | 0 | 1 | Programmed bit | | 0 | 1 | 0 | Reprogram bit | | 1 | 0 | 1 | <del></del> | | 1 | 1 | 1 | Remains in erased state | **Table 7.6** Additional-Program Data Computation Table | Reprogram Data | Verify Data | Additional-Program<br>Data | Comments | |----------------|-------------|----------------------------|---------------------------| | 0 | 0 | 0 | Additional-program bit | | 0 | 1 | 1 | No additional programming | | 1 | 0 | 1 | No additional programming | | 1 | 1 | 1 | No additional programming | **Table 7.7 Programming Time** | n<br>(Number of Writes) | Programming<br>Time | In Additional<br>Programming | Comments | |-------------------------|---------------------|------------------------------|----------| | 1 to 6 | 30 | 10 | | | 7 to 1,000 | 200 | | | Note: Time shown in μs. ### 7.6.2 Erase/Erase-Verify To erase flash memory, follow the erase/erase-verify flowchart shown in figure 7.10. - 1. Prewriting (setting all data in the memory to be erased to all 0s) is not necessary before erasing. - 2. Erasing is performed on one block at a time. Select the block to be erased in erase block register 1 (EBR1). When erasing a number of blocks, each block must be erased in turn. - 3. The time during which the E bit is set is the erase time. - 4. A watchdog timer setting is made to prevent overerasing due to program runaway, etc. Set an overflow period of around 19.8 ms. - 5. For the dummy write to verify addresses, write one H'FF byte to addresses with b'00 in the lower 2 bits. Verify data can be read in longword format from the address on which the dummy write was executed. - 6. If the read data is unerased, set erase mode again and repeat the erase/erase-verify sequence as before. However, ensure that this sequence is not repeated more than 100 times. ## 7.6.3 Interrupts during Flash Memory Programming/Erasing For the following reasons, all interrupts, including $\overline{NMI}$ , should be disabled when flash memory is being programmed or erased. - 1. If an interrupt occurred during programming or erasing, it would not be possible to guarantee normal operation in accordance with the programming or erasing algorithm. - If interrupt exception handling were initiated during programming or erasing before the vector start address had been written, a normal vector fetch would not be possible and CPU runaway would result. - 3. If an interrupt occurred during boot program execution, it would not be possible to execute the normal boot mode sequence. Figure 7.10 Erase/Erase-Verify Flowchart ## 7.7 Protection There are three kinds of flash memory program/erase protection: hardware protection, software protection, and error protection. #### 7.7.1 Hardware Protection Hardware protection refers to a state in which programming/erasing of flash memory is forcibly disabled or aborted. Hardware protection is reset by settings in flash memory control register 1 (FLMCR1), flash memory control register 2 (FLMCR2), and erase block register 1 (EBR1). **Table 7.8** Hardware Protection | | | Fu | nctions | |--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------| | Item | Description | Program | Erase | | Reset/standby protection | <ul> <li>In a power-on reset (including a WDT power-on reset) and in standby mode, FLMCR1, FLMCR2, and EBR1 are initialized, and the program/erase-protected state is entered.</li> <li>In a reset via the RES pin, the reset state is not entered unless the RES pin is held low until oscillation stabilizes after powering on. In the case of a reset during operation, hold the RES pin low for the RES pulse width specified in the AC Characteristics section.</li> </ul> | Yes | Yes | #### 7.7.2 Software Protection Software protection can be implemented by clearing the SWE bit in FLMCR1, and by clearing each bit in erase block register 1 (EBR1). When software protection is in effect, setting the P or E bit in flash memory control register 1 (FLMCR1), does not cause a transition to program mode or erase mode. (See table 7.9.) **Table 7.9 Software Protection** | | Functions | | | |--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------| | Item | Description | Program | Erase | | SWE bit protection | Setting bit SWE in FLMCR1 to 0 will place<br>all blocks in the program/erase-protected<br>state. (Execute the program in the on-chip<br>RAM/external memory) | Yes | Yes | | Block specification protection | <ul> <li>Erase protection can be set for individual blocks by settings in erase block register 1 (EBR1)</li> <li>Setting EBR1 to H'00 places all blocks in the erase-protected state.</li> </ul> | _ | Yes | #### 7.7.3 Error Protection In error protection, an error is detected when CPU runaway occurs during flash memory programming/erasing, or operation is not performed in accordance with the program/erase algorithm, and the program/erase operation is forcibly aborted. Aborting the program/erase operation prevents damage to the flash memory due to overprogramming or overerasing. If the CPU malfunctions during flash memory programming/erasing, the FLER bit is set to 1 in FLMCR2 and the error protection state is entered. - (1) The flash memory is read during programming/erasing (including vector read and instruction fetch) - (2) Exception handling (excluding a reset) during programming/erasing - (3) SLEEP instruction (including software standby) is executed during programming/erasing The FLMCR1, FLMCR2, and EBR1 settings are retained, but program mode or erase mode is aborted at the point at which the error is detected. Program mode or erase mode cannot be reentered by re-setting the P or E bit. However, PV and EV bit setting is enabled, and a transition can be made to verify mode. Error protection is released only by a power-on reset and in hardware standby mode. Figure 7.11 shows the flash memory state transition diagram. Figure 7.11 Flash Memory State Transitions # 7.8 Interrupt Handling when Programming/Erasing Flash Memory All interrupts, including NMI interrupt is disabled when flash memory is being programmed or erased (when the P or E bit is set in FLMCR1), and while the boot program is executing. There are three reasons for this: - (1) Interrupt during programming or erasing might cause a violation of the programming or erasing algorithm, with the result that normal operation could not be assured. - (2) In the interrupt exception handling sequence during programming or erasing, the vector would not be fetched correctly, possibly resulting in MCU runaway. - (3) If interrupt occurred during boot program execution, it would not be possible to execute the normal boot mode sequence. Notes: 1. Interrupt requests must be disabled inside and outside the MCU until the programming control program has completed programming. ## 7.9 Flash Memory and Power-Down States There are three flash memory operating states in user mode: - (1) Normal operating mode: The flash memory can be read and written to at high speed. - (2) Power-down mode: Part of the power supply circuitry is halted, and the flash memory can be read when the LSI is operating in the subactive mode. - (3) Standby mode: When the LSI transits to standby mode, all flash memory circuits are halted, and the flash memory cannot be read or written to. Table 7.10 shows the correspondence between the operating states of the LSI and the flash memory. The flash memory is transited to power-down mode if the LSI is transited to the subactive mode while the PDWND bit in FLPWCR is cleared. When the flash memory is in a power-down state or in standby mode, part or all of the internal power supply circuitry is halted. Therefore, a power supply circuit stabilization period must be provided when returning to normal operation. When the flash memory returns to its normal operating state from a power-down state, bits STS2 to STS0 in SBYCR must be set to provide a wait time of at least 20 µs including when using an external clock. **Table 7.10 Flash Memory Operating States** | Flash Memory Operating State | | | | | | |--------------------------------|-----------------------------------------------------------------------------------------|--|--|--|--| | When PDWND = 0 (Initial value) | When PDWND = 1 | | | | | | Normal mode | Normal mode | | | | | | Power-down mode | Normal mode | | | | | | Normal mode | Normal mode | | | | | | Standby mode | Standby mode | | | | | | Standby mode | Standby mode | | | | | | | When PDWND = 0 (Initial value) Normal mode Power-down mode Normal mode Standby mode | | | | | # 7.10 Flash Memory Programmer Mode Programs and data can be written and erased in programmer mode as well as in the on-board programming modes. In programmer mode, flash memory read mode, auto-program mode, auto-erase mode, and status read mode are supported. In auto-program mode, auto-erase mode, and status read mode, a status polling procedure is used, and in status read mode, detailed internal signals are output after execution of an auto-program or auto-erase operation. In programmer mode, set the mode pins to programmer mode (see table 7.11) and input a 10 MHz input clock. Use a PROM programmer that supports the Hitachi 64-kbyte on-chip flash memory microcomputer device type (FZTAT64V5). Table 7.11 shows the pin settings for programmer mode. For the pin names in programmer mode, see section 1.4, Pin Functions. **Table 7.11 PROM Mode Pin Settings** | Pin Names | Settings | |----------------------------------|--------------------------------------| | Mode pins: TEST | High level input to TEST | | Mode setting pins: PB2, PB1, PB0 | Low level input to PB2, PB1, and PB0 | | RES pin | Power-on reset circuit | | OSC2, OSC1 | Oscillator circuit | #### 7.10.1 Socket Adapter Pin Correspondence Diagram Connect the socket adapter to the chip as shown in figure 7.12. This will enable conversion to a 32-pin arrangement. The on-chip ROM memory map is shown in figure 7.12, and the socket adapter pin correspondence diagram in figure 7.13. Figure 7.12 On-Chip ROM Memory Map Figure 7.13 Socket Adapter Pin Correspondence Diagram ### 7.10.2 Programmer Mode Operation Table 7.12 shows how the different operating modes are set when using programmer mode, and table 7.13 lists the commands used in programmer mode. Details of each mode are given below. ## • Memory Read Mode Memory read mode supports byte reads. ### • Auto-Program Mode Auto-program mode supports programming of 128 bytes at a time. Status polling is used to confirm the end of auto-programming. #### Auto-Erase Mode Auto-erase mode supports automatic erasing of the entire flash memory. Status polling is used to confirm the end of auto-programming. #### Status Read Mode Chip disable Status polling is used for auto-programming and auto-erasing, and normal termination can be confirmed by reading the I/O6 signal. In status read mode, error information is output if an error occurs. **Table 7.12** Settings for Various Operating Modes In Programmer Mode | Mode | CE | ΘE | WE | I/O7- I/O0 | A18-A0 | |----------------|----|----|----|-------------|--------| | Read | L | L | Н | Data output | Ain | | Output disable | L | Н | Н | Hi-z | X | | Command write | L | Н | L | Data input | *Ain | Х Pin Names Hi-7 Χ Notes: Chip disable is not a standby state; internally, it is an operation state. Х н <sup>\*</sup>Ain indicates that there is also address input in auto-program mode. **Table 7.13 Programmer Mode Commands** | | Number | 1st Cycle | | | 2nd Cycle | | | |-------------------|-----------|-----------|---------|------|-----------|---------|------| | | of Cycles | Mode | Address | Data | Mode | Address | Data | | Memory read mode | 1 + n | Write | Х | H'00 | Read | RA | Dout | | Auto-program mode | 129 | Write | Х | H'40 | Write | WA | Din | | Auto-erase mode | 2 | Write | Х | H'20 | Write | X | H'20 | | Status read mode | 2 | Write | X | H'71 | Write | Χ | H'71 | Notes: 1. In auto-program mode, 129 cycles are required for command writing by a simultaneous 128-byte write. 2. In memory read mode, the number of cycles depends on the number of address write cycles (n). ## 7.10.3 Memory Read Mode - After completion of auto-program/auto-erase/status read operations, a transition is made to the command wait state. When reading memory contents, a transition to memory read mode must first be made with a command write, after which the memory contents are read. - 2. In memory read mode, command writes can be performed in the same way as in the command wait state. - 3. Once memory read mode has been entered, consecutive reads can be performed. - 4. After powering on, memory read mode is entered. Table 7.14 AC Characteristics in Transition to Memory Read Mode (Conditions: $V_{CC} = 5.0 \text{ V} \pm 0.5 \text{ V}, V_{SS} = 0 \text{ V}, T_a = 25^{\circ}\text{C} \pm 5^{\circ}\text{C}$ ) | Item | Symbol | Min | Max | Unit | Notes | |---------------------|-------------------|-----|-----|------|-------------| | Command write cycle | t <sub>nxtc</sub> | 20 | | μs | Figure 7.14 | | CE hold time | t <sub>ceh</sub> | 0 | | ns | | | CE setup time | t <sub>ces</sub> | 0 | " | ns | | | Data hold time | t <sub>dh</sub> | 50 | | ns | | | Data setup time | t <sub>ds</sub> | 50 | | ns | | | Write pulse width | t <sub>wep</sub> | 70 | " | ns | | | WE rise time | t <sub>r</sub> | | 30 | ns | | | WE fall time | t <sub>f</sub> | | 30 | ns | | Figure 7.14 Timing Waveforms for Memory Read after Memory Write Table 7.15 AC Characteristics in Transition from Memory Read Mode to Another Mode (Conditions: $V_{CC} = 5.0 \text{ V} \pm 0.5 \text{ V}$ , $V_{SS} = 0 \text{ V}$ , $T_a = 25^{\circ}\text{C} \pm 5^{\circ}\text{C}$ ) | Item | Symbol | Min | Max | Unit | Notes | |---------------------|-------------------|-----|-----|------|-------------| | Command write cycle | t <sub>nxtc</sub> | 20 | _ | μs | Figure 7.15 | | CE hold time | t <sub>ceh</sub> | 0 | _ | ns | | | CE setup time | t <sub>ces</sub> | 0 | _ | ns | | | Data hold time | t <sub>dh</sub> | 50 | _ | ns | | | Data setup time | t <sub>ds</sub> | 50 | | ns | | | Write pulse width | t <sub>wep</sub> | 70 | | ns | | | WE rise time | t <sub>r</sub> | _ | 30 | ns | | | WE fall time | t <sub>f</sub> | _ | 30 | ns | | Figure 7.15 Timing Waveforms in Transition from Memory Read Mode to Another Mode Table 7.16 AC Characteristics in Memory Read Mode (Conditions: $V_{CC}$ = 5.0 V ±0.5 V, $V_{SS}$ = 0 V, $T_a$ = 25°C ±5°C) | Item | Symbol | Min | Max | Unit | Notes | |---------------------------|------------------|-----|--------------|------|-------------| | Access time | t <sub>acc</sub> | _ | 20 | μs | Figure 7.16 | | CE output delay time | t <sub>ce</sub> | _ | 150 | ns | Figure 7.17 | | OE output delay time | t <sub>oe</sub> | _ | 150 | ns | | | Output disable delay time | t <sub>df</sub> | | 100 | ns | | | Data output hold time | t <sub>oh</sub> | 5 | <del>_</del> | ns | | Figure 7.16 $\overline{\text{CE}}$ and $\overline{\text{OE}}$ Enable State Read Timing Waveforms #### 7.10.4 Auto-Program Mode - 1. When reprogramming previously programmed addresses, perform auto-erasing before auto-programming. - 2. Perform auto-programming once only on the same address block. It is not possible to program an address block that has already been programmed. - 3. In auto-program mode, 128 bytes are programmed simultaneously. This should be carried out by executing 128 consecutive byte transfers. - 4. A 128-byte data transfer is necessary even when programming fewer than 128 bytes. In this case, H'FF data must be written to the extra addresses. - 5. The lower 7 bits of the transfer address must be low. If a value other than an effective address is input, processing will switch to a memory write operation but a write error will be flagged. - 6. Memory address transfer is performed in the second cycle (figure 7.18). Do not perform transfer after the third cycle. - 7. Do not perform a command write during a programming operation. - 8. Perform one auto-program operation for a 128-byte block for each address. Two or more additional programming operations cannot be performed on a previously programmed address block. - 9. Confirm normal end of auto-programming by checking I/O6. Alternatively, status read mode can also be used for this purpose (I/O7 status polling uses the auto-program operation end decision pin). - 10. Status polling I/O6 and I/O7 pin information is retained until the next command write. As long as the next command write has not been performed, reading is possible by enabling $\overline{\text{CE}}$ and $\overline{\text{OE}}$ . Table 7.17 AC Characteristics in Auto-Program Mode (Conditions: $V_{CC}$ = 5.0 V ±0.5 V, $V_{SS}$ = 0 V, $T_a$ = 25°C ±5°C) | Item | Symbol | Min | Max | Unit | Notes | |----------------------------|--------------------|-----|-------------|------|-------------| | Command write cycle | t <sub>nxtc</sub> | 20 | _ | μs | Figure 7.18 | | CE hold time | t <sub>ceh</sub> | 0 | <del></del> | ns | | | CE setup time | t <sub>ces</sub> | 0 | | ns | | | Data hold time | t <sub>dh</sub> | 50 | <del></del> | ns | | | Data setup time | t <sub>ds</sub> | 50 | <del></del> | ns | | | Write pulse width | t <sub>wep</sub> | 70 | _ | ns | | | Status polling start time | t <sub>wsts</sub> | 1 | <u> </u> | ms | | | Status polling access time | t <sub>spa</sub> | _ | 150 | ns | | | Address setup time | t <sub>as</sub> | 0 | _ | ns | | | Address hold time | t <sub>ah</sub> | 60 | <u> </u> | ns | | | Memory write time | t <sub>write</sub> | 1 | 3000 | ms | | | WE rise time | t <sub>r</sub> | _ | 30 | ns | | | WE fall time | t <sub>f</sub> | _ | 30 | ns | <del></del> | Figure 7.18 Auto-Program Mode Timing Waveforms #### 7.10.5 Auto-Erase Mode - 1. Auto-erase mode supports only entire memory erasing. - 2. Do not perform a command write during auto-erasing. - 3. Confirm normal end of auto-erasing by checking I/O6. Alternatively, status read mode can also be used for this purpose (I/O7 status polling uses the auto-erase operation end decision pin). - 4. Status polling I/O6 and I/O7 pin information is retained until the next command write. As long as the next command write has not been performed, reading is possible by enabling $\overline{CE}$ and $\overline{OE}$ . Table 7.18 AC Characteristics in Auto-Erase Mode (Conditions: $V_{CC}$ = 5.0 V ±0.5 V, $V_{SS}$ = 0 V, $T_a$ = 25°C ±5°C) | Item | Symbol | Min | Max | Unit | Notes | |----------------------------|--------------------|-----|-------|------|-------------| | Command write cycle | t <sub>nxtc</sub> | 20 | _ | μs | Figure 7.19 | | CE hold time | t <sub>ceh</sub> | 0 | _ | ns | | | CE setup time | t <sub>ces</sub> | 0 | _ | ns | <del></del> | | Data hold time | t <sub>dh</sub> | 50 | | ns | | | Data setup time | t <sub>ds</sub> | 50 | _ | ns | | | Write pulse width | $t_{wep}$ | 70 | _ | ns | _ | | Status polling start time | t <sub>ests</sub> | 1 | | ms | | | Status polling access time | t <sub>spa</sub> | _ | 150 | ns | | | Memory erase time | t <sub>erase</sub> | 100 | 40000 | ms | | | WE rise time | t <sub>r</sub> | | 30 | ns | | | WE fall time | t <sub>f</sub> | | 30 | ns | _ | Figure 7.19 Auto-Erase Mode Timing Waveforms #### 7.10.6 Status Read Mode - 1. Status read mode is provided to identify the kind of abnormal end. Use this mode when an abnormal end occurs in auto-program mode or auto-erase mode. - 2. The return code is retained until a command write other than a status read mode command write is executed. Table 7.19 AC Characteristics in Status Read Mode (Conditions: $V_{CC}$ = 5.0 V ±0.5 V, $V_{SS}$ = 0 V, $T_a$ = 25°C ±5°C) | Item | Symbol | Min | Max | Unit | Notes | |-------------------------------|-------------------|-----|-----|------|-------------| | Read time after command write | t <sub>nxtc</sub> | 20 | _ | μs | Figure 7.20 | | CE hold time | t <sub>ceh</sub> | 0 | _ | ns | | | CE setup time | t <sub>ces</sub> | 0 | | ns | | | Data hold time | t <sub>dh</sub> | 50 | _ | ns | | | Data setup time | t <sub>ds</sub> | 50 | _ | ns | | | Write pulse width | t <sub>wep</sub> | 70 | | ns | | | OE output delay time | t <sub>oe</sub> | _ | 150 | ns | | | Disable delay time | t <sub>df</sub> | | 100 | ns | | | CE output delay time | t <sub>ce</sub> | | 150 | ns | | | WE rise time | t <sub>r</sub> | _ | 30 | ns | | | WE fall time | t <sub>f</sub> | _ | 30 | ns | | Figure 7.20 Status Read Mode Timing Waveforms **Table 7.20 Status Read Mode Return Commands** | Pin Name | 1/07 | I/O6 | 1/05 | I/O4 | I/O3 | I/O2 | I/O1 | I/O0 | |---------------|---------------------------|------------------|------------------------|------------------|------|------|------------------------------------------------|-------------------------| | Attribute | Normal<br>end<br>decision | Command error | Program-<br>ming error | Erase<br>error | _ | _ | Program-<br>ming or<br>erase count<br>exceeded | Effective address error | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Indications | Normal<br>end: 0 | Command error: 1 | Program-<br>ming | Erasing error: 1 | _ | _ | Count exceeded: 1 | | | | Abnormal | Otherwise: 0 | | Otherwise: 0 | ) | | Otherwise: 0 | | | | end: 1 | | Otherwise: 0 | | | | | Otherwise: 0 | Note: I/O2 and I/O3 are undefined. #### 7.10.7 Status Polling - 1. The I/O7 status polling flag indicates the operating status in auto-program/auto-erase mode. - 2. The I/O6 status polling flag indicates a normal or abnormal end in auto-program/auto-erase mode. **Table 7.21 Status Polling Output Truth Table** | Pin Name | During Internal<br>Operation | Abnormal End | _ | Normal End | |-----------|------------------------------|--------------|---|------------| | I/O7 | 0 | 1 | 0 | 1 | | I/O6 | 0 | 0 | 1 | 1 | | I/O0–I/O5 | 0 | 0 | 0 | 0 | # 7.10.8 Programmer Mode Transition Time Commands cannot be accepted during the oscillation stabilization period or the programmer mode setup period. After the programmer mode setup time, a transition is made to memory read mode. **Table 7.22** Stipulated Transition Times to Command Wait State | Item | Symbol | Min | Max | Unit | Notes | |--------------------------------------------------|-------------------|------|-----|------|-------------------------------------------------------| | Standby release (oscillation stabilization time) | t <sub>osc1</sub> | 10/5 | _ | ms | 10 ms: Crystal oscillator<br>5 ms: Ceramic oscillator | | Programmer mode setup time | t <sub>bmv</sub> | 10 | _ | ms | | | V <sub>cc</sub> hold time | t <sub>dwn</sub> | 0 | _ | ms | | Figure 7.21 Oscillation Stabilization Time, Boot Program Transfer Time, and Power-Down Sequence #### 7.10.9 Notes on Memory Programming - 1. When programming addresses which have previously been programmed, carry out autoerasing before auto-programming. - When performing programming using programmer mode on a chip that has been programmed/erased in an on-board programming mode, auto-erasing is recommended before carrying out auto-programming. - Notes: 1. The flash memory is initially in the erased state when the device is shipped by Hitachi. For other chips for which the erasure history is unknown, it is recommended that autoerasing be executed to check and supplement the initialization (erase) level. - 2. Auto-programming should be performed once only on the same address block. Additional programming cannot be performed on previously programmed address blocks. # Section 8 RAM #### 8.1 Overview H8/3664 Series has 1 kbyte and 512 bytes of high-speed static RAM on-chip. The RAM is connected to the CPU by a 16-bit data bus, allowing high-speed 2-state access for both byte data and word data. #### 8.1.1 Block Diagram Figure 8.1 shows a block diagram of the on-chip RAM. Figure 8.1 RAM Block Diagram # Section 9 I/O Ports #### 9.1 Overview The H8/3664 Series is provided with two 8-bit I/O ports, one 7-bit I/O port, two 3-bit I/O ports, and one 8-bit input-only port. Each port has of a port control register (PCR) that controls input and output, and a port data register (PDR) for storing output data. Input or output can be assigned to individual bits. See section 2.9.2, Notes on Bit Manipulation, for information on executing bit-manipulation instructions to write data in PCR or PDR. Pin states in each operation mode are given in Appendix D, Port States in the Different Processing State. # 9.2 Port 1 #### 9.2.1 Overview Port 1 is a 7-bit I/O port. Figure 9.1 shows its pin configuration. Figure 9.1 Port 1 Pin Configuration # 9.2.2 Register Configuration and Description Table 9.1 shows the port 1 register configuration. **Table 9.1 Port 1 Registers** | Name | Abbrev. | R/W | Initial Value | Address | |---------------------------------|---------|-----|---------------|---------| | Port data register 1 | PDR1 | R/W | H'08 | H'FFD4 | | Port control register 1 | PCR1 | W | H'00 | H'FFE4 | | Port pull-up control register 1 | PUCR1 | R/W | H'08 | H'FFD0 | | Port mode register 1 | PMR1 | R/W | H'0C | H'FFE0 | #### 9.2.3 Port Data Register 1 (PDR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------|-----|-----|-----|-----|----|-----|-----|-----|--| | | P17 | P16 | P15 | P14 | _ | P12 | P11 | P10 | | | Initial value | 0 | 0 | 0 | 0 | 1* | 0 | 0 | 0 | | | Read/Write | R/W | R/W | R/W | R/W | _ | R/W | R/W | R/W | | Note: \* Bit 3 is reserved; it is always read as 1 and cannot be modified. PDR1 is an 8-bit register that stores data for port 1 pins P17 to P14 and P12 to P10. If port 1 is read while PCR1 bits are set to 1, the values stored in PDR1 are read, regardless of the actual pin states. If port 1 is read while PCR1 bits are cleared to 0, the pin states are read. Upon reset, PDR1 is initialized to H'08. #### 9.2.4 Port Control Register 1 (PCR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|---|-------|-------|-------| | | PCR17 | PCR16 | PCR15 | PCR14 | _ | PCR12 | PCR11 | PCR10 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | _ | W | W | W | PCR1 is an 8-bit register for controlling whether each of the port 1 pins P17 to P14 and P12 to P10 functions as an input pin or output pin. Setting a PCR1 bit to 1 makes the corresponding pin an output pin, while clearing the bit to 0 makes the pin an input pin. The settings in PCR1 and in PDR1 are valid only when the corresponding pin is designated in PMR1 as a general I/O pin. Upon reset, PCR1 is initialized to H'00. PCR1 is a write-only register, which is always read as all 1s. # 9.2.5 Port Pull-Up Control Register 1 (PUCR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|----|--------|--------|--------| | | PUCR17 | PUCR16 | PUCR15 | PUCR14 | _ | PUCR12 | PUCR11 | PUCR10 | | Initial value | 0 | 0 | 0 | 0 | 1* | 0 | 0 | 0 | | Read/Write | R/W | R/W | R/W | R/W | _ | R/W | R/W | R/W | Note: \* Bit 3 is reserved; it is always read as 1 and cannot be modified. PUCR1 controls whether the MOS pull-up of each of the port 1 pins P17 to P14 and P12 to P10 is on or off. When a PCR1 bit is cleared to 0, setting the corresponding PUCR1 bit to 1 turns on the MOS pull-up for the corresponding pin, while clearing the bit to 0 turns off the MOS pull-up. Upon reset, PUCR1 is initialized to H'08. #### 9.2.6 Port Mode Register 1 (PMR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|------|---|---|-----|------| | | IRQ3 | IRQ2 | IRQ1 | IRQ0 | _ | _ | TXD | TMOW | | Initial value | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | Read/Write | R/W | R/W | R/W | R/W | _ | | R/W | R/W | PMR1 is an 8-bit read/write register, controlling the selection of pin functions for ports 1 and 2 pins. Upon reset, PMR1 is initialized to H'0C. # **Bit 7—P17/IRQ3/TRGV Pin Function Switch (IRQ3):** This bit selects whether pin P17/IRQ3/TRGV is used as P17 or as IRQ3/TRGV. | Bit 7: IRQ3 | Description | | |-------------|----------------------------------|-----------------| | 0 | Functions as P17 I/O pin | (Initial value) | | 1 | Functions as IRQ3/TRGV input pin | | Note: Rising or falling edge sensing can be designated for IRQ3. Rising, falling, or both edge sensing can be designated for TRGV. For details on TRGV settings, see section 11.2.5, Timer Control Register V1 (TCRV1). # Bit 6—P16/ $\overline{IRQ2}$ Pin Function Switch (IRQ2): This bit selects whether pin P16/ $\overline{IRQ2}$ is used as P16 or as $\overline{IRQ2}$ . | Bit 6: IRQ2 | Description | | |-------------|-----------------------------|-----------------| | 0 | Functions as P16 I/O pin | (Initial value) | | 1 | Functions as IRQ2 input pin | | Note: Rising or falling edge sensing can be designated for IRQ2. Bit 5—P15/ $\overline{IRQ1}$ Pin Function Switch (IRQ1): This bit selects whether pin P15/ $\overline{IRQ1}$ is used as P15 or as $\overline{IRQ1}$ . | Bit 5: IRQ1 | Description | | |-------------|-----------------------------|-----------------| | 0 | Functions as P15 I/O pin | (Initial value) | | 1 | Functions as IRQ1 input pin | | Note: Rising or falling edge sensing can be designated for IRQ1. Bit 4—P14/ $\overline{IRQ0}$ Pin Function Switch (IRQ0): This bit selects whether pin P14/ $\overline{IRQ0}$ is used as P14 or as $\overline{IRQ0}$ . | Bit 4: IRQ0 | Description | | |-------------|------------------------------|-----------------| | 0 | Functions as P14 I/O pin | (Initial value) | | 1 | Functions as IRQ0 output pin | | Bit 3—Reserved Bit: Bit 3 is reserved: it is always read as 1 and cannot be modified. Bit 2—Reserved Bit: Bit 2 is reserved: it is always read as 1 and cannot be modified. **Bit 1—P22/TXD Pin Function Switch (TXD):** This bit selects whether pin P22/TXD is used as P22 or as TXD. | Bit 1: TXD | Description | | |------------|-----------------------------|-----------------| | 0 | Functions as P22 I/O pin | (Initial value) | | 1 | Functions as TXD output pin | | **Bit 0—P10/TMOW Pin Function Switch (TMOW):** This bit selects whether pin P10/TMOW is used as P10 or as TMOW. | Bit 0: TMOW | Description | | |-------------|------------------------------|-----------------| | 0 | Functions as P10 I/O pin | (Initial value) | | 1 | Functions as TMOW output pin | | # 9.2.7 Pin Functions Table 9.2 shows the port 1 pin functions. **Table 9.2 Port 1 Pin Functions** | Pin | Pin Functions and Selection Method | | | | | | | | |----------------------------------|----------------------------------------------------------------------------------------------------------|-----------------|----------------|---------------------|--|--|--|--| | P17/IRQ3/TRGV | The pin function depends on bit IRQ3 in PMR1 and bit PCR17 in PCR1. | | | | | | | | | | IRQ3 | ( | 1 | | | | | | | | PCR17 | 0 1 | | * | | | | | | | Pin function | P17 input pin | P17 output pin | IRQ3/TRGV input pin | | | | | | P16/ĪRQ2<br>P15/ĪRQ1<br>P14/ĪRQ0 | The pin function depends on bits IRQ2 and IRQ1 in PMR1 and bit PCR1n in IRQ0 and PCR1. $(m=n-4,n=6,5,4)$ | | | | | | | | | | IRQm | | 0 | 1 | | | | | | | PCR1n | 0 | 1 | * | | | | | | | Pin function | P1n input pin | P1n output pin | IRQm input pin | | | | | | P12 | The pin function d | epends on bit P | CR1n in PCR1. | | | | | | | P11 | PCR1n | | 0 | 1 | | | | | | | Pin function | P1n in | put pin | P1n output pin | | | | | | P10/TMOW | The pin function depends on bit TMOW in PMR1 and bit PCR10 in PCR1. | | | | | | | | | | TMOW | | 0 | 1 | | | | | | | PCR10 | 0 | 1 | * | | | | | | | Pin function | P10 input pin | P10 output pin | TMOW output pin | | | | | Note: \* Don't care # 9.2.8 MOS Input Pull-Up Port 1 has an on-chip MOS input pull-up function that can be controlled by software. When a PCR1 bit is cleared to 0, setting the corresponding PUCR1 bit to 1 turns on the MOS input pull-up for that pin. The MOS input pull-up function is in the off state after a reset. | PCR1n | ( | ) | 1 | |-------------------|-----|----|-----| | PUCR1n | 0 1 | | * | | MOS input pull-up | Off | On | Off | (n = 7 to 4, 2 to 0) Note: \* Don't care #### 9.3 Port 2 #### 9.3.1 Overview Port 2 is a 3-bit I/O port, configured as shown in figure 9.2. Figure 9.2 Port 2 Pin Configuration # 9.3.2 Register Configuration and Description Table 9.3 shows the port 2 register configuration. **Table 9.3** Port 2 Registers | Name | Abbrev. | R/W | Initial Value | Address | |-------------------------|---------|-----|---------------|---------| | Port data register 2 | PDR2 | R/W | H'F8 | H'FFD5 | | Port control register 2 | PCR2 | W | H'00 | H'FFE5 | # 9.3.3 Port Data Register 2 (PDR2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|-----|-----|-----| | | _ | _ | _ | _ | _ | P22 | P21 | P20 | | Initial value | 1* | 1* | 1* | 1* | 1* | 0 | 0 | 0 | | Read/Write | _ | _ | _ | _ | _ | R/W | R/W | R/W | Note: \* Bits 7 to 3 are reserved; they are always read as 1 and cannot be modified. PDR2 is an 8-bit register that stores data for port 2 pins P22 to P20. If port 2 is read while PCR2 bits are set to 1, the values stored in PDR2 are read, regardless of the actual pin states. If port 2 is read while PCR2 bits are cleared to 0, the pin states are read. Upon reset, PDR2 is initialized to H'F8. # 9.3.4 Port Control Register 2 (PCR2) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|---|-------|-------|-------| | | _ | _ | _ | _ | _ | PCR22 | PCR21 | PCR20 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | _ | _ | _ | _ | W | W | W | PCR2 is an 8-bit register for controlling whether each of the port 1 pins P22 to P20 functions as an input pin or output pin. Setting a PCR2 bit to 1 makes the corresponding pin an output pin, while clearing the bit to 0 makes the pin an input pin. The settings in PCR2 and PDR2 are valid only when the corresponding pin is designated in SCR3 as a general I/O pin. Upon reset, PCR2 is initialized to H'00. PCR2 is a write-only register, which is always read as all 1s. # 9.3.5 Pin Functions Table 9.4 shows the port 2 pin functions. **Table 9.4 Port 2 Pin Functions** | Pin | Pin Functions and Selection Method | | | | | | | | |---------------------------------------------------------------------------|------------------------------------|--------------------------------------------------------------------|-------------------------------|---------|--------------|----------------|--|--| | P22/TXD | The pin function of | The pin function depends on bit TXD in PMR1 and bit PCR22 in PCR2. | | | | | | | | | TXD | | 1 | | | | | | | | PCR22 | 0 | 1 | | : | * | | | | | Pin function | P22 input pin | P22 output pin | | TXD ou | tput pin | | | | P21/RXD The pin function depends on bit RE in SCR3 and bit PCR21 in PCR2. | | | | | | | | | | P21/RXD | ine pin function of | depends on bit F | KE IN SCR3 and | DIT PCF | K21 IN P | CR2. | | | | | RE | ( | 1 | | | | | | | | PCR21 | 0 1 | | * | | | | | | | Pin function | P21 input pin | put pin P21 output pin RXD ir | | put pin | | | | | P20/SCK3 | The pin function of | • | CKE1 and CKE | 0 in SC | R3, bit 0 | COM in SMR, | | | | | CKE1 | | | 1 | | | | | | | CKE0 | | 0 | | 1 | * | | | | | СОМ | | 0 | 1 | * | * | | | | | PCR20 | 0 1 | | * | | * | | | | | Pin function | P20 input pin | P20 output pin | | output<br>in | SCK3 input pin | | | Note: \* Don't care # 9.4 Port 5 #### 9.4.1 Overview Port 5 is an 8-bit I/O port, configured as shown in figure 9.3. Figure 9.3 Port 5 Pin Configuration # 9.4.2 Register Configuration and Description Table 9.5 shows the port 5 register configuration. **Table 9.5 Port 5 Registers** | Name | Abbrev. | R/W | Initial Value | Address | |---------------------------------|---------|-----|---------------|---------| | Port data register 5 | PDR5 | R/W | H'00 | H'FFD8 | | Port control register 5 | PCR5 | W | H'00 | H'FFE8 | | Port pull-up control register 5 | PUCR5 | R/W | H'00 | H'FFD1 | | Port mode register 5 | PMR5 | R/W | H'00 | H'FFE1 | #### 9.4.3 Port Data Register 5 (PDR5) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W PDR5 is an 8-bit register that stores data for port 5 pins P57 to P50. If port 5 is read while PCR5 bits are set to 1, the values stored in PDR5 are read, regardless of the actual pin states. If port 5 is read while PCR5 bits are cleared to 0, the pin states are read. Upon reset, PDR5 is initialized to H'00. #### 9.4.4 Port Control Register 5 (PCR5) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | | PCR57 | PCR56 | PCR55 | PCR54 | PCR53 | PCR52 | PCR51 | PCR50 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | W | W | W | W | PCR5 is an 8-bit register for controlling whether each of the port 5 pins P57 to P50 functions as an input pin or output pin. Setting a PCR5 bit to 1 makes the corresponding pin an output pin, while clearing the bit to 0 makes the pin an input pin. Upon reset, PCR5 is initialized to H'00. PCR5 is a write-only register, which is always read as all 1s. #### 9.4.5 Port Pull-Up Control Register 5 (PUCR5) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|--------|--------|--------|--------|--------|--------| | | _ | _ | PUCR55 | PUCR54 | PUCR53 | PUCR52 | PUCR51 | PUCR50 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | | R/W | R/W | R/W | R/W | R/W | R/W | PUCR5 controls whether the MOS pull-up of each port 5 pin is on or off. When a PCR5 bit is cleared to 0, setting the corresponding PUCR5 bit to 1 turns on the MOS pull-up for the corresponding pin, while clearing the bit to 0 turns off the MOS pull-up. Upon reset, PUCR5 is initialized to H'00. # 9.4.6 Port Mode Register 5 (PMR5) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|------|------|------|------|------|------| | | _ | _ | WKP5 | WKP4 | WKP3 | WKP2 | WKP1 | WKP0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | _ | R/W | R/W | R/W | R/W | R/W | R/W | PMR5 is an 8-bit read/write register, controlling the selection of pin functions for port 5 pins. Upon reset, PMR5 is initialized to H'00. Bit n—P5n/WKPn Pin Function Switch (WKPn): This bit selects whether pin P5n/WKPn is used as P5n or as $\overline{WKPn}$ . | Bit n: WKPn | Description | | |-------------|-----------------------------|-----------------| | 0 | Functions as P5n I/O pin | (Initial value) | | 1 | Functions as WKPn input pin | | | | | (n = 5 to 0) | # 9.4.7 Pin Functions Table 9.6 shows the port 5 pin functions. The output type of SCL and SDA is open-drain, providing direct bus driving capability. **Table 9.6 Port 5 Pin Functions** | Pin | Pin Functions and Selection Method | | | | | | | |-------------|-----------------------------------------------------------------------------|-----------------|----------------|--------------------------------|--|--|--| | P57/SCL | The pin function depends on bit PCR57 in PCR5 and bit ICE in I2C. | | | | | | | | | ICE | 0 | | 1 | | | | | | PCR57 | 0 | 1 | * | | | | | | Pin function | P57 input pin | P57 output pin | SCL I/O pin | | | | | | The SCL output format is NMOS open drain and direct bus driving is enabled. | | | | | | | | P56/SDA | The pin function d | epends on bit P | CR56 in PCR5 a | and bit ICE in I2C. | | | | | | ICE | | 0 | 1 | | | | | | PCR56 | 0 | 1 | * | | | | | | Pin function | P56 input pin | P56 output pin | SDA I/O pin | | | | | | The SDA output format is NMOS open drain and direct bus driving is enabled. | | | | | | | | P55/WKP5/ | The pin function d | epends on bit P | CR55 in PCR5 a | and bit WKP5 in PMR5. | | | | | ADTRG | WKP5 | | 0 | 1 | | | | | | PCR55 | 0 | 1 | * | | | | | | Pin function | P55 input pin | P55 output pin | WKP5 input pin ADTRG input pin | | | | | P54/WKP4 to | The pin function d | epends on bit P | CR5n in PCR5 a | and bit WKPn in PMR5. | | | | | P50/WKP0 | WKPn | | 0 | 1 | | | | | | PCR5n | 0 | 1 | * | | | | | | Pin function | P5n input pin | P5n output pin | WKPn input pin | | | | | | (n = 4 to 0) | 1. | I. | | | | | Note: \* Don't care. # 9.4.8 MOS Input Pull-Up Port 5 has an on-chip MOS input pull-up function that can be controlled by software. When a PCR5 bit is cleared to 0, setting the corresponding PUCR5 bit to 1 turns on the MOS pull-up for that pin. The MOS pull-up function is in the off state after a reset. | PCR5n | ( | ) | 1 | |-------------------|-----|----|-----| | PUCR5n | 0 | 1 | * | | MOS input pull-up | Off | On | Off | (n = 5 to 0) Note: \* Don't care #### 9.5 Port 7 #### 9.5.1 Overview Port 7 is a 3-bit I/O port, configured as shown in figure 9.4. Figure 9.4 Port 7 Pin Configuration #### 9.5.2 Register Configuration and Description Table 9.7 shows the port 7 register configuration. **Table 9.7 Port 7 Registers** | Name | Abbrev. | R/W | Initial Value | Address | |-------------------------|---------|-----|---------------|---------| | Port data register 7 | PDR7 | R/W | H'8F | H'FFDA | | Port control register 7 | PCR7 | W | H'00 | H'FFEA | # 9.5.3 Port Data Register 7 (PDR7) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|-----|-----|-----|----|----|----|----| | | _ | P76 | P75 | P74 | _ | _ | _ | _ | | Initial value | 1* | 0 | 0 | 0 | 1* | 1* | 1* | 1* | | Read/Write | _ | R/W | R/W | R/W | _ | _ | _ | _ | Note: \* Bits 7 and 3 to 0 are reserved; they are always read as 1 and cannot be modified. PDR7 is an 8-bit register that stores data for port 7 pins P76 to P74. If port 7 is read while PCR7 bits are set to 1, the values stored in PDR7 are read, regardless of the actual pin states. If port 7 is read while PCR7 bits are cleared to 0, the pin states are read. Upon reset, PDR7 is initialized to H'8F. #### 9.5.4 Port Control Register 7 (PCR7) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|-------|-------|-------|---|---|---|---| | | _ | PCR76 | PCR75 | PCR74 | _ | _ | _ | _ | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | _ | W | W | W | _ | _ | _ | _ | PCR7 is an 8-bit register for controlling whether each of the port 7 pins P76 to P74 functions as an input pin or output pin. Setting a PCR7 bit to 1 makes the corresponding pin an output pin, while clearing the bit to 0 makes the pin an input pin. Upon reset, PCR7 is initialized to H'00. PCR7 is a write-only register, which always reads as all 1s. #### 9.5.5 **Pin Functions** | Table 9.8 F | Port 7 Pin Function | ns | | | | | |-------------|-------------------------|------------------------------------------------|------------------|----------------------|--|--| | Pin | Pin Functions | and Selection Me | thod | | | | | P76/TMOV | The pin function TCSRV. | depends on bit P | CR76 in PCR7 and | d bits OS3 to OS0 in | | | | | OS3 to OS0 | 00 | 00 | Not 0000 | | | | | PCR76 | 0 | 1 | * | | | | | Pin function | P76 input pin | P76 output pin | TMOV output pir | | | | P75/TMCIV | | depends on bit P | | | | | | | PCR75 | | 0 | 1 | | | | | Pin function | P75 in | put pin | P75 output pin | | | | | | | TMCIV inp | ut pin | | | | P74/TMRIV | The pin function | The pin function depends on bit PCR74 in PCR7. | | | | | | | PCR74 | | 0 | 1 | | | | | Pin function | P74 in | put pin | P74 output pin | | | | | | | | TMRIV input pin | | | Note: \* Don't care # 9.6 Port 8 #### 9.6.1 Overview Port 8 is an 8-bit I/O port configured as shown in figure 9.5. Figure 9.5 Port 8 Pin Configuration # 9.6.2 Register Configuration and Description Table 9.9 shows the port 8 register configuration. **Table 9.9 Port 8 Registers** | Name | Abbrev. | R/W | Initial Value | Address | |-------------------------|---------|-----|---------------|---------| | Port data register 8 | PDR8 | R/W | H'00 | H'FFDB | | Port control register 8 | PCR8 | W | H'00 | H'FFEB | #### 9.6.3 Port Data Register 8 (PDR8) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----| | | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W PDR8 is an 8-bit register that stores data for port 8 pins P87 to P80. If port 8 is read while PCR8 bits are set to 1, the values stored in PDR8 are read, regardless of the actual pin states. If port 8 is read while PCR8 bits are cleared to 0, the pin states are read. Upon reset, PDR8 is initialized to H'00. # 9.6.4 Port Control Register 8 (PCR8) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | | PCR87 | PCR86 | PCR85 | PCR84 | PCR83 | PCR82 | PCR81 | PCR80 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | W | W | W | W | W | W | W | W | PCR8 is an 8-bit register for controlling whether each of the port 8 pins P87 to P80 functions as an input or output pin. Setting a PCR8 bit to 1 makes the corresponding pin an output pin, while clearing the bit to 0 makes the pin an input pin. Upon reset, PCR8 is initialized to H'00. PCR8 is a write-only register, which is always read as all 1s. # 9.6.5 Pin Functions Table 9.10 shows the port 8 pin functions. **Table 9.10 Port 8 Pin Functions** | Pin | Pin Functions ar | nd Selection Me | thod | Pin Functions and Selection Method | | | | | | | |--------------|---------------------|-------------------------------------------------------------------------|--------------------|------------------------------------|----------------|--|--|--|--|--| | P87 | The pin function of | depends on bit PO | CR87 in | PCR8. | | | | | | | | | PCR87 | 0 | | | 1 | | | | | | | | Pin function | P87 input p | pin | P8 | 7 output pin | | | | | | | P86 | The pin function of | The pin function depends on bit PCR86 in PCR8. | | | | | | | | | | | PCR86 | 0 | | | 1 | | | | | | | Pin function | | P86 input | pin | P8 | 6 output pin | | | | | | | P85 | The pin function of | depends on bit P0 | CR85 in | PCR8. | | | | | | | | | PCR85 | 0 | | 1 | | | | | | | | | Pin function | P85 input | oin P85 output pin | | 5 output pin | | | | | | | P84/FTIOD | | The pin function depends on bit PCR84 in PCR8 and bit TIOR1 in timer W. | | | | | | | | | | | Timer W Setting | (2) | (1) | | (2) | | | | | | | | IOD2 | | 0 | | 1 | | | | | | | | IOD1 | 0 | 0 | 1 | _ | | | | | | | | IOD0 | 0 | 1 | _ | _ | | | | | | | | Timer W Setting | (1) above | (2) above | | bove | | | | | | | | PCR84 | _ | | 0 | 1 | | | | | | | | Pin function | FTIOD output | P84 input pin | | P84 output pin | | | | | | | | | pin | FTIOD input pin | | nnut nin | | | | | | P83/FTIOC The pin function depends on bit PCR83 in PCR8 and bit TIOR1 in timer W. | Timer W Setting | (2) | (1) | | (2) | |-----------------|-----|-----|---|-----| | IOC2 | | 0 | | 1 | | IOC1 | 0 | 0 | 1 | _ | | IOC0 | 0 | 1 | | _ | | Timer W Setting | (1) above | (2) above | | | |-----------------|--------------|-----------------|----------------|--| | PCR83 | _ | 0 | 1 | | | Pin function | FTIOC output | P83 input pin | P83 output pin | | | | pin | FTIOC input pin | | | P82/FTIOB The pin function depends on bit PCR82 in PCR8 and bit TIOR0 in timer W. | Timer W Setting | (2) | (1) | | (2) | |-----------------|-----|-----|---|-----| | IOB2 | | 0 | | 1 | | IOB1 | 0 | 0 | 1 | _ | | IOB0 | 0 | 1 | _ | _ | | Timer W Setting | (1) above | (2) above | | | | |-----------------|--------------|-----------------|----------------|--|--| | PCR82 | _ | 0 | 1 | | | | Pin function | FTIOB output | P82 input pin | P82 output pin | | | | pin | | FTIOB input pin | | | | | Pin | | |-----|--| |-----|--| #### **Pin Functions and Selection Method** P82/FTIOA The pin function depends on bit PCR81 in PCR8 and bit TIOR0 in timer W. | Timer W Setting | (2) | (1) | | (2) | |-----------------|-----|-----|---|-----| | IOA2 | | 0 | | 1 | | IOA1 | 0 | 0 | 1 | _ | | IOA0 | 0 | 1 | | _ | | Timer W Setting | (1) above | (2) above | | | | |-----------------|--------------|-----------------|----------------|--|--| | PCR81 | _ | 0 | 1 | | | | Pin function | FTIOA output | P81 input pin | P81 output pin | | | | | pin | FTIOA input pin | | | | P80/FTCI The pin function depends on bit PCR80 in PCR8. | PCR80 | 0 | 1 | | | | |--------------|----------------|----------------|--|--|--| | Pin function | P80 input pin | P80 output pin | | | | | | FTCI input pin | | | | | # **9.7** Port B #### 9.7.1 Overview Port B is an 8-bit input-only port, configured as shown in figure 9.6. Figure 9.6 Port B Pin Configuration # 9.7.2 Register Configuration and Description Table 9.11 shows the port B register configuration. Table 9.11 Port B Register | Name | Abbrev. | R/W | Address | |----------------------|---------|-----|---------| | Port data register B | PDRB | R | H'FFDD | # 9.7.3 Port Data Register B (PDRB) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-----|-----|-----|-----|-----|-----|-----|-----| | | PB7 | PB6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | | | | | | | | | | | | Read/Write | R | R | R | R | R | R | R | R | Reading PDRB always gives the pin states. However, if a port B pin is selected as an analog input channel by the A/D converter's ADCSR register, that pin reads 0. # 9.7.4 Pin Functions Table 9.12 shows the port B pin functions. **Table 9.12 Port B Pin Functions** | Pin<br>PBn/ANn | Pin Functions and Selection Method | | | | | | | |----------------|------------------------------------|--------------------------------|----------------|--|--|--|--| | | Always as below. | | | | | | | | | | | (n = 7 to 0) | | | | | | | Pin function | PBn input pin or ANn input pin | | | | | | # Section 10 Timer A #### 10.1 Overview Timer A is an 8-bit timer with interval timing and real-time clock time-base functions. The clock time-base function is available when a 32.768-kHz crystal oscillator is connected. A clock signal divided from 32.768 kHz or from the system clock can be output at the TMOW pin. #### 10.1.1 Features Features of timer A are given below. - Choice of eight internal clock sources (ø/8192, ø/4096, ø/2048, ø/512, ø/256, ø/128, ø/32, ø/8). - Choice of four overflow periods (1 s, 0.5 s, 0.25 s, 31.25 ms) when timer A is used as a clock time base (using a 32.768 kHz crystal oscillator). - An interrupt is requested when the counter overflows. - Any of eight clock signals can be output from pin TMOW: 32.768 kHz divided by 32, 16, 8, or 4 (1 kHz, 2 kHz, 4 kHz, 8 kHz), or the system clock divided by 32, 16, 8, or 4. # 10.1.2 Block Diagram Figure 10.1 shows a block diagram of timer A. Figure 10.1 Block Diagram of Timer A # 10.1.3 Pin Configuration Table 10.1 shows the timer A pin configuration. **Table 10.1 Pin Configuration** | Name | Abbrev. | I/O | Function | |--------------|---------|--------|--------------------------------------------------------| | Clock output | TMOW | Output | Output of waveform generated by timer A output circuit | ### 10.1.4 Register Configuration Table 10.2 shows the register configuration of timer A. **Table 10.2** Timer A Registers | Name | Abbrev. | R/W | Initial Value | Address | |-----------------------|---------|-----|---------------|---------| | Timer mode register A | TMA | R/W | H'10 | H'FFA6 | | Timer counter A | TCA | R | H'00 | H'FFA7 | # 10.2 Register Descriptions #### 10.2.1 Timer Mode Register A (TMA) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|---|------|------|------|------| | | TMA7 | TMA6 | TMA5 | _ | TMA3 | TMA2 | TMA1 | TMA0 | | Initial value | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/W | R/W | R/W | | R/W | R/W | R/W | R/W | TMA is an 8-bit read/write register for selecting the prescaler, input clock, and output clock. Upon reset, TMA is initialized to H'10. **Bits 7 to 5—Clock Output Select (TMA7 to TMA5):** Bits 7 to 5 choose which of eight clock signals is output at the TMOW pin. The system clock divided by 32, 16, 8, or 4 can be output in active mode and sleep mode. A 32.768 kHz signal divided by 32, 16, 8, or 4 can be output in active mode, sleep mode, and subactive mode. | Bit 7: TMA7 | Bit 6: TMA6 | Bit 5: TMA5 | Clock Output | | |-------------|-------------|-------------|--------------------|-----------------| | 0 | 0 | 0 | ø/32 | (Initial value) | | | | 1 | ø/16 | | | | 1 | 0 | ø/8 | | | | | 1 | ø/4 | | | 1 | 0 | 0 | ø <sub>w</sub> /32 | | | | | 1 | ø <sub>w</sub> /16 | | | | 1 | 0 | ø <sub>w</sub> /8 | | | | | 1 | ø <sub>W</sub> /4 | | **Bit 4—Reserved Bit:** Bit 4 is reserved; it is always read as 1, and cannot be modified. **Bits 3 to 0—Internal Clock Select (TMA3 to TMA0):** Bits 3 to 0 select the clock input to TCA. The selection is made as follows. Description | | | | | Description | | |----------------|----------------|----------------|----------------|------------------------------------------------|-----------------| | Bit 3:<br>TMA3 | Bit 2:<br>TMA2 | Bit 1:<br>TMA1 | Bit 0:<br>TMA0 | Prescaler and Divider Ratio or Overflow Period | Function | | 0 | 0 | 0 | 0 | PSS, ø/8192 (Initial value) | Interval timer | | | | | 1 | PSS, ø/4096 | _ | | | | 1 | 0 | PSS, ø/2048 | _ | | | | | 1 | PSS, ø/512 | _ | | | 1 | 0 | 0 | PSS, ø/256 | _ | | | | | 1 | PSS, ø/128 | _ | | | | 1 | 0 | PSS, ø/32 | _ | | | | | 1 | PSS, ø/8 | _ | | 1 | 0 | 0 | 0 | PSW, 1 s | Clock time base | | | | | 1 | PSW, 0.5 s | _ | | | | 1 | 0 | PSW, 0.25 s | _ | | | | | 1 | PSW, 0.03125 s | | | | 1 | 0 | 0 | PSW and TCA are reset | _ | | | | | 1 | | | | | | 1 | 0 | | | | | | | 1 | | | ## 10.2.2 Timer Counter A (TCA) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|------|------|------|------|------| | | TCA7 | TCA6 | TCA5 | TCA4 | TCA3 | TCA2 | TCA1 | TCA0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R | R | R | R | R | R | R | TCA is an 8-bit read-only up-counter, which is incremented by internal clock input. The clock source for input to this counter is selected by bits TMA3 to TMA0 in timer mode register A (TMA). TCA values can be read by the CPU in active mode, but cannot be read in subactive mode. When TCA overflows, the IRRTA bit in interrupt request register 1 (IRR1) is set to 1. TCA is cleared by setting bits TMA3 and TMA2 of TMA to 11. Upon reset, TCA is initialized to H'00. ## 10.3 Timer Operation #### 10.3.1 Interval Timer Operation When bit TMA3 in timer mode register A (TMA) is cleared to 0, timer A functions as an 8-bit interval timer Upon reset, TCA is cleared to H'00 and bit TMA3 is cleared to 0, so up-counting and interval timing resume immediately. The clock input to timer A is selected by bits TMA2 to TMA0 in TMA; any of eight internal clock signals output by prescaler S can be selected. After the count value in TCA reaches H'FF, the next clock signal input causes timer A to overflow, setting bit IRRTA to 1 in interrupt request register 1 (IRR1). If IENTA = 1 in interrupt enable register 1 (IENR1), a CPU interrupt is requested.\* At overflow, TCA returns to H'00 and starts counting up again. In this mode timer A functions as an interval timer that generates an overflow output at intervals of 256 input clock pulses. Note: \* For details on interrupts, see 3.3, Interrupts. ## **10.3.2** Clock Time Base Operation When bit TMA3 in TMA is set to 1, timer A functions as a clock time base by counting clock signals output by prescaler W. The overflow period of timer A is set by bits TMA1 and TMA0 in TMA. A choice of four periods is available. In time base operation (TMA3 = 1), setting bit TMA2 to 1 clears both TCA and prescaler W to their initial values of H'00. ## 10.3.3 Clock Output Setting bit TMOW in port mode register 1 (PMR1) to 1 causes a clock signal to be output at pin TMOW. Eight different clock output signals can be selected by means of bits TMA7 to TMA5 in TMA. The system clock divided by 32, 16, 8, or 4 can be output in active mode and sleep mode. A 32.768 kHz signal divided by 32, 16, 8, or 4 can be output in active mode, sleep mode, and subactive mode. ## **10.4** Timer A Operation States Table 10.3 summarizes the timer A operation states. **Table 10.3** Timer A Operation States | Oper | ation Mode | Reset | Active | Sleep | Sub-<br>active | Sub-<br>sleep | Standby | Module<br>Standby | |------|-----------------|-------|-----------|-----------|----------------|---------------|----------|-------------------| | TCA | Interval | Reset | Functions | Functions | Halted | Halted | Halted | Halted | | | Clock time base | Reset | Functions | Functions | Functions | Functions | Halted | Halted | | TMA | | Reset | Functions | Retained | Functions | Retained | Retained | Retained | Note: When the clock time base function is selected as the internal clock of TCA in active mode or sleep mode, the internal clock is not synchronous with the system clock, so it is synchronized by a synchronizing circuit. This may result in a maximum error of 1/ø (s) in the count cycle. ## Section 11 Timer V #### 11.1 Overview Timer V is an 8-bit timer based on an 8-bit counter. Timer V counts external events. Also compare match signals can be used to reset the counter, request an interrupt, or output a pulse signal with an arbitrary duty cycle. Counting can be initiated by a trigger input at the TRGV pin, enabling pulse output control to be synchronized to the trigger, with an arbitrary delay from the trigger input. #### 11.1.1 Features Features of timer V are given below. - Choice of six internal clock sources (ø/128, ø/64, ø/32, ø/16, ø/8, ø/4) or an external clock (can be used as an external event counter). - Counter can be cleared by compare match A or B, or by an external reset signal. If the count stop function is selected, the counter can be halted when cleared. - Timer output is controlled by two independent compare match signals, enabling pulse output with an arbitrary duty cycle, PWM output, and other applications. - Three interrupt sources: two compare match, one overflow - Counting can be initiated by trigger input at the TRGV pin. The rising edge, falling edge, or both edges of the TRGV input can be selected. ## 11.1.2 Block Diagram Figure 11.1 shows a block diagram of timer V. Figure 11.1 Block Diagram of Timer V # 11.1.3 Pin Configuration Table 11.1 shows the timer V pin configuration. **Table 11.1 Pin Configuration** | Name | Abbrev. | I/O | Function | |---------------------|---------|--------|------------------------------------| | Timer V output | TMOV | Output | Timer V waveform output | | Timer V clock input | TMCIV | Input | Clock input to TCNTV | | Timer V reset input | TMRIV | Input | External input to reset TCNTV | | Trigger input | TRGV | Input | Trigger input to initiate counting | ## 11.1.4 Register Configuration Table 11.2 shows the register configuration of timer V. **Table 11.2** Timer V Registers | Name | Abbrev. | R/W | Initial Value | Address | |---------------------------------|---------|--------|---------------|---------| | Timer control register V0 | TCRV0 | R/W | H'00 | H'FFA0 | | Timer control/status register V | TCSRV | R/(W)* | H'10 | H'FFA1 | | Time constant register A | TCORA | R/W | H'FF | H'FFA2 | | Time constant register B | TCORB | R/W | H'FF | H'FFA3 | | Timer counter V | TCNTV | R/W | H'00 | H'FFA4 | | Timer control register V1 | TCRV1 | R/W | H'E2 | H'FFA5 | Note: \* Bits 7 to 5 can only be written with 0, for flag clearing. ## 11.2 Register Descriptions ### 11.2.1 Timer Counter V (TCNTV) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|--------|--------|--------|--------| | | TCNTV7 | TCNTV6 | TCNTV5 | TCNTV4 | TCNTV3 | TCNTV2 | TCNTV1 | TCNTV0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W TCNTV is an 8-bit read/write up-counter which is incremented by internal or external clock input. The clock source is selected by bits CKS2 to CKS0 in TCRV0. The TCNTV value can be read and written by the CPU at any time. TCNTV can be cleared by an external reset signal, or by compare match A or B. The clearing signal is selected by bits CCLR1 and CCLR0 in TCRV0. When TCNTV overflows from H'FF to H'00, OVF is set to 1 in TCSRV. TCNTV is initialized to H'00 upon reset and in standby mode, subsleep mode, and subactive mode. ## 11.2.2 Time Constant Registers A and B (TCORA, TCORB) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|--------|--------|--------|-------------| | | TCORn7 | TCORn6 | TCORn5 | TCORn4 | TCORn3 | TCORn2 | TCORn1 | TCORn0 | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W | | | | | | | | ( | n = A or B) | TCORA and TCORB are 8-bit read/write registers. TCORA and TCNTV are compared at all times, except during the $T_3$ state of a TCORA write cycle. When the TCORA and TCNTV contents match, CMFA is set to 1 in TCSRV. If CMIEA is also set to 1 in TCRV0, a CPU interrupt is requested. Timer output from the TMOV pin can be controlled by a signal resulting from compare match, according to the settings of bits OS3 to OS0 in TCSRV. TCORA is initialized to H'FF upon reset and in standby mode, subsleep mode, and subactive mode. TCORB is similar to TCORA. ## 11.2.3 Timer Control Register V0 (TCRV0) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|------|-------|-------|------|------|------| | | СМІЕВ | CMIEA | OVIE | CCLR1 | CCLR0 | CKS2 | CKS1 | CKS0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W TCRV0 is an 8-bit read/write register that selects the TCNTV input clock, controls the clearing of TCNTV, and enables interrupts. TCRV0 is initialized to H'00 upon reset and in standby mode, subsleep mode, and subactive mode. **Bit 7—Compare Match Interrupt Enable B (CMIEB):** Bit 7 enables or disables the interrupt request (CMIB) generated from CMFB when CMFB is set to 1 in TCSRV. | Bit 7: CMIEB | Description | | |--------------|---------------------------------------------|-----------------| | 0 | Interrupt request (CMIB) from CMFB disabled | (Initial value) | | 1 | Interrupt request (CMIB) from CMFB enabled | | **Bit 6—Compare Match Interrupt Enable A (CMIEA):** Bit 6 enables or disables the interrupt request (CMIA) generated from CMFA when CMFA is set to 1 in TCSRV. | Bit 6: CMIEA | Description | | |--------------|---------------------------------------------|-----------------| | 0 | Interrupt request (CMIA) from CMFA disabled | (Initial value) | | 1 | Interrupt request (CMIA) from CMFA enabled | | **Bit 5—Timer Overflow Interrupt Enable (OVIE):** Bit 5 enables or disables the interrupt request (OVI) generated from OVF when OVF is set to 1 in TCSRV. | Bit 5: OVIE | Description | | |-------------|-------------------------------------------|-----------------| | 0 | Interrupt request (OVI) from OVF disabled | (Initial value) | | 1 | Interrupt request (OVI) from OVF enabled | | **Bits 4 and 3—Counter Clear 1 and 0 (CCLR1, CCLR0):** Bits 4 and 3 specify whether or not to clear TCNTV, and select compare match A or B or an external reset input. When clearing is specified, if TRGE is set to 1 in TCRV1, then when TCNTV is cleared it is also halted. Counting resumes when a trigger edge is input at the TRGV pin. If TRGE is cleared to 0, after TCNTV is cleared it continues counting up. | Bit 4: CCLR1 | Bit 3: CCLR0 | Description | | |--------------|--------------|------------------------------------------------|-----------------| | 0 | 0 | Clearing is disabled | (Initial value) | | | 1 | Cleared by compare match A | | | 1 | 0 | Cleared by compare match B | | | | 1 | Cleared by rising edge of external reset input | | **Bits 2 to 0—Clock Select 2 to 0 (CKS2 to CKS0):** Bits 2 to 0 and bit ICKS0 in TCRV1 select the clock input to TCNTV. Six internal clock sources divided from the system clock $(\emptyset)$ can be selected. The counter increments on the falling edge. If the external clock is selected, there is a further selection of incrementing on the rising edge, falling edge, or both edges. If TRGE is cleared to 0, after TCNTV is cleared it continues counting up. | | TCRV | ) | TCRV1 | | | | | |----------------|----------------|----------------|-----------------|------------------------------------------|--|--|--| | Bit 2:<br>CKS2 | Bit 1:<br>CKS1 | Bit 0:<br>CKS0 | Bit 0:<br>ICKS0 | | | | | | 0 | 0 | 0 | _ | Clock input disabled (Initial value) | | | | | | | 1 | 0 | Internal clock: ø/4, falling edge | | | | | | | | 1 | Internal clock: ø/8, falling edge | | | | | | 1 | 0 | 0 | Internal clock: ø/16, falling edge | | | | | | | | 1 | Internal clock: ø/32, falling edge | | | | | | | 1 | 0 | Internal clock: ø/64, falling edge | | | | | | | | 1 | Internal clock: ø/128, falling edge | | | | | 1 | 0 | 0 | _ | Clock input disabled | | | | | | | 1 | _ | External clock: rising edge | | | | | | 1 | 0 | <del>-</del> | External clock: falling edge | | | | | | | 1 | | External clock: rising and falling edges | | | | ## 11.2.4 Timer Control/Status Register V (TCSRV) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|---|-----|-----|-----|-----| | | CMFB | CMFA | OVF | _ | OS3 | OS2 | OS1 | OS0 | | Initial value | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/(W)* | R/(W)* | R/(W)* | _ | R/W | R/W | R/W | R/W | Note: \* Bits 7 to 5 can be only written with 0, for flag clearing. TCSRV is an 8-bit register that sets compare match flags and the timer overflow flag, and controls compare match output. TCSRV is initialized to H'10 upon reset and in standby mode, subsleep mode, and subactive mode. **Bit 7—Compare Match Flag B (CMFB):** Bit 7 is a status flag indicating that TCNTV has matched TCORB. This flag is set by hardware and cleared by software. It cannot be set by software. | Bit 7: CMFB | Description | | |-------------|---------------------------------------------------------------------------|-----------------| | 0 | Clearing conditions: After reading CMFB = 1, cleared by writing 0 to CMFB | (Initial value) | | 1 | Setting conditions: Set when the TCNTV value matches the TCORB value | | **Bit 6—Compare Match Flag A (CMFA):** Bit 6 is a status flag indicating that TCNTV has matched TCORA. This flag is set by hardware and cleared by software. It cannot be set by software. | Bit 6: CMFA | Description | | |-------------|---------------------------------------------------------------------------|-----------------| | 0 | Clearing conditions: After reading CMFA = 1, cleared by writing 0 to CMFA | (Initial value) | | 1 | Setting conditions: Set when the TCNTV value matches the TCORA value | | **Bit 5—Timer Overflow Flag (OVF):** Bit 5 is a status flag indicating that TCNTV has overflowed from H'FF to H'00. This flag is set by hardware and cleared by software. It cannot be set by software. | Bit 5: OVF | Description | | |------------|-------------------------------------------------------------------------|-----------------| | 0 | Clearing conditions: After reading OVF = 1, cleared by writing 0 to OVF | (Initial value) | | 1 | Setting conditions:<br>Set when TCNTV overflows from H'FF to H'00 | | Bit 4—Reserved Bit: Bit 4 is reserved; it is always read as 1, and cannot be modified. **Bits 3 to 0—Output Select 3 to 0 (OS3 to OS0):** Bits 3 to 0 select the way in which the output level at the TMOV pin changes in response to compare match between TCNTV and TCORA or TCORB. OS3 and OS2 select the output level for compare match B. OS1 and OS0 select the output level for compare match A. The two levels can be controlled independently. If two compare matches occur simultaneously, any conflict between the settings is resolved according to the following priority order: toggle output > 1 output > 0 output. When OS3 to OS0 are all cleared to 0, timer output is disabled. After a reset, the timer output is 0 until the first compare match. | Bit 3: OS3 | Bit 2: OS2 | Description | | |------------|------------|-----------------------------------|-----------------| | 0 | 0 | No change at compare match B | (Initial value) | | | 1 | 0 output at compare match B | | | 1 | 0 | 1 output at compare match B | | | | 1 | Output toggles at compare match B | | | Bit 1: OS1 | Bit 0: OS0 | Description | | |------------|------------|-----------------------------------|-----------------| | 0 | 0 | No change at compare match A | (Initial value) | | | 1 | 0 output at compare match A | | | 1 | 0 | 1 output at compare match A | | | | 1 | Output toggles at compare match A | | ### 11.2.5 Timer Control Register V1 (TCRV1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|-------|-------|------|---|-------| | | _ | _ | _ | TVEG1 | TVEG0 | TRGE | _ | ICKS0 | | Initial value | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | | Read/Write | _ | _ | _ | R/W | R/W | R/W | _ | R/W | TCRV1 is an 8-bit read/write register that selects the valid edge at the TRGV pin, enables TRGV input, and selects the clock input to TCNTV. TCRV1 is initialized to H'E2 upon reset and in subsleep mode and subactive mode. **Bits 7 to 5—Reserved Bits:** Bit 7 to 5 are reserved; they are always read as 1, and cannot be modified. **Bits 4 and 3—TRGV Input Edge Select (TVEG1, TVEG0):** Bits 4 and 3 select the TRGV input edge. | Bit 4: TVEG1 | Bit 3: TVEG0 | Description | | |--------------|--------------|--------------------------------------------|-----------------| | 0 | 0 | TRGV trigger input is disabled | (Initial value) | | | 1 | Rising edge is selected | | | 1 | 0 | Falling edge is selected | | | | 1 | Rising and falling edges are both selected | | **Bit 2—TRGV Input Enable (TRGE):** Bit 2 enables TCNTV counting to be triggered by input at the TRGV pin, and enables TCNTV counting to be halted when TCNTV is cleared by compare match. TCNTV stops counting when TRGE is set to 1, then starts counting when the edge selected by bits TVEG1 and TVEG0 is input at the TRGV pin. | Bit 2: TRGE | Description | |-------------|------------------------------------------------------------------------------------------------------------------------------------| | 0 | TCNTV counting is not triggered by input at the TRGV pin, and does not stop when TCNTV is cleared by compare match (Initial value) | | 1 | TCNTV counting is triggered by input at the TRGV pin, and stops when TCNTV is cleared by compare match | **Bit 1—Reserved Bit:** Bit 1 is reserved; it is always read as 1, and cannot be modified. **Bit 0—Internal Clock Select 0 (ICKS0):** Bit 0 and bits CKS2 to CKS0 in TCRV0 select the TCNTV clock source. For details see 11.2.3 Timer Control Register V0. ## 11.3 Timer Operation **Timer V Operation:** A reset initializes TCNTV to H'00, TCORA and TCORB to H'FF, TCRV0 to H'00, TCSRV to H'10, and TCRV1 to H'E2. Timer V can be clocked by one of six internal clocks output from prescaler S, or an external clock, as selected by bits CKS2 to CKS0 in TCRV0 and bit ICKS0 in TCRV1. The valid edge or edges of the external clock can also be selected by CKS2 to CKS0. When the clock source is selected, TCNTV starts counting the selected clock input. The TCNTV contents are always compared with TCORA and TCORB. When a match occurs, the CMFA or CMFB bit is set to 1 in TCSRV. If CMIEA or CMIEB is set to 1 in TCRV0, a CPU interrupt is requested. At the same time, the output level selected by bits OS3 to OS0 in TCSRV is output from the TMOV pin. When TCNT overflows from H'FF to H'00, if OVIE is 1 in TCRV0, a CPU interrupt is requested. If bits CCLR1 and CCLR0 in TCRV0 are set to 01 (clear by compare match A) or 10 (clear by compare match B), TCNTV is cleared by the corresponding compare match. If these bits are set to 11, TCNTV is cleared by input of a rising edge at the TMRIV pin. When the counter clear event selected by bits CCLR1 and CCLR0 in TCRV0 occurs, TCNTV is cleared and the count-up is halted. TCNTV starts counting when the signal edge selected by bits TVEG1 and TVEG0 in TCRV1 is input at the TRGV pin. **TCNTV Increment Timing:** TCNTV is incremented by an input (internal or external) clock. #### Internal clock One of six clocks ( $\phi$ /128, $\phi$ /64, $\phi$ /32, $\phi$ /16, $\phi$ /8, $\phi$ /4) divided from the system clock ( $\phi$ ) can be selected by bits CKS2 to CKS0 in TCRV0 and bit ICKS0 in TCRV1. Figure 11.2 shows the timing. Figure 11.2 Increment Timing with Internal Clock #### External clock Incrementation on the rising edge, falling edge, or both edges of the external clock can be selected by bits CKS2 to CKS0 in TCRV0. The external clock pulse width should be at least 1.5 system clocks (ø) when a single edge is counted, and at least 2.5 system clocks when both edges are counted. Shorter pulses will not be counted correctly. Figure 11.3 shows the timing when both the rising and falling edges of the external clock are selected. Figure 11.3 Increment Timing with External Clock **Overflow flag Set Timing:** The overflow flag (OVF) is set to 1 when TCNTV overflows from H'FF to H'00. Figure 11.4 shows the timing. Figure 11.4 OVF Set Timing **Compare Match Flag set Timing:** Compare match flag A or B (CMFA or CMFB) is set to 1 when TCNTV matches TCORA or TCORB. The internal compare-match signal is generated in the last state in which the values match (when TCNTV changes from the matching value to a new value). Accordingly, when TCNTV matches TCORA or TCORB, the compare match signal is not generated until the next clock input to TCNTV. Figure 11.5 shows the timing. Figure 11.5 CMFA and CMFB Set Timing **TMOV Output Timing:** The TMOV output responds to compare match A or B by remaining unchanged, changing to 0, changing to 1, or toggling, as selected by bits OS3 to OS0 in TCSRV. Figure 11.6 shows the timing when the output is toggled by compare match A. Figure 11.6 TMOV Output Timing **TCNTV Clear Timing by Compare Match:** TCNTV can be cleared by compare match A or B, as selected by bits CCLR1 and CCLR0 in TCRV0. Figure 117 shows the timing. Figure 11.7 Clear Timing by Compare Match **TCNTV Clear Timing by TMRIV:** TCNTV can be cleared by a rising edge at the TMRIV pin, as selected by bits CCLR1 and CCLR0 in TCRV0. A TMRIV input pulse width of at least 1.5 system clocks is necessary. Figure 11.8 shows the timing. Figure 11.8 Clear Timing by TMRIV Input ## 11.3.1 Timer V Operation Modes Table 11.3 summarizes the timer V operation states. **Table 11.3 Timer V Operation States** | Operation Mode | Reset | Active | Sleep | Sub-active | Sub-sleep | Standby | |----------------|-------|-----------|-----------|------------|-----------|---------| | TCNTV | Reset | Functions | Functions | Reset | Reset | Reset | | TCRV0, TCRV1 | Reset | Functions | Functions | Reset | Reset | Reset | | TCORA, TCORB | Reset | Functions | Functions | Reset | Reset | Reset | | TCSRV | Reset | Functions | Functions | Reset | Reset | Reset | ### 11.3.2 Interrupt Sources Timer V has three interrupt sources: CMIA, CMIB, and OVI. Table 11.4 lists the interrupt sources and their vector address. Each interrupt source can be enabled or disabled by an interrupt enable bit in TCRV0. Although all three interrupts share the same vector, they have individual interrupt flags, so software can discriminate the interrupt source. **Table 11.4 Timer V Interrupt Sources** | Interrupt | Description | Vector Address | | |-----------|---------------------|----------------|--| | CMIA | Generated from CMFA | H'0022 | | | CMIB | Generated from CMFB | | | | OVI | Generated from OVF | | | ## 11.3.3 Application Examples **Pulse Output with Arbitrary Duty Cycle:** Figure 11.9 shows an example of output of pulses with an arbitrary duty cycle. To set up this output: - Clear bit CCLR1 to 0 and set bit CCLR0 to 1 in TCRV0 so that TCNTV will be cleared by compare match with TCORA. - Set bits OS3 to OS0 to 0110 in TCSRV so that the output will go to 1 at compare match with TCORA and to 0 at compare match with TCORB. - Set bits CKS2 to CKS0 in TCRV0 and bit ICKS0 in TCRV1 to select the desired clock source. With these settings, a waveform is output without further software intervention, with a period determined by TCORA and a pulse width determined by TCORB. Figure 11.9 Pulse Output Example **Single-Shot Output with Arbitrary Pulse Width and Delay from TRGV Input:** The trigger function can be used to output a pulse with an arbitrary pulse width at an arbitrary delay from the TRGV input, as shown in figure 11.10. To set up this output: - Set bit CCLR1 to 1 and clear bit CCLR0 to 0 in TCRV0 so that TCNTV will be cleared by compare match with TCORB. - Set bits OS3 to OS0 to 0110 in TCSRV so that the output will go to 1 at compare match with TCORA and to 0 at compare match with TCORB. - Set bits TVEG1 and TVEG0 to 10 in TCRV1 and set TRGE to 1 to select the falling edge of the TRGV input. - Set bits CKS2 to CKS0 in TCRV0 and bit ICKS0 in TCRV1 to select the desired clock source. After these settings, a pulse waveform will be output without further software intervention, with a delay determined by TCORA from the TRGV input, and a pulse width determined by (TCORB – TCORA). Figure 11.10 Pulse Output Synchronized to TRGV Input ## 11.3.4 Application Notes The following types of contention can occur in timer V operation. Contention between TCNTV Write and Counter Clear: If a TCNTV clear signal is generated in the $T_3$ state of a TCNTV write cycle, clearing takes precedence and the write to the counter is not carried out. Figure 11.11 shows the timing. Figure 11.11 Contention between TCNTV Write and Clear Contention between TCNTV Write and Increment: If a TCNTV increment clock signal is generated in the $T_3$ state of a TCNTV write cycle, the write takes precedence and the counter is not incremented. Figure 11.12 shows the timing. Figure 11.12 Contention between TCNTV Write and Increment Contention between TCOR Write and Compare Match: If a compare match is generated in the $T_3$ state of a TCORA or TCORB write cycle, the write to TCORA or TCORB takes precedence and the compare match signal is inhibited. Figure 11.13 shows the timing. Figure 11.13 Contention between TCORA Write and Compare Match **Contention between Compare Match A and B:** If compare match A and B occur simultaneously, any conflict between the output selections for compare match A and compare match B is resolved by following the priority order in table 11.5. **Table 11.5** Timer Output Priority Order | Output Setting | Priority | |----------------|----------| | Toggle output | High | | 1 output | <b>A</b> | | 0 output | _ | | No change | Low | **Internal Clock Switching and Counter Operation:** Depending on the timing, TCNTV may be incremented by a switch between different internal clock sources. Table 11.5 shows the relation between internal clock switchover timing (by writing to bits CKS1 and CKS0) and TCNTV operation. When TCNTV is internally clocked, an increment pulse is generated from the falling edge of an internal clock signal, which is divided from the system clock ( $\emptyset$ ). For this reason, in a case like No. 3 in table 11.6 where the switch is from a high clock signal to a low clock signal, the switchover is seen as a falling edge, causing TCNTV to increment. TCNTV can also be incremented by a switch between internal and external clocks. Table 11.6 Internal Clock Switching and TCNTV Operation #### **TCNTV Operation** Notes: 1. Including a transition from the low level to the stopped state, or from the stopped state to the low level. Write to CKS1 and CKS0 - 2. Including a transition from the stopped state to the high level. - 3. Including a transition from the high level to the stopped state. - 4. The switchover is seen as a falling edge, and TCNTV is incremented. ## Section 12 Timer W #### 12.1 Overview The H8/3664 has timer W, a 16-bit timer having output compare and input capture functions. Timer W can count external events and output pulses with a desired duty ratio by compare match between the timer counter and four general registers. Thus, it can be applied to various systems. #### 12.1.1 Features Timer W features are listed below. - Selection of five counter clock sources: four internal clocks (φ, φ/2, φ/4, φ/8) and an external clock (external events can be counted) - Capability to process up to four pulse outputs or four pulse inputs - · Four general registers with independently assignable output compare or input capture functions - Four general registers usable as two pairs of registers; one register of each pair operates as a buffer for the output compare or input capture register - Four selectable operating modes : - Waveform output by compare match - Selection of 0 output, 1 output, or toggle output - Input capture function - Rising edge, falling edge, or both edges (selectable) - Counter clearing function - Counters can be cleared by compare match - PWM mode - Up to three-phase PWM output can be provided with desired duty ratio. - High-speed access via an on-chip 16-bit bus - The 16-bit timer counter and 16-bit general registers can be accessed at a high speed via a 16-bit bus interface. - Any initial timer output value can be set - Five interrupt sources - Four compare match/input capture interrupts and an overflow interrupt. **Table 12.1** Timer W Functions | | | | input/Outpu | | | | | |---------------------------------------------------------|---------|---------------------------------|----------------------------------------------------------|-----------------------------------|-------------------------------------------------------|-------------------------------------------------------|--| | Item | | Counter | FTIOA | FTIOB | FTIOC | FTIOD | | | Clock sources | | Internal clock<br>External cloc | ocks: $\phi$ , $\phi$ /2, $\phi$ /4, $\phi$ /8 ock: FTCI | | | | | | General register<br>(output compart<br>capture register | e/input | Period<br>specified in<br>GRA | GRA | GRB | GRC (buffer<br>register for<br>GRA in buffer<br>mode) | GRD (buffer<br>register for<br>GRB in buffer<br>mode) | | | Counter clearing function | | GRA<br>compare<br>match | GRA<br>compare<br>match | _ | <del></del> | _ | | | Initial output value setting function | | _ | Yes | Yes | Yes | Yes | | | Buffer function | | _ | Yes | Yes | _ | _ | | | Compare | 0 | _ | Yes | Yes | Yes | Yes | | | match output | 1 | _ | Yes | Yes | Yes | Yes | | | | Toggle | _ | Yes | Yes | Yes | Yes | | | Input capture function | | _ | Yes | Yes | Yes | Yes | | | PWM mode | | _ | _ | Yes | Yes | Yes | | | Interrupt source | es | Overflow | Compare<br>match/input<br>capture | Compare<br>match/input<br>capture | Compare<br>match/input<br>capture | Compare<br>match/input<br>capture | | ### 12.1.2 Block Diagrams Figure 12.1 is a block diagram of timer W. Figure 12.1 Timer W Block Diagram # 12.1.3 Input/Output Pins Table 12.2 summarizes the timer W pins. **Table 12.2** Timer W Pins | Name | Abbreviation | Input/Output | Function | |--------------------------------|--------------|--------------|---------------------------------------------------------------------------------------------------| | External clock input | FTCI | Input | External clock input pin | | Input capture/output compare A | FTIOA | Input/output | Output pin for GRA output compare or input pin for GRA input capture | | Input capture/output compare B | FTIOB | Input/output | Output pin for GRB output compare, input pin for GRB input capture, or PWM output pin in PWM mode | | Input capture/output compare C | FTIOC | Input/output | Output pin for GRC output compare, input pin for GRC input capture, or PWM output pin in PWM mode | | Input capture/output compare D | FTIOD | Input/output | Output pin for GRD output compare, input pin for GRD input capture, or PWM output pin in PWM mode | ## 12.1.4 Register Configuration Table 12.3 summarizes the timer W registers. **Table 12.3** Timer W Registers | Name | Abbreviation | R/W | Initial Value | Address | |-----------------------------------|--------------|---------|---------------|----------| | Timer mode register W | TMRW | R/W | H'48 | H'FF80 | | Timer control register W | TCRW | R/W | H'00 | H'FF81 | | Timer interrupt enable register W | TIERW | R/W | H'70 | H'FF82 | | Timer status register W | TSRW | R/(W)*1 | H'70 | H'FF83 | | Timer I/O control register 0 | TIOR0 | R/W | H'88 | H'FF84 | | Timer I/O control register 1 | TIOR1 | R/W | H'88 | H'FF85 | | Timer counter | TCNT | R/W | H'0000 | H'FF86*2 | | General register A | GRA | R/W | H'FFFF | H'FF88*2 | | General register B | GRB | R/W | H'FFFF | H'FF8A*2 | | General register C | GRC | R/W | H'FFFF | H'FF8C*2 | | General register D | GRD | R/W | H'FFFF | H'FF8E*2 | Notes: 1. Only 0 can be written to clear the flags. <sup>2.</sup> Must be always read or written in 16-bit units; 8-bit access is not allowed. ## 12.2 Register Description ### 12.2.1 Timer Mode Register W (TMRW) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|---|-------|-------|---|------|------|------| | | CTS | _ | BUFEB | BUFEA | _ | PWMD | PWMC | PWMB | | Initial value | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | Read/Write | R/W | _ | R/W | R/W | _ | R/W | R/W | R/W | TMRW is an 8-bit read/write register that selects PWM mode and buffer operation. TMRW is initialized to H'48 by a reset. Bit 7—Counter Start (CTS): Starts and stops TCNT. | Bit 7: CTS | Description | | |------------|-------------|-----------------| | 0 | Stops TCNT | (Initial value) | | 1 | Starts TCNT | | Note: Writing 0 to the CST bit while a compare match output pin is outputting a signal stops the counter, but the output level at the pin is retained. When the TCRW is modified to change the initial output level while the CST bit is 0, the output level at the pin is updated to the modified initial level. **Bit 6—Reserved:** This bit cannot be modified and is always read as 1. **Bit 5—Buffer Operation B (BUFEB):** Selects whether GRD operates as an input capture/output compare register or the buffer register for GRB. When GRD is used as the buffer register, no input capture or compare match occurs for GRD. | Bit 5: BUFEB | Description | | |--------------|----------------------------------------------------------|-----------------| | 0 | GRD operates as an input capture/output compare register | (Initial value) | | 1 | GRD operates as the buffer register for GRB | | **Bit 4—Buffer Operation A (BUFEA):** Selects whether GRC operates as an input capture/output compare register or the buffer register for GRA. When GRC is used as the buffer register, no input capture or compare match occurs for GRC. | Bit 4: BUFEA | Description | | |--------------|----------------------------------------------------------|-----------------| | 0 | GRC operates as an input capture/output compare register | (Initial value) | | 1 | GRC operates as the buffer register for GRA | | Bit 3—Reserved: This bit cannot be modified and is always read as 1. **Bit 2—PWM Mode D (PWMD):** Selects whether the compare match output pin (FTIOD) operates normally or in PWM mode. | Bit 2: PWMD | Description | | |-------------|-------------------------------------------------|-----------------| | 0 | FTIOD operates normally (output compare output) | (Initial value) | | 1 | FTIOD operates in PWM mode* | | Note: \* The period is specified in GRA. **Bit 1—PWM Mode C (PWMC):** Selects whether the compare match output pin (FTIOC) operates normally or in PWM mode. | Bit 1: PWMC | Description | | |-------------|-------------------------------------------------|-----------------| | 0 | FTIOC operates normally (output compare output) | (Initial value) | | 1 | FTIOC operates in PWM mode* | | Note: \* The period is specified in GRA. **Bit 0—PWM Mode B (PWMB):** Selects whether the compare match output pin (FTIOB) operates normally or in PWM mode. | Bit 0: PWMB | Description | | |-------------|-------------------------------------------------|-----------------| | 0 | FTIOB operates normally (output compare output) | (Initial value) | | 1 | FTIOB operates in PWM mode* | | Note: \* The period is specified in GRA. ## 12.2.2 Timer Control Register W (TCRW) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|------|-----|-----|-----|-----| | | CCLR | CKS2 | CKS1 | CKS0 | TOD | TOC | ТОВ | TOA | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W TCRW is an 8-bit read/write register that specifies the timer output levels, selects the timer counter clock source, and selects how the counter is cleared. TCRW is initialized to H'00 by a reset. Bit 7—Counter Clear (CCLR): Selects how TCNT is cleared. | Bit 7: CCLR | Description | | |-------------|------------------------------------------|-----------------| | 0 | TCNT is not cleared by GRA compare match | (Initial value) | | 1 | TCNT is cleared by GRA compare match | | Bits 6 to 4—Clock Select (CKS2 to CKS0): These bits select the TCNT clock source from four internal clock sources and one external event. | Bit 6: CKS | S2 Bit 5: CKS1 | Bit 4: CKS0 | Function | |------------|----------------|-------------|-------------------------------------------------| | 0 | 0 | 0 | Internal clock: φ* (Initial value) | | | | 1 | Internal clock: φ/2 | | | 1 | 0 | Internal clock: φ/4 | | | | 1 | Internal clock: φ/8 | | 1 | 0 or 1 | 0 or 1 | Rising edges of the external event input (FTCI) | Note: \*When internal clock $\phi$ is selected, the counter operates by the subclock in subactive or subsleep mode. **Bit 3—Timer Output Level Setting D (TOD):** Sets the value output from the FTIOD pin after reset until the first compare match D (TCNT and GRD matching signal) is generated. After a compare match is generated, FTIOD outputs the value specified in timer I/O control register 1 (IOD2 to IOD0). | Bit 3: TOD | Description | | |------------|-------------|-----------------| | 0 | FTIOD is 0 | (Initial value) | | 1 | FTIOD is 1 | | **Bit 2—Timer Output Level Setting C** (**TOC**): Sets the value output from the FTIOC pin after reset until the first compare match C (TCNT and GRC matching signal) is generated. After a compare match is generated, FTIOC outputs the value specified in timer I/O control register 1 (IOC2 to IOC0). | Bit 2: TOC | Description | | |------------|-------------|-----------------| | 0 | FTIOC is 0 | (Initial value) | | 1 | FTIOC is 1 | | **Bit 1—Timer Output Level Setting B (TOB):** Sets the value output from the FTIOB pin after reset until the first compare match B (TCNT and GRB matching signal) is generated. After a compare match is generated, FTIOB outputs the value specified in timer I/O control register 0 (IOB2 to IOB0). | Bit 1: TOB | Description | | | |------------|-------------|-----------------|---| | 0 | FTIOB is 0 | (Initial value) | ) | | 1 | FTIOB is 1 | | _ | **Bit 0—Timer Output Level Setting A (TOA):** Sets the value output from the FTIOA pin after reset until the first compare match A (TCNT and GRA matching signal) is generated. After a compare match is generated, FTIOA outputs the value specified in timer I/O control register 0 (IOA2 to IOA0). | Bit 0: TOA | Description | | |------------|-------------|-----------------| | 0 | FTIOA is 0 | (Initial value) | | 1 | FTIOA is 1 | | ### 12.2.3 Timer Interrupt Enable Register W (TIERW) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|---|---|---|-------|-------|-------|-------| | | OVIE | _ | _ | _ | IMIED | IMIEC | IMIEB | IMIEA | | Initial value | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/W | _ | _ | _ | R/W | R/W | R/W | R/W | TIERW is an 8-bit read/write register that enables or disables the TCNT overflow interrupt request and general register (GRA, GRB, GRC, and GRD) compare match or input capture interrupt requests. TIERW is initialized to H'70 by a reset. **Bit 7—Timer Overflow Interrupt Enable (OVIE):** Enables or disables the FOVI interrupt requested by the OVF flag of TSRW when OVF is set to 1. | Bit 7: OVIE | Description | | |-------------|--------------------------------------------------|-----------------| | 0 | FOVI interrupt requested by OVF flag is disabled | (Initial value) | | 1 | FOVI interrupt requested by OVF flag is enabled | | Bits 6 to 4—Reserved: These bits cannot be modified and are always read as 1. **Bit 3—Input Capture/Compare Match Interrupt Enable D (IMIED):** Enables or disables the IMID interrupt requested by the IMFD flag of TSRW when IMFD is set to 1. | Bit 3: IMIED | Description | | |--------------|---------------------------------------------------|-----------------| | 0 | IMID interrupt requested by IMFD flag is disabled | (Initial value) | | 1 | IMID interrupt requested by IMFD flag is enabled | | **Bit 2—Input Capture/Compare Match Interrupt Enable C (IMIEC):** Enables or disables the IMIC interrupt requested by the IMFC flag of TSRW when IMFC is set to 1. | Bit 2: IMIEC | Description | _ | |--------------|---------------------------------------------------|-----------------| | 0 | IMIC interrupt requested by IMFC flag is disabled | (Initial value) | | 1 | IMIC interrupt requested by IMFC flag is enabled | | **Bit 1—Input Capture/Compare Match Interrupt Enable B (IMIEB):** Enables or disables the IMIB interrupt requested by the IMFB flag of TSRW when IMFB is set to 1. | Bit 1: IMIEB | Description | | |--------------|---------------------------------------------------|-----------------| | 0 | IMIB interrupt requested by IMFB flag is disabled | (Initial value) | | 1 | IMIB interrupt requested by IMFB flag is enabled | | **Bit 0—Input Capture/Compare Match Interrupt Enable A (IMIEA):** Enables or disables the IMIA interrupt requested by the IMFA flag of TSRW when IMFA is set to 1. | Bit 0: IMIEA | Description | | |--------------|---------------------------------------------------|-----------------| | 0 | IMIA interrupt requested by IMFA flag is disabled | (Initial value) | | 1 | IMIA interrupt requested by IMFA flag is enabled | | ## 12.2.4 Timer Status Register W (TSRW) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|---|---|---|--------|--------|--------|--------| | | OVF | _ | _ | _ | IMFD | IMFC | IMFB | IMFA | | Initial value | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | Read/Write | R/(W)* | | _ | | R/(W)* | R/(W)* | R/(W)* | R/(W)* | Note: \* Only 0 can be written, to clear the flag. TSRW is an 8-bit read/write register that shows the TCNT overflow interrupt request and general register (GRA, GRB, GRC, and GRD) compare match or input capture interrupt requests. TSRW is initialized to H'70 by a reset. **Bit 7—Timer Overflow Flag (OVF):** This status flag indicates the TCNT has overflowed (from H'FFFF to H'0000). This flag is cleared by software and set by hardware; it cannot be set by software. | Bit 7: OVF | Description | | |------------|-------------------------------------------|-----------------| | 0 | [Clearing condition] | (Initial value) | | | Read OVF when OVF =1, then write 0 in OVF | | | 1 | [Setting condition] | | | | TCNT overflowed from H'FFFF to H'0000 | | Bits 6 to 4—Reserved: These bits cannot be modified and are always read as 1. **Bit 3—Input Capture/Compare Match Flag D (IMFD):** This status flag indicates a GRD compare match or input capture event has occurred. This flag is cleared by software and set by hardware; it cannot be set by software. | Bit 3: IMFD | Description | | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0 | [Clearing condition] (Initial value | | | | | | Read IMFD when IMFD =1, then write 0 in IMFD | | | | | 1 | [Setting conditions] | | | | | | <ul> <li>TCNT = GRD when GRD functions as an output compare register</li> </ul> | | | | | | <ul> <li>The TCNT value is transferred to GRD by an input capture signal when<br/>GRD functions as an input capture register</li> </ul> | | | | **Bit 2—Input Capture/Compare Match Flag C (IMFC):** This status flag indicates a GRC compare match or input capture event has occurred. This flag is cleared by software and set by hardware; it cannot be set by software. | Bit 2: IMFC | Description | | | | |-------------|----------------------------------------------------------------------|---|--|--| | 0 | [Clearing condition] (Initial | | | | | | Read IMFC when IMFC =1, then write 0 in IMFC | | | | | 1 | [Setting conditions] | | | | | | TCNT = GRC when GRC functions as an output compare register | | | | | | The TCNT value is transferred to GRC by an input capture signal when | 1 | | | | | GRC functions as an input capture register | | | | **Bit 1—Input Capture/Compare Match Flag B (IMFB):** This status flag indicates a GRB compare match or input capture event has occurred. This flag is cleared by software and set by hardware; it cannot be set by software. | Bit 1: IMFB | Description | | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------|---------------|--|--| | 0 | [Clearing condition] (Initial va | | | | | | Read IMFB when IMFB =1, then write 0 in IMFB | | | | | 1 | [Setting conditions] | | | | | | <ul> <li>TCNT = GRB when GRB functions as an output compare registe</li> </ul> | | | | | | <ul> <li>The TCNT value is transferred to GRB by an input capture<br/>GRB functions as an input capture register</li> </ul> | e signal when | | | **Bit 0—Input Capture/Compare Match Flag A (IMFA):** This status flag indicates a GRA compare match or input capture event has occurred. This flag is cleared by software and set by hardware; it cannot be set by software. | Bit 0: IMFA | Description | | | | | |-------------|---------------------------------------------------------------------------------|--|--|--|--| | 0 | [Clearing condition] (Initial v | | | | | | | Read IMFA when IMFA =1, then write 0 in IMFA | | | | | | 1 | [Setting conditions] | | | | | | | <ul> <li>TCNT = GRA when GRA functions as an output compare register</li> </ul> | | | | | | | The TCNT value is transferred to GRA by an input capture signal when | | | | | | | GRA functions as an input capture register | | | | | ## 12.2.5 Timer I/O Control Register 0 (TIOR0) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|------|------|------|---|------|------|------| | | _ | IOB2 | IOB1 | IOB0 | | IOA2 | IOA1 | IOA0 | | Initial value | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | Read/Write | _ | R/W | R/W | R/W | _ | R/W | R/W | R/W | TIOR0 is an 8-bit read/write register that selects the output compare or input capture function for GRA and GRB, and specifies the functions of the FTIOA and FTIOB pins. If the output compare function is selected, TIOR0 also selects the type of output. If input capture is selected, TIOR0 also selects the edges of the input capture signal. TIOR0 is initialized to H'88 by a reset. Bit 7—Reserved: This bit cannot be modified and is always read as 1. Bits 6 to 4—I/O Control B2 to B0 (IOB2 to IOB0): These bits select the GRB function. | Bit 6:<br>IOB2 | Bit 5:<br>IOB1 | Bit 4:<br>IOB0 | Function | | | | |----------------|----------------|----------------|------------------|--------------------------------------------|--|--| | 0 | 0 | 0 | GRB is an output | No output at compare match (Initial value) | | | | | | 1 | compare register | 0 output at GRB compare match*1 | | | | | 1 | 0 | | 1 output at GRB compare match*1 | | | | | | 1 | _ | Output toggles at GRB compare match*1 | | | | 1 | 0 | 0 | GRB is an input | Input capture at rising edge | | | | | | 1 | capture register | Input capture at falling edge | | | | | 1 | *2 | | Input capture at both edges | | | | | | *2 | _ | | | | Notes: 1. After a reset, the output conforms to the TOB setting in TCRW until the first compare match. 2. Don't care **Bit 3—Reserved:** This bit cannot be modified and is always read as 1. Bits 2 to 0—I/O Control A2 to A0 (IOA2 to IOA0): These bits select the GRA function. | Bit 2:<br>IOA2 | Bit 1:<br>IOA1 | Bit 0:<br>IOA0 | Function | | | | |----------------|----------------|----------------|------------------|--------------------------------------------|--|--| | 0 | 0 | 0 | GRA is an output | No output at compare match (Initial value) | | | | | | 1 | compare register | 0 output at GRA compare match*1 | | | | | 1 | 0 | | 1 output at GRA compare match*1 | | | | | | 1 | _ | Output toggles at GRA compare match*1 | | | | 1 | 0 | 0 | GRA is an input | Input capture at rising edge | | | | | | 1 | capture register | Input capture at falling edge | | | | | 1 *2 | | _ | Input capture at both edges | | | | | | *2 | _ | | | | Notes: 1. After a reset, the output conforms to the TOA setting in TCRW until the first compare match. 2. Don't care # 12.2.6 Timer I/O Control Register 1 (TIOR1) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|------|------|------|---|------|------|------| | | _ | IOD2 | IOD1 | IOD0 | _ | IOC2 | IOC1 | IOC0 | | Initial value | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | Read/Write | _ | R/W | R/W | R/W | _ | R/W | R/W | R/W | TIOR1 is an 8-bit read/write register that selects the output compare or input capture function for GRC and GRD, and specifies the functions of the FTIOC and FTIOD pins. If the output compare function is selected, TIOR0 also selects the type of output. If input capture is selected, TIOR0 also selects the edges of the input capture signal. TIOR1 is initialized to H'88 by a reset. **Bit 7—Reserved:** This bit cannot be modified and is always read as 1. Bits 6 to 4—I/O Control D2 to D0 (IOD2 to IOD0): These bits select the GRD function. | Bit 6:<br>IOD2 | Bit 5:<br>IOD1 | Bit 4:<br>IOD0 | Function | | | | |----------------|----------------|------------------|---------------------------------|--------------------------------------------|--|--| | 0 | 0 | 0 | GRD is an output | No output at compare match (Initial value) | | | | | 1 | compare register | 0 output at GRD compare match*1 | | | | | | 1 | 0 | _ | 1 output at GRD compare match*1 | | | | | | 1 | _ | Output toggles at GRD compare match*1 | | | | 1 | 0 0 G | | GRD is an input | Input capture at rising edge | | | | | | 1 | capture register | Input capture at falling edge | | | | | 1 | *2 | _ | Input capture at both edges | | | | | | *2 | <del>_</del> | | | | Notes: 1. After a reset, the output conforms to the TOD setting in TCRW until the first compare match. 2. Don't care **Bit 3—Reserved:** This bit cannot be modified and is always read as 1. Bits 2 to 0—I/O Control C2 to C0 (IOC2 to IOC0): These bits select the GRC function. | Bit 2:<br>IOC2 | Bit 1:<br>IOC1 | Bit 0:<br>IOC0 | Function | | | | |----------------|------------------|-------------------------------|------------------|--------------------------------------------|--|--| | 0 | 0 | 0 | GRC is an output | No output at compare match (Initial value) | | | | | | 1 | compare register | 0 output at GRC compare match*1 | | | | | 1 | 0 | | 1 output at GRC compare match*1 | | | | | | 1 | <u> </u> | Output toggles at GRC compare match*1 | | | | 1 | 0 | 0 | GRC is an input | Input capture at rising edge | | | | 1 capture re | capture register | Input capture at falling edge | | | | | | | 1 *2 | | <u> </u> | Input capture at both edges | | | | | | *2 | _ | | | | Notes: 1. After a reset, the output conforms to the TOC setting in TCRW until the first compare match. 2. Don't care #### 12.2.7 Timer Counter (TCNT) | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | | | | | | | | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W TCNT is a 16-bit read/write up-counter that counts the pulses input from the internal or external clock source. The clock source is selected by bits CKS2 to CKS0 in TCRW. TCNT can be cleared to H'0000 through a compare match with GRA by setting CCLR of TCRW to 1. When TCNT overflows (changes from H'FFFF to H'0000), the OVF flag in TCRW is set to 1, and if OVIE in TIERW is set to 1 at this time, an interrupt request is sent to the CPU. TCNT must be always read or written in 16-bit units; 8-bit access is not allowed. TCNT is initialized to H'0000 by a reset. ## 12.2.8 General Registers A to D (GRA to GRD) | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | | | | | | | | | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W Each general register is a 16-bit read/write register that can function as either an output compare register or an input capture register. The function is selected by settings in TIOR0 and TIOR1. When a general register is used as an output compare register, its value is constantly compared with the TCNT value. When the two values match (a compare match), the corresponding flag (IMFA, IMFB, IMFC, or IMFD) in TSRW is set to 1. If the corresponding interrupt enable bit (IMIEA, IMIEB, IMIEC, or IMIED) in TIERW is set to 1 at this time, an interrupt request is sent to the CPU. Compare match output can be selected in TIOR0 and TIOR1. When a general register is used as an input capture register, an external input capture signal is detected and the current TCNT value is stored in the general register. The corresponding flag (IMFA, IMFB, IMFC, or IMFD) in TSRW is set to 1. If the corresponding interrupt enable bit (IMIEA, IMIEB, IMIEC, or IMIED) in TIERW is set to 1 at this time, an interrupt request is sent to the CPU. The edges of the input capture signal are selected in TIOR0 and TIOR1. GRC and GRD can be used as the buffer registers of GRA and GRB, respectively, by setting BUFEA and BUFEB in TMRW. The general registers are initialized to H'FFFF by a reset. # 12.3 CPU Interface ### **12.3.1 16-Bit Registers** TCNT, GRA, GRB, GRC, and GRD are 16-bit registers connected to the CPU by an on-chip 16-bit data bus. These registers must be written or read in 16-bit units; 8-bit access is not allowed. Figure 12.2 shows the interface between the CPU and a 16-bit register. Figure 12.2 16-Bit Register Interface (CPU and TCNT (16 bits)) # 12.3.2 8-Bit Registers The registers other than TCNT, GRA, GRB, GRC, and GRD are 8-bit registers, and are connected to the CPU by an on-chip 8-bit data bus. Figure 12.3 shows the interface between the CPU and an 8-bit register. Figure 12.3 8-Bit Register Interface (CPU and TCRW (8 bits)) ## 12.4 Operation #### 12.4.1 Overview A summary of operations in the various modes is given below. ### Normal Operation Timer W has a timer counter (TCNT) and general registers (GRA to GRD). TCNT is a 16-bit counter that increments the count each time a clock pulse is input, and that can operate as a free-running counter or an external event counter. GRA to GRD can be used for input capture or output compare. ## • Buffer Operation If a compare match is generated when a GR is used as an output compare register, , the corresponding buffer register value is transferred to the GR. If input capture is generated when a GR is used as an input capture register, the GR value is transferred to the buffer register and the TCNT value is transferred to the GR. #### PWM Mode PWM waveforms are output from the FTIOB, FTIOC, and FTIOD pins. The period can be specified in the GRA, and the duty ratio can be varied from 0% to 100% depending on the settings of GRB to GRD. When an output pin is set to PWM mode, the corresponding GR automatically becomes an output compare register. **Counting Operation:** TCNT performs free-running or periodic counting operations. Figure 12.4 shows an example of the setup procedure for counting. Figure 12.4 Counter Setup Procedure (Example) After a reset, TCNT is initialized to H'0000 and set as a free-running counter. A free-running counter starts incrementing the count when the CST bit in TMRW is set to 1. The input clock source can be selected from four internal clocks and an external clock by the CKS2 to CKS0 bits in TCRW. When the count overflows from H'FFFF to H'0000, the OVF flag in TSRW is set to 1. If the OVIE bit in TIERW is set to 1 at this time, an interrupt request is sent to the CPU. After the overflow, the counter continues counting from H'0000. Figure 12.5 illustrates free-running counting. Figure 12.5 Free-Running Counter Operation When compare match is selected as the TCNT clear source, TCNT operates as a periodic counter. Select the output compare function for GRA, set bit CCLR in TCRW to 1, and set the count period in GRA. When the count matches GRA, the IMFA flag in TSRW is set to 1 and TCNT is cleared to H'0000. If the IMIEA bit in TSRW is set to 1 at this time, an interrupt request is sent to the CPU. After the compare match, TCNT continues counting from H'0000. Figure 12.6 illustrates periodic counting. Figure 12.6 Periodic Counter Operation **Signal Output by Compare Match:** Compare match A, B, C, or D can cause the output at the FTIOA, FTIOB, FTIOC, or FTIOD pin to go to 0, go to 1, or toggle. Figure 12.7 shows an example of the setup procedure for outputting signals by compare match. Figure 12.7 Setup Procedure for Outputting Signals by Compare Match (Example) Figure 12.8 shows an example of 0 and 1 output. TCNT operates as a free-running counter, 1 output is selected for compare match A, and 0 output is selected for compare match B. When the signal is already at the selected output level, the signal level does not change at compare match. Figure 12.8 0 and 1 Output (TOA = 0, TOB = 1) Figure 12.9 shows an example of toggle output. TCNT operates as a free-running counter, and toggle output is selected for both compare match A and B. Figure 12.9 Toggle Output (1) (TOA = 0, TOB = 1) Figure 12.10 shows another example of toggle output. TCNT operates as a periodic counter, cleared by compare match A. Toggle output is selected for both compare match A and B. Figure 12.10 Toggle Output (2) (TOA = 0, TOB = 1) **Input Capture Function:** The TCNT value can be captured into a general register (GRA, GRB, GRC, or GRD) when a signal level changes at an input capture pin (FTIOA, FTIOB, FTIOC, or FTIOD). Capture can take place on the rising edge, falling edge, or both edges. Figure 12.11 shows an example of the procedure for setting up input capture. Figure 12.11 Setup Procedure for Input Capture (Example) Figure 12.22 shows an example of input capture when both edges of FTIOA and the falling edge of FTIOB are selected as capture edges. TCNT operates as a free-running counter. Figure 12.12 Input Capture (Example) **Buffer Operation:** GRC and GRD can be used as buffer registers for GRA and GRB, respectively. The buffer operation differs depending on whether the GR is set as an input capture register or as an output compare register. Table 12.4 shows the register combination for buffer operation. **Table 12.4 Register Combination for Buffer Operation** | General Register | Buffer Register | |------------------|-----------------| | GRA | GRC | | GRB | GRD | When GR Operates as an Output Compare Register When a compare match occurs, the buffer register value is transferred to the corresponding general register. Figure 12.13 shows the compare buffer operation. Figure 12.13 Compare Buffer Operation When GR Operates as an Input Capture Register When an input capture occurs, the general register value is transferred to the corresponding buffer register, and the TCNT value is transferred to the general register. Figure 12.14 shows the input capture buffer operation. Figure 12.14 Input Capture Buffer Operation Figure 12.15 shows an example of the procedure for setting up buffer operation. Figure 12.15 Setup Procedure for Buffer Operation (Example) Figure 12.16 shows an example of buffer operation when the FTIOB pin is set to PWM mode and GRD is set as the buffer register for GRB. TCNT is cleared by compare match A, and FTIOB outputs 1 at compare match B and 0 at compare match A. Every time compare match B occurs, the FTIOB output level changes and the value of buffer register GRD is transferred to GRB. For details on PWM mode, refer to the description of PWM Operation in this section. **Figure 12.16 Buffer Operation Example (Output Compare)** Figure 12.17 shows an example of buffer operation when the GRA is set as an input capture register and GRC is set as the buffer register for GRA. TCNT operates as a free-running counter, and FTIOA captures both rising and falling edges of the input signal. Every time compare match A occurs, the GRA value is transferred to GRC and the TCNT value is stored in GRA. Figure 12.17 Buffer Operation Example (Input Capture) **PWM Operation:** In PWM mode, PWM waveforms are output from the FTIOB, FTIOC, and FTIOD pins. PWM waveforms are generated by using GRA as the period register and GRB, GRC, and GRD as duty registers. The output level of each pin depends on the corresponding timer output level set bit (TOB, TOC, or TOD) in TCRW. For example, when TOB is 1, the FTIOB output goes to 0 at compare match B and to 1 at compare match A. When TOB is 0, the FTIOB output goes to 1 at compare match B and to 0 at compare match A. Thus the compare match output level settings in the timer I/O control register are ignored for the output pin set to PWM mode. If the same value is set in the period register and the duty register, the output does not change when a compare match occurs. Up to three-phase PWM waveforms can be output. Figure 12.18 shows an example of a procedure for setting up PWM mode. Figure 12.18 Setup Procedure for PWM Mode (Example) Figure 12.19 shows an example of operation in PWM mode. The output signals go to 1 and TCNT is cleared at compare match A, and the output signals go to 0 at compare match B, C, and D (TOB, TOC, and TOD = 1: initial output values are set to 1). Figure 12.19 PWM Mode (Example 1) Figure 12.20 shows another example of operation in PWM mode. The output signals go to 0 and TCNT is cleared at compare match A, and the output signals go to 1 at compare match B, C, and D (TOB, TOC, and TOD = 0: initial output values are set to 1). Figure 12.20 PWM Mode (Example 2) Figures 12.21 and 12.22 show examples of the output of PWM waveforms with duty cycles of 0% and 100%. • TOB, TOC, and TOD = 0: initial output values are set to 0 Figure 12.21 PWM Mode (Example 3) • TOB, TOC, and TOD = 1: initial output values are set to 1 Figure 12.22 PWM Mode (Example 4) ## 12.4.2 Operation Timing **TCNT Count Timing:** Figure 12.23 shows the TCNT count timing when the internal clock source is selected. Figure 12.24 shows the timing when the external clock source is selected. The pulse width of the external clock signal must be at least two system clock (φ) cycles; shorter pulses will not be counted correctly. Figure 12.23 Count Timing for Internal Clock Source Figure 12.24 Count Timing for External Clock Source **Output Compare Timing:** The compare match signal is generated in the last state in which TCNT and the general register match (when TCNT changes from the matching value to the next value). When the compare match signal is generated, the output value selected in TIOR is output at the compare match output pin (FTIOA, FTIOB, FTIOC, or FTIOD). When TCNT matches a general register, the compare match signal is generated only after the next counter clock pulse is input. Figure 12.25 shows the output compare timing. Figure 12.25 Output Compare Timing **Input Capture Timing:** Input capture on the rising edge, falling edge, or both edges can be selected through settings in TIOR0 and TIOR1. Figure 12.26 shows the timing when the falling edge is selected. The pulse width of the input capture signal must be at least two system clock ( $\phi$ ) cycles; shorter pulses will not be detected correctly. Figure 12.26 Input Capture Timing **Timing of Counter Clearing by Compare Match:** Figure 12.27 shows the timing when the counter is cleared by compare match A. Figure 12.27 Timing of Counter Clearing by Compare Match **Buffer Operation Timing:** Figures 12.28 and 12.29 show the buffer operation timing. **Figure 12.28 Buffer Operation Timing (Compare Match)** **Figure 12.29 Buffer Operation Timing (Input Capture)** **Timing of IMFA to IMFD Flag Setting at Compare Match:** If a general register (GRA, GRB, GRC, or GRD) is used as an output compare register, the corresponding IMFA, IMFB, IMFC, or IMFD flag is set to 1 when TCNT matches the general register. The compare match signal is generated in the last state in which the values match (when TCNT is updated from the matching count to the next count). Therefore, when TCNT matches a general register, the compare match signal is generated only after the next TCNT clock pulse is input. Figure 12.30 shows the timing of the IMFA to IMFD flag setting at compare match. Figure 12.30 Timing of IMFA to IMFD Flag Setting at Compare Match **Timing of IMFA to IMFD Setting at Input Capture:** If a general register (GRA, GRB, GRC, or GRD) is used as an input capture register, the corresponding IMFA, IMFB, IMFC, or IMFD flag is set to 1 when an input capture occurs. Figure 12.31 shows the timing of the IMFA to IMFD flag setting at input capture. Figure 12.31 Timing of IMFA to IMFD Flag Setting at Input Capture **Timing of Status Flag Clearing:** When the CPU reads a status flag while it is set to 1, then writes 0 in the status flag, the status flag is cleared. Figure 12.32 shows the status flag clearing timing. Figure 12.32 Timing of Status Flag Clearing # 12.5 Usage Notes **Input Pulse Width:** The pulse width of the input clock signal and the input capture signal must be at least two system clock $(\phi)$ cycles; shorter pulses will not be detected correctly. **Note on Waveform Period Setting:** When compare match is selected as the TCNT clearing source, TCNT is cleared in the last state in which the TCNT value matches GRA (when TCNT is updated from the matching count to the next count). The actual counter frequency is therefore given by the following formula: $$f = \frac{\phi}{(N+1)}$$ (f: counter frequency; $\phi$ : system clock frequency; N: value set in GRA) **Contention between TCNT Write and Clear:** If a counter clear signal occurs in the T2 state of a TCNT write cycle, clearing of the counter takes priority and the write is not performed. Figure 12.33 shows this timing. Figure 12.33 Contention between TCNT Write and Clear **Contention between TCNT Write and Increment:** If an increment pulse occurs in the T2 state of a TCNT write cycle, writing takes priority and TCNT is not incremented. Figure 12.34 shows this timing. Figure 12.34 Contention between TCNT Write and Increment Contention between General Register Write and Compare Match in Buffer Operation: If a compare match occurs in the T2 state of a general register write cycle, writing takes priority and the buffer operation (data transfer from the buffer register to the general register) is not performed. Figure 12.35 shows this timing. Figure 12.35 Contention between General Register Write and Compare Match in Buffer Operation Contention between Buffer Register Write and Compare Match in Buffer Operation: If a compare match occurs in the T2 state of a buffer register write cycle, the old data (before being updated) in the buffer register is transferred to the general data in a buffer operation. Figure 12.36 shows this timing. Figure 12.36 Contention between Buffer Register Write and Compare Match **Contention between General Register Write and Compare Match:** If a compare match (TCNT = GR data before writing) occurs in the T2 state of a general register write cycle, the compare match signal is generated. Figure 12.37 shows this timing. Figure 12.37 Contention between General Register Write and Compare Match Contention between General Register Write and Input Capture: If a capturing signal is generated in the T2 state of a general register write cycle, writing to GR takes priority and input capture (data transfer from TCNT to GR) is not performed. Figure 12.38 shows this timing. Figure 12.38 Contention between General Register Write and Input Capture Contention between Buffer Register Write and Input Capture in Buffer Operation: If a capturing signal is generated in the T2 state of a buffer register write cycle, writing to the buffer register takes priority and input capture (data transfer from GR to the buffer register) is not performed. Figure 12.39 shows this timing. Figure 12.39 Contention between Buffer Register Write and Input Capture **Contention between General Register Read and Input Capture:** If a capturing signal is generated in the T1 state of a general register read cycle, the value before input capture is read. Figure 12.40 shows this timing. Figure 12.40 Contention between General Register Read and Input Capture **TCNT Read Timing Error:** This LSI takes two states (two system clock ( $\phi$ ) cycles) to access timer W. Therefore, when $\phi$ is selected as the TCNT input clock and TCNT is read, the read timing will include $1/\phi$ -second error. **Internal Clock Switching and TCNT Operation:** When the input clock is switched between internal clocks, the TCNT may erroneously increase the count. When an internal clock is selected, the count clock is generated by detecting the rising edges of the internal clock obtained by dividing the system clock ( $\phi$ ). If the input clock is switched when the previous clock is low and the new clock is high, the change in clock signal level (low to high) is assumed to be a clock rising edge; a count clock pulse is generated and TCNT erroneously increments the count. Figure 12.41 shows this timing. Figure 12.41 Internal Clock Switching and TCNT Operation **Interrupt in Module Stop Mode:** If timer W enters module stop mode while an interrupt request is sent to the CPU, the interrupt request cannot be cleared. Before entering module stop mode, disable interrupt requests. # Section 13 Watchdog Timer #### 13.1 Overview The watchdog timer (WDT) is equipped with an 8-bit counter that is incremented by an input clock. An internal chip reset can be executed if the counter overflows because it is not updated normally due to a system crash, etc. #### 13.1.1 Features Features of the watchdog timer are given below. - Nine internal clocks selectable - Choice of eight internal clock sources (ø/64, ø/128, ø/256, ø/512, ø/1024, ø/2048, ø/4096, ø/8192) and the internal oscillator - Reset signal generated on counter overflow An overflow period of 1 to 256 times the selected clock can be set. ### 13.1.2 Block Diagram Figure 13.1 shows a block diagram of the watchdog timer. Figure 13.1 Block Diagram of Watchdog Timer ## 13.1.3 Register Configuration Table 13.1 shows the watchdog timer register configuration. Table 13.1 Watchdog Timer Registers | Name | Abbrev. | R/W | Initial Value | Address | |----------------------------------|---------|-----|---------------|---------| | Timer control/status register WD | TCSRWD | R/W | H'AA | H'FFC0 | | Timer counter WD | TCWD | R/W | H'00 | H'FFC1 | | Timer mode register WD | TMWD | R/W | H'FF | H'FFC2 | ## 13.2 Register Descriptions ## 13.2.1 Timer Control/Status Register WD (TCSRWD) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|--------|------|--------|------|--------|------|--------| | | B6WI | TCWE | B4WI | TCSRWE | B2WI | WDON | B0WI | WRST | | Initial value | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | Read/Write | R | R/(W)* | R | R/(W)* | R | R/(W)* | R | R/(W)* | Note: \* Can be written to only when the write condition is satisfied. For the write conditions, see the individual bit descriptions. TCSRWD is an 8-bit read/write register that performs TCSRWD and TCWD write control and watchdog timer operation control, and indicates the operation status. Bit 7—Bit 6 Write Inhibit (B6WI): Bit 7 controls writing of data to bit 6 of TCSRWD. | Bit 7: B6WI | Description | | |-------------|------------------------------|-----------------| | 0 | Writing to bit 6 is enabled | | | 1 | Writing to bit 6 is disabled | (Initial value) | This bit is always read as 1. Data is not stored if written to this bit. **Bit 6—Timer Counter WD Write Enable (TCWE):** Bit 6 controls writing of 8-bit data to TCWD. | Bit 6: TCWE | Description | | |-------------|-------------------------------------------|-----------------| | 0 | Writing of 8-bit data to TCWD is disabled | (Initial value) | | 1 | Writing of 8-bit data to TCWD is enabled | | Bit 5—Bit 4 Write Inhibit (B4WI): Bit 5 controls writing of data to bit 4 of TCSRWD. | Bit 5: B4WI | Description | | |-------------|------------------------------|-----------------| | 0 | Writing to bit 4 is enabled | _ | | 1 | Writing to bit 4 is disabled | (Initial value) | This bit is always read as 1. Data is not stored if written to this bit. **Bit 4—Timer Control/Status Register W Write Enable (TCSRWE):** Bit 4 controls writing of data to bits 2 and 0 of TCSRWD. | Bit 4: TCSRWE | Description | | |---------------|-------------------------------------|-----------------| | 0 | Writing to bits 2 and 0 is disabled | (Initial value) | | 1 | Writing to bits 2 and 0 is enabled | | Bit 3—Bit 2 Write Inhibit (B2WI): Bit 3 controls writing of data to bit 2 of TCSRWD. | Bit 3: B2WI | Description | | |-------------|------------------------------|-----------------| | 0 | Writing to bit 2 is enabled | | | 1 | Writing to bit 2 is disabled | (Initial value) | This bit is always read as 1. Data is not stored if written to this bit. Bit 2—Watchdog Timer On (WDON): Bit 2 controls watchdog timer operation. | Bit 2: WDON | Description | | | | | | |-------------|----------------------------------------------------------------------------------|---------|--|--|--|--| | 0 | Watchdog timer operation is disabled (Initial va | | | | | | | | [Clearing condition] | | | | | | | | In a reset, or when 0 is written to WDON while writing 0 to B2WI when TCSRWE = 1 | | | | | | | 1 | Watchdog timer operation is enabled | | | | | | | | [Setting condition] | | | | | | | | When 1 is written to WDON while writing 0 to B2WI when TCSF | RWE = 1 | | | | | The count-up starts when this bit is set to 1, and stops when it is cleared to 0. **Bit 1—Bit 0 Write Inhibit (B0WI):** Bit 1 controls writing of data to bit 0 of timer control/status register W. | Bit 1: B0WI | Description | | |-------------|------------------------------|-----------------| | 0 | Writing to bit 0 is enabled | | | 1 | Writing to bit 0 is disabled | (Initial value) | This bit is always read as 1. Data is not stored if written to this bit. **Bit 0—Watchdog Timer Reset (WRST):** Bit 0 indicates that TCW has overflowed and an internal reset signal has been generated. The internal reset signal generated by the overflow resets the entire chip. WRST is cleared by a reset via the $\overline{RES}$ pin or by a 0 write by software. | Bit 0: WRST | Description | | |-------------|--------------------------------------------------------------|-----------------| | 0 | [Clearing conditions] | (Initial value) | | | Reset by RES pin | | | | When 0 is written to WRST while writing 0 to B0WI when T | CSRWE = 1 | | 1 | [Setting condition] | | | | When TCW overflows and an internal reset signal is generated | i | ## 13.2.2 Timer Counter WD (TCWD) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | | TCWD7 | TCWD6 | TCWD5 | TCWD4 | TCWD3 | TCWD2 | TCWD1 | TCWD0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W TCWD is an 8-bit read/write up-counter that is incremented by an input internal clock. The TCWD value can be read or written by the CPU at any time. When TCWD overflows (from H'FF to H'00), an internal reset signal is generated and WRST in TCSRWD is set to 1. Upon reset, TCWD is initialized to H'00. ## 13.2.3 Timer Mode Register WD (TMWD) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|------|------|------|------| | | _ | _ | _ | _ | CKS3 | CKS2 | CKS1 | CKS0 | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | _ | _ | _ | _ | R/W | R/W | R/W | R/W | TMWD is an 8-bit read/write register that selects the input clock. Upon reset, TMWD is initialized to H'FF. **Bits 7 to 4—Reserved Bits:** Bits 7 to 4 are reserved; they are always read as 1 and cannot be modified. **Bits 3 to 0—Clock Select 3 to 0 (CKS3 to CKS0):** Bits 3 to 0 select the clock to be input to TCWD. | Bit 3:<br>CKS3 | Bit 2:<br>CKS2 | Bit 1:<br>CKS1 | Bit 0:<br>CKS0 | Description | | |----------------|----------------|----------------|----------------|------------------------|-----------------| | 1 | 0 | 0 | 0 | Internal clock: ø/64 | _ | | | | | 1 | Internal clock: ø/128 | | | | | 1 | 0 | Internal clock: ø/256 | | | | | | 1 | Internal clock: ø/512 | | | | 1 | 0 | 0 | Internal clock: ø/1024 | | | | | | 1 | Internal clock: ø/2048 | | | | | 1 | 0 | Internal clock: ø/4096 | | | | | | 1 | Internal clock: ø/8192 | (Initial value) | | 0 | * | * | * | Internal oscillator | | Note: \* Don't care # 13.3 Operation The watchdog timer is provided with an 8-bit counter that increments with the input clock. If 1 is written to WDON while writing 0 to B2WI when TCSRWE in TCSRWD is set to 1, TCWD begins counting up. (To operate the watchdog timer, two write accesses to TCSRWD is required.) When a clock pulse is input after the TCWD count value has reached H'FF, the watchdog timer overflows and an internal reset signal is generated one base clock ( $\emptyset$ ) cycle later. The internal reset signal is output for a period of 512 $\emptyset_{osc}$ clock cycles. TCWD is a writable counter, and when a value is set in TCWD, the count-up starts from that value. An overflow period in the range of 1 to 256 input clock cycles can therefore be set, according to the TCWD value. Figure 13.2 shows an example of watchdog timer operation. Figure 13.2 Example of Watchdog Timer Operation # 13.3.1 Watchdog Timer Operating Modes Watchdog timer operating modes are shown in table 13.2. **Table 13.2 Watchdog Timer Operating Modes** | Operating mode | Reset | Active | Sleep | Subactive | Subsleep | Standby | |----------------|-------|-----------|-----------|-----------|----------|----------| | TCWD | Reset | Functions | Functions | Halted* | Halted* | Halted* | | TCSRWD | Reset | Functions | Functions | Functions | Retained | Retained | | TMWD | Reset | Functions | Retained | Functions | Retained | Retained | Note: \* The watchdog timer functions if the internal oscillator is selected as the clock source. # Section 14 Serial Communication Interface 3 #### 14.1 Overview Serial communication interface 3 (SCI3) can carry out serial data communication in either asynchronous or synchronous mode. It is also provided with a multiprocessor communication function that enables serial data to be transferred among processors. #### 14.1.1 Features Features of SCI3 are listed below. - Choice of asynchronous or synchronous mode for serial data communication - Asynchronous mode Serial data communication is performed asynchronously, with synchronization provided character by character. In this mode, serial data can be exchanged with standard asynchronous communication LSIs such as a Universal Asynchronous Receiver/Transmitter (UART) or Asynchronous Communication Interface Adapter (ACIA). A multiprocessor communication function is also provided, enabling serial data communication among processors. There is a choice of 12 data transfer formats. | Data length | 7 or 8 bits | |-------------------------|----------------------------------------------------------------------------------| | Stop bit length | 1 or 2 bits | | Parity | Even, odd, or none | | Multiprocessor bit | 1 or 0 | | Receive error detection | Parity, overrun, and framing errors | | Break detection | Break detected by reading the RXD pin level directly when a framing error occurs | ### - Synchronous mode Serial data communication is synchronized with a clock. In his mode, serial data can be exchanged with another LSI that has a synchronous communication function. | Data length | 8 bits | |-------------------------|----------------| | Receive error detection | Overrun errors | - Full-duplex communication - Separate transmission and reception units are provided, enabling transmission and reception to be carried out simultaneously. The transmission and reception units are both double-buffered, allowing continuous transmission and reception. - On-chip baud rate generator, allowing any desired bit rate to be selected - Choice of an internal or external clock as the transmit/receive clock source - Six interrupt sources: transmit end, transmit data empty, receive data full, overrun error, framing error, and parity error ## 14.1.2 Block Diagram Figure 14.1 shows a block diagram of SCI3. Figure 14.1 SCI3 Block Diagram # 14.1.3 Pin Configuration Table 14.1 shows the SCI3 pin configuration. **Table 14.1 Pin Configuration** | Name | Abbrev. | I/O | Function | |---------------------------|---------|--------|---------------------------| | SCI3 clock | SCK3 | I/O | SCI3 clock input/output | | SCI3 receive data input | RXD | Input | SCI3 receive data input | | SCI3 transmit data output | TXD | Output | SCI3 transmit data output | # 14.1.4 Register Configuration Table 14.2 shows the SCI3 register configuration. Table 14.2 Registers | Name | Abbrev. | R/W | Initial Value | Address | |---------------------------|---------|-----------|---------------|---------| | Serial mode register | SMR | R/W | H'00 | H'FFA8 | | Bit rate register | BRR | R/W | H'FF | H'FFA9 | | Serial control register 3 | SCR3 | R/W | H'00 | H'FFAA | | Transmit data register | TDR | R/W | H'FF | H'FFAB | | Serial status register | SSR | R/W | H'84 | H'FFAC | | Receive data register | RDR | R | H'00 | H'FFAD | | Transmit shift register | TSR | Protected | _ | _ | | Receive shift register | RSR | Protected | | | | Bit rate counter | BRC | Protected | _ | _ | # 14.2 Register Descriptions #### 14.2.1 Receive Shift Register (RSR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| | | | | | | | | | | | | | | | | | | | | | Read/Write | _ | _ | _ | _ | _ | _ | _ | _ | RSR is a register used to receive serial data. Serial data input to RSR from the RXD pin is set in the order in which it is received, starting from the LSB (bit 0), and converted to parallel data. When one byte of data is received, it is transferred to RDR automatically. RSR cannot be read or written directly by the CPU. #### 14.2.2 Receive Data Register (RDR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|------|------|------|------|------| | | RDR7 | RDR6 | RDR5 | RDR4 | RDR3 | RDR2 | RDR1 | RDR0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R | R | R | R | R | R | R | R | RDR is an 8-bit register that stores received serial data. When reception of one byte of data is finished, the received data is transferred from RSR to RDR, and the receive operation is completed. RSR is then enabled for reception. RSR and RDR are double-buffered, allowing consecutive receive operations. RDR is a read-only register, and cannot be written by the CPU. RDR is initialized to H'00 upon reset, and in standby, subactive, or subsleep mode. #### 14.2.3 Transmit Shift Register (TSR) Rit | DIL | , | U | 3 | 7 | 3 | _ | ' | U | |------------|---|---|---|---|----|----|----|---| | | | | | | | | | | | | | L | | | I. | I. | I. | | | Read/Write | _ | _ | _ | _ | _ | _ | _ | _ | TSR is a register used to transmit serial data. Transmit data is first transferred from TDR to TSR, and serial data transmission is carried out by sending the data to the TXD pin in order, starting from the LSB (bit 0). When one byte of data is transmitted, the next byte of transmit data is transferred from TDR to TSR, and transmission started, automatically. Data transfer from TDR to TSR is not performed if no data has been written to TDR (if bit TDRE is set to 1). TSR cannot be read or written directly by the CPU. #### 14.2.4 Transmit Data Register (TDR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|------|------|------|------|------| | | TDR7 | TDR6 | TDR5 | TDR4 | TDR3 | TDR2 | TDR1 | TDR0 | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W TDR is an 8-bit register that stores transmit data. When TSR is found to be empty, the transmit data written in TDR is transferred to TSR, and serial data transmission is started. Continuous transmission is possible by writing the next transmit data to TDR during TSR serial data transmission TDR can be read or written by the CPU at any time. TDR is initialized to H'FF upon reset, and in standby, subactive, or subsleep mode. #### 14.2.5 Serial Mode Register (SMR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|------|-----|------|------| | | СОМ | CHR | PE | PM | STOP | MP | CKS1 | CKS0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W SMR is an 8-bit register used to set the serial data transfer format and to select the clock source for the baud rate generator. SMR can be read or written by the CPU at any time. SMR is initialized to H'00 upon reset, and in standby, subactive, or subsleep mode. **Bit 7—Communication Mode (COM):** Bit 7 selects whether SCI3 operates in asynchronous mode or synchronous mode. | Bit 7: COM | Description | | |------------|-------------------|-----------------| | 0 | Asynchronous mode | (Initial value) | | 1 | Synchronous mode | | **Bit 6—Character Length (CHR):** Bit 6 selects either 7 or 8 bits as the data length to be used in asynchronous mode. In synchronous mode the data length is always 8 bits, irrespective of the bit 6 setting. | Bit 6: CHR | Description | | |------------|-------------|-----------------| | 0 | 8-bit data | (Initial value) | | 1 | 7-bit data* | | Note: \* When 7-bit data is selected, the MSB (bit 7) of TDR is not transmitted. **Bit 5—Parity Enable (PE):** Bit 5 selects whether a parity bit is to be added during transmission and checked during reception in asynchronous mode. In synchronous mode parity bit addition and checking is not performed, irrespective of the bit 5 setting. | Bit 5: PE | Description | | |-----------|-------------------------------------------|-----------------| | 0 | Parity bit addition and checking disabled | (Initial value) | | 1 | Parity bit addition and checking enabled* | | Note: \* When PE is set to 1, even or odd parity, as designated by bit PM, is added to transmit data before it is sent, and the received parity bit is checked against the parity designated by bit PM. **Bit 4—Parity Mode (PM):** Bit 4 selects whether even or odd parity is to be used for parity addition and checking. The PM bit setting is only valid in asynchronous mode when bit PE is set to 1, enabling parity bit addition and checking. The PM bit setting is invalid in synchronous mode, and in asynchronous mode if parity bit addition and checking is disabled. | Bit 4: PM | Description | | |-----------|--------------------------|-----------------| | 0 | Even parity*1 | (Initial value) | | 1 | Odd parity* <sup>2</sup> | | - Notes: 1. When even parity is selected, a parity bit is added in transmission so that the total number of 1s in the transmit data plus the parity bit is an even number; in reception, a check is carried out to confirm that the number of 1s in the receive data plus the parity bit is an even number. - When odd parity is selected, a parity bit is added in transmission so that the total number of 1s in the transmit data plus the parity bit is an odd number; in reception, a check is carried out to confirm that the number of 1s in the receive data plus the parity bit is an odd number. **Bit 3—Stop Bit Length (STOP):** Bit 3 selects 1 bit or 2 bits as the stop bit length in asynchronous mode. The STOP bit setting is only valid in asynchronous mode. When synchronous mode is selected the STOP bit setting is invalid since stop bits are not added. | Bit 3: STOP | Description | | |-------------|---------------|-----------------| | 0 | 1 stop bit*1 | (Initial value) | | 1 | 2 stop bits*2 | | - Notes: 1. In transmission, a single 1 bit (stop bit) is added at the end of a transmit character. - 2. In transmission, two 1 bits (stop bits) are added at the end of a transmit character. In reception, only the first of the received stop bits is checked, irrespective of the STOP bit setting. If the second stop bit is 1 it is treated as a stop bit, but if 0, it is treated as the start bit of the next transmit character. **Bit 2—Multiprocessor Mode (MP):** Bit 2 enables or disables the multiprocessor communication function. When the multiprocessor communication function is enabled, the parity settings in the PE and PM bits are invalid. The MP bit setting is only valid in asynchronous mode. When synchronous mode is selected the MP bit should be set to 0. For details on the multiprocessor communication function, see 14.6. | Bit 2: MP | Description | | |-----------|------------------------------------------------|-----------------| | 0 | Multiprocessor communication function disabled | (Initial value) | | 1 | Multiprocessor communication function enabled | | **Bits 1 and 0—Clock Select 1, 0 (CKS1, CKS0):** Bits 1 and 0 choose $\emptyset/64$ , $\emptyset/16$ , $\emptyset/4$ , or $\emptyset$ as the clock source for the baud rate generator. For the relation between the clock source, bit rate register setting, and baud rate, see section 14.2.8, Bit Rate Register (BRR). The set value of n is in decimal notation, and represents a value of n in section 14.2.8, bit rate register (BRR). | Bit 1: CKS1 | Bit 0: CKS0 | Description | | |-------------|-------------|--------------------|-----------------| | 0 | 0 | ø clock (n = 0) | (Initial value) | | | 1 | ø/4 clock (n = 1) | | | 1 | 0 | ø/16 clock (n = 2) | | | | 1 | ø/64 clock (n = 3) | | #### 14.2.6 Serial Control Register 3 (SCR3) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|-----|-----|-----|------|------|------|------| | | TIE | RIE | TE | RE | MPIE | TEIE | CKE1 | CKE0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W SCR3 is an 8-bit register for selecting transmit or receive operation, the asynchronous mode clock output, interrupt request enabling or disabling, and the transmit/receive clock source. SCR3 can be read or written by the CPU at any time. SCR3 is initialized to H'00 upon reset, and in standby, subactive, or subsleep mode. **Bit 7—Transmit interrupt Enable (TIE):** Bit 7 selects enabling or disabling of the transmit data empty interrupt request (TXI) when transmit data is transferred from the transmit data register (TDR) to the transmit shift register (TSR), and bit TDRE in the serial status register (SSR) is set to 1. TXI can be released by clearing bit TDRE or bit TIE to 0. | Bit 7: TIE | Description | | |------------|------------------------------------------------------|-----------------| | 0 | Transmit data empty interrupt request (TXI) disabled | (Initial value) | | 1 | Transmit data empty interrupt request (TXI) enabled | | **Bit 6—Receive Interrupt Enable (RIE):** Bit 6 selects enabling or disabling of the receive data full interrupt request (RXI) and the receive error interrupt request (ERI) when receive data is transferred from the receive shift register (RSR) to the receive data register (RDR), and bit RDRF in the serial status register (SSR) is set to 1. There are three kinds of receive error: overrun, framing, and parity. RXI and ERI can be released by clearing bit RDRF or the FER, PER, or OER error flag to 0, or by clearing bit RIE to 0. | Bit 6: RIE | Description | |------------|--------------------------------------------------------------------------------------------------------------| | 0 | Receive data full interrupt request (RXI) and receive error interrupt request (ERI) disabled (Initial value) | | 1 | Receive data full interrupt request (RXI) and receive error interrupt request (ERI) enabled | **Bit 5—Transmit Enable (TE):** Bit 5 selects enabling or disabling of the start of transmit operation. | Bit 5: TE | Description | | |-----------|----------------------------------------------------------------|-----------------| | 0 | Transmit operation disabled*1 (TXD pin is transmit data pin)*3 | (Initial value) | | 1 | Transmit operation enabled*2 (TXD pin is transmit data pin) *3 | | Notes: 1. Bit TDRE in SSR is fixed at 1. - When transmit data is written to TDR in this state, bit TDR in SSR is cleared to 0 and serial data transmission is started. Be sure to carry out serial mode register (SMR) settings to decide the transmission format before setting bit TE to 1. - 3. When bit TXD in PMR7 is set to 1. When bit TXD is cleared to 0, the TXD pin functions as an I/O port regardless of the TE bit setting. **Bit 4—Receive Enable (RE):** Bit 4 selects enabling or disabling of the start of receive operation. | Bit 4: RE | Description | | |-----------|-----------------------------------------------------------|-----------------| | 0 | Receive operation disabled*1 (RXD pin is I/O port) | (Initial value) | | 1 | Receive operation enabled*2 (RXD pin is receive data pin) | | - Notes: 1. Note that the RDRF, FER, PER, and OER flags in SSR are not affected when bit RE is cleared to 0, and retain their previous state. - 2. In this state, serial data reception is started when a start bit is detected in asynchronous mode or serial clock input is detected in synchronous mode. Be sure to carry out serial mode register (SMR) settings to decide the reception format before setting bit RE to 1. **Bit 3—Multiprocessor Interrupt Enable (MPIE):** Bit 3 selects enabling or disabling of the multiprocessor interrupt request. The MPIE bit setting is only valid when asynchronous mode is selected and reception is carried out with bit MP in SMR set to 1. The MPIE bit setting is invalid when bit COM is set to 1 or bit MP is cleared to 0. | Bit 3: MPIE | Description | |-------------|----------------------------------------------------------------------| | 0 | Multiprocessor interrupt request disabled (normal receive operation) | | | (Initial value) | | | [Clearing condition] | | | When data is received in which the multiprocessor bit is set to 1 | | 1 | Multiprocessor interrupt request enabled* | Note: \* Receive data transfer from RSR to RDR, receive error detection, and setting of the RDRF, FER, and OER status flags in SSR is not performed. RXI, ERI, and setting of the RDRF, FER, and OER flags in SSR, are disabled until data with the multiprocessor bit set to 1 is received. When a receive character with the multiprocessor bit set to 1 is received, bit MPBR in SSR is set to 1, bit MPIE is automatically cleared to 0, and RXI and ERI requests (when bits TIE and RIE in serial control register (SCR) are set to 1) and setting of the RDRF, FER, and OER flags are enabled. **Bit 2—Transmit End Interrupt Enable (TEIE):** Bit 2 selects enabling or disabling of the transmit end interrupt request (TEI) if there is no valid transmit data in TDR when MSB data is to be sent. | Bit 2: TEIE | Description | | |-------------|-----------------------------------------------|-----------------| | 0 | Transmit end interrupt request (TEI) disabled | (Initial value) | | 1 | Transmit end interrupt request (TEI) enabled* | | Note: \* TEI can be released by clearing bit TDRE to 0 and clearing bit TEND to 0 in SSR, or by clearing bit TEIE to 0. **Bits 1 and 0—Clock Enable 1 and 0 (CKE1, CKE0):** Bits 1 and 0 select the clock source and enabling or disabling of clock output from the SCK<sub>3</sub> pin. These bits determine whether the SCK<sub>3</sub> pin functions as an I/O port, a clock output pin, or a clock input pin. The CKE0 bit setting is only valid in case of internal clock operation (CKE1 = 0) in asynchronous mode. In synchronous mode, or when external clock operation is used (CKE1 = 1), bit CKE0 should be cleared to 0. After setting bits CKE1 and CKE0, set the operating mode in the serial mode register (SMR). For details on clock source selection, see table 14.7 in 14.2.8, Operation. | | | | Description | | | |-------------|-------------|--------------------|----------------|-------------------------------|--| | Bit 1: CKE1 | Bit 0: CKE0 | Communication Mode | Clock Source | SCK <sub>3</sub> Pin Function | | | 0 | 0 | Asynchronous | Internal clock | I/O port*1 | | | | | Synchronous | Internal clock | Serial clock output*1 | | | | 1 | Asynchronous | Internal clock | Clock output*2 | | | | | Synchronous | Reserved | | | | 1 | 0 | Asynchronous | External clock | Clock input*3 | | | | | Synchronous | External clock | Serial clock input | | | | 1 | Asynchronous | Reserved | | | | | | Synchronous | Reserved | | | Description Notes: 1. Initial value - 2. A clock with the same frequency as the bit rate is output. - 3. Input a clock with a frequency 16 times the bit rate. ### 14.2.7 Serial Status Register (SSR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|--------|------|------|------| | | TDRE | RDRF | OER | FER | PER | TEND | MPBR | MPBT | | Initial value | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | Read/Write | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R | R | R/W | Note: \* Only a write of 0 for flag clearing is possible. SSR is an 8-bit register containing status flags that indicate the operational status of SCI3, and multiprocessor bits. SSR can be read or written by the CPU at any time, but only a write of 1 is possible to bits TDRE, RDRF, OER, PER, and FER. In order to clear these bits by writing 0, 1 must first be read. Bits TEND and MPBR are read-only bits, and cannot be modified. SSR is initialized to H'84 upon reset, and in standby, subactive, or subsleep mode. **Bit 7—Transmit Data Register Empty (TDRE):** Bit 7 indicates that transmit data has been transferred from TDR to TSR. | Bit 7: TDRE | Description | | | | | |-------------|---------------------------------------------------------------------------------------------------------------------------------|----------|--|--|--| | 0 | Transmit data written in TDR has not been transferred to TSR | | | | | | | [Clearing conditions] | | | | | | | <ul> <li>After reading TDRE = 1, cleared by writing 0 to TDRE</li> <li>When data is written to TDR by an instruction</li> </ul> | | | | | | 1 | Transmit data has not been written to TDR, or transmit data written in TD been transferred to TSR | OR has | | | | | | [Setting conditions] | | | | | | | <ul> <li>When bit TE in SCR3 is cleared to 0</li> <li>When data is transferred from TDR to TSR (Initia</li> </ul> | l value) | | | | Bit 6—Receive Data Register Full (RDRF): Bit 6 indicates that received data is stored in RDR. | Bit 6: RDRF | Description | | | | | |-------------|---------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--| | 0 | There is no receive data in RDR (Initial v | | | | | | | [Clearing conditions] | | | | | | | <ul> <li>After reading RDRF = 1, cleared by writing 0 to RDRF</li> <li>When RDR data is read by an instruction</li> </ul> | | | | | | 1 | There is receive data in RDR | | | | | | | [Setting condition] | | | | | | | When reception ends normally and receive data is transferred to RDR | from RSR to | | | | Note: If an error is detected in the receive data, or if the RE bit in SCR3 has been cleared to 0, RDR and bit RDRF are not affected and retain their previous state. Note that if data reception is completed while bit RDRF is still set to 1, an overrun error (OER) will result and the receive data will be lost. **Bit 5—Overrun Error (OER):** Bit 5 indicates that an overrun error has occurred during reception. | Bit 5: OER | Description | | | | | |------------|----------------------------------------------------|--|--|--|--| | 0 | Reception in progress or completed*1 (Initial va | | | | | | | [Clearing condition] | | | | | | | After reading OER = 1, cleared by writing 0 to OER | | | | | | 1 | An overrun error has occurred during reception*2 | | | | | | | [Setting condition] | | | | | | | When reception is completed with RDRF set to 1 | | | | | Notes: 1. When bit RE in SCR3 is cleared to 0, bit OER is not affected and retains its previous state. 2. RDR retains the receive data it held before the overrun error occurred, and data received after the error is lost. Reception cannot be continued with bit OER set to 1, and in synchronous mode, transmission cannot be continued either. **Bit 4—Framing Error (FER):** Bit 4 indicates that a framing error has occurred during reception in asynchronous mode. | Bit 4: FER | Description | | | | |------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0 | Reception in progress or completed*1 (Initia | | | | | | [Clearing condition] | | | | | | After reading FER = 1, cleared by writing 0 to FER | | | | | 1 | A framing error has occurred during reception*2 | | | | | | [Setting condition] | | | | | | When the stop bit at the end of the receive data is checked for a value of 1 at the end of reception, and the stop bit is $0^{*2}$ | | | | | | | | | | Notes: 1. When bit RE in SCR3 is cleared to 0, bit FER is not affected and retains its previous state. 2. Note that, in 2-stop-bit mode, only the first stop bit is checked for a value of 1, and the second stop bit is not checked. When a framing error occurs the receive data is transferred to RDR but bit RDRF is not set. Reception cannot be continued with bit FER set to 1. In synchronous mode, neither transmission nor reception is possible when bit FER is set to 1. **Bit 3—Parity Error (PER):** Bit 3 indicates that a parity error has occurred during reception with parity added in asynchronous mode. | Bit 3: PER | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Reception in progress or completed*1 (Initial value) | | | [Clearing condition] | | | After reading PER = 1, cleared by writing 0 to PER | | 1 | A parity error has occurred during reception*2 | | | [Setting condition] | | | When the number of 1 bits in the receive data plus parity bit does not match the parity designated by bit PM in the serial mode register (SMR) | - Notes: 1. When bit RE in SCR3 is cleared to 0, bit PER is not affected and retains its previous state. - 2. Receive data in which it a parity error has occurred is still transferred to RDR, but bit RDRF is not set. Reception cannot be continued with bit PER set to 1. In synchronous mode, neither transmission nor reception is possible when bit PER is set to 1. **Bit 2—Transmit End (TEND):** Bit 2 indicates that bit TDRE is set to 1 when the last bit of a transmit character is sent. Bit 2 is a read-only bit and cannot be modified. | Bit 2: TEND | Description | | |-------------|---------------------------------------------------------------------------------------------------------------------------------|------------------| | 0 | Transmission in progress | | | | [Clearing conditions] | | | | <ul> <li>After reading TDRE = 1, cleared by writing 0 to TDRE</li> <li>When data is written to TDR by an instruction</li> </ul> | | | 1 | Transmission ended | (Initial value) | | | [Setting conditions] | | | | <ul><li>When bit TE in SCR3 is cleared to 0</li><li>When bit TDRE is set to 1 when the last bit of a transmit cl</li></ul> | haracter is sent | **Bit 1—Multiprocessor Bit Receive (MPBR):** Bit 1 stores the multiprocessor bit in a receive character during multiprocessor format reception in asynchronous mode. Bit 1 is a read-only bit and cannot be modified. | Bit 1: MPBR | Description | | |-------------|--------------------------------------------------------------|-----------------| | 0 | Data in which the multiprocessor bit is 0 has been received* | (Initial value) | | 1 | Data in which the multiprocessor bit is 1 has been received | | Note: \* When bit RE is cleared to 0 in SCR3 with the multiprocessor format, bit MPBR is not affected and retains its previous state. **Bit 0—Multiprocessor Bit Transfer (MPBT):** Bit 0 stores the multiprocessor bit added to transmit data when transmitting in asynchronous mode. The bit MPBT setting is invalid when synchronous mode is selected, when the multiprocessor communication function is disabled, and when not transmitting. | Bit 0: MPBT | Description | | |-------------|------------------------------------------------|-----------------| | 0 | Multiprocessor bit value in transmit data is 0 | (Initial value) | | 1 | Multiprocessor bit value in transmit data is 1 | | #### 14.2.8 Bit Rate Register (BRR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|------|------|------|------|------|------| | | BRR7 | BRR6 | BRR5 | BRR4 | BRR3 | BRR2 | BRR1 | BRR0 | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Read/Write | R/W BRR is an 8-bit register that designates the transmit/receive bit rate in accordance with the baud rate generator operating clock selected by bits CKS1 and CKS0 of the serial mode register (SMR). BRR can be read or written by the CPU at any time. BRR is initialized to H'FF upon reset, and in standby, subactive, or subsleep mode. Table 14.3 shows examples of BRR settings in asynchronous mode. The values shown are for active (high-speed) mode. Table 14.3 Examples of BRR Settings for Various Bit Rates (Asynchronous Mode) ø (MHz) | | | 2 | | 2.097152 | | 2.4576 | | | 3 | | | | |----------------------|---|-----|--------------|----------|-----|--------------|---|-----|--------------|---|-----|--------------| | Bit Rate<br>(bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 1 | 141 | 0.03 | 1 | 148 | -0.04 | 1 | 174 | -0.26 | 1 | 212 | 0.03 | | 150 | 1 | 103 | 0.16 | 1 | 108 | 0.21 | 1 | 127 | 0.00 | 1 | 155 | 0.16 | | 300 | 0 | 207 | 0.16 | 0 | 217 | 0.21 | 0 | 255 | 0.00 | 1 | 77 | 0.16 | | 600 | 0 | 103 | 0.16 | 0 | 108 | 0.21 | 0 | 127 | 0.00 | 0 | 155 | 0.16 | | 1200 | 0 | 51 | 0.16 | 0 | 54 | -0.70 | 0 | 63 | 0.00 | 0 | 77 | 0.16 | | 2400 | 0 | 25 | 0.16 | 0 | 26 | 1.14 | 0 | 31 | 0.00 | 0 | 38 | 0.16 | | 4800 | 0 | 12 | 0.16 | 0 | 13 | -2.48 | 0 | 15 | 0.00 | 0 | 19 | -2.34 | | 9600 | 0 | 6 | -6.99 | 0 | 6 | -2.48 | 0 | 7 | 0.00 | 0 | 9 | -2.34 | | 19200 | 0 | 2 | 8.51 | 0 | 2 | 13.78 | 0 | 3 | 0.00 | 0 | 4 | -2.34 | | 31250 | 0 | 1 | 0.00 | 0 | 1 | 4.86 | 0 | 1 | 22.88 | 0 | 2 | 0.00 | | 38400 | 0 | 1 | -18.62 | 0 | 1 | -14.67 | 0 | 1 | 0.00 | _ | | _ | ø (MHz) | | | 3.68 | 64 | 4 | | 4.9152 | | | 5 | | | | |----------------------|---|------|--------------|---|-----|--------------|---|-----|--------------|---|-----|--------------| | Bit Rate<br>(bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 2 | 64 | 0.70 | 2 | 70 | 0.03 | 2 | 86 | 0.31 | 2 | 88 | -0.25 | | 150 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | 1 | 255 | 0.00 | 2 | 64 | 0.16 | | 300 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | | 600 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | | 1200 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | | 2400 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | | 4800 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | | 9600 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | | 19200 | 0 | 5 | 0.00 | 0 | 6 | -6.99 | 0 | 7 | 0.00 | 0 | 7 | 1.73 | | 31250 | _ | | | 0 | 3 | 0.00 | 0 | 4 | -1.70 | 0 | 4 | 0.00 | | 38400 | 0 | 2 | 0.00 | 0 | 2 | 8.51 | 0 | 3 | 0.00 | 0 | 3 | 1.73 | # ø (MHz) | | | 6 | | | 6.144 | | 7.3728 | | | 8 | | | |-------------------|---|-----|--------------|---|-------|--------------|--------|-----|--------------|---|-----|--------------| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 2 | 106 | -0.44 | 2 | 108 | 0.08 | 2 | 130 | -0.07 | 2 | 141 | 0.03 | | 150 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | 2 | 95 | 0.00 | 2 | 103 | 0.16 | | 300 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | | 600 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | | 1200 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | | 2400 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | | 4800 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | | 9600 | 0 | 19 | -2.34 | 0 | 19 | 0.00 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | | 19200 | 0 | 9 | -2.34 | 0 | 9 | 0.00 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | | 31250 | 0 | 5 | 0.00 | 0 | 5 | 2.40 | 0 | 6 | 5.33 | 0 | 7 | 0.00 | | 38400 | 0 | 4 | -2.34 | 0 | 4 | 0.00 | 0 | 5 | 0.00 | 0 | 6 | -6.99 | # ø (MHz) | | 9.8304 10 | | | | ) | | 12 | ! | 12.888 | | | | |-------------------|-----------|-----|--------------|---|-----|--------------|----|-----|--------------|---|-----|--------------| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 2 | 174 | -0.26 | 2 | 177 | -0.25 | 2 | 212 | 0.03 | 2 | 217 | 0.08 | | 150 | 2 | 127 | 0.00 | 2 | 129 | 0.16 | 2 | 155 | 0.16 | 2 | 159 | 0.00 | | 300 | 1 | 255 | 0.00 | 2 | 64 | 0.16 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | | 600 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | | 1200 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | | 2400 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | | 4800 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | | 9600 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | | 19200 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | 0 | 19 | -2.34 | 0 | 19 | 0.00 | | 31250 | 0 | 9 | -1.70 | 0 | 9 | 0.00 | 0 | 11 | 0.00 | 0 | 11 | 2.40 | | 38400 | 0 | 7 | 0.00 | 0 | 7 | 1.73 | 0 | 9 | -2.34 | 0 | 9 | 0.00 | | ø (MHz) | |---------| |---------| | | | 14 | , | | 14.7456 | | 16 | | | |-------------------|---|-----|--------------|---|---------|--------------|----|-----|--------------| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 2 | 248 | -0.17 | 3 | 64 | 0.70 | 3 | 70 | 0.03 | | 150 | 2 | 181 | 0.16 | 2 | 191 | 0.00 | 2 | 207 | 0.16 | | 300 | 2 | 90 | 0.16 | 2 | 95 | 0.00 | 2 | 103 | 0.16 | | 600 | 1 | 181 | 0.16 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | | 1200 | 1 | 90 | 0.16 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | | 2400 | 0 | 181 | 0.16 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | | 4800 | 0 | 90 | 0.16 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | | 9600 | 0 | 45 | -0.93 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | | 19200 | 0 | 22 | -0.93 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | | 31250 | 0 | 13 | 0.00 | 0 | 14 | -1.70 | 0 | 15 | 0.00 | | 38400 | _ | _ | _ | 0 | 11 | 0.00 | 0 | 12 | 0.16 | —: A setting can be made, but an error will result. Notes: 1. The value set in BRR is given by the following equation: $$N = \frac{\emptyset}{64 \times 2^{2n-1} \times B} \times 10^6 - 1$$ where B: Bit rate (bit/s) N: Baud rate generator BRR setting $(0 \le N \le 255)$ ø: Operating frequency (MHz) n: Value set in bits CKS1 and CKS0 in SMR (The relation between n and the clock is shown in table 14.4.) Table 14.4 Relation between n and Clock **SMR Setting** | | | _ | | | |---|-------|------|------|--| | n | Clock | CKS1 | CKS0 | | | 0 | Ø | 0 | 0 | | | 1 | ø/4 | 0 | 1 | | | 2 | ø16 | 1 | 0 | | | 3 | ø/64 | 1 | 1 | | 2. The bit rate error in asynchronous mode is given by the following equation: Error (%) = $$\left\{ \frac{\text{Ø} \times 10^6}{(\text{N} + 1) \times \text{B} \times 64 \times 2^{2n-1}} - 1 \right\} \times 100$$ Table 14.5 shows the maximum bit rate for each frequency. The values shown are for active (high-speed) mode. Table 14.5 Maximum Bit Rate for Each Frequency (Asynchronous Mode) | | | | Setting | |----------|---------------------------|---|---------| | ø (MHz) | Maximum Bit Rate (bits/s) | n | N | | 2 | 62500 | 0 | 0 | | 2.097152 | 65536 | 0 | 0 | | 2.4576 | 76800 | 0 | 0 | | 3 | 93750 | 0 | 0 | | 3.6864 | 115200 | 0 | 0 | | 4 | 125000 | 0 | 0 | | 4.9152 | 153600 | 0 | 0 | | 5 | 156250 | 0 | 0 | | 6 | 187500 | 0 | 0 | | 6.144 | 192000 | 0 | 0 | | 7.3728 | 230400 | 0 | 0 | | 8 | 250000 | 0 | 0 | | 9.8304 | 307200 | 0 | 0 | | 10 | 312500 | 0 | 0 | | 12 | 375000 | 0 | 0 | | 12.288 | 384000 | 0 | 0 | | 14 | 437500 | 0 | 0 | | 14.7456 | 460800 | 0 | 0 | | 16 | 500000 | 0 | 0 | Table 14.6 shows examples of BRR settings in synchronous mode. The values shown are for active (high-speed) mode. **Table 14.6 Examples of BRR Settings for Various Bit Rates (Synchronous Mode)** | osc | (MHz) | |-----|-------| |-----|-------| | Bit Rate | 2 | | | 4 | | 8 | | 10 | | 16 | | |----------|---|-----|---|-----|---|-----|---|-----|---|-----|--| | (bits/s) | n | N | n | N | n | N | n | N | n | N | | | 110 | 3 | 70 | _ | _ | _ | _ | _ | _ | 3 | 249 | | | 250 | 2 | 124 | 2 | 249 | 3 | 124 | _ | _ | 3 | 124 | | | 500 | 1 | 249 | 2 | 124 | 2 | 249 | _ | | 2 | 249 | | | 1k | 1 | 124 | 1 | 249 | 2 | 124 | _ | | 2 | 99 | | | 2.5k | 0 | 199 | 1 | 99 | 1 | 199 | 1 | 249 | 1 | 199 | | | 5k | 0 | 99 | 0 | 199 | 1 | 99 | 1 | 124 | 1 | 99 | | | 10k | 0 | 49 | 0 | 99 | 0 | 199 | 0 | 249 | 0 | 159 | | | 25k | 0 | 19 | 0 | 39 | 0 | 79 | 0 | 99 | 0 | 79 | | | 50k | 0 | 9 | 0 | 19 | 0 | 39 | 0 | 49 | 0 | 39 | | | 100k | 0 | 4 | 0 | 9 | 0 | 19 | 0 | 24 | 0 | 15 | | | 250k | 0 | 1 | 0 | 3 | 0 | 7 | 0 | 9 | 0 | 7 | | | 500k | 0 | 0* | 0 | 1 | 0 | 3 | 0 | 4 | 0 | 3 | | | 1M | | | 0 | 0* | 0 | 1 | _ | _ | 0 | 1 | | | 2M | | | | | 0 | 0* | _ | _ | _ | _ | | | 2.5M | | | | | _ | | 0 | 0* | 0 | 0* | | Blank: Cannot be set. —: A setting can be made, but an error will result. \*: Continuous transmission/reception is not possible. Note: The value set in BRR is given by the following equation: $$N = \frac{\emptyset}{8 \times 2^{2n-1} \times B} \times 10^6 - 1$$ where B: Bit rate (bit/s) N: Baud rate generator BRR setting $(0 \le N \le 255)$ ø: Operating frequency (MHz) n: Baud rate generator input clock number (n = 0, 1, 2, or 3) (The relation between n and the clock is shown in table 14.7.) Table 14.7 Relation between n and Clock | n | Clock | CKS1 | CKS0 | | | | | | | |---|-------|------|------|--|--|--|--|--|--| | 0 | Ø | 0 | 0 | | | | | | | | 1 | ø/4 | 0 | 1 | | | | | | | | 2 | ø16 | 1 | 0 | | | | | | | | 3 | ø/64 | 1 | 1 | | | | | | | ## 14.3 Operation SCI3 can perform serial communication in two modes: asynchronous mode in which synchronization is provided character by character, and synchronous mode in which synchronization is provided by clock pulses. The serial mode register (SMR) is used to select asynchronous or synchronous mode and the data transfer format, as shown in table 14.8. The clock source for SCI3 is determined by bit COM in SMR and bits CKE1 and CKE0 in SCR3, as shown in table 14.9. #### 14.3.1 Asynchronous Mode - Data length is selectable: 7 or 8 bits. - Parity and multiprocessor bits are selectable. So is the stop bit length (1 or 2 bits). These selections determine the communication format and character length. - In receiving, it is possible to detect framing errors, parity errors, overrun errors, and the break state. - An internal or external clock can be selected as the SCI clock source. - When an internal clock is selected, the SCI operates using the on-chip baud rate generator, and can output a serial clock signal with a frequency matching the bit rate. - When an external clock is selected, the external clock input must have a frequency 16 times the bit rate. (The on-chip baud rate generator is not used.) ### 14.3.2 Synchronous Mode - The communication format has a fixed 8-bit data length. - In receiving, it is possible to detect overrun errors. - An internal or external clock can be selected as the SCI clock source. - When an internal clock is selected, the SCI operates using the on-chip baud rate generator, and outputs a serial clock signal to external devices. - When an external clock is selected, the SCI operates on the input serial clock. The on-chip baud rate generator is not used. **Table 14.8 SMR Settings and Corresponding Data Transfer Formats** | SMR Setting | | | | | | Cor | | | | |-------------|---------------|---|--------------|----------------|------------------|-------------|-------------------------|---------------|--------------------| | | Bit 6:<br>CHR | | Bit 5:<br>PE | Bit 3:<br>STOP | Mode | Data Length | Multipro-<br>cessor Bit | Parity<br>Bit | Stop Bit<br>Length | | 0 | 0 | 0 | 0 | 0 | Asynchronous | 8-bit data | No | No | 1 bit | | | | | | 1 | mode | | | | 2 bits | | | | | 1 | 0 | - | | | Yes | 1 bit | | | | | | 1 | - | | | | 2 bits | | | 1 | | 0 | 0 | - | 7-bit data | - | No | 1 bit | | | | | | 1 | - | | | | 2 bits | | | | | 1 | 0 | - | | | Yes | 1 bit | | | | | | 1 | - | | | | 2 bits | | | 0 | 1 | * | 0 | Asynchronous | 8-bit data | Yes | No | 1 bit | | | | | * | 1 | mode | | | | 2 bits | | | 1 | - | * | 0 | (multiprocessor | 7-bit data | - | | 1 bit | | | | | * | 1 | format) | | | | 2 bits | | 1 | * | 0 | * | * | Synchronous mode | 8-bit data | No | No | No | Note: \* Don't care Table 14.9 SMR and SCR3 Settings and Clock Source Selection | SMR | S | CR3 | | Transmit/Receive Clock | | | | | | |---------------|----------------------------|-----|-------------------|------------------------|------------------------------------------------|--|--|--|--| | Bit 7:<br>COM | Bit 1: Bit 0:<br>CKE1 CKE0 | | <br>Mode | Clock<br>Source | SCK3 Pin Function | | | | | | 0 | 0 | 0 | Asynchronous mode | Internal | I/O port (SCK3 pin not used) | | | | | | | | 1 | | | Outputs clock with same frequency as bit rate | | | | | | | 1 | 0 | _ | External | Outputs clock with frequency 16 times bit rate | | | | | | 1 | 0 | 0 | Synchronous | Internal | Outputs serial clock | | | | | | | 1 | 0 | mode | External | Inputs serial clock | | | | | | 0 | 1 | 1 | Reserved (Do n | ot specify th | nese combinations) | | | | | | 1 | 0 | 1 | | | | | | | | | 1 | 1 | 1 | | | | | | | | # 14.3.3 Interrupts and Continuous Transmission/Reception SCI3 can carry out continuous reception using RXI and continuous transmission using TXI. These interrupts are shown in table 14.10. **Table 14.10** Transmit/Receive Interrupts | Interrupt | Flags | Interrupt Request Conditions | Notes | | | | | |-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | RXI | RDRF<br>RIE | When serial reception is performed normally and receive data is transferred from RSR to RDR, bit RDRF is set to 1, and if bit RIE is set to 1 at this time, RXI is enabled and an interrupt is requested. (See figure 14.2 (a).) | The RXI interrupt routine reads the receive data transferred to RDR and clears bit RDRF to 0. Continuous reception can be performed by repeating the above operations until reception of the next RSR data is completed. | | | | | | TXI | TDRE<br>TIE | When TSR is found to be empty (on completion of the previous transmission) and the transmit data placed in TDR is transferred to TSR, bit TDRE is set to 1. If bit TIE is set to 1 at this time, TXI is enabled and an interrupt is requested. (See figure 14.2 (b).) | The TXI interrupt routine writes the next transmit data to TDR and clears bit TDRE to 0. Continuous transmission can be performed by repeating the above operations until the data transferred to TSR has been transmitted. | | | | | | TEI | TEND<br>TEIE | When the last bit of the character in TSR is transmitted, if bit TDRE is set to 1, bit TEND is set to 1. If bit TEIE is set to 1 at this time, TEI is enabled and an interrupt is requested. (See figure 14.2 (c).) | TEI indicates that the next transmit data has not been written to TDR when the last bit of the transmit character in TSR is sent. | | | | | Figure 14.2 (a) RDRF Setting and RXI Interrupt Figure 14.2 (b) TDRE Setting and TXI Interrupt Figure 14.2 (c) TEND Setting and TEI Interrupt ## 14.4 Operation in Asynchronous Mode In asynchronous mode, serial communication is performed with synchronization provided character by character. A start bit indicating the start of communication and one or two stop bits indicating the end of communication are added to each character before it is sent. SCI3 has separate transmission and reception units, allowing full-duplex communication. As the transmission and reception units are both double-buffered, data can be written during transmission and read during reception, making possible continuous transmission and reception. #### 14.4.1 Data Transfer Format The general data transfer format in asynchronous communication is shown in figure 14.3. Figure 14.3 Data Format in Asynchronous Communication In asynchronous communication, the communication line is normally in the mark state (high level). SCI3 monitors the communication line and when it detects a space (low level), identifies this as a start bit and begins serial data communication. One transfer data character consists of a start bit (low level), followed by transmit/receive data (LSB-first format, starting from the least significant bit), a parity bit (high or low level), and finally one or two stop bits (high level). In asynchronous mode, synchronization is performed by the falling edge of the start bit during reception. The data is sampled on the 8th pulse of a clock with a frequency 16 times the bit period, so that the transfer data is latched at the center of each bit. Table 14.11 shows the 12 data transfer formats that can be set in asynchronous mode. The format is selected by the settings in the serial mode register (SMR). Table 14.11 Data Transfer Formats (Asynchronous Mode) | | SMR | Setting | gs | Serial Data Transfer Format and Frame Length | | | | | | | | | | | | |-----|-----|---------|------|----------------------------------------------|---|---|---|-------|------|---|---|------|------|------|------| | CHR | PE | MP | STOP | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | | 0 | 0 | 0 | 0 | S | | | | 8-bit | data | | | | STOP | - | | | 0 | 0 | 0 | 1 | S | | | | 8-bit | data | | | | STOP | STOP | | | 0 | 1 | 0 | 0 | S | | | | 8-bit | data | | | | Р | STOP | | | 0 | 1 | 0 | 1 | S | | | | 8-bit | data | | | | Р | STOP | STOP | | 1 | 0 | 0 | 0 | S | | | | 7-bit | data | | 1 | STOP | ) | | | | 1 | 0 | 0 | 1 | S | | | | 7-bit | data | | | STOP | STOP | - | | | 1 | 1 | 0 | 0 | s | | | | 7-bit | data | | | Р | STOP | - | | | 1 | 1 | 0 | 1 | s | | | | 7-bit | data | | | Р | STOP | STOP | | | 0 | * | 1 | 0 | s | | | | 8-bit | data | | | | МРВ | STOP | | | 0 | * | 1 | 1 | S | | | | 8-bit | data | | | | MPB | STOP | STOP | | 1 | * | 1 | 0 | S | | | | 7-bit | data | | | МРВ | STOP | - | | | 1 | * | 1 | 1 | S | | | | 7-bit | data | | | MPB | STOP | STOP | | Note: \* Don't care Notation: S: Start bit STOP: Stop bit P: Parity bit MPB: Multiprocessor bit #### 14.4.2 Clock Either an internal clock generated by the baud rate generator or an external clock input at the SCK<sub>3</sub> pin can be selected as the SCI3 transmit/receive clock. The selection is made by means of bit COM in SMR and bits CKE1 and CKE0 in SCR3. See table 14.9 for details on clock source selection. When an external clock is input at the SCK<sub>3</sub> pin, a clock with a frequency of 16 times the bit rate used should be input. When SCI3 operates on an internal clock, the clock can be output at the SCK<sub>3</sub> pin. In this case the frequency of the output clock is the same as the bit rate, and the phase is such that the clock rises at the center of each bit of transmit/receive data, as shown in figure 14.4. Figure 14.4 Phase Relationship between Output Clock and Transfer Data (Asynchronous Mode) (8-Bit Data, Parity, 2 Stop Bits) ## 14.4.3 Data Transfer Operations **SCI3 Initialization:** Before data is transferred on SCI3, bits TE and RE in SCR3 must first be cleared to 0, and then SCI3 must be initialized as follows. Note: If the operation mode or data transfer format is changed, bits TE and RE must first be cleared to 0. When bit TE is cleared to 0, bit TDRE is set to 1. Note that the RDRF, PER, FER, and OER flags and the contents of RDR are retained when RE is cleared to 0. When an external clock is used in asynchronous mode, the clock should not be stopped during operation, including initialization. When an external clock is used in synchronous mode, the clock should not be supplied during operation, including initialization. Figure 14.5 shows an example of a flowchart for initializing SCI3. Figure 14.5 Example of SCI3 Initialization Flowchart **Transmitting:** Figure 14.6 shows an example of a flowchart for data transmission. This procedure should be followed for data transmission after initializing SCI3. - Read the serial status register (SSR) and check that bit TDRE is set to 1, then write transmit data to the transmit data register (TDR). When data is written to TDR, bit TDRE is cleared to 0 automatically. - When continuing data transmission, be sure to read TDRE = 1 to confirm that a write can be performed before writing data to TDR. When data is written to TDR, bit TDRE is cleared to 0 automatically. - If a break is to be output when data transmission ends, set the port PCR to 1 and clear the port PDR to 0, then clear bit TXD in PMR7 and bit TE in SCR3 to 0. Figure 14.6 Example of Data Transmission Flowchart (Asynchronous Mode) SCI3 operates as follows when transmitting data. SCI3 monitors bit TDRE in SSR, and when it is cleared to 0, recognizes that data has been written to TDR and transfers data from TDR to TSR. It then sets bit TDRE to 1 and starts transmitting. If bit TIE in SCR3 is set to 1 at this time, a TXI request is made. Serial data is transmitted from the TXD pin using the relevant data transfer format in table 14.11. When the stop bit is sent, SCI3 checks bit TDRE. If bit TDRE is cleared to 0, SCI3 transfers data from TDR to TSR, and when the stop bit has been sent, starts transmission of the next frame. If bit TDRE is set to 1, bit TEND in SSR is set to 1, and the mark state, in which 1s are transmitted, is established after the stop bit has been sent. If bit TEIE in SCR3 is set to 1 at this time, a TEI request is made. Figure 14.7 shows an example of the operation when transmitting in asynchronous mode. Figure 14.7 Example of Operation when Transmitting in Asynchronous Mode (8-Bit Data, Parity, 1 Stop Bit) **Receiving:** Figure 14.8 shows an example of a flowchart for data reception. This procedure should be followed for data reception after initializing SCI3. Figure 14.8 Example of Data Reception Flowchart (Asynchronous Mode) Figure 14.8 Example of Data Reception Flowchart (Asynchronous Mode) (cont) SCI3 operates as follows when receiving data. SCI3 monitors the communication line, and when it detects a 0 start bit, performs internal synchronization and begins reception. Reception is carried out in accordance with the relevant data transfer format in table 14.11. The received data is first placed in RSR in LSB-to-MSB order, and then the parity bit and stop bit(s) are received. SCI3 then carries out the following checks. - Parity check - SCI3 checks that the number of 1 bits in the receive data conforms to the parity (odd or even) set in bit PM in the serial mode register (SMR). - Stop bit check SCI3 checks that the stop bit is 1. If two stop bits are used, only the first is checked. - Status check SCI3 checks that bit RDRF is set to 1, indicating that the receive data can be transferred from RSR to RDR. If no receive error is found in the above checks, bit RDRF is set to 1, and the receive data is stored in RDR. If bit RIE is set to 1 in SCR3, an RXI interrupt is requested. If the error checks identify a receive error, bit OER, PER, or FER is set to 1 depending on the kind of error. Bit RDRF retains its state prior to receiving the data. If bit RIE is set to 1 in SCR3, an ERI interrupt is requested. Table 14.12 shows the conditions for detecting a receive error, and receive data processing. Note: No further receive operations are possible while a receive error flag is set. Bits OER, FER, PER, and RDRF must therefore be cleared to 0 before resuming reception. Table 14.12 Receive Error Detection Conditions and Receive Data Processing | Receive Error | Abbreviation | <b>Detection Conditions</b> | Received Data Processing | |---------------|--------------|-------------------------------------------------------------------------------------------|-------------------------------------------------| | Overrun error | OER | When the next date receive operation is completed while bit RDRF is still set to 1 in SSR | Receive data is not transferred from RSR to RDR | | Framing error | FER | When the stop bit is 0 | Receive data is transferred from RSR to RDR | | Parity error | PER | When the parity (odd or even) set in SMR is different from that of the received data | Receive data is transferred from RSR to RDR | Figure 14.9 shows an example of the operation when receiving in asynchronous mode. Figure 14.9 Example of Operation when Receiving in Asynchronous Mode (8-Bit Data, Parity, 1 Stop Bit) # 14.5 Operation in Synchronous Mode In synchronous mode, SCI3 transmits and receives data in synchronization with clock pulses. This mode is suitable for high-speed serial communication. SCI3 has separate transmission and reception units, allowing full-duplex communication with a shared clock. As the transmission and reception units are both double-buffered, data can be written during transmission and read during reception, making possible continuous transmission and reception. #### 14.5.1 Data Transfer Format The general data transfer format in synchronous communication is shown in figure 14.10. Figure 14.10 Data Format in Synchronous Communication In synchronous communication, data on the communication line is output from one falling edge of the serial clock until the next falling edge. Data confirmation is guaranteed at the rising edge of the serial clock. One transfer data character begins with the LSB and ends with the MSB. After output of the MSB, the communication line retains the MSB state. When receiving in synchronous mode, SCI3 latches receive data at the rising edge of the serial clock. The data transfer format uses a fixed 8-bit data length. Parity and multiprocessor bits cannot be added. #### 14.5.2 Clock Either an internal clock generated by the baud rate generator or an external clock input at the SCK<sub>3</sub> pin can be selected as the SCI3 serial clock. The selection is made by means of bit COM in SMR and bits CKE1 and CKE0 in SCR3. See table 14.12 for details on clock source selection. When SCI3 operates on an internal clock, the serial clock is output at the $SCK_3$ pin. Eight pulses of the serial clock are output in transmission or reception of one character, and when SCI3 is not transmitting or receiving, the clock is fixed at the high level. ### 14.5.3 Data Transfer Operations **SCI3 Initialization:** Data transfer on SCI3 first of all requires that SCI3 be initialized as described in 14.4.3, SCI3 Initialization, and shown in figure 14.5. **Transmitting:** Figure 14.11 shows an example of a flowchart for data transmission. This procedure should be followed for data transmission after initializing SCI3. - Read the serial status register (SSR) and check that bit TDRE is set to 1, then write transmit data to the transmit data register (TDR). When data is written to TDR, bit TDRE is cleared to 0 automatically, the clock is output, and data transmission is started. - When continuing data transmission, be sure to read TDRE = 1 to confirm that a write can be performed before writing data to TDR. When data is written to TDR, bit TDRE is cleared to 0 automatically. Figure 14.11 Example of Data Transmission Flowchart (Synchronous Mode) SCI3 operates as follows when transmitting data. SCI3 monitors bit TDRE in SSR, and when it is cleared to 0, recognizes that data has been written to TDR and transfers data from TDR to TSR. It then sets bit TDRE to 1 and starts transmitting. If bit TIE in SCR3 is set to 1 at this time, a TXI request is made. When clock output mode is selected, SCI3 outputs 8 serial clock pulses. When an external clock is selected, data is output in synchronization with the input clock. Serial data is transmitted from the TXD pin in order from the LSB (bit 0) to the MSB (bit 7). When the MSB (bit 7) is sent, checks bit TDRE. If bit TDRE is cleared to 0, SCI3 transfers data from TDR to TSR, and starts transmission of the next frame. If bit TDRE is set to 1, SCI3 sets bit TEND to 1 in SSR, and after sending the MSB (bit 7), retains the MSB state. If bit TEIE in SCR3 is set to 1 at this time, a TEI request is made. After transmission ends, the SCK<sub>3</sub> pin is fixed at the high level. Note: Transmission is not possible if an error flag (OER, FER, or PER) that indicates the data reception status is set to 1. Check that these error flags (OER, FER, and PER) are all cleared to 0 before a transmit operation. Figure 14.12 shows an example of the operation when transmitting in synchronous mode. Figure 14.12 Example of Operation when Transmitting in Synchronous Mode **Receiving:** Figure 14.13 shows an example of a flowchart for data reception. This procedure should be followed for data reception after initializing SCI3. Figure 14.13 Example of Data Reception Flowchart (Synchronous Mode) SCI3 operates as follows when receiving data. SCI3 performs internal synchronization and begins reception in synchronization with the serial clock input or output. The received data is placed in RSR in LSB-to-MSB order. After the data has been received, SCI3 checks that bit RDRF is set to 0, indicating that the receive data can be transferred from RSR to RDR. If this check shows that there is no overrun error, bit RDRF is set to 1, and the receive data is stored in RDR. If bit RIE is set to 1 in SCR3, an RXI interrupt is requested. If the check identifies an overrun error, bit OER is set to 1. Bit RDRF remains set to 1. If bit RIE is set to 1 in SCR3, an ERI interrupt is requested. See table 14.12 for the conditions for detecting an overrun error, and receive data processing. Note: No further receive operations are possible while a receive error flag is set. Bits OER, FER, PER, and RDRF must therefore be cleared to 0 before resuming reception. Figure 14.14 shows an example of the operation when receiving in synchronous mode. Figure 14.14 Example of Operation when Receiving in Synchronous Mode **Simultaneous Transmit/Receive:** Figure 14.15 shows an example of a flowchart for a simultaneous transmit/receive operation. This procedure should be followed for simultaneous transmission/reception after initializing SCI3. Figure 14.15 Example of Simultaneous Data Transmission/Reception Flowchart (Synchronous Mode) - Notes: 1. When switching from transmission to simultaneous transmission/reception, check that SCI3 has finished transmitting and that bits TDRE and TEND are set to 1, clear bit TE to 0, and then set bits TE and RE to 1 simultaneously with a single instruction. - 2. When switching from reception to simultaneous transmission/reception, check that SCI3 has finished receiving, clear bit RE to 0, then check that bit RDRF and the error flags (OER, FER, and PER) are cleared to 0, and finally set bits TE and RE to 1 simultaneously with a single instruction. # 14.6 Multiprocessor Communication Function The multiprocessor communication function enables data to be exchanged among a number of processors on a shared communication line. Serial data communication is performed in asynchronous mode using the multiprocessor format (in which a multiprocessor bit is added to the transfer data). In multiprocessor communication, each receiver is assigned its own ID code. The serial communication cycle consists of two cycles, an ID transmission cycle in which the receiver is specified, and a data transmission cycle in which the transfer data is sent to the specified receiver. These two cycles are differentiated by means of the multiprocessor bit, 1 indicating an ID transmission cycle, and 0, a data transmission cycle. The sender first sends transfer data with a 1 multiprocessor bit added to the ID code of the receiver it wants to communicate with, and then sends transfer data with a 0 multiprocessor bit added to the transmit data. When a receiver receives transfer data with the multiprocessor bit set to 1, it compares the ID code with its own ID code, and if they are the same, receives the transfer data sent next. If the ID codes do not match, it skips the transfer data until data with the multiprocessor bit set to 1 is sent again. In this way, a number of processors can exchange data among themselves. Figure 14.16 shows an example of communication between processors using the multiprocessor format. Figure 14.16 Example of Inter-Processor Communication Using Multiprocessor Format (Sending Data H'AA to Receiver A) There is a choice of four data transfer formats. If a multiprocessor format is specified, the parity bit specification is invalid. See table 14.11 for details. For details on the clock used in multiprocessor communication, see section 14.4, Operation in Asynchronous Mode. **Multiprocessor Transmitting:** Figure 14.17 shows an example of a flowchart for multiprocessor data transmission. This procedure should be followed for multiprocessor data transmission after initializing SCI3. - Read the serial status register (SSR) and check that bit TDRE is set to 1, then set bit MPBT in SSR to 0 or 1 and write transmit data to the transmit data register (TDR). When data is written to TDR, bit TDRE is cleared to 0 automatically. - When continuing data transmission, be sure to read TDRE = 1 to confirm that a write can be performed before writing data to TDR. When data is written to TDR, bit TDRE is cleared to 0 automatically. - If a break is to be output when data transmission ends, set the port PCR to 1 and clear the port PDR to 0, then clear bit TE in SCR3 to 0. Figure 14.17 Example of Multiprocessor Data Transmission Flowchart SCI3 operates as follows when transmitting data. SCI3 monitors bit TDRE in SSR, and when it is cleared to 0, recognizes that data has been written to TDR and transfers data from TDR to TSR. It then sets bit TDRE to 1 and starts transmitting. If bit TIE in SCR3 is set to 1 at this time, a TXI request is made. Serial data is transmitted from the TXD pin using the relevant data transfer format in table 14.11. When the stop bit is sent, SCI3 checks bit TDRE. If bit TDRE is cleared to 0, SCI3 transfers data from TDR to TSR, and when the stop bit has been sent, starts transmission of the next frame. If bit TDRE is set to 1, bit TEND in SSR is set to 1, and the mark state, in which 1s are transmitted, is established after the stop bit has been sent. If bit TEIE in SCR3 is set to 1 at this time, a TEI request is made. Figure 14.18 shows an example of the operation when transmitting using the multiprocessor format. Figure 14.18 Example of Operation when Transmitting using Multiprocessor Format (8-Bit Data, Multiprocessor Bit, 1 Stop Bit) **Multiprocessor Receiving:** Figure 14.19 shows an example of a flowchart for multiprocessor data reception. This procedure should be followed for multiprocessor data reception after initializing SCI3. - 1. Set bit MPIE to 1 in SCR3. - Read bits OER and FER in the serial status register (SSR) to determine if there is an error. If a receive error has occurred, execute receive error processing. - Read SSR and check that bit RDRF is set to 1. If it is, read the receive data in RDR and compare it with this receiver's own ID. If the ID is not this receiver's, set bit MPIE to 1 again. When the RDR data is read, bit RDRF is cleared to 0 automatically. - Read SSR and check that bit RDRF is set to 1, then read the data in RDR. - 5. If a receive error has occurred, read bits OER and FER in SSR to identify the error, and after carrying out the necessary error processing, ensure that bits OER and FER are both cleared to 0. Reception cannot be resumed if either of these bits is set to 1. In the case of a framing error, a break can be detected by reading the value of the RXD pin. Figure 14.19 Example of Multiprocessor Data Reception Flowchart Figure 14.19 Example of Multiprocessor Data Reception Flowchart (cont) Figure 14.20 shows an example of the operation when receiving using the multiprocessor format. Figure 14.20 Example of Operation when Receiving using Multiprocessor Format (8-Bit Data, Multiprocessor Bit, 1 Stop Bit) ## 14.7 Interrupts SCI3 can generate six kinds of interrupts: transmit end, transmit data empty, receive data full, and three receive error interrupts (overrun error, framing error, and parity error). These interrupts have the same vector address. The various interrupt requests are shown in table 14.13. **Table 14.13 SCI3 Interrupt Requests** | Interrupt<br>Abbreviation | Interrupt Request | Vector Address | |---------------------------|-------------------------------------------------------------------|----------------| | RXI | Interrupt request initiated by receive data full flag (RDRF) | H'002A | | TXI | Interrupt request initiated by transmit data empty flag (TDRE) | _ | | TEI | Interrupt request initiated by transmit end flag (TEND) | _ | | ERI | Interrupt request initiated by receive error flag (OER, FER, PER) | _ | Each interrupt request can be enabled or disabled by means of bits TIE and RIE in SCR3. When bit TDRE is set to 1 in SSR, a TXI interrupt is requested. When bit TEND is set to 1 in SSR, a TEI interrupt is requested. These two interrupts are generated during transmission. The initial value of bit TDRE in SSR is 1. Therefore, if the transmit data empty interrupt request (TXI) is enabled by setting bit TIE to 1 in SCR3 before transmit data is transferred to TDR, a TXI interrupt will be requested even if the transmit data is not ready. Also, the initial value of bit TEND in SSR is 1. Therefore, if the transmit end interrupt request (TEI) is enabled by setting bit TEIE to 1 in SCR3 before transmit data is transferred to TDR, a TEI interrupt will be requested even if the transmit data has not been sent. Effective use of these interrupt requests can be made by having processing that transfers transmit data to TDR carried out in the interrupt service routine. To prevent the generation of these interrupt requests (TXI and TEI), on the other hand, the enable bits for these interrupt requests (bits TIE and TEIE) should be set to 1 after transmit data has been transferred to TDR. When bit RDRF is set to 1 in SSR, an RXI interrupt is requested, and if any of bits OER, PER, and FER is set to 1, an ERI interrupt is requested. These two interrupt requests are generated during reception. For further details, see section 3.3, Interrupts. ## 14.8 Usage Notes The following points should be noted when using SCI3. #### 14.8.1 Relation between Writes to TDR and Bit TDRE Bit TDRE in the serial status register (SSR) is a status flag that indicates that data for serial transmission has not been prepared in TDR. When data is written to TDR, bit TDRE is cleared to 0 automatically. When SCI3 transfers data from TDR to TSR, bit TDRE is set to 1. Data can be written to TDR irrespective of the state of bit TDRE, but if new data is written to TDR while bit TDRE is cleared to 0, the data previously stored in TDR will be lost of it has not yet been transferred to TSR. Accordingly, to ensure that serial transmission is performed dependably, you should first check that bit TDRE is set to 1, then write the transmit data to TDR once only (not two or more times). ### 14.8.2 Operation when a Number of Receive Errors Occur Simultaneously If a number of receive errors are detected simultaneously, the status flags in SSR will be set to the states shown in table 14.14. If an overrun error is detected, data transfer from RSR to RDR will not be performed, and the receive data will be lost. Table 14.14 SSR Status Flag States and Receive Data Transfer | SSR Status Flags | | Receive Data Transfer | | | | |------------------|-----|-----------------------|-----|------------------------|----------------------------------------------| | RDRF* | OER | FER | PER | (RSR $ ightarrow$ RDR) | Receive Error Status | | 1 | 1 | 0 | 0 | × | Overrun error | | 0 | 0 | 1 | 0 | 0 | Framing error | | 0 | 0 | 0 | 1 | 0 | Parity error | | 1 | 1 | 1 | 0 | × | Overrun error + framing error | | 1 | 1 | 0 | 1 | × | Overrun error + parity error | | 0 | 0 | 1 | 1 | 0 | Framing error + parity error | | 1 | 1 | 1 | 1 | × | Overrun error + framing error + parity error | O: Receive data is transferred from RSR to RDR. ×: Receive data is not transferred from RSR to RDR. Note: \* Bit RDRF retains its state prior to data reception. ### 14.8.3 Break Detection and Processing When a framing error is detected, a break can be detected by reading the value of the RXD pin directly. In a break, the input from the RXD pin becomes all 0s, with the result that bit FER is set and bit PER may also be set. SCI3 continues the receive operation even after receiving a break. Note, therefore, that even though bit FER is cleared to 0 it will be set to 1 again. #### 14.8.4 Mark State and Break Detection When bit TE is cleared to 0, the TXD pin functions as an I/O port whose input/output direction and level are determined by PDR and PCR. This fact can be used to set the TXD pin to the mark state, or to detect a break during transmission. To keep the communication line in the mark state (1 state) until bit TE is set to 1, set PCR = 1 and PDR = 1. Since bit TE is cleared to 0 at this time, the TXD pin functions as an I/O port and 1 is output. To detect a break during transmission, clear bit TE to 0 after setting PCR = 1 and PDR = 0. When bit TE is cleared to 0, the transmission unit is initialized regardless of the current transmission state, the TXD pin functions as an I/O port, and 0 is output from the TXD pin. ## 14.8.5 Receive Error Flags and Transmit Operation (Synchronous Mode Only) When a receive error flag (OER, PER, or FER) is set to 1, transmission cannot be started even if bit TDRE is cleared to 0. The receive error flags must be cleared to 0 before starting transmission. Note also that receive error flags cannot be cleared to 0 even if bit RE is cleared to 0. # 14.8.6 Receive Data Sampling Timing and Receive Margin in Asynchronous Mode In asynchronous mode, SCI3 operates on a basic clock with a frequency 16 times the transfer rate. When receiving, SCI3 performs internal synchronization by sampling the falling edge of the start bit with the basic clock. Receive data is latched internally at the 8th rising edge of the basic clock. This is illustrated in figure 14.21. Figure 14.21 Receive Data Sampling Timing in Asynchronous Mode Consequently, the receive margin in asynchronous mode can be expressed as shown in equation (1). $$M = \left\{ (0.5 - \frac{1}{2N}) - \frac{D - 0.5}{N} - (L - 0.5) \text{ F} \right\} \times 100(\%) \dots \text{Equation (1)}$$ where N: Ratio of bit rate to clock (N = 16) D: Clock duty (D = 0.5 to 1.0) L: Frame length (L = 9 to 12) F: Absolute value of clock frequency deviation Substituting 0 for F (absolute value of clock frequency deviation) and 0.5 for D (clock duty) in equation (1), a receive margin of 46.875% is given by equation (2). When D = 0.5 and F = 0, $$M = \{0.5 - 1/(2 \times 16)\} \times 100 [\%] = 46.875\%$$ .... Equation (2) However, this is only a computed value, and a margin of 20% to 30% should be allowed when carrying out system design. #### 14.8.7 Relation between RDR Reads and Bit RDRF In a receive operation, SCI3 continually checks the RDRF flag. If bit RDRF is cleared to 0 when reception of one frame ends, normal data reception is completed. If bit RDRF is set to 1, this indicates that an overrun error has occurred. When the contents of RDR are read, bit RDRF is cleared to 0 automatically. Therefore, if bit RDR is read more than once, the second and subsequent read operations will be performed while bit RDRF is cleared to 0. Note that, when an RDR read is performed while bit RDRF is cleared to 0, if the read operation coincides with completion of reception of a frame, the next frame of data may be read. This is illustrated in figure 14.22. Figure 14.22 Relation between RDR Read Timing and Data In this case, only a single RDR read operation (not two or more) should be performed after first checking that bit RDRF is set to 1. If two or more reads are performed, the data read the first time should be transferred to RAM, etc., and the RAM contents used. Also, ensure that there is sufficient margin in an RDR read operation before reception of the next frame is completed. To be precise in terms of timing, the RDR read should be completed before bit 7 is transferred in synchronous mode, or before the STOP bit is transferred in asynchronous mode. # Section 15 I<sup>2</sup>C Bus Interface (IIC) ### 15.1 Overview A two-channel I<sup>2</sup>C bus interface is available for the H8/3664 Series. The I<sup>2</sup>C bus interface conforms to and provides a subset of the Philips I<sup>2</sup>C bus (inter-IC bus) interface functions. The register configuration that controls the I<sup>2</sup>C bus differs partly from the Philips configuration, however. #### 15.1.1 Features - Selection of I<sup>2</sup>C format or synchronous serial format - I<sup>2</sup>C bus format: addressing format with acknowledge bit, for master/slave operation - Synchronous serial format: non-addressing format without acknowledge bit, for master operation only - Conforms to Philips I<sup>2</sup>C bus interface (I<sup>2</sup>C bus format) - Two ways of setting slave address (I<sup>2</sup>C bus format) - Start and stop conditions generated automatically in master mode (I<sup>2</sup>C bus format) - Selection of acknowledge output levels when receiving (I<sup>2</sup>C bus format) - Automatic loading of acknowledge bit when transmitting (I<sup>2</sup>C bus format) - Wait function in master mode (I<sup>2</sup>C bus format) - A wait can be inserted by driving the SCL pin low after data transfer, excluding acknowledgement. The wait can be cleared by clearing the interrupt flag. - Wait function in slave mode (I<sup>2</sup>C bus format) - A wait request can be generated by driving the SCL pin low after data transfer, excluding acknowledgement. The wait request is cleared when the next transfer becomes possible. - Three interrupt sources - Data transfer end (including transmission mode transition with I<sup>2</sup>C bus format and address reception after loss of master arbitration) - Address match: when any slave address matches or the general call address is received in slave receive mode (I<sup>2</sup>C bus format) - Stop condition detection - Selection of 16 internal clocks (in master mode) - Direct bus drive (with SCL and SDA pins) - Two pins—(normally NMOS push-pull outputs) function as NMOS open-drain outputs when the bus drive function is selected. ### 15.1.2 Block Diagram Figure 15.1 shows a block diagram of the I<sup>2</sup>C bus interface. Figure 15.2 shows an example of I/O pin connections to external circuits. The I/O pins are NMOS open drains. Set the upper limit of voltage applied to the power supply ( $V_{CC}$ ) voltage range + 0.3 V, i.e. 5.8 V. Figure 15.1 Block Diagram of I<sup>2</sup>C Bus Interface Figure 15.2 I<sup>2</sup>C Bus Interface Connections (Example: H8/3664 Series Chip as Master) ## 15.1.3 Pin Configuration Table 15.1 summarizes the input/output pins used by the $I^2C$ bus interface. Table 15.1 I<sup>2</sup>C Bus Interface Pins | Name | Abbreviation | I/O | Function | |--------------|--------------|-----|-------------------------------| | Serial clock | SCL | I/O | IIC serial clock input/output | | Serial data | SDA | I/O | IIC serial data input/output | ## 15.1.4 Register Configuration Table 15.2 summarizes the registers of the I<sup>2</sup>C bus interface. **Table 15.2 Register Configuration** | Name | Abbreviation | R/W | Initial Value | Address | |---------------------------------------|--------------|-----|---------------|---------| | I <sup>2</sup> C bus control register | ICCR | R/W | H'01 | H'FFC4 | | I <sup>2</sup> C bus status register | ICSR | R/W | H'00 | H'FFC5 | | I <sup>2</sup> C bus data register | ICDR | R/W | Undefined | H'FFC6* | | I <sup>2</sup> C bus mode register | ICMR | R/W | H'00 | H'FFC7* | | Slave address register | SAR | R/W | H'00 | H'FFC7* | | Second slave address register | SARX | R/W | H'01 | H'FFC6* | | Timer serial control register | TSCR | R/W | H'00 | H'FFFC | Note: \* The register that can be written or read depends on the ICE bit in the I<sup>2</sup>C bus control register. The slave address register can be accessed when ICE = 0, and the I<sup>2</sup>C bus mode register can be accessed when ICE = 1. # 15.2 Register Descriptions # 15.2.1 I<sup>2</sup>C Bus Data Register (ICDR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | | ICDR7 | ICDR6 | ICDR5 | ICDR4 | ICDR3 | ICDR2 | ICDR1 | ICDR0 | | Initial value | | _ | _ | _ | _ | _ | _ | _ | | Read/Write | R/W ## • ICDRR | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|--------|--------|--------|--------| | | ICDRR7 | ICDRR6 | ICDRR5 | ICDRR4 | ICDRR3 | ICDRR2 | ICDRR1 | ICDRR0 | | Initial value | _ | _ | _ | _ | _ | _ | _ | _ | | Read/Write | R | R | R | R | R | R | R | R | ## • ICDRS | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|--------|--------|--------|--------| | | ICDRS7 | ICDRS6 | ICDRR5 | ICDRS4 | ICDRS3 | ICDRS2 | ICDRS1 | ICDRS0 | | Initial value | _ | _ | _ | _ | _ | _ | _ | | | Read/Write | _ | _ | | _ | _ | _ | | _ | ## • ICDRT | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|--------|--------|--------|--------| | | ICDRT7 | ICDRT6 | ICDRT5 | ICDRT4 | ICDRT3 | ICDRT2 | ICDRT1 | ICDRT0 | | Initial value | _ | _ | _ | | _ | _ | _ | _ | | Read/Write | W | W | W | W | W | W | W | W | # • TDRE, RDRF (internal flags) | Bit | | _ | |---------------|------|------| | | TDRE | RDRF | | Initial value | 0 | 0 | | Read/Write | _ | _ | ICDR is an 8-bit readable/writable register that is used as a transmit data register when transmitting and a receive data register when receiving. ICDR is divided internally into a shift register (ICDRS), receive buffer (ICDRR), and transmit buffer (ICDRT). ICDRS cannot be read or written by the CPU, ICDRR is read-only, and ICDRT is write-only. Data transfers among the three registers are performed automatically in coordination with changes in the bus state, and affect the status of internal flags such as TDRE and RDRF. If $I^2C$ is in transmit mode and the next data is in ICDRT (the TDRE flag is 0) following transmission/reception of one frame of data using ICDRS, data is transferred automatically from ICDRT to ICDRS. If IIC is in receive mode and no previous data remains in ICDRR (the RDRF flag is 0) following transmission/reception of one frame of data using ICDRS, data is transferred automatically from ICDRS to ICDRR. If the number of bits in a frame, excluding the acknowledge bit, is less than 8, transmit data and receive data are stored differently. Transmit data should be written justified toward the MSB side when MLS = 0, and toward the LSB side when MLS = 1. Receive data bits read from the LSB side should be treated as valid when MLS = 0, and bits read from the MSB side when MLS = 1. ICDR is assigned to the same address as SARX, and can be written and read only when the ICE bit is set to 1 in ICCR. The value of ICDR is undefined after a reset. When TDRE is 1 and the transmit buffer is empty, TDRE shows that the next transmit data can be written from the CPU. When RDRF is 1, it shows that the valid receive data is stored in the receive buffer. The TDRE and RDRF flags are set and cleared under the conditions shown below. Setting the TDRE and RDRF flags affects the status of the interrupt flags. | TDRE | Description | | | | | | | |------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | [Clearing conditions] | | | | | | | | | <ul> <li>When transmit data is written in ICDR (ICDRT) in transmit mode (TRS = 1)</li> </ul> | | | | | | | | | <ul> <li>When a stop condition is detected in the bus line state after a stop condition is<br/>issued with the I<sup>2</sup>C bus format or serial format selected</li> </ul> | | | | | | | | | <ul> <li>When a stop condition is detected with the I<sup>2</sup>C bus format selected</li> </ul> | | | | | | | | | <ul><li>In receive mode (TRS = 0)</li></ul> | | | | | | | | | (A 0 write to TRS during transfer is valid after reception of a frame containing an acknowledge bit) | | | | | | | | 1 | [Setting conditions] | | | | | | | | | <ul> <li>In transmit mode (TRS = 1), when a start condition is detected in the bus line state after a start condition is issued in master mode with the I<sup>2</sup>C bus format or serial format selected</li> </ul> | | | | | | | | | When data is transferred from ICDRT to ICDRS | | | | | | | | | (Data transfer from ICDRT to ICDRS when TRS = 1 and TDRE = 0, and ICDRS is empty) | | | | | | | | | <ul> <li>When a switch is made from receive mode (TRS = 0) to transmit mode (TRS = 1) after detection of a start condition</li> </ul> | | | | | | | | RDRF | Description | |------|---------------------------------------------------------------------------------------------| | 0 | [Clearing condition] | | | When ICDR (ICDRR) receive data is read in receive mode | | 1 | [Setting condition] | | | When data is transferred from ICDRS to ICDRR | | | (Data transfer from ICDRS to ICDRR in case of normal termination with TRS = 0 and RDRF = 0) | ### 15.2.2 Slave Address Register (SAR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------|------|------|------|------|------|------|------|-----|---| | | SVA6 | SVA5 | SVA4 | SVA3 | SVA2 | SVA1 | SVA0 | FS | | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | | Read/Write | R/W | SAR is an 8-bit readable/writable register that stores the slave address and selects the communication format. When the chip is in slave mode (and the addressing format is selected), if the upper 7 bits of SAR match the upper 7 bits of the first frame received after a start condition, the chip operates as the slave device specified by the master device. SAR is assigned to the same address as ICMR, and can be written and read only when the ICE bit is cleared to 0 in ICCR. SAR is initialized to H'00 by a reset. Bits 7 to 1—Slave Address (SVA6 to SVA0): Set a unique address in bits SVA6 to SVA0, differing from the addresses of other slave devices connected to the I<sup>2</sup>C bus. **Bit 0—Format Select (FS):** Used together with the FSX bit in SARX to select the communication format. The FS bit also specifies whether or not SAR slave address recognition is performed in slave mode. For details on formats, refer to section 15.3.1, I<sup>2</sup>C Bus Data Format. | SARX | | | | | | | |------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit 0: FSX | Operating Mode | | | | | | | 0 | I <sup>2</sup> C bus format | | | | | | | | <ul> <li>SAR and SARX slave addresses recognized</li> </ul> | | | | | | | 1 | I <sup>2</sup> C bus format | (Initial value) | | | | | | | <ul> <li>SAR slave address recognized</li> </ul> | | | | | | | | <ul> <li>SARX slave address ignored</li> </ul> | | | | | | | 0 | I <sup>2</sup> C bus format | | | | | | | | <ul> <li>SAR slave address ignored</li> </ul> | | | | | | | | <ul> <li>SARX slave address recognized</li> </ul> | | | | | | | 1 | Synchronous serial format | | | | | | | | <ul> <li>SAR and SARX slave addresses ignored</li> </ul> | | | | | | | | Bit 0: FSX 0 1 | Bit 0: FSX Operating Mode 0 I²C bus format • SAR and SARX slave addresses recognized 1 I²C bus format • SAR slave address recognized • SARX slave address ignored 0 I²C bus format • SAR slave address ignored • SARX slave address recognized 5 SARX slave address recognized SARX slave address recognized Synchronous serial format | | | | | ### 15.2.3 Second Slave Address Register (SARX) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-----| | | SVAX6 | SVAX5 | SVAX4 | SVAX3 | SVAX2 | SVAX1 | SVAX0 | FSX | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Read/Write | R/W SARX is an 8-bit readable/writable register that stores the second slave address and selects the communication format. When the chip is in slave mode (and the addressing format is selected), if the upper 7 bits of SARX match the upper 7 bits of the first frame received after a start condition, the chip operates as the slave device specified by the master device. SARX is assigned to the same address as ICDR, and can be written and read only when the ICE bit is cleared to 0 in ICCR. SARX is initialized to H'01 by a reset. Bits 7 to 1—Second Slave Address (SVAX6 to SVAX0): Set a unique address in bits SVAX6 to SVAX0, differing from the addresses of other slave devices connected to the I<sup>2</sup>C bus. Bit 0—Format Select X (FSX): Used together with the FS bit in SAR to select the communication format. The FSX bit also specifies whether or not SARX slave address recognition is performed in slave mode. For details, see the description of the FS bit in SAR. ## 15.2.4 I<sup>2</sup>C Bus Mode Register (ICMR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|------|------|------|------|-----|-----|-----| | | MLS | WAIT | CKS2 | CKS1 | CKS0 | BC2 | BC1 | BC0 | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/W ICMR is an 8-bit readable/writable register that selects whether the MSB or LSB is transferred first, performs master mode wait control, and selects the master mode transfer clock frequency and the transfer bit count. ICMR is assigned to the same address as SAR. ICMR can be written and read only when the ICE bit is set to 1 in ICCR. ICMR is initialized to H'00 by a reset. **Bit 7—MSB-First/LSB-First Select (MLS):** Selects whether data is transferred MSB-first or LSB-first. If the number of bits in a frame, excluding the acknowledge bit, is less than 8, transmit data and receive data are stored differently. Transmit data should be written justified toward the MSB side when MLS = 0, and toward the LSB side when MLS = 1. Receive data bits read from the LSB side should be treated as valid when MLS = 0, and bits read from the MSB side when MLS = 1. Do not set this bit to 1 when the I<sup>2</sup>C bus format is used. | Bit 7: MLS | Description | | |------------|-------------|-----------------| | 0 | MSB-first | (Initial value) | | 1 | LSB-first | | **Bit 6—Wait Insertion Bit (WAIT):** Selects whether to insert a wait between the transfer of data and the acknowledge bit, in master mode with the I<sup>2</sup>C bus format. When WAIT is set to 1, after the fall of the clock for the final data bit, the IRIC flag is set to 1 in ICCR, and a wait state begins (with SCL at the low level). When the IRIC flag is cleared to 0 in ICCR, the wait ends and the acknowledge bit is transferred. If WAIT is cleared to 0, data and acknowledge bits are transferred consecutively with no wait inserted. The IRIC flag in ICCR is set to 1 on completion of the acknowledge bit transfer, regardless of the WAIT setting. The setting of this bit is invalid in slave mode. | Bit 6: WAIT | Description | | |-------------|-----------------------------------------------------|-----------------| | 0 | Data and acknowledge bits transferred consecutively | (Initial value) | | 1 | Wait inserted between data and acknowledge bits | | **Bits 5 to 3—Serial Clock Select (CKS2 to CKS0):** These bits, together with the IICX bit in the TSCR register, select the serial clock frequency in master mode. They should be set according to the required transfer rate. | TSCR | | | | | Transfer Rate | | | | | |----------------|----------------|----------------|----------------|-------|---------------|--------------|---------------|---------------|--| | Bit 0:<br>IICX | Bit 5:<br>CKS2 | Bit 4:<br>CKS1 | Bit 3:<br>CKS0 | Clock | ø =<br>5 MHz | ø =<br>8 MHz | ø =<br>10 MHz | ø =<br>16 MHz | | | 0 | 0 | 0 | 0 | ø/28 | 179 kHz | 286 kHz | 357 kHz | 517 kHz | | | | | | 1 | ø/40 | 125 kHz | 200 kHz | 250 kHz | 400 kHz | | | | | 1 | 0 | ø/48 | 104 kHz | 167 kHz | 208 kHz | 333 kHz | | | | | | 1 | ø/64 | 78.1 kHz | 125 kHz | 156 kHz | 250 kHz | | | | 1 | 0 | 0 | ø/80 | 62.5 kHz | 100 kHz | 125 kHz | 200 kHz | | | | | | 1 | ø/100 | 50.0 kHz | 80.0 kHz | 100 kHz | 160 kHz | | | | | 1 | 0 | ø/112 | 44.6 kHz | 71.4 kHz | 89.3 kHz | 143 kHz | | | | | | 1 | ø/128 | 39.1 kHz | 62.5 kHz | 78.1 kHz | 125 kHz | | | 1 | 0 | 0 | 0 | ø/56 | 89.3 kHz | 143 kHz | 179 kHz | 286 kHz | | | | | | 1 | ø/80 | 62.5 kHz | 100 kHz | 125 kHz | 200 kHz | | | | | 1 | 0 | ø/96 | 52.1 kHz | 83.3 kHz | 104 kHz | 167 kHz | | | | | | 1 | ø/128 | 39.1 kHz | 62.5 kHz | 78.1 kHz | 125 kHz | | | | 1 | 0 | 0 | ø/160 | 31.3 kHz | 50.0 kHz | 62.5 kHz | 100 kHz | | | | | | 1 | ø/200 | 25.0 kHz | 40.0 kHz | 50.0 kHz | 80 kHz | | | | | 1 | 0 | ø/224 | 22.3 kHz | 35.7 kHz | 44.6 kHz | 71.4 kHz | | | | | | 1 | ø/256 | 19.5 kHz | 31.3 kHz | 39.1 kHz | 62.5 kHz | | **Bits 2 to 0—Bit Counter (BC2 to BC0):** Bits BC2 to BC0 specify the number of bits to be transferred next. With the I<sup>2</sup>C bus format (when the FS bit in SAR or the FSX bit in SARX is 0), the data is transferred with one addition acknowledge bit. Bit BC2 to BC0 settings should be made during an interval between transfer frames. If bits BC2 to BC0 are set to a value other than 000, the setting should be made while the SCL line is low. The bit counter is initialized to 000 by a reset and when a start condition is detected. The value returns to 000 at the end of a data transfer, including the acknowledge bit. | Bit 2: | Bit 1: | Bit 0: | Bits | /Frame | | |--------|--------|--------|---------------------------|--------|-----------------| | BC2 | BC1 | BC0 | Synchronous Serial Format | | | | 0 | 0 | 0 | 8 | 9 | (Initial value) | | | | 1 | 1 | 2 | | | | 1 | 0 | 2 | 3 | | | | | 1 | 3 | 4 | | | 1 | 0 | 0 | 4 | 5 | | | | | 1 | 5 | 6 | | | | 1 | 0 | 6 | 7 | | | | | 1 | 7 | 8 | | ## 15.2.5 I<sup>2</sup>C Bus Control Register (ICCR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|------|-----|-----|------|------|--------|-----| | | ICE | IEIC | MST | TRS | ACKE | BBSY | IRIC | SCP | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Read/Write | R/W | R/W | R/W | R/W | R/W | R/W | R/(W)* | W | Note: \* Only 0 can be written, to clear the flag. ICCR is an 8-bit readable/writable register that enables or disables the I<sup>2</sup>C bus interface, enables or disables interrupts, selects master or slave mode and transmission or reception, enables or disables acknowledgement, confirms the I<sup>2</sup>C bus interface bus status, issues start/stop conditions, and performs interrupt flag confirmation. ICCR is initialized to H'01 by a reset. **Bit 7—I**<sup>2</sup>C **Bus Interface Enable (ICE):** Selects whether or not the I<sup>2</sup>C bus interface is to be used. When ICE is set to 1, port pins function as SCL and SDA input/output pins and transfer operations are enabled. When ICE is cleared to 0, the I<sup>2</sup>C bus interface module is disabled. The SAR and SARX registers can be accessed when ICE is 0. The ICMR and ICDR registers can be accessed when ICE is 1. | Bit 7: ICE | Description | |------------|-------------------------------------------------------------------------------------------------------------------| | 0 | I <sup>2</sup> C bus interface module disabled, with SCL and SDA signal pins set to port function (Initial value) | | | SAR and SARX can be accessed | | 1 | I <sup>2</sup> C bus interface module enabled for transfer operations (pins SCL and SCA are driving the bus) | | | ICMR and ICDR can be accessed | Bit 6—I<sup>2</sup>C Bus Interface Interrupt Enable (IEIC): Enables or disables interrupts from the I<sup>2</sup>C bus interface to the CPU. | Bit 6: IEIC | Description | | |-------------|---------------------|-----------------| | 0 | Interrupts disabled | (Initial value) | | 1 | Interrupts enabled | | ### Bit 5—Master/Slave Select (MST) ## Bit 4—Transmit/Receive Select (TRS) MST selects whether the I<sup>2</sup>C bus interface operates in master mode or slave mode. TRS selects whether the I<sup>2</sup>C bus interface operates in transmit mode or receive mode. In master mode with the $I^2C$ bus format, when arbitration is lost, MST and TRS are both reset by hardware, causing a transition to slave receive mode. In slave receive mode with the addressing format (FS = 0 or FSX = 0), hardware automatically selects transmit or receive mode according to the R/W bit in the first frame after a start condition. Modification of the TRS bit during transfer is deferred until transfer of the frame containing the acknowledge bit is completed, and the changeover is made after completion of the transfer. MST and TRS select the operating mode as follows. | Bit 5: MST | Bit 4: TRS | Operating Mode | | |------------|------------|----------------------|-----------------| | 0 | 0 | Slave receive mode | (Initial value) | | | 1 | Slave transmit mode | | | 1 | 0 | Master receive mode | | | | 1 | Master transmit mode | | | Bit 5: MST | Description | | | | | | | |------------|---------------------------------------------------------------------------------------------------|-------------|--|--|--|--|--| | 0 | Slave mode (Initia | | | | | | | | | [Clearing conditions] | | | | | | | | | 1. When 0 is written by software | | | | | | | | | 2. When bus arbitration is lost after transmission is started in I <sup>2</sup> C bu | | | | | | | | | master mode | | | | | | | | 1 | Master mode | Master mode | | | | | | | | [Setting conditions] | | | | | | | | | 1. When 1 is written by software (in cases other than clearing cor | ndition 2) | | | | | | | | <ol><li>When 1 is written in MST after reading MST = 0 (in case of cle<br/>condition 2)</li></ol> | aring | | | | | | | Bit 4: TRS | Description | |------------|------------------------------------------------------------------------------------------------------------------------| | 0 | Receive mode (Initial value) | | | [Clearing conditions] | | | 1. When 0 is written by software (in cases other than setting condition 3) | | | <ol><li>When 0 is written in TRS after reading TRS = 1 (in case of clearing<br/>condition 3)</li></ol> | | | 3. When bus arbitration is lost after transmission is started in I <sup>2</sup> C bus format master mode | | 1 | Transmit mode | | | [Setting conditions] | | | <ol> <li>When 1 is written by software (in cases other than clearing conditions 3<br/>and 4)</li> </ol> | | | <ol><li>When 1 is written in TRS after reading TRS = 0 (in case of clearing<br/>conditions 3 and 4)</li></ol> | | | <ol> <li>When a 1 is received as the R/W bit of the first frame in I<sup>2</sup>C bus format<br/>slave mode</li> </ol> | **Bit 3—Acknowledge Bit Judgement Selection (ACKE):** Specifies whether the value of the acknowledge bit returned from the receiving device when using the I<sup>2</sup>C bus format is to be ignored and continuous transfer is performed, or transfer is to be aborted and error handling, etc., performed if the acknowledge bit is 1. When the ACKE bit is 0, the value of the received acknowledge bit is not indicated by the ACKB bit, which is always 0. | Bit 3: ACKE | Description | | |-------------|-----------------------------------------------------------------------------|----------------------------| | 0 | The value of the acknowledge bit is ignored, and continuous tr is performed | ransfer<br>(Initial value) | | 1 | If the acknowledge bit is 1, continuous transfer is interrupted | | **Bit 2—Bus Busy (BBSY):** The BBSY flag can be read to check whether the I<sup>2</sup>C bus (SCL, SDA) is busy or free. In master mode, this bit is also used to issue start and stop conditions. A high-to-low transition of SDA while SCL is high is recognized as a start condition, setting BBSY to 1. A low-to-high transition of SDA while SCL is high is recognized as a stop condition, clearing BBSY to 0. To issue a start condition, use a MOV instruction to write 1 in BBSY and 0 in SCP. A retransmit start condition is issued in the same way. To issue a stop condition, use a MOV instruction to write 0 in BBSY and 0 in SCP. It is not possible to write to BBSY in slave mode; the I<sup>2</sup>C bus interface must be set to master transmit mode before issuing a start condition. MST and TRS should both be set to 1 before writing 1 in BBSY and 0 in SCP. | Bit 2: BBSY | Description | | |-------------|------------------------------------|-----------------| | 0 | Bus is free | (Initial value) | | | [Clearing condition] | | | | When a stop condition is detected | | | 1 | Bus is busy | | | | [Setting condition] | | | | When a start condition is detected | | **Bit 1—I**<sup>2</sup>C **Bus Interface Interrupt Request Flag (IRIC):** Indicates that the I<sup>2</sup>C bus interface has issued an interrupt request to the CPU. IRIC is set to 1 at the end of a data transfer, when a slave address or general call address is detected in slave receive mode, when bus arbitration is lost in master transmit mode, and when a stop condition is detected. IRIC is set at different times depending on the FS bit in SAR and the WAIT bit in ICMR. See section 15.3.6, IRIC Setting Timing and SCL Control. The conditions under which IRIC is set also differ depending on the setting of the ACKE bit in ICCR. IRIC is cleared by reading IRIC after it has been set to 1, then writing 0 in IRIC. When the DTC is used, IRIC is cleared automatically and transfer can be performed continuously without CPU intervention. | Bit 1: IRIC | Description | | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0 | [Clearing conditions] (In | nitial value) | | | 1. When 0 is written in IRIC after reading IRIC = 1 | | | | <ol><li>When ICDR is written or read by the DTC<br/>(When the TDRE or RDRF flag is cleared to 0)</li></ol> | | | | (This is not always a clearing condition; see the description of D operation for details) | TC | | 1 | [Setting conditions] | | | | <ul> <li>I<sup>2</sup>C bus format master mode</li> </ul> | | | | <ol> <li>When a start condition is detected in the bus line state after<br/>condition is issued<br/>(when the TDRE flag is set to 1 because of first frame transr</li> </ol> | | | | <ol><li>When a wait is inserted between the data and acknowledge<br/>WAIT = 1</li></ol> | bit when | | | <ol><li>At the end of data transfer<br/>(when the TDRE or RDRF flag is set to 1)</li></ol> | | | | <ol> <li>When a slave address is received after bus arbitration is lost<br/>(when the AL flag is set to 1)</li> </ol> | t | | | <ol><li>When 1 is received as the acknowledge bit when the ACKE<br/>(when the ACKB bit is set to 1)</li></ol> | bit is 1 | | | <ul> <li>I<sup>2</sup>C bus format slave mode</li> </ul> | | | | <ol> <li>When the slave address (SVA, SVAX) matches<br/>(when the AAS and AASX flags are set to 1)</li> </ol> | | | | and at the end of data transfer up to the subsequent retransistant condition or stop condition detection (when the TDRE or RDRF flag is set to 1) | mission | | | <ol><li>When the general call address is detected<br/>(when the ADZ flag is set to 1)</li></ol> | | | | and at the end of data transfer up to the subsequent retransistant condition or stop condition detection (when the TDRE or RDRF flag is set to 1) | mission | | | <ol><li>When 1 is received as the acknowledge bit when the ACKE<br/>(when the ACKB bit is set to 1)</li></ol> | bit is 1 | | | <ol> <li>When a stop condition is detected<br/>(when the STOP or ESTP flag is set to 1)</li> </ol> | | | | Synchronous serial format | | | | <ol> <li>At the end of data transfer<br/>(when the TDRE or RDRF flag is set to 1)</li> </ol> | | | | 2. When a start condition is detected with serial format selected | <u> </u> | When, with the I<sup>2</sup>C bus format selected, IRIC is set to 1 and an interrupt is generated, other flags must be checked in order to identify the source that set IRIC to 1. Although each source has a corresponding flag, caution is needed at the end of a transfer. When the TDRE or RDRF internal flag is set, the readable IRTR flag may or may not be set. Even when the IRIC flag and IRTR flag are set, the TDRE or RDRF internal flag may not be set. Table 15.3 shows the relationship between the flags and the transfer states. **Table 15.3 Flags and Transfer States** | MST | TRS | BBSY | ESTP | STOP | IRTR | AASX | AL | AAS | ADZ | ACKB | State | |-----|-----|------|------|------|------|------|----|-----|-----|------|--------------------------------------------------------------------| | 1/0 | 1/0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Idle state (flag clearing required) | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Start condition issuance | | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | Start condition established | | 1 | 1/0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0/1 | Master mode wait | | 1 | 1/0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0/1 | Master mode transmit/receive end | | 0 | 0 | 1 | 0 | 0 | 0 | 1/0 | 1 | 1/0 | 1/0 | 0 | Arbitration lost | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | SAR match by first frame in slave mode | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | General call address match | | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | SARX match | | 0 | 1/0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0/1 | Slave mode<br>transmit/receive end<br>(except after SARX<br>match) | | 0 | 1/0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | Slave mode | | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | transmit/receive end (after SARX match) | | 0 | 1/0 | 0 | 1/0 | 1/0 | 0 | 0 | 0 | 0 | 0 | 0/1 | Stop condition detected | **Bit 0—Start Condition/Stop Condition Prohibit (SCP):** Controls the issuing of start and stop conditions in master mode. To issue a start condition, write 1 in BBSY and 0 in SCP. A retransmit start condition is issued in the same way. To issue a stop condition, write 0 in BBSY and 0 in SCP. This bit is always read as 1. If 1 is written, the data is not stored. | Bit 0: SCP | Description | | |------------|----------------------------------------------------------|-------------------------| | 0 | Writing 0 issues a start or stop condition, in combinate | tion with the BBSY flag | | 1 | Reading always returns a value of 1 | (Initial value) | | | Writing is ignored | | ## 15.2.6 I<sup>2</sup>C Bus Status Register (ICSR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|--------|--------|--------|--------|------| | | ESTP | STOP | IRTR | AASX | AL | AAS | ADZ | ACKB | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Read/Write | R/(W)* R/W | Note: \* Only 0 can be written, to clear the flags. ICSR is an 8-bit readable/writable register that performs flag confirmation and acknowledge confirmation and control. ICSR is initialized to H'00 by a reset. **Bit 7—Error Stop Condition Detection Flag (ESTP):** Indicates that a stop condition has been detected during frame transfer in I<sup>2</sup>C bus format slave mode. | Bit 7: ESTP | Description | |-------------|---------------------------------------------------------| | 0 | [Clearing conditions] | | | 1. When 0 is written in ESTP after reading ESTP = 1 | | | 2. When the IRIC flag is cleared to 0 | | 1 | [Setting conditions] | | | In I <sup>2</sup> C bus format slave mode | | | When a stop condition is detected during frame transfer | | | In other modes | | | No meaning | **Bit 6—Normal Stop Condition Detection Flag (STOP):** Indicates that a stop condition has been detected after completion of frame transfer in I<sup>2</sup>C bus format slave mode. | Bit 6: STOP | Description | |-------------|----------------------------------------------------------------------| | 0 | [Clearing conditions] | | | 1. When 0 is written in STOP after reading STOP = 1 | | | 2. When the IRIC flag is cleared to 0 | | 1 | [Setting conditions] | | | <ul> <li>In I<sup>2</sup>C bus format slave mode</li> </ul> | | | When a stop condition is detected after completion of frame transfer | | | In other modes | | | No meaning | Bit 5—I<sup>2</sup>C Bus Interface Continuous Transmission/Reception Interrupt Request Flag (IRTR): Indicates that the I<sup>2</sup>C bus interface has issued an interrupt request to the CPU, and the source is completion of reception/transmission of one frame in continuous transmission/reception. When the IRTR flag is set to 1, the IRIC flag is also set to 1 at the same time. IRTR flag setting is performed when the TDRE or RDRF flag is set to 1. IRTR is cleared by reading IRTR after it has been set to 1, then writing 0 in IRTR. IRTR is also cleared automatically when the IRIC flag is cleared to 0. | Bit 5: IRTR | Description | | | | | |-------------|----------------------------------------------------------------|--|--|--|--| | 0 | Waiting for transfer, or transfer in progress | | | | | | | [Clearing conditions] | | | | | | | 1. When 0 is written in IRTR after reading IRTR = 1 | | | | | | | 2. When the IRIC flag is cleared to 0 | | | | | | 1 | Continuous transfer state | | | | | | | [Setting conditions] | | | | | | | <ul> <li>In I<sup>2</sup>C bus interface slave mode</li> </ul> | | | | | | | When the TDRE or RDRF flag is set to 1 when AASX = 1 | | | | | | | In other modes | | | | | | | When the TDRE or RDRF flag is set to 1 | | | | | **Bit 4—Second Slave Address Recognition Flag (AASX):** In I<sup>2</sup>C bus format slave receive mode, this flag is set to 1 if the first frame following a start condition matches bits SVAX6 to SVAX0 in SARX. AASX is cleared by reading AASX after it has been set to 1, then writing 0 in AASX. AASX is also cleared automatically when a start condition is detected. | Bit 4: AASX | Description | | | | | |-------------|----------------------------------------------------------------------|-----------------|--|--|--| | 0 | [Clearing conditions] | (Initial value) | | | | | | 1. When 0 is written in AASX after reading AASX = 1 | | | | | | | 2. When a start condition is detected | | | | | | | 3. In master mode | | | | | | 1 | [Setting condition] | | | | | | | When the second slave address is detected in slave receive $FSX = 0$ | mode and | | | | Bit 3—Arbitration Lost (AL): This flag indicates that arbitration was lost in master mode. The $I^2C$ bus interface monitors the bus. When two or more master devices attempt to seize the bus at nearly the same time, if the $I^2C$ bus interface detects data differing from the data it sent, it sets AL to 1 to indicate that the bus has been taken by another master. AL is cleared by reading AL after it has been set to 1, then writing 0 in AL. In addition, AL is reset automatically by write access to ICDR in transmit mode, or read access to ICDR in receive mode. | Bit 3: AL | Description | |-----------|-------------------------------------------------------------------------------------------------------------| | 0 | [Clearing conditions] | | | 1. When ICDR data is written (transmit mode) or read (receive mode) | | | 2. When 0 is written in AL after reading AL = 1 | | 1 | [Setting conditions] | | | <ol> <li>If the internal SDA and SDA pin disagree at the rise of SCL in master<br/>transmit mode</li> </ol> | | | 2. If the internal SCL line is high at the fall of SCL in master transmit mode | **Bit 2—Slave Address Recognition Flag (AAS):** In I<sup>2</sup>C bus format slave receive mode, this flag is set to 1 if the first frame following a start condition matches bits SVA6 to SVA0 in SAR, or if the general call address (H'00) is detected. AAS is cleared by reading AAS after it has been set to 1, then writing 0 in AAS. In addition, AAS is reset automatically by write access to ICDR in transmit mode, or read access to ICDR in receive mode. | Bit 2: AAS | Description | |------------|-----------------------------------------------------------------------------------------------| | 0 | [Clearing conditions] | | | 1. When ICDR data is written (transmit mode) or read (receive mode) | | | 2. When 0 is written in AAS after reading AAS = 1 | | | 3. In master mode | | 1 | [Setting condition] | | | When the slave address or general call address is detected in slave receive mode and $FS = 0$ | Bit 1—General Call Address Recognition Flag (ADZ): In I<sup>2</sup>C bus format slave receive mode, this flag is set to 1 if the first frame following a start condition is the general call address (H'00). ADZ is cleared by reading ADZ after it has been set to 1, then writing 0 in ADZ. In addition, ADZ is reset automatically by write access to ICDR in transmit mode, or read access to ICDR in receive mode. | Bit 1: ADZ | Description | | | | |------------|-----------------------------------------------------------------------------------------|--|--|--| | 0 | [Clearing conditions] | | | | | | 1. When ICDR data is written (transmit mode) or read (receive mode) | | | | | | 2. When 0 is written in ADZ after reading ADZ = 1 | | | | | | 3. In master mode | | | | | 1 | [Setting condition] | | | | | | When the general call address is detected in slave receive mode and (FSX = 0 or FS = 0) | | | | **Bit 0—Acknowledge Bit (ACKB):** Stores acknowledge data. In transmit mode, after the receiving device receives data, it returns acknowledge data, and this data is loaded into ACKB. In receive mode, after data has been received, the acknowledge data set in this bit is sent to the transmitting device. When this bit is read, in transmission (when TRS = 1), the value loaded from the bus line (returned by the receiving device) is read. In reception (when TRS = 0), the value set by internal software is read. | Bit 0: ACKB | Description | | | | | | |-------------|----------------------------------------------------------------------------------|------------------|--|--|--|--| | 0 | Receive mode: 0 is output at acknowledge output timing (Initial value) | | | | | | | | Transmit mode: Indicates that the receiving device has acknown (signal is 0) | wledged the data | | | | | | 1 | Receive mode: 1 is output at acknowledge output timing | | | | | | | | Transmit mode: Indicates that the receiving device has not ac data (signal is 1) | knowledged the | | | | | #### 15.2.7 Timer Serial Control Register (TSCR) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------|---|---|---|---|---|---|--------|------|---| | | _ | _ | _ | _ | _ | _ | IICRST | IICX | ] | | Initial value | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | _ | | Read/Write | _ | _ | _ | _ | _ | _ | R/W | R/W | | TSCR is an 8-bit readable/writable register that controls, the I<sup>2</sup>C interface operating mode. TSCR is initialized to H'FC by a reset. Bits 7 to 2—Reserved: Reserved bits. **Bit 1—I<sup>2</sup>C Control Unit Reset (IICRST):** Resets the control unit except for the I<sup>2</sup>C registers. When a hang up occurs due to illegal communication during I<sup>2</sup>C operation, setting IICRST to 1 can set a port or reset the I<sup>2</sup>C control unit without initializing rregisters. Bit 0—I<sup>2</sup>C Transfer Rate Select (IICX): This bit, together with bits CKS2 to CKS0 in ICMR, selects the transfer rate in master mode. For details, see section 15.2.4, I<sup>2</sup>C Bus Mode Register (ICMR). ## 15.3 Operation #### 15.3.1 I<sup>2</sup>C Bus Data Format The I<sup>2</sup>C bus interface has serial and I<sup>2</sup>C bus formats. The I<sup>2</sup>C bus formats are addressing formats and an acknowledge bit is inserted. These are shown in figures 15.3 (a) and (b). The first frame following a start condition always consists of 8 bits. The serial format is a non-addressing format with no acknowledge bit. This is shown in figure 15.4. Figure 15.5 shows the I<sup>2</sup>C bus timing. The symbols used in figures 15.3 to 15.5 are explained in table 15.4. Figure 15.3 I<sup>2</sup>C Bus Data Formats (I<sup>2</sup>C Bus Formats) Figure 15.4 I<sup>2</sup>C Bus Data Format (Serial Format) Figure 15.5 I<sup>2</sup>C Bus Timing Table 15.4 I<sup>2</sup>C Bus Data Format Symbols | S | Start condition. The master device drives SDA from high to low while SCL is high | |------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SLA | Slave address, by which the master device selects a slave device | | R/W | Indicates the direction of data transfer: from the slave device to the master device when $R/\overline{W}$ is 1, or from the master device to the slave device when $R/\overline{W}$ is 0 | | A | Acknowledge. The receiving device (the slave in master transmit mode, or the master in master receive mode) drives SDA low to acknowledge a transfer | | DATA | Transferred data. The bit length is set by bits BC2 to BC0 in ICMR. The MSB-first or LSB-first format is selected by bit MLS in ICMR | | P | Stop condition. The master device drives SDA from low to high while SCL is high | ### 15.3.2 Master Transmit Operation In I<sup>2</sup>C bus format master transmit mode, the master device outputs the transmit clock and transmit data, and the slave device returns an acknowledge signal. The transmission procedure and operations synchronize with the ICDR writing are described below. - [1] Set the ICE bit in ICCR to 1. Set bits MLS, WAIT, and CKS2 to CKS0 in ICMR, and bit IICX in TSCR, according to the operating mode. - [2] Read the BBSY flag in ICCR to confirm that the bus is free. - [3] Set bits MST and TRS to 1 in ICCR to select master transmit mode. - [4] Write 1 to BBSY and 0 to SCP. This changes SDA from high to low when SCL is high, and generates the start condition. - [5] Then IRIC and IRTR flags are set to 1. If the IEIC bit in ICCR has been set to 1, an interrupt request is sent to the CPU. - [6] Write the data (slave address + R/W) to ICDR. With the I<sup>2</sup>C bus format (when the FS bit in SAR or the FSX bit in SARX is 0), the first frame data following the start condition indicates the 7-bit slave address and transmit/receive direction. As indicating the end of the transfer, and so the IRIC flag is cleared to 0. After writing ICDR, clear IRIC immediately not to execute other interrupt handling routine. If one frame of data has been transmitted before the IRIC clearing, it can not be determine the end of transmission. The master device - sequentially sends the transmission clock and the data written to ICDR using the timing shown in figure 3.1. The selected slave device (i.e. the slave device with the matching slave address) drives SDA low at the 9th transmit clock pulse and returns an acknowledge signal. - [7] When one frame of data has been transmitted, the IRIC flag is set to 1 at the rise of the 9th transmit clock pulse. After one frame has been transmitted SCL is automatically fixed low in synchronization with the internal clock until the next transmit data is written. - [8] Read the ACKB bit in ICSR to confirm that ACKB is cleared to 0. When the slave device has not acknowledged (ACKB bit is 1), operate the step [12] to end transmission, and retry the transmit operation. - [9] Write the transmit data to ICDR. As indicating the end of the transfer, and so the IRIC flag is cleared to 0. After writing ICDR, clear IRIC immediately not to execute other interrupt handling routine. The master device sequentially sends the transmission clock and the data written to ICDR. Transmission of the next frame is performed in synchronization with the internal clock. - [10] When one frame of data has been transmitted, the IRIC flag is set to 1 at the rise of the 9th transmit clock pulse. After one frame has been transmitted SCL is automatically fixed low in synchronization with the internal clock until the next transmit data is written. - [11] Read the ACKB bit in ICSR and confirm ACKB is cleared to 0. When there is data to be transmitted, go to the step [9] to continue next transmission. When the slave device has not acknowledged (ACKB bit is set to 1), operate the step [12] to end transmission. - [12] Clear the IRIC flag to 0. And write 0 to BBSY and SCP in ICCR. This changes SDA from low to high when SCL is high, and generates the stop condition. Figure 15.6 Example of Master Transmit Mode Operation Timing (MLS = WAIT = 0) ### 15.3.3 Master Receive Operation In master receive mode, the master device outputs the receive clock, receives data, and returns an acknowledge signal. The slave device transmits data. The reception procedure and operations with the wait function in master receive mode are described below. - [1] Clear the TRS bit in ICCR to 0 to switch from transmit mode to receive mode, and set the WAIT bit in ICMR to 1. Also clear the bit in ICSR to ACKB 0 (acknowledge data setting). - [2] When ICDR is read (dummy data read), reception is started, and the receive clock is output, and data received, in synchronization with the internal clock. In order to detect wait operation, set the IRIC flag in ICCR must be cleared to 0. After reading ICDR, clear IRIC immediately not to execute other interrupt handling routine. If one frame of data has been received before the IRIC clearing, it can not be determine the end of reception. - [3] The IRIC flag is set to 1 at the fall of the 8th receive clock pulse. If the IEIC bit in ICCR has been set to 1, an interrupt request is sent to the CPU. SCL is automatically fixed low in synchronization with the internal clock until the IRIC flag clearing. If the first frame is the last receive data, execute step [10] to halt reception. - [4] Clear the IRIC flag to release from the Wait State. The master device outputs the 9th clock and drives SDA at the 9th receive clock pulse to return an acknowledge signal. - [5] When one frame of data has been received, the IRIC flag in ICCR and the IRTR flag in ICSR are set to 1 at the rise of the 9th receive clock pulse. The master device outputs SCL clock to receive next data. - [6] Read ICDR. - [7] Clear the IRIC flag to detect next wait operation. Data reception process from [5] to [7] should be executed during one byte reception period after IRIC flag clearing in [4] or [9] to release wait status. - [8] The IRIC flags set to 1 at the fall of 8th receive clock pulse. SCL is automatically fixed low in synchronization with the internal clock until the IRIC flag clearing. If this frame is the last receive data, execute step [10] to halt reception. - [9] Clear the IRIC flag in ICCR to cancel wait operation. The master device outputs the 9th clock and drives SDA at the 9th receive clock pulse to return an ackowledge signal. Data can be received continuously by repeating step [5] to [9]. - [10] Set the ACKB bit in ICSR to 1 so as to return "No acknowledge" data. Also set the TRS bit to 1 to switch from receive mode to transmit mode. - [11] Clear IRIC flag to 0 to release from the Wait State. - [12] When one frame of data has been received, the IRIC flag is set to 1 at the rise of the 9th receive clock pulse. - [13] Clear the WAIT bit to 0 to switch from wait mode to no wait mode. Read ICDR and the IRIC flag to 0. Clearing of the IRIC flag should be after the WAIT = 0. - [14] Clear the BBSY bit and SCP bit to 0. This changes SDA from low to high when SCL is high, and generates the stop condition. Figure 15.7 Example of Master Receive Mode Operation Timing (1) (NLS = ACKB = 0, WAIT = 1) Figure 15.7 Example of Master Receive Mode Operation Timing (2) (MLS = ACKB = 0, WAIT = 1) #### 15.3.4 Slave Receive Operation In slave receive mode, the master device outputs the transmit clock and transmit data, and the slave device returns an acknowledge signal. The reception procedure and operations in slave receive mode are described below. - [1] Set the ICE bit in ICCR to 1. Set the MLS bit in ICMR and the MST and TRS bits in ICCR according to the operating mode. - [2] When the start condition output by the master device is detected, the BBSY flag in ICCR is set to 1. - [3] When the slave address matches in the first frame following the start condition, the device operates as the slave device specified by the master device. If the 8th data bit $(R/\overline{W})$ is 0, the TRS bit in ICCR remains cleared to 0, and slave receive operation is performed. - [4] At the 9th clock pulse of the receive frame, the slave device drives SDA low and returns an acknowledge signal. At the same time, the IRIC flag in ICCR is set to 1. If the IEIC bit in ICCR has been set to 1, an interrupt request is sent to the CPU. If the RDRF internal flag has been cleared to 0, it is set to 1, and the receive operation continues. If the RDRF internal flag has been set to 1, the slave device drives SCL low from the fall of the receive clock until data is read into ICDR. - [5] Read ICDR and clear the IRIC flag in ICCR to 0. The RDRF flag is cleared to 0. Receive operations can be performed continuously by repeating steps [4] and [5]. When SDA is changed from low to high when SCL is high, and the stop condition is detected, the BBSY flag in ICCR is cleared to 0. Figure 15.8 Example of Slave Receive Mode Operation Timing (1) (MLS = ACKB = 0) Figure 15.9 Example of Slave Receive Mode Operation Timing (2) (MLS = ACKB = 0) ## 15.3.5 Slave Transmit Operation In slave transmit mode, the slave device outputs the transmit data, while the master device outputs the receive clock and returns an acknowledge signal. The transmission procedure and operations in slave transmit mode are described below. - [1] Set the ICE bit in ICCR to 1. Set the MLS bit in ICMR and the MST and TRS bits in ICCR according to the operating mode. - [2] When the slave address matches in the first frame following detection of the start condition, the slave device drives SDA low at the 9th clock pulse and returns an acknowledge signal. At the same time, the IRIC flag in ICCR is set to 1. If the IEIC bit in ICCR has been set to 1, an interrupt request is sent to the CPU. If the 8th data bit (R/W) is 1, the TRS bit in ICCR is set to 1, and the mode changes to slave transmit mode automatically. The TDRE internal flag is set to 1. The slave device drives SCL low from the fall of the transmit clock until ICDR data is written. - [3] After clearing the IRIC flag to 0, write data to ICDR. The TDRE internal flag is cleared to 0. The written data is transferred to ICDRS, and the TDRE internal flag and the IRIC and IRTR flags are set to 1 again. After clearing the IRIC flag to 0, write the next data to ICDR. The - slave device sequentially sends the data written into ICDR in accordance with the clock output by the master device at the timing shown in figure 15.10. - [4] When one frame of data has been transmitted, the IRIC flag in ICCR is set to 1 at the rise of the 9th transmit clock pulse. If the TDRE internal flag has been set to 1, this slave device drives SCL low from the fall of the transmit clock until data is written to ICDR. The master device drives SDA low at the 9th clock pulse, and returns an acknowledge signal. As this acknowledge signal is stored in the ACKB bit in ICSR, this bit can be used to determine whether the transfer operation was performed normally. When the TDRE internal flag is 0, the data written into ICDR is transferred to ICDRS, transmission is started, and the TDRE internal flag and the IRIC and IRTR flags are set to 1 again. - [5] To continue transmission, clear the IRIC flag to 0, then write the next data to be transmitted into ICDR. The TDRE flag is cleared to 0. Transmit operations can be performed continuously by repeating steps [4] and [5]. To end transmission, write H'FF to ICDR. When SDA is changed from low to high when SCL is high, and the stop condition is detected, the BBSY flag in ICCR is cleared to 0. Figure 15.10 Example of Slave Transmit Mode Operation Timing (MLS = 0) ### 15.3.6 IRIC Setting Timing and SCL Control The interrupt request flag (IRIC) is set at different times depending on the WAIT bit in ICMR, the FS bit in SAR, and the FSX bit in SARX. If the TDRE or RDRF internal flag is set to 1, SCL is automatically held low after one frame has been transferred; this timing is synchronized with the internal clock. Figure 15.11 shows the IRIC set timing and SCL control. Figure 15.11 IRIC Setting Timing and SCL Control #### 15.3.7 Noise Canceler The logic levels at the SCL and SDA pins are routed through noise cancelers before being latched internally. Figure 15.12 shows a block diagram of the noise canceler circuit. The noise canceler consists of two cascaded latches and a match detector. The SCL (or SDA) input signal is sampled on the system clock, but is not passed forward to the next circuit unless the outputs of both latches agree. If they do not agree, the previous value is held. Figure 15.12 Block Diagram of Noise Canceler ## 15.3.8 Sample Flowcharts Figures 15.13 to 15.16 show sample flowcharts for using the I<sup>2</sup>C bus interface in each mode. Figure 15.13 Flowchart for Master Transmit Mode (Example) Figure 15.14 Flowchart for Master Receive Mode (Example) Figure 15.15 Flowchart for Slave Receive Mode (Example) Figure 15.16 Flowchart for Slave Transmit Mode (Example) ## 15.4 Usage Notes - In master mode, if an instruction to generate a start condition is immediately followed by an instruction to generate a stop condition, neither condition will be output correctly. To output consecutive start and stop conditions, after issuing the instruction that generates the start condition, read the relevant ports, check that SCL and SDA are both low, then issue the instruction that generates the stop condition. Note that SCL may not yet have gone low when BBSY is cleared to 0. - Either of the following two conditions will start the next transfer. Pay attention to these conditions when reading or writing to ICDR. - Write access to ICDR when ICE = 1 and TRS = 1 (including automatic transfer from ICDRT to ICDRS) - Read access to ICDR when ICE = 1 and TRS = 0 (including automatic transfer from ICDRS to ICDRR) - Table 15.5 shows the timing of SCL and SDA output in synchronization with the internal clock. Timings on the bus are determined by the rise and fall times of signals affected by the bus load capacitance, series resistance, and parallel resistance. Table 15.5 I<sup>2</sup>C Bus Timing (SCL and SDA Output) | Item | Symbol | <b>Output Timing</b> | Unit | Notes | |--------------------------------------------------|--------------------|-------------------------------------------|------|-------| | SCL output cycle time | t <sub>SCLO</sub> | 28t <sub>cyc</sub> to 256t <sub>cyc</sub> | ns | | | SCL output high pulse width | t <sub>SCLHO</sub> | 0.5t <sub>SCLO</sub> | ns | - | | SCL output low pulse width | t <sub>SCLLO</sub> | 0.5t <sub>SCLO</sub> | ns | - | | SDA output bus free time | t <sub>BUFO</sub> | $0.5t_{SCLO} - 1t_{cyc}$ | ns | • | | Start condition output hold time | t <sub>STAHO</sub> | $0.5t_{SCLO} - 1t_{cyc}$ | ns | - | | Retransmission start condition output setup time | t <sub>STASO</sub> | 1t <sub>sclo</sub> | ns | - | | Stop condition output setup time | t <sub>stoso</sub> | $0.5t_{SCLO} + 2t_{cyc}$ | ns | - | | Data output setup time (master) | t <sub>SDASO</sub> | $1t_{\text{SCLLO}} - 3t_{\text{cyc}}$ | ns | • | | Data output setup time (slave) | _ | $1t_{\text{SCLL}} - 3t_{\text{cyc}}$ | ns | - | | Data output hold time | t <sub>SDAHO</sub> | 3t <sub>cyc</sub> | ns | • | - SCL and SDA inputs are sampled in synchronization with the internal clock. The AC timing therefore depends on the system clock cycle t<sub>cyc</sub>, as shown in table 17.4 in section 17, Electrical Characteristics. Note that the I<sup>2</sup>C bus interface AC timing specifications will not be met with a system clock frequency of less than 5 MHz. - The I<sup>2</sup>C bus interface specification for the SCL rise time t<sub>sr</sub> is under 1000 ns (300 ns for high-speed mode). In master mode, the I<sup>2</sup>C bus interface monitors the SCL line and synchronizes one bit at a time during communication. If t<sub>sr</sub> (the time for SCL to go from low to V<sub>IH</sub>) exceeds the time determined by the input clock of the I<sup>2</sup>C bus interface, the high period of SCL is extended. The SCL rise time is determined by the pull-up resistance and load capacitance of the SCL line. To insure proper operation at the set transfer rate, adjust the pull-up resistance and load capacitance so that the SCL rise time does not exceed the values given in the table below. Table 15.6 Permissible SCL Rise Time (t<sub>sr</sub>) Values | | | | Time Indication | | | | | | |------|--------------------------------|-----------------|-------------------------------------------------|--------------|--------------|---------------|---------------|--| | IICX | t <sub>cyc</sub><br>Indication | | I <sup>2</sup> C Bus<br>Specification<br>(Max.) | ø =<br>5 MHz | ø =<br>8 MHz | ø =<br>10 MHz | ø =<br>16 MHz | | | 0 | 7.5t <sub>cyc</sub> | Normal mode | 1000 ns | 1000 ns | 937 ns | 750 ns | 468 ns | | | | | High-speed mode | 300 ns | 300 ns | 300 ns | 300 ns | 300 ns | | | 1 | 17.5t <sub>cyc</sub> | Normal mode | 1000 ns | 1000 ns | 1000 ns | 1000 ns | 1000 ns | | | | | High-speed mode | 300 ns | 300 ns | 300 ns | 300 ns | 300 ns | | • The I<sup>2</sup>C bus interface specifications for the SCL and SDA rise and fall times are under 1000 ns and 300 ns. The I<sup>2</sup>C bus interface SCL and SDA output timing is prescribed by t<sub>Scyc</sub> and t<sub>cyc</sub>, as shown in table 15.6. However, because of the rise and fall times, the I<sup>2</sup>C bus interface specifications may not be satisfied at the maximum transfer rate. Table 15.8 shows output timing calculations for different operating frequencies, including the worst-case influence of rise and fall times. $t_{BUFO}$ fails to meet the $I^2C$ bus interface specifications at any frequency. The solution is either (a) to provide coding to secure the necessary interval (approximately 1 $\mu$ s) between issuance of a stop condition and issuance of a start condition, or (b) to select devices whose input timing permits this output timing for use as slave devices connected to the $I^2C$ bus. $t_{SCLLO}$ in high-speed mode and $t_{STASO}$ in standard mode fail to satisfy the $I^2C$ bus interface specifications for worst-case calculations of $t_{Sr}/t_{Sr}$ . Possible solutions that should be investigated include (a) adjusting the rise and fall times by means of a pull-up resistor and capacitive load, (b) reducing the transfer rate to meet the specifications, or (c) selecting devices whose input timing permits this output timing for use as slave devices connected to the $I^2C$ bus. Table 15.7 I<sup>2</sup>C Bus Timing (with Maximum Influence of $t_{Sr}/t_{Sf}$ ) #### Time Indication (at Maximum Transfer Rate) [ns] | | | | t <sub>sr</sub> /t <sub>sf</sub><br>Influence | I <sup>2</sup> C Bus<br>Specifi-<br>cation | ø= | ø = | ø = | ø = | |--------------------------------|---------------------------------------------|-----------------|-----------------------------------------------|--------------------------------------------|--------------------|--------------------|--------------------|--------------------| | Item | t <sub>cyc</sub> Indication | 1 | (Max.) | (Min.) | 5 MHz | 8 MHz | 10 MHz | 16 MHz | | $t_{\scriptsize \text{SCLHO}}$ | $0.5t_{\text{SCLO}}$ (- $t_{\text{Sr}}$ ) | Standard mode | -1000 | 4000 | 4000 | 4000 | 4000 | 4000 | | | | High-speed mode | -300 | 600 | 950 | 950 | 950 | 950 | | t <sub>SCLLO</sub> | 0.5t <sub>SCLO</sub> (-t <sub>Sf</sub> ) | Standard mode | -250 | 4700 | 4750 | 4750 | 4750 | 4750 | | | | High-speed mode | -250 | 1300 | 1000*1 | 1000*1 | 1000*1 | 1000*1 | | t <sub>BUFO</sub> | 0.5t <sub>SCLO</sub> -1t <sub>cyc</sub> | Standard mode | -1000 | 4700 | 3800* <sup>1</sup> | 3875* <sup>1</sup> | 3900* <sup>1</sup> | 3938* <sup>1</sup> | | | $(-t_{Sr})$ | High-speed mode | -300 | 1300 | 750*1 | 825*1 | 850*1 | 888*1 | | t <sub>STAHO</sub> | $0.5t_{SCLO}-1t_{cyc} (-t_{Sf})$ | Standard mode | -250 | 4000 | 4550 | 4625 | 4650 | 4688 | | | | High-speed mode | -250 | 600 | 800 | 875 | 900 | 938 | | t <sub>STASO</sub> | 1t <sub>SCLO</sub> (-t <sub>Sr</sub> ) | Standard mode | -1000 | 4700 | 9000 | 9000 | 9000 | 9000 | | | | High-speed mode | -300 | 600 | 2200 | 2200 | 2200 | 2200 | | t <sub>STOSO</sub> | $0.5t_{SCLO} + 2t_{cyc}$ $(-t_{Sr})$ | Standard mode | -1000 | 4000 | 4400 | 4250 | 4200 | 4125 | | | | High-speed mode | -300 | 600 | 1350 | 1200 | 1150 | 1075 | | t <sub>SDASO</sub> | $1t_{SCLLO}^{*2} - 3t_{cyc}$ $(-t_{Sr}^{})$ | Standard mode | -1000 | 250 | 3100 | 3325 | 3400 | 3513 | | (master) | | High-speed mode | -300 | 100 | 400 | 625 | 700 | 813 | | t <sub>SDASO</sub> (slave) | $1t_{SCLL}^{*2} - 3t_{cyc}$<br>$(-t_{Sr})$ | Standard mode | -1000 | 250 | 3100 | 3325 | 2400 | 3513 | | | | High-speed mode | -300 | 100 | 400 | 625 | 700 | 813 | | t <sub>SDAHO</sub> | 3t <sub>cyc</sub> | Standard mode | 0 | 0 | 600 | 375 | 300 | 188 | | | | High-speed mode | 0 | 0 | 600 | 375 | 300 | 188 | Notes: 1. Does not meet the I<sup>2</sup>C bus interface specification. Remedial action such as the following is necessary: (a) secure a start/stop condition issuance interval; (b) adjust the rise and fall times by means of a pull-up resistor and capacitive load; (c) reduce the transfer rate; (d) select slave devices whose input timing permits this output timing. The values in the above table will vary depending on the settings of the IICX bit and bits CKS0 to CKS2. Depending on the frequency it may not be possible to achieve the maximum transfer rate; therefore, whether or not the I<sup>2</sup>C bus interface specifications are met must be determined in accordance with the actual setting conditions. 2. Calculated using the I<sup>2</sup>C bus specification values (standard mode: 4700 ns min.; high-speed mode: 1300 ns min.). • Note on ICDR Read at end of Master Reception To halt reception after completion of a receive operation in master receive mode, set the TRS bit to 1 and write 0 to BBSY and SCP in ICCR. This changes the SDA pin from low to high when the SCL pin is high, and generates the stop condition. After this, receive data can be read by means of an ICDR read, but if data remains in the buffer the ICDRS receive data will not be transferred to ICDR, and so it will not be possible to read the second byte of data. If it is necessary to read the second byte of data, issue the stop condition in master receive mode (i.e. with the TRS bit cleared to 0). When reading the receive data, first confirm that the BBSY bit in ICCR is cleared to 0, the stop condition has been generated, and the bus has been released, then read ICDR with TRS cleared to 0. Note that if the receive data (ICDR data) is read in the interval between execution of the instruction for issuance of the stop condition (writing of 0 to BBSY and SCP in ICCR) and the actual generation of the stop condition, the clock may not be output correctly in subsequent master transmission. • Notes on Start Condition Issuance for Retransmission Depending on the timing combination with the start condition issuance and the subsequently writing data to ICDR, it may not be possible to issue the retransmission and the data transmission after retransmission condition issuance. After start condition issuance is done and determined the start condition, write the transmit data to ICDR, as shown below. Figure 15.17 shows the timing of start condition issuance for retransmission, and the timing for subsequently writing data to ICDR, together with the corresponding flowchart. Figure 15.17 Flowchart and Timing of Start Condition Instruction Issuance for Retransmission ## Section 16 A/D Converter #### 16.1 Overview The H8/3664 Series includes a 10-bit successive-approximations A/D converter with a selection of up to eight analog input channels. When the A/D converter is not used, it can be halted independently to conserve power. For details see section 6.10, Module Standby Mode. #### 16.1.1 Features A/D converter features are listed below. - 10-bit resolution - Eight input channels (for 42-pin type: four input channels) - High-speed conversion Conversion time: minimum 4.4 µs per channel (with 16 MHz system clock) - Two operating modes - Single mode: A/D conversion of one channel - Scan mode: continuous A/D conversion on one to four channels - Four 16-bit data registers - A/D conversion results are transferred for storage into data registers corresponding to the channels. - Sample-and-hold function - Two conversion start sources - The A/D converter can be activated by software or an external trigger. - A/D interrupt requested at end of conversion - At the end of A/D conversion, an A/D end interrupt (ADI) can be requested. ### 16.1.2 Block Diagram Figure 16.1 shows a block diagram of the A/D converter. Figure 16.1 A/D Converter Block Diagram ## 16.1.3 Input Pins Table 16.1 summarizes the A/D converter's input pins. The eight analog input pins are divided into two groups: group 0 (AN0 to AN3), and group 1 (AN4 to AN7). $AV_{CC}$ is the power supply for the analog circuits in the A/D converter. Table 16.1 A/D Converter Pins | Pin Name | Abbrevi-<br>ation | I/O | Function | |--------------------------------|-------------------|-------|----------------------------------------------------| | Analog power supply pin | $AV_{cc}$ | Input | Analog power supply | | Analog input pin 0 | AN0 | Input | Group 0 analog inputs | | Analog input pin 1 | AN1 | Input | _ | | Analog input pin 2 | AN2 | Input | - | | Analog input pin 3 | AN3 | Input | - | | Analog input pin 4 | AN4 | Input | Group 1 analog inputs | | Analog input pin 5 | AN5 | Input | - | | Analog input pin 6 | AN6 | Input | _ | | Analog input pin 7 | AN7 | Input | - | | A/D external trigger input pin | ADTRG | Input | External trigger input for starting A/D conversion | ### 16.1.4 Register Configuration Table 16.2 summarizes the A/D converter's registers. Table 16.2 A/D Converter Registers | Address | Name | Abbreviation | R/W | Initial Value | |---------|-----------------------------|--------------|--------|---------------| | H'FFFB0 | A/D data register A H | ADDRAH | R | H'00 | | H'FFFB1 | A/D data register A L | ADDRAL | R | H'00 | | H'FFFB2 | A/D data register B H | ADDRBH | R | H'00 | | H'FFFB3 | A/D data register B L | ADDRBL | R | H'00 | | H'FFFB4 | A/D data register C H | ADDRCH | R | H'00 | | H'FFFB5 | A/D data register C L | ADDRCL | R | H'00 | | H'FFFB6 | A/D data register D H | ADDRDH | R | H'00 | | H'FFFB7 | A/D data register D L | ADDRDL | R | H'00 | | H'FFFB8 | A/D control/status register | ADCSR | R/(W)* | H'00 | | H'FFFB9 | A/D control register | ADCR | R/W | H'7E | Note: \* Only 0 can be written in bit 7, to clear the flag. # 16.2 Register Descriptions ### 16.2.1 A/D Data Registers A to D (ADDRA to ADDRD) The four A/D data registers (ADDRA to ADDRD) are 16-bit read-only registers that store the results of A/D conversion. An A/D conversion produces 10-bit data, which is transferred for storage into the A/D data register corresponding to the selected channel. The upper 8 bits of the result are stored in the upper byte of the A/D data register. The lower 2 bits are stored in the lower byte. Bits 5 to 0 of an A/D data register are reserved bits that are always read as 0. Table 16.3 indicates the pairings of analog input channels and A/D data registers. The CPU can always read the A/D data registers. The upper byte can be read directly, but the lower byte is read through a temporary register (TEMP). For details see section 16.3, CPU Interface. The A/D data registers are initialized to H'0000 by a reset and in standby mode. Table 16.3 Analog Input Channels and A/D Data Registers (ADDRA to ADDRD) **Analog Input Channel** | Group 0 | Group 1 | A/D Data Register | |---------|---------|-------------------| | AN0 | AN4 | ADDRA | | AN1 | AN5 | ADDRB | | AN2 | AN6 | ADDRC | | AN3 | AN7 | ADDRD | #### 16.2.2 A/D Control/Status Register (ADCSR) A/D end flag Indicates end of A/D conversion Note: \* Only 0 can be written, to clear the flag. ADCSR is an 8-bit readable/writable register that selects the mode and controls the A/D converter. ADCSR is initialized to H'00 by a reset and in standby mode. Bit 7—A/D End Flag (ADF): Indicates the end of A/D conversion. | Bit 7: ADF | Description | | |------------|---------------------------------------------------------|-----------------| | 0 | [Clearing condition] | (Initial value) | | | Read ADF when ADF =1, then write 0 in ADF. | | | 1 | [Setting conditions] | | | | Single mode: A/D conversion ends | | | | Scan mode: A/D conversion ends in all selected channels | | **Bit 6—A/D Interrupt Enable (ADIE):** Enables or disables the interrupt (ADI) requested at the end of A/D conversion. | Bit 6: ADIE | Description | | |-------------|---------------------------------------------|-----------------| | 0 | A/D end interrupt request (ADI) is disabled | (Initial value) | | 1 | A/D end interrupt request (ADI) is enabled | | **Bit 5—A/D Start (ADST):** Starts or stops A/D conversion. The ADST bit remains set to 1 during A/D conversion. It can also be set to 1 by external trigger input at the ADTRG pin. | Bit 5: ADST | Description | | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------------| | 0 | A/D conversion is stopped | (Initial value) | | 1 | Single mode: A/D conversion starts; ADST is automatically clear conversion ends. | ared to 0 when | | | Scan mode: A/D conversion starts and continues, cycling amor channels, until ADST is cleared to 0 by software, by a reset, or to standby mode. | • | **Bit 4—Scan Mode (SCAN):** Selects single mode or scan mode. For further information on operation in these modes, see section 16.4, Operation. Clear the ADST bit to 0 before switching the conversion mode. | Bit 4: SCAN | Description | | |-------------|-------------|-----------------| | 0 | Single mode | (Initial value) | | 1 | Scan mode | | **Bit 3—Clock Select (CKS):** Selects the A/D conversion time. Clear the ADST bit to 0 before switching the conversion time. | Bit 3: CKS | Description | | |------------|----------------------------------------|-----------------| | 0 | Conversion time = 134 states (maximum) | (Initial value) | | 1 | Conversion time = 70 states (maximum) | | Bits 2 to 0—Channel Select 2 to 0 (CH2 to CH0): These bits and the SCAN bit select the analog input channels. Clear the ADST bit to 0 before changing the channel selection. | Group<br>Selection | Channel Selection | | Description | | | | | |--------------------|-------------------|-----|---------------------|------------|--|--|--| | CH2 | CH1 | CH0 | Single Mode | Scan Mode | | | | | 0 | 0 | 0 | AN0 (Initial value) | AN0 | | | | | | | 1 | AN1 | AN0, AN1 | | | | | | 1 | 0 | AN2 | AN0 to AN2 | | | | | | | 1 | AN3 | AN0 to AN3 | | | | | 1* | 0 | 0 | AN4 | AN4 | | | | | | | 1 | AN5 | AN4, AN5 | | | | | | 1 | 0 | AN6 | AN4 to AN6 | | | | | | | 1 | AN7 | AN4 to AN7 | | | | Note: 1 can not be set on the 42-pin type. #### 16.2.3 A/D Control Register (ADCR) Enables or disables starting of A/D conversion by an external trigger ADCR is an 8-bit readable/writable register that enables or disables starting of A/D conversion by external trigger input. ADCR is initialized to H'7E by a reset and in standby mode. **Bit 7—Trigger Enable (TRGE):** Enables or disables starting of A/D conversion by an external trigger. | Bit 7: TRGE | Description | | |-------------|------------------------------------------------------------------------------------------|-------------------| | 0 | Starting of A/D conversion by an external trigger is disabled | (Initial value) | | 1 | A/D conversion is started at the falling edge and the rising edge trigger signal (ADTRG) | e of the external | Note: The selection between the falling edge and rising edge of the external trigger pin (ADTRG) conforms to the setting of the interrupt edge select register 2 (IEGR2). **Bits 6 to 1—Reserved:** These bits cannot be modified and are always read as 1. **Bit 0—Reserved:** This bit can be read or written, but must not be set to 1. #### 16.3 CPU Interface ADDRA to ADDRD are 16-bit registers, but they are connected to the CPU by an 8-bit data bus. Therefore, although the upper byte can be be accessed directly by the CPU, the lower byte is read through an 8-bit temporary register (TEMP). An A/D data register is read as follows. When the upper byte is read, the upper-byte value is transferred directly to the CPU and the lower-byte value is transferred into TEMP. Next, when the lower byte is read, the TEMP contents are transferred to the CPU. When reading an A/D data register, always read the upper byte before the lower byte. It is possible to read only the upper byte, but if only the lower byte is read, incorrect data may be obtained. Figure 16.2 shows the data flow for access to an A/D data register. Figure 16.2 A/D Data Register Access Operation (Reading H'AA40) ### 16.4 Operation The A/D converter operates by successive approximations with 10-bit resolution. It has two operating modes: single mode and scan mode. #### 16.4.1 Single Mode (SCAN = 0) Single mode should be selected when only one A/D conversion on one channel is required. A/D conversion starts when the ADST bit is set to 1 by software, or by external trigger input. The ADST bit remains set to 1 during A/D conversion and is automatically cleared to 0 when conversion ends. When conversion ends the ADF flag is set to 1. If the ADIE bit is also set to 1, an ADI interrupt is requested at this time. To clear the ADF flag to 0, first read ADCSR, then write 0 in ADF. When the mode or analog input channel must be switched during analog conversion, to prevent incorrect operation, first clear the ADST bit to 0 in ADCSR to halt A/D conversion. After making the necessary changes, set the ADST bit to 1 to start A/D conversion again. The ADST bit can be set at the same time as the mode or channel is changed. Typical operations when channel 1 (AN1) is selected in single mode are described next. Figure 16.3 shows a timing diagram for this example. - Single mode is selected (SCAN = 0), input channel AN1 is selected (CH2 = CH1 = 0, CH0 = 1), the A/D interrupt is enabled (ADIE = 1), and A/D conversion is started (ADST = 1). - 2. When A/D conversion is completed, the result is transferred into ADDRB. At the same time the ADF flag is set to 1, the ADST bit is cleared to 0, and the A/D converter becomes idle. - 3. Since ADF = 1 and ADIE = 1, an ADI interrupt is requested. - 4. The A/D interrupt handling routine starts. - 5. The routine reads ADCSR, then writes 0 in the ADF flag. - 6. The routine reads and processes the conversion result (ADDRB). - 7. Execution of the A/D interrupt handling routine ends. After that, if the ADST bit is set to 1, A/D conversion starts again and steps 2 to 7 are repeated. Figure 16.3 Example of A/D Converter Operation (Single Mode, Channel 1 Selected) #### 16.4.2 Scan Mode (SCAN = 1) Scan mode is useful for monitoring analog inputs in a group of one or more channels. When the ADST bit is set to 1 by software or external trigger input, A/D conversion starts on the first channel in the group (AN0 when CH2 = 0, AN4 when CH2 = 1). When two or more channels are selected, after conversion of the first channel ends, conversion of the second channel (AN1 or AN5) starts immediately. A/D conversion continues cyclically on the selected channels until the ADST bit is cleared to 0. The conversion results are transferred for storage into the A/D data registers corresponding to the channels. When the mode or analog input channel selection must be changed during analog conversion, to prevent incorrect operation, first clear the ADST bit to 0 in ADCSR to halt A/D conversion. After making the necessary changes, set the ADST bit to 1. A/D conversion will start again from the first channel in the group. The ADST bit can be set at the same time as the mode or channel selection is changed. Typical operations when three channels in group 0 (AN0 to AN2) are selected in scan mode are described next. Figure 16.4 shows a timing diagram for this example. - 1. Scan mode is selected (SCAN = 1), scan group 0 is selected (CH2 = 0), analog input channels $AN_0$ to $AN_2$ are selected (CH1 = 1, CH0 = 0), and A/D conversion is started (ADST = 1). - 2. When A/D conversion of the first channel (AN0) is completed, the result is transferred into ADDRA. Next, conversion of the second channel (AN1) starts automatically. - 3. Conversion proceeds in the same way through the third channel (AN2). - 4. When conversion of all selected channels (AN0 to AN2) is completed, the ADF flag is set to 1 and conversion of the first channel (AN0) starts again. If the ADIE bit is set to 1, an ADI interrupt is requested when A/D conversion ends. - 5. Steps 2 to 4 are repeated as long as the ADST bit remains set to 1. When the ADST bit is cleared to 0, A/D conversion stops. After that, if the ADST bit is set to 1, A/D conversion starts again from the first channel (AN0). Figure 16.4 Example of A/D Converter Operation (Scan Mode, Channels AN0 to AN2 Selected) #### 16.4.3 Input Sampling and A/D Conversion Time The A/D converter has a built-in sample-and-hold circuit. The A/D converter samples the input at a time $t_D$ after the ADST bit is set to 1, then starts conversion. Figure 16.5 shows the A/D conversion timing. Table 16.4 indicates the A/D conversion time. As indicated in figure 16.5, the A/D conversion time includes $t_{\rm D}$ and the input sampling time. The length of $t_{\rm D}$ varies depending on the timing of the write access to ADCSR. The total conversion time therefore varies within the ranges indicated in table 16.4. In scan mode, the values given in table 16.4 apply to the first conversion. In the second and subsequent conversions the conversion time is fixed at 128 states when CKS = 0 or 66 states when CKS = 1. Figure 16.5 A/D Conversion Timing **Table 16.4** A/D Conversion Time (Single Mode) | | | CKS = 0 | | | CKS = 1 | | | |-----------------------|-------------------|---------|-----|-----|---------|-----|-----| | | Symbol | Min | Тур | Max | Min | Тур | Max | | Synchronization delay | t <sub>D</sub> | 6 | _ | 9 | 4 | _ | 5 | | Input sampling time | t <sub>SPL</sub> | _ | 31 | _ | | 15 | | | A/D conversion time | t <sub>CONV</sub> | 131 | _ | 134 | 69 | _ | 70 | Note: Values in the table are numbers of states. #### 16.4.4 External Trigger Input Timing A/D conversion can be externally triggered. When the TRGE bit is set to 1 in ADCR, external trigger input is enabled at the $\overline{ADTRG}$ pin. A rising or falling edge on the $\overline{ADTRG}$ input pin sets the ADST bit to 1 in ADCSR, starting A/D conversion. Other operations, in both single and scan modes, are the same as if the ADST bit had been set to 1 by software. Figure 16.6 shows the timing. Figure 16.6 External Trigger Input Timing #### 16.5 Interrupts The A/D converter generates an interrupt (ADI) at the end of A/D conversion. The ADI interrupt request can be enabled or disabled by the ADIE bit in ADCSR. ### 16.6 Usage Notes When using the A/D converter, note the following points: - 1. A/D Conversion Accuracy Definitions: A/D conversion accuracy in the H8/3664 Series is defined as follows: - Resolution Digital output code length of A/D converter - Offset error Deviation from ideal A/D conversion characteristic of analog input voltage required to raise digital output from minimum voltage value 0000000000 to 0000000001 (figure 16.8) - Full-scale error Deviation from ideal A/D conversion characteristic of analog input voltage required to raise digital output from 11111111110 to 1111111111 (figure 16.8) - Quantization error Intrinsic error of the A/D converter; 1/2 LSB (figure 16.7) - Nonlinearity error Deviation from ideal A/D conversion characteristic in range from zero volts to full scale, exclusive of offset error, full-scale error, and quantization error. - Absolute accuracy Deviation of digital value from analog input value, including offset error, full-scale error, quantization error, and nonlinearity error. Figure 16.7 A/D Converter Accuracy Definitions (1) Figure 16.8 A/D Converter Accuracy Definitions (2) 2. Allowable Signal-Source Impedance: The analog inputs of the H8/3664 Series are designed to assure accurate conversion of input signals with a signal-source impedance not exceeding 10 k $\Omega$ . The reason for this rating is that it enables the input capacitor in the sample-and-hold circuit in the A/D converter to charge within the sampling time. If the sensor output impedance exceeds 10 k $\Omega$ , charging may be inadequate and the accuracy of A/D conversion cannot be guaranteed. If a large external capacitor is provided in single mode, then the internal 10-k $\Omega$ input resistance becomes the only significant load on the input. In this case the impedance of the signal source is not a problem. A large external capacitor, however, acts as a low-pass filter. This may make it impossible to track analog signals with high dv/dt (e.g. a variation of 5 mV/ $\mu$ s) (figure 16.9). To convert high-speed analog signals or to use scan mode, insert a low-impedance buffer. 3. Effect on Absolute Accuracy: Attaching an external capacitor creates a coupling with ground, so if there is noise on the ground line, it may degrade absolute accuracy. The capacitor must be connected to an electrically stable ground. If a filter circuit is used, be careful of interference with digital signals on the same board, and make sure the circuit does not act as an antenna. Figure 16.9 Analog Input Circuit (Example) # Section 17 Power Supply Circuit #### 17.1 Overview The H8/3664 Series incorporates an internal power supply step-down circuit. Use of this circuit enables the internal power supply to be fixed at a constant level of approximately 3.0 V, independently of the voltage of the power supply connected to the external $V_{\rm cc}$ pin. As a result, the current consumed when an external power supply is used at 3.0 V or above can be held down to virtually the same low level as when used at approximately 3.0 V. If the external power supply is 3.0 V or below, the internal voltage will be practically the same as the external voltage. It is, of course, also possible to use the same level of external power supply voltage and internal power supply voltage without using the internal power supply step-down circuit. #### 17.2 When Using the Internal Power Supply Step-Down Circuit Connect the external power supply to the $V_{\rm cc}$ pin, and connect a capacitance of approximately 0.1 $\mu F$ between $CV_{\rm cc}$ and $V_{\rm ss}$ , as shown in figure 17.1. The internal step-down circuit is made effective simply by adding this external circuit. - Notes: 1. In the external circuit interface, the external power supply voltage connected to $V_{\text{cc}}$ and the GND potential connected to $V_{ss}$ are the reference levels. For example, for port input/output levels, the $V_{\text{cc}}$ level is the reference for the high level, and the $V_{ss}$ level is that for the low level. - The A/D converter analog power supply is not affected by internal step-down processing. Figure 17.1 Power Supply Connection when Internal Step-Down Circuit Is Used ### 17.3 When Not Using the Internal Power Supply Step-Down Circuit When the internal power supply step-down circuit is not used, connect the external power supply to the $V_{\rm cc}$ pin and $CV_{\rm cc}$ pin, as shown in figure 17.2. The external power supply is then input directly to the internal power supply. Note: The permissible range for the power supply voltage is 3.0 V to 3.6 V. Operation cannot be guaranteed if a voltage outside this range (less than 3.0 V or more than 3.6 V) is input. Figure 17.2 Power Supply Connection when Internal Step-Down Circuit Is Not Used ### Section 18 Electrical Characteristics ### 18.1 Absolute Maximum Ratings Table 18.1 lists the absolute maximum ratings. **Table 18.1 Absolute Maximum Ratings** | Item | | Symbol | Value | Unit | Note | |----------------------|--------------------------------|------------------|-------------------------------|------|------| | Power supply voltage | | $V_{cc}$ | -0.3 to +7.0 | V | * | | Analog power sup | oply voltage | AV <sub>cc</sub> | -0.3 to +7.0 | V | * | | Input voltage | Ports other than Port B and X1 | V <sub>IN</sub> | $-0.3$ to $V_{cc}$ +0.3 | V | * | | | Port B | <del></del> | -0.3 to AV <sub>cc</sub> +0.3 | V | * | | | X1 | | -0.3 to 4.3 | V | * | | Operating temper | ature | T <sub>opr</sub> | -20 to +75 | °C | * | | Storage temperate | ure | T <sub>stg</sub> | -55 to +125 | °C | * | Note: \* Permanent damage may occur to the chip if maximum ratings are exceeded. Normal operation should be under the conditions specified in Electrical Characteristics. Exceeding these values can result in incorrect operation and reduced reliability. # **18.2** Electrical Characteristics (F-ZTAT<sup>TM</sup> Version) ### 18.2.1 Power Supply Voltage and Operating Ranges ### **Power Supply Voltage and Oscillation Frequency Range** #### **Power Supply Voltage and Operating Frequency Range** ### Analog Power Supply Voltage and A/D Converter Accuracy Guarantee Range #### 18.2.2 DC Characteristics Table 18.2 lists the DC characteristics. Table 18.2 DC Characteristics (1) $V_{CC}$ = 3.0 V to 5.5 V, $V_{SS}$ = 0.0 V, $T_a$ = -20°C to +75°C unless otherwise indicated. | | | | | Value | es | | | | |-----------------------|-----------------|-------------------------------------------------------------|-----------------------|-------|------------------------|------|--------------------------------------------|-------| | Item | Symbol | Applicable Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | | Input high<br>voltage | V <sub>IH</sub> | RES, NMI,<br>WKP0 to WKP5,<br>IRQ0 to IRQ3,<br>ADTRG,TMRIV, | 0.8 V <sub>cc</sub> | _ | V <sub>cc</sub> + 0.3 | V | V <sub>CC</sub> = 4.0 V to 5.5 V | | | | | TMCIV, FTCI,<br>FTIOA to FTIOD,<br>SCK3, TRGV | 0.9 V <sub>cc</sub> | _ | V <sub>CC</sub> + 0.3 | | | | | | | RXD, SCL, SDA,<br>P10 to P12,<br>P14 to P17,<br>P20 to P22, | 0.7 V <sub>CC</sub> | _ | V <sub>cc</sub> + 0.3 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | P50 to P57,<br>P74 to P76,<br>P80 to P87 | 0.8 V <sub>CC</sub> | _ | V <sub>CC</sub> + 0.3 | | | | | | | PB0 to PB7 | 0.7 V <sub>CC</sub> | _ | AV <sub>CC</sub> + 0.3 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | 0.8 V <sub>CC</sub> | _ | AV <sub>CC</sub> + 0.3 | - | | | | | | OSC1 | V <sub>CC</sub> - 0.5 | _ | V <sub>CC</sub> + 0.3 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | V <sub>CC</sub> - 0.3 | _ | V <sub>CC</sub> + 0.3 | - | | | | Input low<br>voltage | V <sub>IL</sub> | RES, NMI, WKP0 to WKP5, IRQ0 to IRQ3, ADTRG,TMRIV, | -0.3 | _ | 0.2 V <sub>CC</sub> | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | TMCIV, FTCI,<br>FTIOA to FTIOD,<br>SCK3, TRGV | -0.3 | _ | 0.1 V <sub>cc</sub> | | | | | | | RXD, SCL, SDA,<br>P10 to P12,<br>P14 to P17,<br>P20 to P22, | -0.3 | _ | 0.3 V <sub>CC</sub> | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | P50 to P57,<br>P74 to P76,<br>P80 to P87,<br>PB0 to PB7 | -0.3 | | 0.2 V <sub>CC</sub> | | | | | | | OSC1 | -0.3 | _ | 0.5 | V | V <sub>CC</sub> = 4.0 V to 5.5 V | | | | | | -0.3 | _ | 0.3 | | | | | | | | | Values | | | | | |----------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------|-----------------------|--------|-----|------|-------------------------------------------------------------|-------| | Item | Symbol | Applicable Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | | Output | $V_{OH}$ | P10 to P12, | V <sub>CC</sub> - 1.0 | _ | _ | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | high<br>voltage | | P14 to P17,<br>P20 to P22, | | | | | $-I_{OH} = 1.5 \text{ mA}$ | | | remage | | P50 to P55,<br>P74 to P76,<br>P80 to P87, | V <sub>CC</sub> - 0.5 | _ | _ | | -I <sub>OH</sub> = 0.1 mA | | | | | P56, P57 | V <sub>CC</sub> - 2.5 | _ | _ | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | - | | | | | | | | | $-I_{OH} = 0.1 \text{ mA}$ | | | | | | V <sub>CC</sub> - 2.0 | _ | _ | | $V_{\rm CC} = 3.0 \text{ V to } 4.0 \text{ V}$ | • | | | | | | | | | $-I_{OH} = 0.1 \text{ mA}$ | | | Output | V <sub>OL</sub> | P10 to P12, | _ | _ | 0.6 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | • | | low<br>voltage | | P14 to P17,<br>P20 to P22, | | | | | $I_{OL} = 1.6 \text{ mA}$ | | | vollago | | P50 to P57,<br>P74 to P76, | _ | _ | 0.4 | | I <sub>OL</sub> = 0.4 mA | - | | | | P80 to P87 | _ | _ | 1.5 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | • | | | | | | | | | $I_{OL} = 20.0 \text{ mA}$ | | | | | | _ | _ | 1.0 | | $V_{\rm CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | | | | | $I_{OL} = 10.0 \text{ mA}$ | _ | | | | | _ | _ | 0.4 | | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | | | | | I <sub>OL</sub> = 1.6 mA | _ | | | | | _ | _ | 0.4 | | $I_{OL} = 0.4 \text{ mA}$ | _ | | | | SCL, SDA | _ | _ | 0.6 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | | | | | I <sub>OL</sub> = 6.0 mA | | | | | | _ | _ | 0.4 | | I <sub>OL</sub> = 3.0 mA | | | Input/<br>output<br>leakage<br>current | I <sub>IL</sub> | OSC1, RES, NMI, WKP0 to WKP5, IRQ0 to IRQ3, ADTRG, TRGV, TMRIV, TMCIV, FTCI, FTIOD, RXD, SCK3, SCL, SDA | _ | _ | 1.0 | μА | $V_{IN} = 0.5 \text{ V to}$<br>( $V_{CC} - 0.5 \text{ V}$ ) | | | | | P10 to P12,<br>P14 to P17,<br>P20 to P22,<br>P50 to P57,<br>P74 to P76,<br>P80 to P87, | | _ | 1.0 | μΑ | $V_{IN} = 0.5 \text{ V to}$<br>$(V_{CC} - 0.5 \text{ V})$ | | | | | PB0 to PB7 | _ | _ | 1.0 | μA | $V_{IN} = 0.5 \text{ V to}$<br>(AV <sub>CC</sub> - 0.5 V) | | | | | | | Value | es | | | | |---------------------------------------------|---------------------|-----------------------------------------------|------|-------|-------|------|-------------------------------------------------------------------------------------------------------|-------------------------| | Item | Symbol | Applicable Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | | Pull-up<br>MOS | -I <sub>p</sub> | P10 to P12,<br>P14 to P17, | 50.0 | _ | 300.0 | μΑ | $V_{CC} = 5.0 \text{ V},$<br>$V_{IN} = 0.0 \text{ V}$ | | | current | | P50 to P55 | _ | 60.0 | _ | | $V_{CC} = 3.0 \text{ V},$<br>$V_{IN} = 0.0 \text{ V}$ | Reference value | | Input<br>capaci-<br>tance | C <sub>in</sub> | All input pins<br>except power<br>supply pins | | _ | 15.0 | pF | f = 1 MHz,<br>$V_{IN} = 0.0 \text{ V},$<br>$T_a = 25^{\circ}\text{C}$ | | | Active<br>mode<br>current | I <sub>OPE1</sub> | V <sub>cc</sub> | _ | 15.0 | 22.5 | mA | Active mode 1<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | dissipation | | | _ | 8.0 | _ | | Active mode 1<br>$V_{CC} = 3.0 \text{ V},$<br>$f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | | I <sub>OPE2</sub> | V <sub>cc</sub> | _ | 1.8 | 2.7 | mA | Active mode 2<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | | | | _ | 1.2 | | | Active mode 2 $V_{CC} = 3.0 \text{ V},$ $f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | Sleep<br>mode<br>current | I <sub>SLEEP1</sub> | V <sub>cc</sub> | _ | 11.5 | 17.0 | mA | Sleep mode 1<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | dissipation | | | _ | 6.5 | _ | _ | Sleep mode 1<br>$V_{CC} = 3.0 \text{ V},$<br>$f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | | I <sub>SLEEP2</sub> | V <sub>cc</sub> | _ | 1.7 | 2.5 | mA | Sleep mode 2<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | | | | _ | 1.1 | _ | | Sleep mode 2<br>$V_{CC} = 3.0 \text{ V},$<br>$f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | Subactive<br>mode<br>current<br>dissipation | I <sub>SUB</sub> | V <sub>cc</sub> | | 35.0 | 70.0 | μА | $V_{CC} = 3.0 \text{ V}$<br>32-kHz crystal<br>oscillator<br>$(\varnothing_{SUB} = \varnothing_{W}/2)$ | * | | | | | _ | 25.0 | _ | | $V_{CC} = 3.0 \text{ V}$<br>32-kHz crystal<br>oscillator<br>$(\varnothing_{SUB} = \varnothing_W/8)$ | *<br>Reference<br>value | | Subsleep<br>mode<br>current<br>dissipation | I <sub>SUBSP</sub> | V <sub>cc</sub> | | 25.0 | 50.0 | μА | $V_{CC} = 3.0 \text{ V}$<br>32-kHz crystal<br>oscillator<br>$(\varnothing_{SUB} = \varnothing_{W}/2)$ | * | | | | Applicable Pins | | value | es | | | Notes | |-------------------------------------------|-------------------|-----------------|-----|-------|-----|------|------------------------------------|-------| | Item | Symbol | | Min | Тур | Max | Unit | Test Condition | | | Standby<br>mode<br>current<br>dissipation | I <sub>STBY</sub> | V <sub>cc</sub> | _ | _ | 5.0 | μА | 32-kHz crystal oscillator not used | * | | RAM data retaining voltage | V <sub>RAM</sub> | V <sub>cc</sub> | 2.0 | _ | _ | V | | | Note: \* Pin states during current dissipation measurement are given below (excluding current in the pull-up MOS transistors and output buffers). | Mode | RES Pin | Internal State | Other Pins | Oscillator Pins | |----------------|-----------------|----------------------------|-----------------|--------------------------------------------------| | Active mode 1 | V <sub>cc</sub> | Operates | V <sub>cc</sub> | System clock oscillator: ceramic or crystal | | Active mode 2 | | Operates<br>(ø/64) | | Subclock oscillator:<br>Pin X1 = V <sub>SS</sub> | | Sleep mode 1 | V <sub>cc</sub> | Only timers operate | V <sub>CC</sub> | _ | | Sleep mode 2 | | Only timers operate (ø/64) | | | | Subactive mode | V <sub>cc</sub> | Operates | V <sub>cc</sub> | System clock oscillator: ceramic or crystal | | Subsleep mode | V <sub>cc</sub> | Only time base operates | V <sub>cc</sub> | Subclock oscillator: crystal | | Standby mode | V <sub>CC</sub> | CPU and timers both stop | V <sub>cc</sub> | System clock oscillator: ceramic or crystal | | | | | | Subclock oscillator:<br>Pin X1 = V <sub>SS</sub> | ### Table 18.2 DC Characteristics (2) $V_{CC}$ = 3.0 V to 5.5 V, $V_{SS}$ = 0.0 V, $T_a$ = $-20^{\circ}C$ to $+75^{\circ}C$ , unless otherwise indicated. | | | | | Value | s | | | |----------------------------------------|----------------------------------------------|-------------------|-----|-------|------|---------------|----------------------------------| | Item | | Symbol | Min | Тур | Max | Unit | Test Condition | | Allowable output low current (per pin) | Output pins<br>except port 8,<br>SCL and SDA | I <sub>OL</sub> | _ | _ | 2.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | | Port 8 | _ | _ | _ | 20.0 | _ | | | | SCL and SDA | _ | _ | _ | 6.0 | _ | | | | Port 8 | _ | _ | _ | 10.0 | _ | | | | Output pins<br>except port 8,<br>SCL and SDA | _ | _ | | 0.5 | | | | Allowable output low current (total) | Output pins<br>except port 8,<br>SCL and SDA | $\Sigma I_{OL}$ | _ | | 40.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | | Port 8,<br>SCL and SDA | _ | _ | _ | 80.0 | <del></del> | | | | Output pins<br>except port 8,<br>SCL and SDA | _ | _ | | 20.0 | _ | | | | Port 8,<br>SCL and SDA | _ | _ | _ | 40.0 | <del></del> , | | | Allowable output high | All output pins | -I <sub>OH</sub> | _ | _ | 2.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | current (per pin) | | | _ | _ | 0.2 | _ | | | Allowable output high | All output pins | $\Sigma(-I_{OH})$ | _ | | 30.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | current (total) | | | _ | _ | 8.0 | | | #### 18.2.3 AC Characteristics Table 18.3 lists the AC characteristics. Tables 18.4 and 18.5 list the PC bus interface timing and the serial interface timing, respectively. Table 18.3 AC Characteristics $V_{CC} = 3.0 \text{ V}$ to 5.5 V, $V_{SS} = 0.0 \text{ V}$ , $T_a = -20^{\circ}\text{C}$ to $+75^{\circ}\text{C}$ , unless otherwise specified. | | | Applicable | | Values | | | | Reference | |-----------------------------------------------------------|---------------------|---------------|------|--------|------|------------------|--------------------------------------------|-------------| | Item | Symbol | Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Figure | | System clock oscillation | f <sub>osc</sub> | OSC1,<br>OSC2 | 2.0 | _ | 16.0 | MHz | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | *1 | | frequency | | | 2.0 | | 10.0 | | | _ | | System clock (ø) | t <sub>cyc</sub> | | 1 | _ | 64 | t <sub>osc</sub> | | *2 | | cycle time | | | _ | _ | 12.8 | μs | _ | | | Subclock oscillation frequency | f <sub>W</sub> | X1, X2 | _ | 32.768 | _ | kHz | | | | Watch clock (Ø <sub>W</sub> ) cycle time | t <sub>w</sub> | X1, X2 | _ | 30.5 | _ | μs | | | | Subclock (Ø <sub>SUB</sub> )<br>cycle time | t <sub>subcyc</sub> | | 2 | _ | 8 | t <sub>W</sub> | | *2 | | Instruction cycle time | | | 2 | _ | _ | t <sub>cyc</sub> | | | | Oscillation stabilization time (crystal oscillator) | t <sub>rc</sub> | OSC1,<br>OSC2 | | _ | 10.0 | ms | | | | Oscillation<br>stabilization time<br>(ceramic oscillator) | t <sub>rc</sub> | OSC1,<br>OSC2 | _ | _ | 5.0 | ms | | | | Oscillation stabilization time | t <sub>rcx</sub> | X1, X2 | _ | _ | 2.0 | S | | | | External clock | t <sub>CPH</sub> | OSC1 | 25.0 | _ | _ | ns | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.1 | | high width | | | 40.0 | _ | _ | _ | | - | | External clock | t <sub>CPL</sub> | OSC1 | 25.0 | _ | _ | ns | V <sub>CC</sub> = 4.0 V to 5.5 V | - | | low width | | | 40.0 | _ | _ | | | _ | | External clock | t <sub>CPr</sub> | OSC1 | _ | _ | 10.0 | ns | V <sub>CC</sub> = 4.0 V to 5.5 V | | | rise time | | | _ | _ | 15.0 | | | _ | | External clock | t <sub>CPf</sub> | OSC1 | _ | _ | 10.0 | ns | V <sub>CC</sub> = 4.0 V to 5.5 V | - | | fall time | | | _ | _ | 15.0 | | | _ | | | | Applicable | | Value | s | | | Reference | |-------------------------|------------------|----------------------------------------------------------------------------|-----------------|-------|-----|-----------------------------------------|-------------------------------------------------|-------------| | Item | Symbol | Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Figure | | RES pin low width | t <sub>REL</sub> | RES | t <sub>rc</sub> | _ | _ | ms | At power-on and in modes other than those below | Figure 18.2 | | | | | 10 | _ | | t <sub>cyc</sub> | In active mode and sleep mode operation | _ | | Input pin high<br>width | t <sub>IH</sub> | NMI, IRQ0 to IRQ3, WKP0 to WKP5, TMCIV, TMRIV, TRGV, ADTRG, FTCI, FTIOA to | 2 | _ | _ | t <sub>cyc</sub> t <sub>subcyc</sub> | | Figure 18.3 | | Input pin low width | t <sub>IL</sub> | NMI, IRQ0 to IRQ3, WKP0 to WKP5, TMCIV, TMRIV, TRGV, ADTRG, FTIOA to | 2 | _ | _ | t <sub>cyc</sub><br>t <sub>subcyc</sub> | | _ | Notes: 1. When an external clock is input, the minimum system clock oscillator frequency is 1.0 MHz. 2. Determined by MA2, MA1, MA0, SA1, and SA0 of system control register 2 (SYSCR2). ### Table 18.4 I<sup>2</sup>C Bus Interface Timing $V_{CC} = 3.0 \text{ V}$ to 5.5 V, $V_{SS} = 0.0 \text{ V}$ , $T_a = -20$ to $+75^{\circ}\text{C}$ , unless otherwise specified. | | | | Values | | | Test | Reference | |--------------------------------------------------|-------------------|--------------------------|--------|-------------------|------|-----------------------------------|-------------| | Item | Symbol | Min | Тур | Max | Unit | Condition | Figure | | SCL input cycle time | t <sub>scl</sub> | 12t <sub>cyc</sub> + 600 | _ | _ | ns | | Figure 18.4 | | SCL input high width | t <sub>sclh</sub> | 3t <sub>cyc</sub> + 300 | | | ns | " | - | | SCL input low width | t <sub>scll</sub> | 5t <sub>cyc</sub> + 300 | | | ns | " | - | | Input fall time of SCL and SDA | t <sub>Sf</sub> | _ | _ | 300 | ns | | _ | | SCL and SDA input<br>spike pulse removal<br>time | t <sub>SP</sub> | _ | | 1t <sub>cyc</sub> | ns | | - | | SDA input bus-free time | t <sub>BUF</sub> | 5t <sub>cyc</sub> | _ | _ | ns | | - | | Start condition input hold time | t <sub>STAH</sub> | 3t <sub>cyc</sub> | | | ns | | - | | Retransmission start condition input setup time | t <sub>STAS</sub> | 3t <sub>cyc</sub> | _ | _ | ns | | _ | | Setup time for stop condition input | t <sub>stos</sub> | 3t <sub>cyc</sub> | _ | _ | ns | | _ | | Data-input setup time | $t_{\text{SDAS}}$ | 0.5t <sub>cyc</sub> | _ | _ | ns | | _ | | Data-input hold time | t <sub>SDAH</sub> | 0 | _ | _ | ns | | _ | | Capacitive load of SCL and SDA | C <sub>b</sub> | 0 | _ | 400 | pF | | _ | | SCL and SDA output fall time | t <sub>Sf</sub> | _ | | 250 | ns | $V_{cc} = 4.0 \text{ V}$ to 5.5 V | _ | | | | _ | | 300 | | | | Note: \* The value can be changed to 17.5t<sub>cyc</sub>, depending on the clock used in the I<sup>2</sup>C module. ### Table 18.5 Serial Interface (SCI3) Timing $V_{CC} = 3.0 \text{ V}$ to 5.5 V, $V_{SS} = 0.0 \text{ V}$ , $T_a = -20^{\circ}\text{C}$ to $+75^{\circ}\text{C}$ , unless otherwise specified. | | | | Applicable | | Values | \$ | | | Reference | |----------------|-------------------|-------------------|------------|-------|--------|-----|-------------------|--------------------------------------------|-------------| | Item | | Symbol | Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Figure | | Input<br>clock | Asynchro-<br>nous | t <sub>Scyc</sub> | SCK3 | 4 | _ | _ | t <sub>cyc</sub> | | Figure 18.5 | | cycle | Synchro-<br>nous | _ | | 6 | _ | _ | _ | | | | Input clo | ock pulse | t <sub>SCKW</sub> | SCK3 | 0.4 | _ | 0.6 | t <sub>Scyc</sub> | | Figure 18.5 | | Transm | it data delay | t <sub>TXD</sub> | TXD | | _ | 1 | t <sub>cyc</sub> | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.6 | | time (sy | nchronous) | | | _ | _ | 1 | _ | | - | | Receive | data setup | t <sub>RXS</sub> | RXD | 62.5 | _ | _ | ns | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.6 | | time (sy | nchronous) | | | 100.0 | _ | _ | _ | | - | | Receive | data hold | t <sub>RXH</sub> | RXD | 62.5 | _ | _ | ns | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.6 | | time (sy | nchronous) | | | 100.0 | _ | _ | _ | | - | ### 18.2.4 A/D Converter Characteristics **Table 18.6 A/D Converter Characteristics** $V_{CC}=3.0~V$ to 5.5 V, $V_{SS}=0.0~V,\,T_a=-20^{\circ}C$ to +75°C, unless otherwise specified. | | | Applicable | | Value | es | | Test | Reference | |-----------------------------------|---------------------|------------------|-----------------------|-----------------|------------------------|------------------|---------------------------------------|--------------------------| | Item | Symbol | Pins | Min | Тур | Max | Unit | Condition | Figure | | Analog power supply voltage | AV <sub>CC</sub> | AV <sub>CC</sub> | 3.3 | V <sub>cc</sub> | 5.5 | V | | *1 | | Analog input voltage | AV <sub>IN</sub> | AN0 to<br>AN7 | V <sub>SS</sub> - 0.3 | _ | AV <sub>CC</sub> + 0.3 | V | | | | Analog power | Al <sub>OPE</sub> | AV <sub>CC</sub> | _ | _ | 2.0 | mA | AV <sub>CC</sub> = 5.0 V | | | | | | | | | | f <sub>osc</sub> =<br>16 MHz | | | supply current | Al <sub>STOP1</sub> | AV <sub>cc</sub> | _ | 50 | <u> </u> | μA | | *2<br>Reference<br>value | | | AI <sub>STOP2</sub> | AV <sub>CC</sub> | _ | _ | 5.0 | μΑ | | *3 | | Analog input capacitance | $C_{AIN}$ | AN0 to<br>AN7 | _ | _ | 30.0 | pF | | | | Allowable signal source impedance | R <sub>AIN</sub> | AN0 to<br>AN7 | | · | 5.0 | kΩ | | | | Resolution | | | 10 | 10 | 10 | bit | | | | Conversion time (single mode) | | | 134 | · | _ | t <sub>cyc</sub> | $AV_{CC} = 3.3 \text{ V}$<br>to 5.5 V | | | Nonlinearity error | | | _ | _ | ±7.5 | LSB | = | | | Offset error | | | _ | _ | ±7.5 | LSB | = | | | Full-scale error | | | _ | _ | ±7.5 | LSB | = | | | Quantization error | | | _ | _ | ±0.5 | LSB | _ | | | Absolute accuracy | | | _ | _ | ±8.0 | LSB | _ | | | Conversion time (single mode) | | | 70 | _ | _ | t <sub>cyc</sub> | $AV_{CC} = 4.0 \text{ V}$<br>to 5.5 V | | | Nonlinearity error | | | | _ | ±7.5 | LSB | _ | | | Offset error | | | | _ | ±7.5 | LSB | _ | | | Full-scale error | | | _ | _ | ±7.5 | LSB | _ | | | Quantization error | | | | _ | ±0.5 | LSB | _ | | | Absolute accuracy | | | _ | _ | ±8.0 | LSB | | | | | | | Applicable | | Value | s | | Test | Reference | |----|-------------------------------|--------|------------|-----|-------|------|------------------|---------------------------------------|-----------| | lt | em | Symbol | Pins | Min | Тур | Max | Unit | Condition | Figure | | _ | onversion time<br>ingle mode) | | | 134 | _ | _ | t <sub>cyc</sub> | $AV_{CC} = 4.0 \text{ V}$<br>to 5.5 V | | | | Nonlinearity error | | | _ | _ | ±3.5 | LSB | - | | | | Offset error | | | _ | | ±3.5 | LSB | _ | | | | Full-scale error | | | _ | | ±3.5 | LSB | - | | | | Quantization error | | | _ | | ±0.5 | LSB | - | | | | Absolute accuracy | | | _ | | ±4.0 | LSB | - | | Notes: 1. Set $AV_{cc} = V_{cc}$ when the A/D converter is not used. - 2. Al<sub>STOP1</sub> is the current in active and sleep modes while the A/D converter is idle. - Al<sub>STOP2</sub> is the current at reset and in standby, subactive, and subsleep modes while the A/D converter is idle. #### 18.2.5 Watchdog Timer #### **Table 18.7 Watchdog Timer Characteristics** $V_{CC} = 3.0 \text{ V}$ to 5.5 V, $V_{SS} = 0.0 \text{ V}$ , $T_a = -20^{\circ}\text{C}$ to $+75^{\circ}\text{C}$ , unless otherwise specified. | | | Applicable _<br>Symbol Pins I | | Values | | | Test | Reference | | |----------------------------------|------------------|-------------------------------|-----|--------|-----|------|-----------|-----------|--| | Item | Symbol | | Min | Тур | Max | Unit | Condition | Figure | | | On-chip oscillator overflow time | t <sub>ovf</sub> | | 0.2 | 0.4 | _ | S | | * | | Note: \* Shows the time to count from 0 to 255, at which point an internal reset is generated, when the internal oscillator is selected. ### **18.2.6** Flash Memory Characteristics (Preliminary) **Table 18.8 Flash Memory Characteristics (Preliminary)** $V_{CC}\!=3.0$ V to 5.5 V, $V_{SS}\!=0.0$ V, $T_a\!=\!-20^{\circ}C$ to +75°C, unless otherwise specified. | | | | Test | | Value | es | | | |----------------|-----------------------------------------------------------------------|------------------|----------------------------|-----|-------|------------|-------|---------| | Item | | Symbol | | Min | Тур | Max | Unit | Notes | | Programming | ogramming time (per 128 bytes) use time (per block) programming count | t <sub>P</sub> | | _ | 7 | _ | ms | 1, 2, 4 | | Erase time (pe | er block) | t <sub>E</sub> | | _ | 100 | _ | ms | 1, 3, 6 | | Reprogrammir | ng count | N <sub>WEC</sub> | | _ | _ | 100 | Times | | | Programming | Wait time after SWE bit setting | х | | 1 | _ | _ | μs | 1 | | | | у | | 50 | _ | _ | μs | 1 | | | | z1 | 1 ≤ n ≤ 6 | 28 | 30 | 32 | μs | 1, 4 | | | | z2 | 7 ≤ n ≤ 1000 | 198 | 200 | 202 | μs | _ | | | | z3 | Additional-<br>programming | 8 | 10 | 12 | μs | _ | | | | α | | 5 | _ | _ | μs | 1 | | | | β | | 5 | _ | _ | μs | 1 | | | | γ | | 4 | | _ | μs | 1 | | | | ε | | 2 | _ | _ | μs | 1 | | | | η | | 2 | _ | _ | μs | 1 | | | Wait time after SWE bit clear | θ | | 100 | | . <u>—</u> | μs | 1 | | | Maximum programming count | N | | _ | _ | 1000 | Times | 1, 4, 5 | | | | | Test | | value | | | | |-------|---------------------------------|--------|-----------|-----|-------|-----|-------|---------| | Item | | Symbol | Condition | Min | Тур | Max | Unit | Notes | | Erase | Wait time after SWE bit setting | х | | 1 | _ | _ | μs | 1 | | | Wait time after ESU bit setting | у | | 100 | | _ | μs | 1 | | | Wait time after E bit setting | Z | | 10 | _ | 100 | ms | 1, 6 | | | Wait time after E bit clear | α | | 10 | _ | _ | μs | 1 | | | Wait time after ESU bit clear | β | | 10 | | _ | μs | 1 | | | Wait time after EV bit setting | γ | | 20 | _ | | μs | 1 | | | Wait time after dummy write | ε | | 2 | _ | _ | μs | 1 | | | Wait time after EV bit clear | η | | 4 | _ | _ | μs | 1 | | | Wait time after SWE bit clear | θ | | 100 | _ | _ | μs | 1 | | | Maximum erase count | N | | _ | _ | 120 | Times | 1, 6, 7 | Values Notes: 1. Make the time settings in accordance with the program/erase algorithms. - 2. The programming time for 128 bytes. (Indicates the total time for which the P bit in flash memory control register 1 (FLMCR1) is set. The program-verify time is not included.) - 3. The time required to erase one block. (Indicates the time for which the E bit in flash memory control register 1 (FLMCR1) is set. The erase-verify time is not included.) - 4. Programming time maximum value $(t_P(MAX))$ = wait time after P bit setting $(z) \times$ maximum number of writes (N) - Set the maximum number of writes (N) according to the actual set values of z1, z2, and z3, so that it does not exceed the programming time maximum value (t<sub>P</sub>(MAX)). The wait time after P bit setting (z1, z2) should be changed as follows according to the value of the number of writes (n). Number of writes (n) $$1 \le n \le 6$$ $z1 = 30 \mu s$ $7 \le n \le 1000$ $z2 = 200 \mu s$ - 6. Erase time maximum value $(t_E(max))$ = wait time after E bit setting $(z) \times maximum$ number of erases (N) - Set the maximum number of erases (N) according to the actual set value of (z), so that it does not exceed the erase time maximum value (t<sub>E</sub>(max)). ## **18.3** Electrical Characteristics (Mask ROM Version) #### 18.3.1 Power Supply Voltage and Operating Ranges #### Power Supply Voltage and Oscillation Frequency Range #### **Power Supply Voltage and Operating Frequency Range** # Analog Power Supply Voltage and A/D Converter Accuracy Guarantee Range #### 18.3.2 DC Characteristics Table 18.9 lists the DC characteristics. #### Table 18.9 DC Characteristics (1) $V_{CC}$ = 2.7 V to 5.5 V, $V_{SS}$ = 0.0 V, $T_a$ = -20°C to +75°C unless otherwise indicated. | | | | | Value | es | | | | |----------------------|-----------------|-------------------------------------------------------------|---------------------|-------|------------------------|------|--------------------------------------------|-------| | Item | Symbol | Applicable Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | | Input high voltage | V <sub>IH</sub> | RES, NMI,<br>WKP0 to WKP5,<br>IRQ0 to IRQ3,<br>ADTRG,TMRIV, | 0.8 V <sub>CC</sub> | _ | V <sub>cc</sub> + 0.3 | V | V <sub>CC</sub> = 4.0 V to 5.5 V | | | | | TMCIV, FTCI,<br>FTIOA to FTIOD,<br>SCK3, TRGV | 0.9 V <sub>CC</sub> | _ | V <sub>CC</sub> + 0.3 | | | | | | | RXD, SCL, SDA,<br>P10 to P12,<br>P14 to P17,<br>P20 to P22, | 0.7 V <sub>CC</sub> | _ | V <sub>cc</sub> + 0.3 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | P50 to P57,<br>P74 to P76,<br>P80 to P87 | 0.8 V <sub>CC</sub> | _ | V <sub>CC</sub> + 0.3 | | | | | | | PB0 to PB7 | 0.7 V <sub>CC</sub> | _ | AV <sub>CC</sub> + 0.3 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | 0.8 V <sub>CC</sub> | _ | $AV_{CC} + 0.3$ | | | | | | | OSC1 | $V_{\rm CC}-0.5$ | _ | $V_{CC}$ + 0.3 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | $V_{\rm CC}-0.3$ | _ | $V_{CC} + 0.3$ | | | | | Input low<br>voltage | $V_{IL}$ | RES, NMI, WKP0 to WKP5, IRQ0 to IRQ3, ADTRG,TMRIV, | -0.3 | _ | 0.2 V <sub>CC</sub> | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | TMCIV, FTCI,<br>FTIOA to FTIOD,<br>SCK3, TRGV | -0.3 | | 0.1 V <sub>cc</sub> | | | | | | | RXD, SCL, SDA,<br>P10 to P12,<br>P14 to P17,<br>P20 to P22, | -0.3 | _ | 0.3 V <sub>CC</sub> | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | P50 to P57,<br>P74 to P76,<br>P80 to P87,<br>PB0 to PB7 | -0.3 | | 0.2 V <sub>CC</sub> | | | | | | | OSC1 | -0.3 | _ | 0.5 | V | V <sub>CC</sub> = 4.0 V to 5.5 V | | | _ | | | -0.3 | | 0.3 | | | | | | | | Values | | | | | | |----------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------|-----------------------|-----|-----|------|-------------------------------------------------------------------------|-------| | Item | Symbol | Applicable Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | | Output<br>high<br>voltage | V <sub>OH</sub> | P10 to P12,<br>P14 to P17,<br>P20 to P22,<br>P50 to P55,<br>P74 to P76,<br>P80 to P87, | V <sub>CC</sub> - 1.0 | _ | _ | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | | | | | $-I_{OH} = 1.5 \text{ mA}$ | | | | | | V <sub>CC</sub> - 0.5 | _ | _ | | -I <sub>OH</sub> = 0.1 mA | | | | | P56, P57 | V <sub>CC</sub> - 2.5 | _ | _ | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | - | | | | | | | | | $-I_{OH} = 0.1 \text{ mA}$ | | | | | | V <sub>CC</sub> - 2.0 | _ | _ | | $V_{CC} = 3.0 \text{ V to } 4.0 \text{ V}$ | • | | O | | D40 to D40 | | | 0.0 | | $-I_{OH} = 0.1 \text{ mA}$ | | | Output<br>low<br>voltage | V <sub>OL</sub> | P10 to P12,<br>P14 to P17,<br>P20 to P22,<br>P50 to P57,<br>P74 to P76, | _ | _ | 0.6 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$<br>$I_{OL} = 1.6 \text{ mA}$ | | | · onago | | | _ | _ | 0.4 | | I <sub>OL</sub> = 0.4 mA | - | | | | P80 to P87 | _ | _ | 1.5 | V | V <sub>CC</sub> = 4.0 V to 5.5 V | - | | | | | | | | | $I_{OL} = 20.0 \text{ mA}$ | | | | | | _ | _ | 1.0 | | $V_{\rm CC}$ = 4.0 V to 5.5 V | | | | | | | | | | $I_{OL} = 10.0 \text{ mA}$ | | | | | | _ | _ | 0.4 | | $V_{\rm CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | | | | | $I_{OL} = 1.6 \text{ mA}$ | | | | | | _ | _ | 0.4 | | I <sub>OL</sub> = 0.4 mA | • | | | | SCL, SDA | _ | _ | 0.6 | V | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | | | | | | | | $I_{OL} = 6.0 \text{ mA}$ | | | | | | _ | _ | 0.4 | | I <sub>OL</sub> = 3.0 mA | | | Input/<br>output<br>leakage<br>current | I <sub>IL</sub> | OSC1, RES, NMI, WKP0 to WKP5, IRQ0 to IRQ3, ADTRG, TRGV, TMRIV, TMCIV, FTCI, FTIOA to FTIOD, RXD, SCK3, SCL, SDA | _ | _ | 1.0 | μΑ | $V_{IN} = 0.5 \text{ V to}$<br>( $V_{CC} - 0.5 \text{ V}$ ) | | | | | P10 to P12,<br>P14 to P17,<br>P20 to P22,<br>P50 to P57,<br>P74 to P76,<br>P80 to P87, | _ | _ | 1.0 | μА | $V_{IN} = 0.5 \text{ V to}$<br>( $V_{CC} - 0.5 \text{ V}$ ) | | | | | PB0 to PB7 | _ | _ | 1.0 | μA | $V_{IN} = 0.5 \text{ V to}$<br>(AV <sub>CC</sub> - 0.5 V) | • | | | | | | Values | | | | | |---------------------------------------------|---------------------|-----------------------------------------------|------|--------|-------|------|-------------------------------------------------------------------------------------------------------|-------------------------| | Item | Symbol | Applicable Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Notes | | Pull-up<br>MOS<br>current | -I <sub>p</sub> | P10 to P12,<br>P14 to P17,<br>P50 to P55 | 50.0 | _ | 300.0 | μΑ | $V_{CC} = 5.0 \text{ V},$<br>$V_{IN} = 0.0 \text{ V}$ | | | | | | _ | 60.0 | _ | _ | $V_{CC} = 3.0 \text{ V},$<br>$V_{IN} = 0.0 \text{ V}$ | Reference value | | Input<br>capaci-<br>tance | C <sub>in</sub> | All input pins<br>except power<br>supply pins | _ | _ | 15.0 | pF | f = 1 MHz,<br>$V_{IN} = 0.0 \text{ V},$<br>$T_a = 25^{\circ}\text{C}$ | | | Active<br>mode<br>current<br>dissipation | I <sub>OPE1</sub> | V <sub>cc</sub> | | 15.0 | 22.5 | mA | Active mode 1<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | | | | _ | 8.0 | _ | | Active mode 1<br>$V_{CC} = 3.0 \text{ V},$<br>$f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | | I <sub>OPE2</sub> | V <sub>cc</sub> | _ | 1.8 | 2.7 | mA | Active mode 2<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | | | | _ | 1.2 | _ | | Active mode 2 $V_{CC} = 3.0 \text{ V},$ $f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | Sleep<br>mode<br>current<br>dissipation | I <sub>SLEEP1</sub> | V <sub>CC</sub> | _ | 7.1 | 13.0 | mA | Sleep mode 1<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | | | | _ | 4.0 | _ | | Sleep mode 1<br>$V_{CC} = 3.0 \text{ V},$<br>$f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | | I <sub>SLEEP2</sub> | V <sub>cc</sub> | _ | 1.1 | 2.0 | mA | Sleep mode 2<br>$V_{CC} = 5.0 \text{ V},$<br>$f_{OSC} = 16 \text{ MHz}$ | * | | | | | - | 0.5 | _ | | Sleep mode 2<br>$V_{CC} = 3.0 \text{ V},$<br>$f_{OSC} = 10 \text{ MHz}$ | *<br>Reference<br>value | | Subactive<br>mode<br>current<br>dissipation | I <sub>SUB</sub> | V <sub>cc</sub> | _ | 35.0 | 70.0 | μА | $V_{CC} = 3.0 \text{ V}$<br>32-kHz crystal<br>oscillator<br>$(\varnothing_{SUB} = \varnothing_{W}/2)$ | * | | | | | _ | 25.0 | _ | | $V_{CC} = 3.0 \text{ V}$<br>32-kHz crystal oscillator $(\emptyset_{SUB} = \emptyset_{W}/8)$ | *<br>Reference<br>value | | Subsleep<br>mode<br>current<br>dissipation | I <sub>SUBSP</sub> | V <sub>cc</sub> | _ | 25.0 | 50.0 | μА | $V_{CC} = 3.0 \text{ V}$<br>32-kHz crystal<br>oscillator<br>$(\varnothing_{SUB} = \varnothing_{W}/2)$ | * | | | | | values | | | | | | |-------------------------------------------|-------------------|-----------------|--------|-----|-----|------|------------------------------------|-------| | Item | Symbol | Applicable Pins | Min | Тур | Max | Unit | Test Condition | Notes | | Standby<br>mode<br>current<br>dissipation | I <sub>STBY</sub> | V <sub>cc</sub> | _ | _ | 5.0 | μА | 32-kHz crystal oscillator not used | * | | RAM data retaining voltage | V <sub>RAM</sub> | V <sub>cc</sub> | 2.0 | _ | _ | V | | | Note: \* Pin states during current dissipation measurement are given below (excluding current in the pull-up MOS transistors and output buffers). | Mode | <b>RES</b> Pin | Internal State | Other Pins | Oscillator Pins | |----------------|-----------------|----------------------------|-----------------|--------------------------------------------------| | Active mode 1 | V <sub>cc</sub> | Operates | V <sub>cc</sub> | System clock oscillator: ceramic or crystal | | Active mode 2 | | Operates<br>(ø/64) | | Subclock oscillator:<br>Pin X1 = V <sub>SS</sub> | | Sleep mode 1 | V <sub>cc</sub> | Only timers operate | V <sub>CC</sub> | | | Sleep mode 2 | | Only timers operate (ø/64) | | | | Subactive mode | V <sub>CC</sub> | Operates | V <sub>cc</sub> | System clock oscillator: ceramic or crystal | | Subsleep mode | V <sub>cc</sub> | Only time base operates | V <sub>CC</sub> | Subclock oscillator: crystal | | Standby mode | V <sub>CC</sub> | CPU and timers both stop | V <sub>cc</sub> | System clock oscillator: ceramic or crystal | | | | | | Subclock oscillator:<br>Pin X1 = V <sub>SS</sub> | ### Table 18.9 DC Characteristics (2) $V_{CC}$ = 2.7 V to 5.5 V, $V_{SS}$ = 0.0 V, $T_a$ = –20°C to +75°C, unless otherwise indicated. | | | | Values | | | | | | |----------------------------------------|----------------------------------------------|-------------------|--------|-----|------|------|----------------------------------|--| | Item | | Symbol | Min | Тур | Max | Unit | <b>Test Condition</b> | | | Allowable output low current (per pin) | Output pins<br>except port 8,<br>SCL and SDA | I <sub>OL</sub> | _ | | 2.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | | | Port 8 | _ | _ | _ | 20.0 | _ | | | | | SCL and SDA | _ | _ | _ | 6.0 | _ | | | | | Port 8 | _ | _ | _ | 10.0 | | | | | | Output pins<br>except port 8,<br>SCL and SDA | _ | _ | _ | 0.5 | | | | | Allowable output low current (total) | Output pins<br>except port 8,<br>SCL and SDA | $\Sigma I_{OL}$ | _ | _ | 40.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | | | Port 8,<br>SCL and SDA | _ | _ | _ | 80.0 | | | | | | Output pins<br>except port 8,<br>SCL and SDA | _ | _ | _ | 20.0 | _ | | | | | Port 8,<br>SCL and SDA | _ | _ | _ | 40.0 | | | | | Allowable output high | All output pins | -I <sub>OH</sub> | _ | _ | 2.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | | current (per pin) | | | _ | _ | 0.2 | | | | | Allowable output high | All output pins | $\Sigma(-I_{OH})$ | _ | _ | 30.0 | mA | V <sub>CC</sub> = 4.0 V to 5.5 V | | | current (total) | | | _ | _ | 8.0 | _ | | | #### 18.3.3 AC Characteristics Table 18.10 lists the AC characteristics. Tables 18.11 and 18.12 list the PC bus interface timing and the serial interface timing, respectively. #### **Table 18.10 AC Characteristics** $V_{CC} = 2.7 \text{ V}$ to 5.5 V, $V_{SS} = 0.0 \text{ V}$ , $T_a = -20^{\circ}\text{C}$ to $+75^{\circ}\text{C}$ , unless otherwise specified. | | | Applicable | | Values | | | | Reference | |-----------------------------------------------------|---------------------|---------------|------|--------|------|------------------|--------------------------------------------|-------------| | Item | Symbol | Pins | Min | Тур | Max | Unit | Test Condition | Figure | | System clock oscillation | f <sub>OSC</sub> | OSC1,<br>OSC2 | 2.0 | _ | 16.0 | MHz | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | *1 | | frequency | | | 2.0 | | 10.0 | | | _ | | System clock (ø) | t <sub>cyc</sub> | | 1 | _ | 64 | t <sub>osc</sub> | _ | *2 | | cycle time | | | _ | _ | 12.8 | μs | | | | Subclock oscillation frequency | f <sub>W</sub> | X1, X2 | _ | 32.768 | _ | kHz | | | | Watch clock (ø <sub>w</sub> ) cycle time | t <sub>W</sub> | X1, X2 | _ | 30.5 | _ | μs | | | | Subclock (Ø <sub>SUB</sub> )<br>cycle time | t <sub>subcyc</sub> | | 2 | _ | 8 | t <sub>W</sub> | | *2 | | Instruction cycle time | | | 2 | _ | _ | t <sub>cyc</sub> | | | | Oscillation stabilization time (crystal oscillator) | t <sub>rc</sub> | OSC1,<br>OSC2 | _ | _ | 10.0 | ms | | | | Oscillation stabilization time (ceramic oscillator) | t <sub>rc</sub> | OSC1,<br>OSC2 | _ | _ | 5.0 | ms | | | | Oscillation stabilization time | t <sub>rcx</sub> | X1, X2 | _ | _ | 2.0 | S | | | | External clock | t <sub>CPH</sub> | OSC1 | 25.0 | _ | _ | ns | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.1 | | high width | | | 40.0 | _ | _ | _ | | = | | External clock | t <sub>CPL</sub> | OSC1 | 25.0 | _ | _ | ns | V <sub>CC</sub> = 4.0 V to 5.5 V | _ | | low width | | | 40.0 | _ | _ | | | | | External clock | t <sub>CPr</sub> | OSC1 | _ | _ | 10.0 | ns | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | | | rise time | | | _ | _ | 15.0 | | | | | External clock | t <sub>CPf</sub> | OSC1 | _ | _ | 10.0 | ns | V <sub>CC</sub> = 4.0 V to 5.5 V | _ | | fall time | | | | | 15.0 | | | | | | | Applicable | | Value | Values | | | Reference | |-------------------------|------------------|----------------------------------------------------------------------------|-----------------|-------|--------|-----------------------------------------|-------------------------------------------------|-------------| | Item | Symbol | Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Figure | | RES pin low width | t <sub>REL</sub> | RES | t <sub>rc</sub> | _ | _ | ms | At power-on and in modes other than those below | Figure 18.2 | | | | | 10 | | | t <sub>cyc</sub> | In active mode and sleep mode operation | | | Input pin high<br>width | t <sub>IH</sub> | NMI, IRQ0 to IRQ3, WKP0 to WKP5, TMCIV, TMRIV, TRGV, ADTRG, FTCI, FTIOA to | 2 | _ | _ | t <sub>cyc</sub> | | Figure 18.3 | | Input pin low width | t <sub>IL</sub> | NMI, IRQ0 to IRQ3, WKP0 to WKP5, TMCIV, TMRIV, TRGV, ADTRG, FTIOA to | 2 | _ | _ | t <sub>cyc</sub><br>t <sub>subcyc</sub> | | | Notes: 1. When an external clock is input, the minimum system clock oscillator frequency is 1.0 MHz. **FTIOD** <sup>2.</sup> Determined by MA2, MA1, MA0, SA1, and SA0 of system control register 2 (SYSCR2). ### Table 18.11 I<sup>2</sup>C Bus Interface Timing $V_{CC} = 2.7 \text{ V}$ to 5.5 V, $V_{SS} = 0.0 \text{ V}$ , $T_a = -20 \text{ to } +75^{\circ}\text{C}$ , unless otherwise specified. | | | | Values | | | Test | Reference | |--------------------------------------------------|-------------------|--------------------------|--------|-------------------|------|-----------------------------------|-------------| | Item | Symbol | Min | Тур | Max | Unit | Condition | Figure | | SCL input cycle time | t <sub>SCL</sub> | 12t <sub>cyc</sub> + 600 | _ | | ns | | Figure 18.4 | | SCL input high width | t <sub>SCLH</sub> | 3t <sub>cyc</sub> + 300 | | | ns | | _ | | SCL input low width | t <sub>SCLL</sub> | 5t <sub>cyc</sub> + 300 | | | ns | | _ | | Input fall time of SCL and SDA | t <sub>Sf</sub> | | | 300 | ns | | - | | SCL and SDA input<br>spike pulse removal<br>time | t <sub>SP</sub> | _ | _ | 1t <sub>cyc</sub> | ns | | _ | | SDA input bus-free time | t <sub>BUF</sub> | 5t <sub>cyc</sub> | | | ns | | _ | | Start condition input hold time | t <sub>STAH</sub> | 3t <sub>cyc</sub> | _ | _ | ns | | | | Retransmission start condition input setup time | t <sub>STAS</sub> | 3t <sub>cyc</sub> | _ | _ | ns | | | | Setup time for stop condition input | t <sub>stos</sub> | 3t <sub>cyc</sub> | _ | _ | ns | | _ | | Data-input setup time | t <sub>SDAS</sub> | 0.5t <sub>cyc</sub> | _ | _ | ns | | _ | | Data-input hold time | t <sub>SDAH</sub> | 0 | _ | _ | ns | | _ | | Capacitive load of SCL and SDA | C <sub>b</sub> | 0 | _ | 400 | pF | | _ | | SCL and SDA output fall time | t <sub>Sf</sub> | _ | _ | 250 | ns | $V_{cc} = 4.0 \text{ V}$ to 5.5 V | _ | | | | _ | _ | 300 | _ | | _ | Note: \* The value can be changed to $17.5t_{cyc}$ , depending on the clock used in the $I^2C$ module. ### Table 18.12 Serial Interface (SCI3) Timing $V_{CC}$ = 2.7 V to 5.5 V, $V_{SS}$ = 0.0 V, $T_a$ = –20°C to +75°C, unless otherwise specified. | | | | Applicable | | Values | \$ | | | Reference | |--------------------------------------|--------------------|-------------------|------------|-------|--------|-----|-------------------|--------------------------------------------|-------------| | Item | Item | | Pins | Min | Тур | Max | Unit | <b>Test Condition</b> | Figure | | Input<br>clock | Asynchro-<br>nous | t <sub>Scyc</sub> | SCK3 | 4 | _ | _ | t <sub>cyc</sub> | | Figure 18.5 | | cycle | Synchro-<br>nous | _ | | 6 | _ | _ | _ | | | | Input cla | ck pulse | t <sub>SCKW</sub> | SCK3 | 0.4 | _ | 0.6 | t <sub>Scyc</sub> | | Figure 18.5 | | Transmi | t data delay | t <sub>TXD</sub> | TXD | _ | _ | 1 | t <sub>cyc</sub> | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.6 | | time (sy | nchronous) | | | _ | _ | 1 | _ | | - | | Receive | Receive data setup | | RXD | 62.5 | _ | _ | ns | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.6 | | time (synchronous) | | | | 100.0 | _ | _ | _ | | - | | Receive data hold time (synchronous) | | t <sub>RXH</sub> | RXD | 62.5 | _ | _ | ns | $V_{CC} = 4.0 \text{ V to } 5.5 \text{ V}$ | Figure 18.6 | | | | | | 100.0 | _ | _ | _ | | - | ### 18.3.4 A/D Converter Characteristics ### **Table 18.13 A/D Converter Characteristics** $V_{CC}$ = 2.7 V to 5.5 V, $V_{SS}$ = 0.0 V, $T_a$ = -20°C to +75°C, unless otherwise specified. | | | Applicable | | Values | | i | | Reference | |-----------------------------------|---------------------|------------------|-----------------------|-----------------|------------------------|------------------|---------------------------------------|--------------------------| | Item | Symbol | Pins | Min | Тур | Max | Unit | Test<br>Condition | Figure | | Analog power supply voltage | AV <sub>CC</sub> | AV <sub>CC</sub> | 3.0 | V <sub>cc</sub> | 5.5 | V | | *1 | | Analog input voltage | AV <sub>IN</sub> | AN0 to<br>AN7 | V <sub>SS</sub> - 0.3 | _ | AV <sub>CC</sub> + 0.3 | V | | | | Analog power | Al <sub>OPE</sub> | AV <sub>CC</sub> | _ | _ | 2.0 | mA | AV <sub>CC</sub> = 5.0 V | | | | | | | | | | f <sub>OSC</sub> =<br>16 MHz | | | supply current | Al <sub>STOP1</sub> | AV <sub>CC</sub> | <u> </u> | 50 | <u> </u> | μΑ | | *2<br>Reference<br>value | | | AI <sub>STOP2</sub> | AV <sub>cc</sub> | _ | _ | 5.0 | μΑ | | *3 | | Analog input capacitance | C <sub>AIN</sub> | AN0 to<br>AN7 | _ | _ | 30.0 | pF | | | | Allowable signal source impedance | R <sub>AIN</sub> | AN0 to<br>AN7 | | _ | 5.0 | kΩ | | | | Resolution | | | 10 | 10 | 10 | bit | | | | Conversion time (single mode) | | | 134 | | _ | t <sub>cyc</sub> | $AV_{CC} = 3.0 \text{ V}$<br>to 5.5 V | | | Nonlinearity error | | | _ | _ | ±7.5 | LSB | = | | | Offset error | | | _ | _ | ±7.5 | LSB | = | | | Full-scale error | | | _ | _ | ±7.5 | LSB | _ | | | Quantization error | | | _ | _ | ±0.5 | LSB | _ | | | Absolute accuracy | | | _ | _ | ±8.0 | LSB | _ | | | Conversion time (single mode) | | | 70 | _ | _ | t <sub>cyc</sub> | $AV_{CC} = 4.0 \text{ V}$<br>to 5.5 V | | | Nonlinearity error | | | _ | _ | ±7.5 | LSB | _ | | | Offset error | | | _ | _ | ±7.5 | LSB | _ | | | Full-scale error | | | _ | _ | ±7.5 | LSB | _ | | | Quantization error | | | _ | _ | ±0.5 | LSB | _ | | | Absolute accuracy | | | | _ | ±8.0 | LSB | | | | | | | Applicable | Values | | | | Test | Reference | |----|------------------------------|--------|------------|--------|-----|------|------------------|--------------------------------------|-----------| | lt | Item | Symbol | Pins | Min | Тур | Max | Unit | Condition | Figure | | | Conversion time single mode) | | | 134 | _ | _ | t <sub>cyc</sub> | AV <sub>CC</sub> = 4.0 V<br>to 5.5 V | | | | Nonlinearity error | | | _ | | ±3.5 | LSB | _ | | | | Offset error | | | _ | | ±3.5 | LSB | _ | | | | Full-scale error | | | _ | | ±3.5 | LSB | _ | | | | Quantization error | | | _ | | ±0.5 | LSB | _ | | | | Absolute accuracy | " | | | | ±4.0 | LSB | _ | | Notes: 1. Set $AV_{CC} = V_{CC}$ when the A/D converter is not used. - 2. Al<sub>STOP1</sub> is the current in active and sleep modes while the A/D converter is idle. - Al<sub>STOP2</sub> is the current at reset and in standby, subactive, and subsleep modes while the A/D converter is idle. #### 18.3.5 Watchdog Timer #### **Table 18.14 Watchdog Timer Characteristics** $V_{CC} = 2.7 \text{ V}$ to 5.5 V, $V_{SS} = 0.0 \text{ V}$ , $T_a = -20^{\circ}\text{C}$ to $+75^{\circ}\text{C}$ , unless otherwise specified. | | | Applicable | Values | | | | Test | Reference | |-------------------------------------------|------------------|------------|--------|-----|-----|------|-----------|-----------| | Item | Symbol | Pins | Min | Тур | Max | Unit | Condition | Figure | | On-chip<br>oscillator<br>overflow<br>time | t <sub>ovf</sub> | | 0.2 | 0.4 | _ | S | | * | Note: \* Shows the time to count from 0 to 255, at which point an internal reset is generated, when the internal oscillator is selected. # **18.4** Operation Timing Figure 18.1 System Clock Input Timing Figure 18.2 RES Low Width Timing Figure 18.3 Input Timing Figure 18.4 I<sup>2</sup>C Bus Interface Input/Output Timing Figure 18.5 SCK3 Input Clock Timing Figure 18.6 Serial Interface 3 Synchronous Mode Input/Output Timing # 18.5 Output Load Circuit Figure 18.7 Output Load Condition # Appendix A Instruction Set #### A.1 Instruction List # **Operand Notation** | Symbol | Description | |---------------|---------------------------------------------------------------------------------------------------------------------------------------| | Rd | General destination register | | Rs | General source register | | Rn | General register | | ERd | General destination register (address register or 32-bit register) | | ERs | General source register (address register or 32-bit register) | | ERn | General register (32-bit register) | | (EAd) | Destination operand | | (EAs) | Source operand | | PC | Program counter | | SP | Stack pointer | | CCR | Condition code register | | N | N (negative) flag in CCR | | Z | Z (zero) flag in CCR | | V | V (overflow) flag in CCR | | С | C (carry) flag in CCR | | disp | Displacement | | $\rightarrow$ | Transfer from the operand on the left to the operand on the right, or transition from the state on the left to the state on the right | | + | Addition of the operands on both sides | | _ | Subtraction of the operand on the right from the operand on the left | | × | Multiplication of the operands on both sides | | ÷ | Division of the operand on the left by the operand on the right | | ٨ | Logical AND of the operands on both sides | | V | Logical OR of the operands on both sides | | $\oplus$ | Exclusive logical OR of the operands on both sides | | 7 | NOT (logical complement) | | (), <> | Contents of operand | Note: General registers include 8-bit registers (R0H to R7H and R0L to R7L) and 16-bit registers (R0 to R7 and E0 to E7). #### **Condition Code Notation** | Symbol | Description | |---------|----------------------------------------------------| | <b></b> | Changed according to execution result | | * | Undetermined (no guaranteed value) | | 0 | Cleared to 0 | | 1 | Set to 1 | | _ | Not affected by execution of the instruction | | Δ | Varies depending on conditions, described in notes | #### **Table A.1** Instruction Set #### 1. Data transfer instructions | | | | | | | essi | | | | nd<br>/tes | ) | | | | | | | No<br>Stat | . of<br>es <sup>*1</sup> | |------------------------|--------------|-------------------------------------------------------|-----|---|------|-----------|-------------|----------|----------|------------|---|----------|-----|----------|------|-----|----------|------------|--------------------------| | Mnemonic | Operand Size | Operation | × | | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | n Co | ode | | Normal | Advanced | | | ŏ | | XX# | ~ | @ | <b>®</b> | <b>®</b> | <b>®</b> | @ | @ | ı | I | Н | N | z | ٧ | С | ž | ¥ | | MOV.B #xx:8, Rd | В | #xx:8 → Rd8 | 2 | | | | | | | | | _ | _ | 1 | 1 | 0 | _ | | 2 | | MOV.B Rs, Rd | В | Rs8 → Rd8 | | 2 | | | | | | | | _ | | 1 | 1 | 0 | - | 2 | 2 | | MOV.B @ERs, Rd | В | @ERs → Rd8 | | | 2 | | | | | | | _ | _ | 1 | 1 | 0 | - | 4 | 4 | | MOV.B @(d:16, ERs), Rd | В | @(d:16, ERs) → Rd8 | | | | 4 | | | | | | _ | _ | 1 | 1 | 0 | - | 6 | 6 | | MOV.B @(d:24, ERs), Rd | В | @(d:24, ERs) → Rd8 | | | | 8 | | | | | | _ | _ | 1 | 1 | 0 | - | 1 | 0 | | MOV.B @ERs+, Rd | В | @ERs $\rightarrow$ Rd8<br>ERs32+1 $\rightarrow$ ERs32 | | | | | 2 | | | | | - | _ | 1 | 1 | 0 | - | ( | 6 | | MOV.B @aa:8, Rd | В | @aa:8 → Rd8 | | | | | | 2 | | | | _ | _ | <b>1</b> | 1 | 0 | _ | 4 | 4 | | MOV.B @aa:16, Rd | В | @aa:16 → Rd8 | | | | | | 4 | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 6 | | MOV.B @aa:24, Rd | В | @aa:24 → Rd8 | | | | | | 6 | | | | _ | _ | 1 | 1 | 0 | _ | 8 | В | | MOV.B Rs, @ERd | В | Rs8 → @ERd | | | 2 | | | | | | | _ | _ | 1 | 1 | 0 | _ | | 4 | | MOV.B Rs, @(d:16, ERd) | В | Rs8 → @(d:16, ERd) | | | | 4 | | | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 6 | | MOV.B Rs, @(d:24, ERd) | В | Rs8 → @(d:24, ERd) | | | | 8 | | | | | | _ | _ | 1 | 1 | 0 | _ | 1 | 0 | | MOV.B Rs, @-ERd | В | ERd32–1 $\rightarrow$ ERd32<br>Rs8 $\rightarrow$ @ERd | | | | | 2 | | | | | - | _ | \$ | \$ | 0 | - | 6 | 6 | | MOV.B Rs, @aa:8 | В | Rs8 → @aa:8 | | | | | | 2 | | | | _ | _ | 1 | 1 | 0 | _ | | 4 | | MOV.B Rs, @aa:16 | В | Rs8 → @aa:16 | | | | | | 4 | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 6 | | MOV.B Rs, @aa:24 | В | Rs8 → @aa:24 | | | | | | 6 | | | | _ | _ | 1 | 1 | 0 | _ | 8 | В | | MOV.W #xx:16, Rd | W | #xx:16 → Rd16 | 4 | | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 4 | 4 | | MOV.W Rs, Rd | W | Rs16 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 2 | 2 | | MOV.W @ERs, Rd | W | @ERs → Rd16 | | | 2 | | | | | | | _ | _ | 1 | 1 | 0 | _ | 4 | 4 | | MOV.W @(d:16, ERs), Rd | W | @(d:16, ERs) → Rd16 | | | | 4 | | | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 6 | | MOV.W @(d:24, ERs), Rd | W | @(d:24, ERs) → Rd16 | | | | 8 | | | | | | _ | _ | 1 | 1 | 0 | _ | 1 | 0 | | MOV.W @ERs+, Rd | W | @ERs → Rd16<br>ERs32+2 → @ERd32 | | | | | 2 | | | | | - | _ | \$ | \$ | 0 | - | 6 | 6 | | MOV.W @aa:16, Rd | W | @aa:16 → Rd16 | | | | | | 4 | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 6 | | MOV.W @aa:24, Rd | W | @aa:24 → Rd16 | | | | | | 6 | | | | <u> </u> | _ | 1 | 1 | 0 | 1_ | 8 | B | | MOV.W Rs, @ERd | W | Rs16 → @ERd | | | 2 | | | | | | | <u> </u> | _ | 1 | 1 | 0 | 1_ | | 4 | | MOV.W Rs, @(d:16, ERd) | W | Rs16 → @(d:16, ERd) | | | | 4 | | | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 6 | | MOV.W Rs, @(d:24, ERd) | W | , , , | | | | 8 | | | | | | <u> </u> | _ | <b>1</b> | 1 | 0 | <u> </u> | 1 | 0 | | | | | | | | | • | Mod<br>ngth | | | ) | | | | | | | No. | | |-------------------------|--------------|------------------------------------------------------------|-----|----|------|-----------|-------------|-------------|----------|--------|---|---|-----------|----------|----------|-----|---|--------|----------| | Mnemonic | Operand Size | Operation | xx# | Rn | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @ @ aa | ı | ı | Con | ditio | n Co | ode | С | Normal | Advanced | | MOV.W Rs, @-ERd | W | ERd32–2 $\rightarrow$ ERd32<br>Rs16 $\rightarrow$ @ERd | | | | | 2 | | | | | - | _ | 1 | 1 | 0 | _ | 6 | ; | | MOV.W Rs, @aa:16 | W | Rs16 → @aa:16 | | | | | | 4 | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 6 | | | MOV.W Rs, @aa:24 | W | Rs16 → @aa:24 | | | | | | 6 | | | | _ | _ | 1 | <b>1</b> | 0 | _ | 8 | 3 | | MOV.L #xx:32, Rd | L | #xx:32 → Rd32 | 6 | | | | | | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 6 | ; | | MOV.L ERs, ERd | L | ERs32 → ERd32 | | 2 | | | | | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 2 | ) | | MOV.L @ERs, ERd | L | @ERs → ERd32 | | | 4 | | | | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 8 | } | | MOV.L @(d:16, ERs), ERd | L | @(d:16, ERs) → ERd32 | | | | 6 | | | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 10 | 0 | | MOV.L @(d:24, ERs), ERd | L | @(d:24, ERs) → ERd32 | | | | 10 | | | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 1 | 4 | | MOV.L @ERs+, ERd | L | @ERs → ERd32<br>ERs32+4 → ERs32 | | | | | 4 | | | | | _ | _ | 1 | 1 | 0 | _ | 10 | 0 | | MOV.L @aa:16, ERd | L | @aa:16 → ERd32 | | | | | | | | | | _ | _ | 1 | <b>1</b> | 0 | _ | 10 | 0 | | MOV.L @aa:24, ERd | L | @aa:24 → ERd32 | | | | | | 6 | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 1: | 2 | | MOV.L ERs, @ERd | L | ERs32 → @ERd | | | 4 | | | 8 | | | | _ | _ | 1 | <b>1</b> | 0 | _ | 8 | } | | MOV.L ERs, @(d:16, ERd) | L | ERs32 → @(d:16, ERd) | | | | 6 | | | | | | _ | _ | 1 | <b>1</b> | 0 | _ | 10 | 0 | | MOV.L ERs, @(d:24, ERd) | L | ERs32 → @(d:24, ERd) | | | | 10 | | | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 1- | 4 | | MOV.L ERs, @-ERd | L | ERd32–4 → ERd32<br>ERs32 → @ERd | | | | | 4 | | | | | - | _ | 1 | 1 | 0 | - | 10 | 0 | | MOV.L ERs, @aa:16 | L | ERs32 → @aa:16 | | | | | | | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 10 | 0 | | MOV.L ERs, @aa:24 | L | ERs32 → @aa:24 | | | | | | 6 | | | | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 1: | 2 | | POP.W Rn | W | | | | | | | 8 | | | 2 | - | _ | 1 | 1 | 0 | - | 6 | j | | POP.L ERn | L | | | | | | | | | | 4 | _ | _ | <b>1</b> | <b>1</b> | 0 | _ | 10 | 0 | | PUSH.W Rn | W | $\begin{array}{c} SP-2 \to SP \\ Rn16 \to @SP \end{array}$ | | | | | | | | | 2 | - | _ | 1 | 1 | 0 | - | 6 | <b>,</b> | | PUSH.L ERn | L | $SP-4 \rightarrow SP$<br>$ERn32 \rightarrow @SP$ | | | | | | | | | 4 | _ | _ | 1 | 1 | 0 | _ | 10 | 0 | | MOVFPE @aa:16, Rd | В | Cannot be used in the H8/3664 Series | | | | | | 4 | | | | | inno | | | | | 1 | | | MOVTPE Rs, @aa:16 | В | Cannot be used in the H8/3664 Series | | | | | | 4 | | | | | nno<br>H8 | | | | | | | #### 2. Arithmetic instructions | | | | | | | essi | | | | nd<br>/tes | ) | | | | | | | No<br>Stat | of<br>tes*1 | |-------------------|--------------|---------------------------------|----------|----|------|-----------|-------------|-----|----------|------------|---|---|----------|----------|----------|----------|----------|------------|-------------| | Mnemonic | Operand Size | Operation | #xx | Rn | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @ @ aa | | | | | on Co | | | Normal | Advanced | | ADD.B #xx:8, Rd | _ | Rd8+#xx:8 → Rd8 | <b>#</b> | œ | 0 | 9 | 9 | 9 | 9 | 0 | I | 1 | <b>H</b> | N | <b>z</b> | <b>∨</b> | <b>C</b> | | 2 <b>~</b> | | ADD.B Rs, Rd | В | Rd8+Rs8 → Rd8 | | 2 | | | | | | | | | 1 | 1 | 1 | 1 | 1 | _ | <br>2 | | ADD.W #xx:16, Rd | W | Rd16+#xx:16 → Rd16 | 4 | _ | | | | | | | | | (1) | 1 | 1 | <b>1</b> | 1 | _ | <br>4 | | ADD.W Rs, Rd | | Rd16+Rs16 → Rd16 | _ | 2 | | | | | | | | | (1) | 1 | 1 | 1 | 1 | _ | ·<br>2 | | ADD.L #xx:32, ERd | | ERd32+#xx:32 →<br>ERd32 | 6 | | | | | | | | | _ | (2) | <b>1</b> | \$ | <b>1</b> | \$ | <u> </u> | 6 | | ADD.L ERs, ERd | L | ERd32+ERs32 →<br>ERd32 | | 2 | | | | | | | | _ | (2) | \$ | \$ | \$ | \$ | 2 | 2 | | ADDX.B #xx:8, Rd | В | Rd8+#xx:8 +C $\rightarrow$ Rd8 | 2 | | | | | | | | | _ | 1 | 1 | (3) | 1 | 1 | : | 2 | | ADDX.B Rs, Rd | В | $Rd8+Rs8+C \rightarrow Rd8$ | | 2 | | | | | | | | _ | 1 | 1 | (3) | 1 | 1 | : | 2 | | ADDS.L #1, ERd | L | ERd32+1 → ERd32 | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | ADDS.L #2, ERd | L | ERd32+2 → ERd32 | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | ADDS.L #4, ERd | L | ERd32+4 → ERd32 | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | INC.B Rd | В | $Rd8+1 \rightarrow Rd8$ | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | 2 | 2 | | INC.W #1, Rd | W | Rd16+1 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | 2 | 2 | | INC.W #2, Rd | W | Rd16+2 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | 2 | 2 | | INC.L #1, ERd | L | ERd32+1 → ERd32 | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | : | 2 | | INC.L #2, ERd | L | ERd32+2 → ERd32 | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | : | 2 | | DAA Rd | В | Rd8 decimal adjust → Rd8 | | 2 | | | | | | | | _ | * | \$ | 1 | * | _ | 2 | 2 | | SUB.B Rs, Rd | В | Rd8–Rs8 → Rd8 | | 2 | | | | | | | | _ | 1 | 1 | 1 | 1 | 1 | 2 | 2 | | SUB.W #xx:16, Rd | W | Rd16–#xx:16 → Rd16 | 4 | | | | | | | | | _ | (1) | 1 | 1 | 1 | 1 | 4 | 4 | | SUB.W Rs, Rd | W | Rd16–Rs16 → Rd16 | | 2 | | | | | | | | _ | (1) | 1 | 1 | 1 | 1 | 2 | 2 | | SUB.L #xx:32, ERd | L | ERd32-#xx:32 → ERd32 | 6 | | | | | | | | | _ | (2) | 1 | 1 | 1 | 1 | 6 | 6 | | SUB.L ERs, ERd | L | ERd32–ERs32 → ERd32 | | 2 | | | | | | | | _ | (2) | 1 | 1 | 1 | 1 | 2 | 2 | | SUBX.B #xx:8, Rd | В | Rd8-#xx:8-C $\rightarrow$ Rd8 | 2 | | | | | | | | | _ | 1 | 1 | (3) | 1 | 1 | 7 | 2 | | SUBX.B Rs, Rd | В | $Rd8\text{-}Rs8\text{-}C\toRd8$ | | 2 | | | | | | | | _ | 1 | 1 | (3) | 1 | 1 | 7 | 2 | | SUBS.L #1, ERd | L | ERd32−1 → ERd32 | | 2 | | | | | | | | _ | _ | _ | - | _ | _ | - ; | 2 | | SUBS.L #2, ERd | L | ERd32−2 → ERd32 | | 2 | | | | | | | | _ | _ | _ | - | _ | - | - ; | 2 | | SUBS.L #4, ERd | L | ERd32–4 → ERd32 | | 2 | | | | | | | | _ | _ | _ | - | _ | - | 7 | 2 | | DEC.B Rd | В | $Rd8-1 \rightarrow Rd8$ | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | 7 | 2 | | DEC.W #1, Rd | W | Rd16–1 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | : | 2 | | DEC.W #2, Rd | W | Rd16–2 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | _ | 7 | 2 | | | | | | A<br>Inst | | | _ | Mod | | | ) | | | | | | | No<br>Stat | of<br>es*1 | |-------------------|--------------|---------------------------------------------------------------------------------|-----|-----------|------|-----------|-------------|-----|----------|-----|---|---|----------|----------|----------|----------|----------|------------|------------| | Mnemonic | Operand Size | Operation | × | | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | on Co | ode | | Normal | Advanced | | | ğ | | XX# | ೱ | (9) | 0 | ė | (9) | (9) | (9) | 1 | I | Н | N | z | ٧ | С | ž | A | | DEC.L #1, ERd | L | ERd32−1 → ERd32 | | 2 | | | | | | | | _ | — | 1 | 1 | 1 | _ | : | 2 | | DEC.L #2, ERd | L | ERd32–2 → ERd32 | | 2 | | | | | | | | — | — | 1 | 1 | 1 | — | : | 2 | | DAS.Rd | В | Rd8 decimal adjust → Rd8 | | 2 | | | | | | | | _ | * | 1 | 1 | * | _ | 2 | 2 | | MULXU. B Rs, Rd | В | Rd8 × Rs8 → Rd16 (unsigned multiplication) | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 1 | 4 | | MULXU. W Rs, ERd | W | Rd16 × Rs16 → ERd32 (unsigned multiplication) | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | MULXS. B Rs, Rd | В | Rd8 × Rs8 → Rd16 (signed multiplication) | | 4 | | | | | | | | - | - | 1 | <b>1</b> | - | - | 1 | 6 | | MULXS. W Rs, ERd | W | Rd16 × Rs16 → ERd32 (signed multiplication) | | 4 | | | | | | | | - | - | 1 | <b>1</b> | - | - | 2 | 4 | | DIVXU. B Rs, Rd | В | Rd16 + Rs8 → Rd16<br>(RdH: remainder,<br>RdL: quotient)<br>(unsigned division) | | 2 | | | | | | | | _ | _ | (6) | (7) | _ | _ | 1 | 4 | | DIVXU. W Rs, ERd | W | ERd32 ÷ Rs16 → ERd32<br>(Ed: remainder,<br>Rd: quotient)<br>(unsigned division) | | 2 | | | | | | | | _ | _ | (6) | (7) | _ | _ | 2 | 2 | | DIVXS. B Rs, Rd | В | Rd16 ÷ Rs8 → Rd16<br>(RdH: remainder,<br>RdL: quotient)<br>(signed division) | | 4 | | | | | | | | _ | _ | (8) | (7) | _ | _ | 1 | 6 | | DIVXS. W Rs, ERd | W | ERd32 ÷ Rs16 → ERd32<br>(Ed: remainder,<br>Rd: quotient)<br>(signed division) | | 4 | | | | | | | | _ | _ | (8) | (7) | _ | _ | 2 | 4 | | CMP.B #xx:8, Rd | В | Rd8-#xx:8 | 2 | | | | | | | | | _ | 1 | <b>1</b> | 1 | 1 | 1 | : | 2 | | CMP.B Rs, Rd | В | Rd8-Rs8 | | 2 | | | | | | | | _ | <b>1</b> | 1 | 1 | 1 | 1 | : | 2 | | CMP.W #xx:16, Rd | W | Rd16-#xx:16 | 4 | | | | | | | | | _ | (1) | 1 | 1 | 1 | 1 | 4 | 4 | | CMP.W Rs, Rd | W | Rd16-Rs16 | | 2 | | | | | | | | _ | (1) | <b>1</b> | 1 | \$ | <b>1</b> | : | 2 | | CMP.L #xx:32, ERd | L | ERd32-#xx:32 | 6 | | | | | | | | | | (2) | <b>1</b> | 1 | <b>1</b> | <b>1</b> | 4 | 4 | | CMP.L ERs, ERd | L | ERd32-ERs32 | | 2 | | | | | | | | _ | (2) | 1 | 1 | 1 | \$ | : | 2 | | | | | | | ddre | | • | | | | ) | | | | | | | No<br>Stat | . of<br>es*1 | |------------|--------------|----------------------------------------------------------------------------|-----|---|------|-----------|-------------|----------|----------|----------|---|---|-----|-------|-------|-----|---|------------|--------------| | Mnemonic | Operand Size | Operation | #xx | u | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | on Co | ode | | Normal | Advanced | | | 0 | | # | ~ | (a) | <b>®</b> | <b>®</b> | <b>®</b> | (a) | <b>a</b> | 1 | ı | Н | N | Z | ٧ | С | _ | | | NEG.B Rd | В | 0–Rd8 → Rd8 | | 2 | | | | | | | | _ | 1 | 1 | 1 | 1 | 1 | 2 | 2 | | NEG.W Rd | W | 0–Rd16 → Rd16 | | 2 | | | | | | | | _ | 1 | 1 | 1 | 1 | 1 | 2 | 2 | | NEG.L ERd | L | 0–ERd32 → ERd32 | | 2 | | | | | | | | _ | 1 | 1 | 1 | 1 | 1 | 2 | 2 | | EXTU.W Rd | W | $0 \rightarrow$ ( <bits 15="" 8="" to=""> of Rd16)</bits> | | 2 | | | | | | | | _ | _ | 0 | \$ | 0 | _ | 2 | 2 | | EXTU.L ERd | L | $0 \rightarrow$ ( <bits 16="" 31="" to=""> of ERd32)</bits> | | 2 | | | | | | | | _ | _ | 0 | \$ | 0 | _ | 2 | 2 | | EXTS.W Rd | W | ( <bit 7=""> of Rd16) → (<bits 15="" 8="" to=""> of Rd16)</bits></bit> | | 2 | | | | | | | | _ | _ | \$ | \$ | 0 | _ | 2 | 2 | | EXTS.L ERd | L | ( <bit 15=""> of ERd32) → (<bits 16="" 31="" to=""> of ERd32)</bits></bit> | | 2 | | | | | | | | _ | _ | \$ | \$ | 0 | _ | 2 | 2 | # 3. Logic instructions | | | | | | | | | Mod | | | ) | | | | | No.<br>Stat | of<br>es*1 | | | |-------------------|--------------|----------------------|-----|---|------|-----------|-------------|-----|----------|-----|---|---|-----|----------|-------|-------------|------------|--------|----------| | Mnemonic | Operand Size | Operation | × | | @ERn | @(d, ERn) | @-ERn/@ERn+ | aa | @(d, PC) | @aa | | | Con | ditio | on Co | ode | | Normal | Advanced | | | ŏ | | XX# | 몺 | (9) | (9) | (9) | 0 | @ | (9) | I | I | Н | N | С | N | ¥ | | | | AND.B #xx:8, Rd | В | Rd8∧#xx:8 → Rd8 | 2 | | | | | | | | | _ | _ | \$ | _ | 2 | 2 | | | | AND.B Rs, Rd | В | Rd8∧Rs8 → Rd8 | | 2 | | | | | | | | — | _ | <b>1</b> | — | 2 | 2 | | | | AND.W #xx:16, Rd | W | Rd16∧#xx:16 → Rd16 | 4 | | | | | | | | | _ | _ | \$ | 1 | 0 | _ | 4 | 4 | | AND.W Rs, Rd | W | Rd16∧Rs16 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 2 | 2 | | AND.L #xx:32, ERd | L | ERd32∧#xx:32 → ERd32 | 6 | | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 3 | | AND.L ERs, ERd | L | ERd32∧ERs32 → ERd32 | | 4 | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 4 | 4 | | OR.B #xx:8, Rd | В | Rd8∨#xx:8 → Rd8 | 2 | | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 2 | 2 | | OR.B Rs, Rd | В | Rd8∨Rs8 → Rd8 | | 2 | | | | | | | | _ | _ | <b>1</b> | 1 | 0 | _ | 2 | 2 | | OR.W #xx:16, Rd | W | Rd16∨#xx:16 → Rd16 | 4 | | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 4 | 4 | | OR.W Rs, Rd | W | Rd16∨Rs16 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 2 | 2 | | OR.L #xx:32, ERd | L | ERd32∨#xx:32 → ERd32 | 6 | | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 3 | | OR.L ERs, ERd | L | ERd32∨ERs32 → ERd32 | | 4 | | | | | | | | _ | _ | <b>1</b> | 1 | 0 | _ | 4 | 1 | | XOR.B #xx:8, Rd | В | Rd8⊕#xx:8 → Rd8 | 2 | | | | | | | | | _ | _ | <b>1</b> | 1 | 0 | _ | 2 | 2 | | XOR.B Rs, Rd | В | Rd8⊕Rs8 → Rd8 | | 2 | | | | | | | | _ | _ | <b>1</b> | 1 | 0 | _ | 2 | 2 | | XOR.W #xx:16, Rd | W | Rd16⊕#xx:16 → Rd16 | 4 | | | | | | | | | _ | _ | <b>1</b> | 1 | 0 | _ | 4 | 1 | | XOR.W Rs, Rd | W | Rd16⊕Rs16 → Rd16 | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 2 | 2 | | XOR.L #xx:32, ERd | L | ERd32⊕#xx:32 → ERd32 | 6 | | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 6 | 3 | | XOR.L ERs, ERd | L | ERd32⊕ERs32 → ERd32 | | 4 | | | | | | | | - | - | <b>1</b> | 1 | 0 | _ | 4 | 4 | | NOT.B Rd | В | ¬ Rd8 → Rd8 | | 2 | | | | | | | | _ | - | 1 | 1 | 0 | _ | 2 | 2 | | NOT.W Rd | W | ¬ Rd16 → Rd16 | | 2 | | | | | | | | _ | _ | <b>1</b> | 1 | 0 | - | 2 | 2 | | NOT.L ERd | L | ¬ Rd32 → Rd32 | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | _ | 2 | 2 | #### 4. Shift instructions | | | | | A<br>Inst | ddre | essi | ng l<br>Ler | Mod | le a | nd<br>/tes | ) | | | | | | | No.<br>Stat | | |-------------|--------------|----------------------|-----|-----------|------|-----------|-------------|-----|----------|------------|---|---|-----|-------|------|-----|--------|-------------|---| | Mnemonic | Operand Size | Operation | × | | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | n Co | ode | Normal | Advanced | | | | Q | | XX# | 조 | @ | <b>@</b> | <u>(a)</u> | @ | @ | (9) | ı | ı | Н | N | z | ٧ | С | ž | ¥ | | SHAL.B Rd | В | C - 0 | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | 1 | 2 | 2 | | SHAL.W Rd | W | | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | 1 | 2 | 2 | | SHAL.L ERd | L | MSB LSB | | 2 | | | | | | | | _ | _ | 1 | 1 | 1 | 1 | 2 | 2 | | SHAR.B Rd | В | <b>-</b> C | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHAR.W Rd | W | | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHAR.L ERd | L | MSB LSB | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHLL.B Rd | В | | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHLL.W Rd | W | C 0 | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHLL.L ERd | L | MSB LSB | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHLR.B Rd | В | | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHLR.W Rd | W | 0 C | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | SHLR.L ERd | L | MSB LSB | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTXL.B Rd | В | | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTXL.W Rd | W | | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTXL.L ERd | L | MSB <del>←</del> LSB | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTXR.B Rd | В | | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTXR.W Rd | W | - C | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTXR.L ERd | L | MSB → LSB | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | > | | ROTL.B Rd | В | | | 2 | | | | | | | | - | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTL.W Rd | W | C | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTL.L ERd | L | MSB ← LSB | | 2 | | | | | | | | - | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTR.B Rd | В | | | 2 | | | | | | | | - | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTR.W Rd | W | -C | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | | ROTR.L ERd | L | MSB ──►LSB | | 2 | | | | | | | | _ | _ | 1 | 1 | 0 | 1 | 2 | 2 | # 5. Bit manipulation instructions | | | | | | | | • | Mod | | | ) | | | | | | | No<br>Stat | of<br>es <sup>*1</sup> | |-------------------|--------------|---------------------------------------|-----|---|------|-----------|-------------|-----|----------|-----|---|---|-----|-------|-------|-----|----------|------------|------------------------| | Mnemonic | Operand Size | Operation | xx# | _ | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | on Co | ode | ı | Normal | Advanced | | | ō | | # | ೱ | (9) | @ | @ | @ | @ | @ | ı | I | Н | N | z | ٧ | С | ž | ¥ | | BSET #xx:3, Rd | В | (#xx:3 of Rd8) ← 1 | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | BSET #xx:3, @ERd | В | (#xx:3 of @ERd) ← 1 | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BSET #xx:3, @aa:8 | В | (#xx:3 of @aa:8) ← 1 | | | | | | 4 | | | | _ | — | — | _ | _ | — | 8 | 3 | | BSET Rn, Rd | В | (Rn8 of Rd8) ← 1 | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | BSET Rn, @ERd | В | (Rn8 of @ERd) ← 1 | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 3 | 3 | | BSET Rn, @aa:8 | В | (Rn8 of @aa:8) ← 1 | | | | | | 4 | | | | _ | — | — | _ | _ | — | 8 | 3 | | BCLR #xx:3, Rd | В | (#xx:3 of Rd8) ← 0 | | 2 | | | | | | | | _ | — | — | _ | — | — | 2 | 2 | | BCLR #xx:3, @ERd | В | (#xx:3 of @ERd) ← 0 | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BCLR #xx:3, @aa:8 | В | (#xx:3 of @aa:8) ← 0 | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BCLR Rn, Rd | В | (Rn8 of Rd8) ← 0 | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | BCLR Rn, @ERd | В | (Rn8 of @ERd) ← 0 | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BCLR Rn, @aa:8 | В | (Rn8 of @aa:8) ← 0 | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BNOT #xx:3, Rd | В | (#xx:3 of Rd8) ←<br>¬ (#xx:3 of Rd8) | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | BNOT #xx:3, @ERd | В | (#xx:3 of @ERd) ← ¬ (#xx:3 of @ERd) | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BNOT #xx:3, @aa:8 | В | (#xx:3 of @aa:8) ← ¬ (#xx:3 of @aa:8) | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BNOT Rn, Rd | В | (Rn8 of Rd8) ← ¬ (Rn8 of Rd8) | | 2 | | | | | | | | - | _ | _ | _ | _ | _ | 2 | 2 | | BNOT Rn, @ERd | В | (Rn8 of @ERd) ← ¬ (Rn8 of @ERd) | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BNOT Rn, @aa:8 | В | (Rn8 of @aa:8) ← ¬ (Rn8 of @aa:8) | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BTST #xx:3, Rd | В | ¬ (#xx:3 of Rd8) → Z | | 2 | | | | | | | | - | _ | _ | 1 | _ | _ | 2 | 2 | | BTST #xx:3, @ERd | В | ¬ (#xx:3 of @ERd) → Z | | | 4 | | | | | | | - | _ | _ | 1 | _ | _ | 6 | 6 | | BTST #xx:3, @aa:8 | В | ¬ (#xx:3 of @aa:8) → Z | | | | | | 4 | | | | - | _ | _ | 1 | _ | _ | 6 | 6 | | BTST Rn, Rd | В | ¬ (Rn8 of @Rd8) → Z | | 2 | | | | | | | | _ | _ | _ | 1 | _ | _ | 2 | 2 | | BTST Rn, @ERd | В | ¬ (Rn8 of @ERd) → Z | | | 4 | | | | | | | _ | _ | _ | 1 | _ | _ | 6 | 3 | | BTST Rn, @aa:8 | В | ¬ (Rn8 of @aa:8) → Z | | | | | | 4 | | | | _ | _ | _ | 1 | _ | _ | 6 | 3 | | BLD #xx:3, Rd | В | (#xx:3 of Rd8) → C | | 2 | | | | | | | | _ | _ | _ | _ | _ | <b>1</b> | 2 | 2 | | | | | | A<br>Inst | | | _ | Mod | | | ) | | | | | | | No<br>Stat | . of<br>es <sup>*1</sup> | |--------------------|--------------|--------------------------------------------------------|-----|-----------|------|-----------|-------------|-----|----------|-----|---|---|-----|-------|---|---|---|------------|--------------------------| | Mnemonic | Operand Size | Operation | #xx | u | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | | | | Normal | Advanced | | | | | # | R | | ø | ø | ø | <b>a</b> | (9) | ı | ı | Н | N | z | ٧ | С | Ž | Ă | | BLD #xx:3, @ERd | В | (#xx:3 of @ERd) $\rightarrow$ C | | | 4 | | | | | | | _ | _ | _ | _ | _ | 1 | ( | 5 | | BLD #xx:3, @aa:8 | В | (#xx:3 of @aa:8) → C | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | 6 | 3 | | BILD #xx:3, Rd | В | ¬ (#xx:3 of Rd8) $\rightarrow$ C | | 2 | | | | | | | | _ | | _ | _ | | 1 | 2 | 2 | | BILD #xx:3, @ERd | В | ¬ (#xx:3 of @ERd) $\rightarrow$ C | | | 4 | | | | | | | _ | _ | _ | - | _ | 1 | 6 | 5 | | BILD #xx:3, @aa:8 | В | ¬ (#xx:3 of @aa:8) → C | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | 6 | 3 | | BST #xx:3, Rd | В | $C \rightarrow (\#xx:3 \text{ of Rd8})$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | BST #xx:3, @ERd | В | $C \rightarrow (\#xx:3 \text{ of } @ERd24)$ | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 3 | 3 | | BST #xx:3, @aa:8 | В | $C \rightarrow (\#xx:3 \text{ of } @aa:8)$ | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BIST #xx:3, Rd | В | $\neg C \rightarrow (\#xx:3 \text{ of Rd8})$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | - | 2 | 2 | | BIST #xx:3, @ERd | В | $\neg C \rightarrow (\#xx:3 \text{ of } @ERd24)$ | | | 4 | | | | | | | _ | | | - | | | 8 | 3 | | BIST #xx:3, @aa:8 | В | ¬ C → (#xx:3 of @aa:8) | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | 8 | 3 | | BAND #xx:3, Rd | В | $C \land (\#xx:3 \text{ of } Rd8) \rightarrow C$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | 1 | 2 | 2 | | BAND #xx:3, @ERd | В | $C \land (\#xx:3 \text{ of } @ERd24) \rightarrow C$ | | | 4 | | | | | | | _ | _ | _ | _ | _ | 1 | 6 | 6 | | BAND #xx:3, @aa:8 | В | $C \land (\#xx:3 \text{ of } @aa:8) \rightarrow C$ | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | 6 | 6 | | BIAND #xx:3, Rd | В | $C \land \neg (\#xx:3 \text{ of Rd8}) \rightarrow C$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | 1 | 2 | 2 | | BIAND #xx:3, @ERd | В | $C \land \neg \text{ (#xx:3 of @ERd24)} \rightarrow C$ | | | 4 | | | | | | | _ | _ | _ | _ | _ | 1 | 6 | 6 | | BIAND #xx:3, @aa:8 | В | C∧¬ (#xx:3 of @aa:8) → C | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | 6 | 6 | | BOR #xx:3, Rd | В | $C\lor(\#xx:3 \text{ of } Rd8) \to C$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | 1 | 2 | 2 | | BOR #xx:3, @ERd | В | $C\lor(\#xx:3 \text{ of } @ERd24) \rightarrow C$ | | | 4 | | | | | | | _ | _ | _ | _ | _ | 1 | 6 | 3 | | BOR #xx:3, @aa:8 | В | C∨(#xx:3 of @aa:8) → C | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | 6 | 3 | | BIOR #xx:3, Rd | В | $C \lor \neg \text{ (#xx:3 of Rd8)} \to C$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | 1 | 2 | 2 | | BIOR #xx:3, @ERd | В | $C \lor \neg \text{ (#xx:3 of @ERd24)} \to C$ | | | 4 | | | | | | | _ | _ | _ | _ | _ | 1 | ( | 3 | | BIOR #xx:3, @aa:8 | В | C∨¬ (#xx:3 of @aa:8) → C | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | ( | 3 | | BXOR #xx:3, Rd | В | $C⊕(\#xx:3 \text{ of Rd8}) \rightarrow C$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | 1 | 2 | 2 | | BXOR #xx:3, @ERd | В | C⊕(#xx:3 of @ERd24) → C | | | 4 | | | | | | | _ | _ | _ | _ | _ | 1 | ( | 3 | | BXOR #xx:3, @aa:8 | В | C⊕(#xx:3 of @aa:8) → C | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | ( | 3 | | BIXOR #xx:3, Rd | В | C⊕ ¬ (#xx:3 of Rd8) → $C$ | | 2 | | | | | | | | _ | _ | _ | _ | _ | 1 | 2 | 2 | | BIXOR #xx:3, @ERd | В | C⊕ ¬ (#xx:3 of @ERd24) → $C$ | | | 4 | | | | | | | _ | _ | _ | _ | _ | 1 | ( | 3 | | BIXOR #xx:3, @aa:8 | В | C⊕¬ (#xx:3 of @aa:8) → C | | | | | | 4 | | | | _ | _ | _ | _ | _ | 1 | 6 | 6 | # 6. Branching instructions | | | | | | | | | | Mod | | | ) | | | | No.<br>Stat | of<br>es*1 | | | | |---------------------|----------|-------------------------|---------------------|-----|---|------|-----------|-------------|-----|----------|-----|---|---|-----|-------|-------------|------------|---|--------|----------| | Mnemonic | and Size | Oper | ation | | | c | @(d, ERn) | @-ERn/@ERn+ | | PC) | aa | | | Con | ditio | n Co | ode | | lal | Advanced | | | Operand | | Branch<br>Condition | XX# | R | @ERn | @(d, | @-E | @aa | @(d, PC) | 000 | ı | ı | н | N | z | v | С | Normal | Adva | | BRA d:8 (BT d:8) | _ | If condition | Always | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 4 | 1 | | BRA d:16 (BT d:16) | _ | is true then | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BRN d:8 (BF d:8) | - | PC ← PC+d<br>else next; | Never | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 4 | 4 | | BRN d:16 (BF d:16) | - | eise next, | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BHI d:8 | - | | $C \lor Z = 0$ | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 4 | 4 | | BHI d:16 | <u> </u> | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BLS d:8 | <u> </u> | | C ∨ Z = 1 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 4 | 4 | | BLS d:16 | _ | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BCC d:8 (BHS d:8) | _ | | C = 0 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | | 4 | | BCC d:16 (BHS d:16) | <u> </u> | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BCS d:8 (BLO d:8) | <u> </u> | | C = 1 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | | 4 | | BCS d:16 (BLO d:16) | 1- | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BNE d:8 | <u> </u> | | Z = 0 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | | 4 | | BNE d:16 | <u> </u> | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BEQ d:8 | 1- | | Z = 1 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | | 4 | | BEQ d:16 | 1- | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BVC d:8 | <u> </u> | | V = 0 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | | 4 | | BVC d:16 | 1- | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BVS d:8 | 1- | | V = 1 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | | 4 | | BVS d:16 | 1- | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BPL d:8 | 1- | | N = 0 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 2 | 4 | | BPL d:16 | 1- | | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BMI d:8 | 1- | | N = 1 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 2 | 4 | | BMI d:16 | 1- | 1 | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 3 | | BGE d:8 | 1- | | N⊕V = 0 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 2 | 4 | | BGE d:16 | 1- | 1 | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 6 | | BLT d:8 | 1- | 1 | N⊕V = 1 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 2 | 4 | | BLT d:16 | 1- | 1 | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 6 | | BGT d:8 | 1- | 1 | Z ∨ (N⊕V) = 0 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 2 | 4 | | BGT d:16 | 1- | 1 | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 6 | | BLE d:8 | 1- | 1 | Z ∨ (N⊕V) = 1 | | | | | | | 2 | | | _ | _ | _ | _ | _ | _ | 2 | 4 | | BLE d:16 | 1- | 1 | | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 6 | 6 | | | | | | | | | | | de a | | ) | | | | | | | | . of<br>es*1 | |------------|--------------|-------------------------------------------------|----|---|------|-----------|-------------|-----|----------|--------|---|---|-----|-------|------|-----|---|--------|--------------| | Mnemonic | Operand Size | Operation | × | | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @ @ aa | | | Con | ditio | n Co | ode | | Normal | Advanced | | | ြင္ပ | | #X | ~ | 0 | 0 | <b>e</b> | (9) | 0 | @ | | ı | н | N | z | ٧ | С | 2 | Ad | | JMP @ERn | - | PC ← ERn | | | 2 | | | | | | | _ | _ | _ | _ | _ | _ | 4 | 4 | | JMP @aa:24 | - | PC ← aa:24 | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | ( | 6 | | JMP @@aa:8 | - | PC ← @aa:8 | | | | | | | | 2 | | _ | _ | _ | _ | _ | _ | 8 | 10 | | BSR d:8 | - | $PC \rightarrow @-SP$<br>$PC \leftarrow PC+d:8$ | | | | | | | 2 | | | - | _ | - | _ | - | - | 6 | 8 | | BSR d:16 | - | PC → @-SP<br>PC ← PC+d:16 | | | | | | | 4 | | | _ | _ | _ | _ | _ | _ | 8 | 10 | | JSR @ERn | - | PC → @-SP<br>PC ← ERn | | | 2 | | | | | | | _ | _ | _ | _ | _ | _ | 6 | 8 | | JSR @aa:24 | - | PC → @-SP<br>PC ← aa:24 | | | | | | 4 | | | | _ | _ | _ | _ | _ | _ | 8 | 10 | | JSR @@aa:8 | - | PC → @-SP<br>PC ← @aa:8 | | | | | | | | 2 | | _ | _ | - | _ | - | _ | 8 | 12 | | RTS | 1- | PC ← @SP+ | | | | | | | | | 2 | _ | _ | _ | _ | _ | _ | 8 | 10 | # 7. System control instructions | | | | | | | essi | • | | | nd<br>/tes | ) | | | | | | of<br>tes*1 | | | |-----------------------|--------------|-------------------------------------------------------------------------|-----|---|----------|-----------|-------------|-----|----------|------------|---|----------|----------|----------|----------|----------|-------------|----------|----| | Mnemonic | Operand Size | Operation | × | | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | on Co | | Normal | Advanced | | | | g | | XX# | 쮼 | <u>@</u> | <u>@</u> | 9 | @ | <u>@</u> | (9) | 1 | ı | н | N | z | ٧ | С | ž | A | | TRAPA #x:2 | _ | $\begin{array}{l} PC \to @ -SP \\ CCR \to @ -SP \\ \to PC \end{array}$ | | | | | | | | | 2 | 1 | _ | _ | _ | _ | _ | 14 | 16 | | RTE | _ | CCR ← @SP+<br>PC ← @SP+ | | | | | | | | | | 1 | 1 | <b>1</b> | 1 | <b>1</b> | 1 | 1 | 0 | | SLEEP | - | Transition to power-<br>down state | | | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | LDC #xx:8, CCR | В | #xx:8 → CCR | 2 | | | | | | | | | <b>1</b> | <b>1</b> | <b>1</b> | 1 | 1 | <b>1</b> | 2 | 2 | | LDC Rs, CCR | В | Rs8 → CCR | | 2 | | | | | | | | 1 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | | LDC @ERs, CCR | w | @ERs → CCR | | | 4 | | | | | | | 1 | 1 | <b>1</b> | 1 | 1 | 1 | 6 | 6 | | LDC @(d:16, ERs), CCR | w | @(d:16, ERs) → CCR | | | | 6 | | | | | | 1 | 1 | <b>1</b> | 1 | 1 | 1 | 8 | 8 | | LDC @(d:24, ERs), CCR | W | @(d:24, ERs) → CCR | | | | 10 | | | | | | <b>1</b> | 1 | 1 | 1 | 1 | 1 | 1 | 2 | | LDC @ERs+, CCR | W | @ERs → CCR<br>ERs32+2 → ERs32 | | | | | 4 | | | | | <b>↑</b> | <b>↑</b> | <b>1</b> | <b>↓</b> | <b>1</b> | <b>↑</b> | 8 | 8 | | LDC @aa:16, CCR | w | @aa:16 → CCR | | | | | | 6 | | | | <b>1</b> | <b>1</b> | <b>1</b> | 1 | <b>1</b> | <b>1</b> | 8 | 8 | | LDC @aa:24, CCR | w | @aa:24 → CCR | | | | | | 8 | | | | 1 | 1 | <b>1</b> | 1 | 1 | 1 | 1 | 0 | | STC CCR, Rd | В | CCR → Rd8 | | 2 | | | | | | | | _ | _ | _ | _ | _ | _ | 2 | 2 | | STC CCR, @ERd | w | CCR → @ERd | | | 4 | | | | | | | _ | _ | _ | _ | _ | _ | 6 | 6 | | STC CCR, @(d:16, ERd) | w | CCR → @(d:16, ERd) | | | | 6 | | | | | | _ | _ | _ | - | _ | _ | 3 | 8 | | STC CCR, @(d:24, ERd) | W | CCR → @(d:24, ERd) | | | | 10 | | | | | | _ | _ | _ | _ | _ | _ | 1 | 2 | | STC CCR, @-ERd | W | $\begin{array}{c} ERd322 \to ERd32 \\ CCR \to @ERd \end{array}$ | | | | | 4 | | | | | _ | _ | _ | _ | _ | _ | 8 | 8 | | STC CCR, @aa:16 | w | CCR → @aa:16 | | | | | | 6 | | | | _ | _ | _ | _ | _ | _ | 8 | 8 | | STC CCR, @aa:24 | W | CCR → @aa:24 | | | | | | 8 | | | | _ | _ | _ | _ | _ | _ | 1 | 0 | | ANDC #xx:8, CCR | В | CCR∧#xx:8 → CCR | 2 | | | | | | | | | 1 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | | ORC #xx:8, CCR | В | CCR∨#xx:8 → CCR | 2 | | | | | | | | | <b>1</b> | 1 | 1 | 1 | 1 | 1 | 2 | 2 | | XORC #xx:8, CCR | В | CCR⊕#xx:8 → CCR | 2 | | | | | | | | | 1 | 1 | <b>1</b> | 1 | 1 | 1 | 2 | 2 | | NOP | [- | PC ← PC+2 | | | | | | | | | 2 | _ | _ | _ | _ | _ | _ | 2 | 2 | #### 8. Block transfer instructions | | | | | | | | | Mod<br>ngth | | | ) | | | | | | | No<br>Stat | . of<br>es <sup>*1</sup> | |-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|---|------|-----------|-------------|-------------|----------|-----|---|---|-----|-------|------|-----|---|------------------------|--------------------------| | Mnemonic | Operand Size | Operation | × | | @ERn | @(d, ERn) | @-ERn/@ERn+ | @aa | @(d, PC) | @aa | | | Con | ditio | n Co | ode | | Normal | Advanced | | | ğ | | XX# | ~ | @ | (9) | ė | 0 | (9) | @ | | ı | н | N | z | v | С | ž | Ac | | ЕЕРМОУ. В | _ | if R4L $\neq$ 0 then repeat $@R5 \rightarrow @R6$ $R5+1 \rightarrow R5$ $R6+1 \rightarrow R6$ $R4L-1 \rightarrow R4L$ until $R4L=0$ else next | | | | | | | | | 4 | _ | _ | _ | _ | _ | _ | 8+<br>4n <sup>*2</sup> | | | EEPMOV. W | _ | if R4 $\neq$ 0 then repeat | | | | | | | | | 4 | _ | _ | _ | _ | _ | _ | 8+<br>4n* <sup>2</sup> | | The number of states is the number of states required for execution when the instruction and its operands are located in on-chip memory. For other cases see section A.3, Combinations of Instructions and Addressing Modes. - 2. n is the value set in register R4L or R4. - (1) Set to 1 when a carry or borrow occurs at bit 11; otherwise cleared to 0. - (2) Set to 1 when a carry or borrow occurs at bit 27; otherwise cleared to 0. - (3) Retains its previous value when the result is zero; otherwise cleared to 0. - (4) Set to 1 when the adjustment produces a carry; otherwise retains its previous value. - (5) The number of states required for execution of an instruction that transfers data in synchronization with the E clock is variable. - (6) Set to 1 when the divisor is negative; otherwise cleared to 0. - (7) Set to 1 when the divisor is zero; otherwise cleared to 0. - (8) Set to 1 when the quotient is negative; otherwise cleared to 0. # A.2 Operation Code Map ### **Table A.2** Operation Code Map (1) | | | | | | - | | | | , , | | | | | | | | | |-----------------------------------------------------|-------|-------------------------|-------------------------|---|-------|-----|---------------|--------|--------------------------------|-----|------|-----|------|----|-----|-----|-----| | | ш | Table A-2<br>(2) | Table A-2<br>(2) | | | BLE | | | | | | | | | | | | | | ш | ADDX | SUBX | | | BGT | JSR | | Table A-2<br>(3) | | | | | | | | | | | D | MOV | CMP | | | BLT | | | Table (3 | | | | | | | | | | BH is 1 | O | MO | | | | BGE | BSR | MOV | | | | | | | | | | | t bit of | В | Table A-2<br>(2) | Table A-2 Table A-2 (2) | | | BMI | | W | EEPMOV | | | | | | | | | | - Instruction when most significant bit of BH is 1. | 4 | Table A-2 Table A-2 (2) | Table A-2<br>(2) | | | BPL | JMP | | Table A-2 Table A-2 EEPMOV (2) | | | | | | | | | | nost sig | 6 | | В | | | BVS | | | Table A-2 (2) | | | | | | | | | | when r | 80 | ADD | SUB | | | BVC | Table A-2 (2) | | MOV | | | | | | | | | | ruction | 7 | LDC | Table A-2 (2) | | MOV J | BEQ | Α | BST | BLD | ADD | ADDX | CMP | SUBX | OR | XOR | AND | MOV | | ]← Inst | 9 | ANDC | AND.B | | | BNE | RTE | | BAND | | | | | | | | | | | 5 | XORC | XOR.B | | | BCS | BSR | XOR | BXOR | | | | | | | | | | 3L | 4 | ORC | OR.B | | | ВСС | RTS | | BOR | | | | | | | | | | AH AL BH BL | 8 | ГРС | Table A-2 | | | BLS | DIVXU | i<br>i | <u>8</u> | | | | | | | | | | H AL | 2 | STC | Table A-2<br>(2) | | | ВНІ | MULXU | ,<br>, | BCLK | | | | | | | | | | A | - | Table A-2<br>(2) | Table A-2<br>(2) | | | BRN | DIVXU | i i | BNO | | | | | | | | | | | 0 | NOP | Table A-2<br>(2) | | | BRA | MULXU | i<br>i | BORE | | | | | | | | | | | AH AL | 0 | 1 | 7 | 3 | 4 | 5 | 9 | 7 | 80 | 6 | ٨ | В | ၁ | Q | В | Ŀ | - Instruction when most significant bit of BH is 0. 2nd byte BH BL 1st byte AH AL Instruction code: **Table A.2** Operation Code Map (2) | ш | Table A-2 (3) | | NC<br>NC | | | | | | EXTS | | DEC | | BLE | | | |-------|-------------------------|-----|-----------|-----|------------|------|-------|----------------|--------------|-----|------|-----|-------|-----|----------| | ш | Ľ | | | | | | | | | | | | BGT | | | | | le A-2<br>3) | | NC<br>NC | | | | | | EXTS | | DEC | | BLT E | | | | O | Table A-2 Table A-2 (3) | | = | | | | | | <u> </u> | | | | BGE B | | | | | Table | ADD | | MOV | 7 | A. | | ~ | <sub>O</sub> | SUB | | CMP | | | | | B | | | | | SHAL | SHAR | ROTL | ROTR | NEG | | | | BMI | | | | < | - | | | | | | | | | | | | BPL | | | | 6 | | | ADDS | | SHAL | SHAR | ROTL | ROTR | NEG | | SUB | | BVS | | | | 80 | SLEEP | | AD | | <u></u> \$ | . AS | RO | R <sub>C</sub> | ž | | เร | | BVC | | | | 7 | | | NC<br>INC | | | | | | EXTU | | DEC | | BEQ | | | | 9 | | | | | | | | | | | | | BNE | AND | | | r2 | - | | S<br>N | | | | | | EXTU | | DEC | | BCS | XOR | aC.X | | 4 | LDC/STC | | | | | | | | | | | | BCC | OR | 8 | | ю | | | | | SHLL | SHLR | ROTXL | ROTXR | TON | | | | BLS | SUB | <u>a</u> | | 2 | | | | | | | | | | | | | BHI | CMP | QW. | | - | | | | | 7 | а. | × | X | F | | | | BRN | ADD | ADD | | 0 | MOV | NC | ADDS | DAA | SHLL | SHLR | ROTXL | ROTXR | NOT | DEC | SUBS | DAS | BRA | MOV | À | | AH AL | 10 | 0A | 90<br>80 | 90F | 10 | 11 | 12 | 13 | 17 | 14 | £ | # | 58 | 62 | 47 | Instruction code: 1st byte **Table A.2** Operation Code Map (3) | Instruct | tion cod | e: 1s | 1st byte | 2nd<br>RH | byte 3rd | 3rd byte | 4th byte | <b>e e</b> | | - Instruc | ction w | hen mos | st signi | - Instruction when most significant bit of DH is 0. | it of DI | I is 0. | |---------------------|----------------------------------------------------------------------------------------|-----------------------------|-----------------------------|-----------|----------|----------|----------|------------|---------|-----------|---------|---------|----------|-----------------------------------------------------|----------|---------| | | | 7 | | 1110 | | 3 | 117 | į | <u></u> | - Instruc | ction w | hen mos | st signi | ← Instruction when most significant bit of DH is 1. | it of DI | I is 1. | | ALBH ALBH BLCH | 0 | - | 7 | ю | 4 | 5 | 9 | 7 | 8 | თ | 4 | В | O | Q | ш | ш | | 01406 | | | | | | | | | | LDC STC | | LDC | | STC | | LDC | | 01C05 | MULXS | | MULXS | | | | | | | | | | | | | | | 01D05 | | DIVXS | | DIVXS | | | | | | | | | | | | | | 01F06 | | | | | OR | XOR | AND | | | | | | | | | | | 7Cr06*1 | | | | BTST | | | | | | | | | | | | | | 7Cr07*1 | | | | BTST | BOR | BXOR | BAND | BLD | | | | | | | | | | 7Dr06*1 | BSET | BNOT | BCLR | | | | | BST | | | | | | | | | | 7Dr07*1 | BSET | BNOT | BCLR | | | | | | | | | | | | | | | 7Eaa6*2 | | | | BTST | | | | | | | | | | | | | | 7Eaa7*2 | | | | BTST | BOR | BXOR | BAND | BLD | | | | | | | | | | 7Faa6* <sup>2</sup> | BSET | BNOT | BCLR | | | | | BST | | | | | | | | | | 7Faa7* <sup>2</sup> | BSET | BNOT | BCLR | | | | | | | | | | | | | | | Notes: 1. | Notes: 1. r is the register designation field.<br>2. aa is the absolute address field. | ster design:<br>solute addr | ation field.<br>ress field. | | | | | | | | | | | | | | 410 #### **A.3** Number of Execution States The tables here can be used to calculate the number of states required for instruction execution. Table A.3 indicates the number of states required for each cycle (instruction fetch, branch address read, stack operation, byte data access, word data access, internal operation). Table A.4 indicates the number of cycles of each type occurring in each instruction. The total number of states required for execution of an instruction can be calculated from these two tables as follows: Execution states = $$I \times S_1 + J \times S_2 + K \times S_K + L \times S_L + M \times S_M + N \times S_N$$ Examples: When instruction is fetched from on-chip ROM, and an on-chip RAM is accessed. BSET #0, @FF00 From table A.4: $$I = L = 2$$ , $J = K = M = N = 0$ From table A.3: $$S_I = 2$$ , $S_L = 2$ Number of states required for execution = $2 \times 2 + 2 \times 2 = 8$ When instruction is fetched from on-chip ROM, branch address is read from on-chip ROM, and on-chip RAM is used for stack area. JSR @@ 30 From table A.4: $$I=2, \quad J=K=1, \quad L=M=N=0$$ From table A.3: $$S_{\rm I} = S_{\rm J} = S_{\rm K} = 2$$ Number of states required for execution = $2 \times 2 + 1 \times 2 + 1 \times 2 = 8$ **Table A.3** Number of Cycles in Each Instruction | Execution Status | | Ac | ccess Location | |---------------------|----------------|----------------|---------------------------| | (Instruction Cycle) | | On-Chip Memory | On-Chip Peripheral Module | | Instruction fetch | Sı | 2 | _ | | Branch address read | S <sub>J</sub> | _ | | | Stack operation | S <sub>K</sub> | _ | | | Byte data access | S <sub>L</sub> | _ | 2 or 3* | | Word data access | S <sub>M</sub> | _ | _ | | Internal operation | S <sub>N</sub> | 1 | | Note: \* Depends on which on-chip module is accessed. See section B.1, Register Addresses. **Table A.4** Number of Cycles in Each Instruction | Instruction | Mnemo | nnic | Instruction<br>Fetch<br>I | Branch<br>Addr. Read<br>J | Stack<br>Operation<br>K | Byte Data<br>Access<br>L | Word Data<br>Access<br>M | Internal<br>Operation<br>N | |-------------|--------|--------------|---------------------------|---------------------------|-------------------------|--------------------------|--------------------------|----------------------------| | ADD | | #xx:8, Rd | <u>.</u><br>1 | | | | | | | 7.00 | ADD.B | | 1 | | | | | | | | | Rs, Rd | 1 | | | | | | | ADDS | | N #1, Rd | 1 | | | | | | | 7.000 | | N #2, Rd | 1 | | | | | | | ADDX | | 3 #xx:8, Rd | 1 | | | | н | | | 7.227 | | B Rs, Rd | 1 | | | | | | | AND | | #xx:8, Rd | 1 | | | | | | | 71110 | AND.B | | 1 | | | | | | | ANDC | | #xx:8, CCR | 1 | | -11- | -11- | 11- | | | BAND | | #xx:3, Rd | 1 | | -11- | -11- | 11- | | | 27 12 | | #xx:3, @Rd | 2 | | | 1 | | | | | | *xx:3, @aa:8 | 2 | | | 1 | | | | Bcc | | 8 (BT d:8) | 2 | | | | | | | | | 8 (BF d:8) | 2 | | | | | | | | ВНІ | d:8 | 2 | | | | | | | | BLS | d:8 | 2 | | | | | | | | BCC d: | 8 (BHS d:8) | 2 | | | | | | | | BCS d: | 8 (BLO d:8) | 2 | | | | | | | | BNE | d:8 | 2 | | | | | | | | BEQ | d:8 | 2 | | | | | | | | BVC | d:8 | 2 | | | | | | | | BVS | d:8 | 2 | | | | | | | | BPL | d:8 | 2 | | | | | | | | BMI | d:8 | 2 | | | | | | | | BGE | d:8 | 2 | | | | | | | | BLT | d:8 | 2 | | | | | | | | BGT | d:8 | 2 | | | | | | | | BLE | d:8 | 2 | | | | | | | BCLR | BCLR # | xx:3, Rd | 1 | | | | | | | | BCLR # | xx:3, @Rd | 2 | | | 2 | | | | | BCLR # | xx:3, @aa:8 | 2 | | | 2 | | | | | BCLR F | Rn, Rd | 1 | | | | | | | Instruction | Mnemonic | Instruction<br>Fetch<br>I | Branch<br>Addr. Read<br>J | Stack<br>Operation<br>K | Byte Data<br>Access<br>L | Word Data<br>Access<br>M | Internal<br>Operation<br>N | |-------------|--------------------|---------------------------|---------------------------|-------------------------|--------------------------|--------------------------|----------------------------| | BCLR | BCLR Rn, @Rd | 2 | | | 2 | | | | | BCLR Rn, @aa:8 | 2 | | | 2 | | | | BIAND | BIAND #xx:3, Rd | 1 | | | | | | | | BIAND #xx:3, @Rd | 2 | | | 1 | | | | | BIAND #xx:3, @aa:8 | 2 | | | 1 | | | | BILD | BILD #xx:3, Rd | 1 | | | | | | | | BILD #xx:3, @Rd | 2 | | | 1 | | | | | BILD #xx:3, @aa:8 | 2 | | | 1 | | | | BIOR | BIOR #xx:3, Rd | 1 | | | | | | | | BIOR #xx:3, @Rd | 2 | | | 1 | | | | | BIOR #xx:3, @aa:8 | 2 | | | 1 | | | | BIST | BIST #xx:3, Rd | 1 | | | | | | | | BIST #xx:3, @Rd | 2 | | | 2 | | | | | BIST #xx:3, @aa:8 | 2 | | | 2 | | | | BIXOR | BIXOR #xx:3, Rd | 1 | | | | | | | | BIXOR #xx:3, @Rd | 2 | | | 1 | | | | | BIXOR #xx:3, @aa:8 | 2 | | | 1 | | | | BLD | BLD #xx:3, Rd | 1 | | | | | | | | BLD #xx:3, @Rd | 2 | | | 1 | | | | | BLD #xx:3, @aa:8 | 2 | | | 1 | | | | BNOT | BNOT #xx:3, Rd | 1 | | | | | | | | BNOT #xx:3, @Rd | 2 | | | 2 | | | | | BNOT #xx:3, @aa:8 | 2 | | | 2 | | | | | BNOT Rn, Rd | 1 | | | | | | | | BNOT Rn, @Rd | 2 | | | 2 | | | | | BNOT Rn, @aa:8 | 2 | | | 2 | | | | BOR | BOR #xx:3, Rd | 1 | | " | | | | | | BOR #xx:3, @Rd | 2 | | | 1 | | | | | BOR #xx:3, @aa:8 | 2 | | | 1 | | | | BSET | BSET #xx:3, Rd | 1 | | | | | | | | BSET #xx:3, @Rd | 2 | | | 2 | | | | | BSET #xx:3, @aa:8 | 2 | | | 2 | | | | | BSET Rn, Rd | 1 | | | | | | | | BSET Rn, @Rd | 2 | | | 2 | | | | Instruction | Mnemonic | Instruction<br>Fetch<br>I | Branch<br>Addr. Read<br>J | Stack<br>Operation<br>K | Byte Data<br>Access<br>L | Word Data<br>Access<br>M | Internal<br>Operation<br>N | |-------------|---------------------|---------------------------|---------------------------|-------------------------|--------------------------|--------------------------|----------------------------| | | | | <u> </u> | N. | | IVI | 14 | | BSET | BSET Rn, @aa:8 | 2 | | | 2 | , | | | BSR | BSR d:8 | 2 | | 1 | | | | | BST | BST #xx:3, Rd | 1 | | | | | | | | BST #xx:3, @Rd | 2 | | | 2 | | | | | BST #xx:3, @aa:8 | 2 | | | 2 | | | | BTST | BTST #xx:3, Rd | 1 | | | | | | | | BTST #xx:3, @Rd | 2 | | | 1 | | | | | BTST #xx:3, @aa:8 | 2 | | | 1 | | | | | BTST Rn, Rd | 1 | | | | | | | | BTST Rn, @Rd | 2 | | | 1 | | | | | BTST Rn, @aa:8 | 2 | | | 1 | | | | BXOR | BXOR #xx:3, Rd | 1 | | | | | | | | BXOR #xx:3, @Rd | 2 | | | 1 | | | | | BXOR #xx:3, @aa:8 | 2 | | | 1 | | | | CMP | CMP. B #xx:8, Rd | 1 | | | | | | | | CMP. B Rs, Rd | 1 | | | | | | | | CMP.W Rs, Rd | 1 | | | | | | | DAA | DAA.B Rd | 1 | | | | | | | DAS | DAS.B Rd | 1 | | | | | | | DEC | DEC.B Rd | 1 | | | | | | | DIVXU | DIVXU.B Rs, Rd | 1 | | | | | 12 | | EEPMOV | EEPMOV | 2 | | | 2n+2* | | 1 | | INC | INC.B Rd | 1 | | | | | | | JMP | JMP @Rn | 2 | | | | | | | | JMP @aa:16 | 2 | | | | | 2 | | | JMP @@aa:8 | 2 | 1 | | | | 2 | | JSR | JSR @Rn | 2 | | 1 | | | | | | JSR @aa:16 | 2 | | 1 | | | 2 | | | JSR @@aa:8 | 2 | 1 | 1 | | | | | LDC | LDC #xx:8, CCR | 1 | " | | | | | | | LDC Rs, CCR | 1 | | | | | | | MOV | MOV.B #xx:8, Rd | 1 | * | | | | | | | MOV.B Rs, Rd | 1 | | | | | | | Notes as I | nitial value in P4I | The source of | nd doctinatio | n onerend | | 00d p 1 1 tir | | Note: n: Initial value in R4L. The source and destination operands are accessed n + 1 times each. | Instruction | Mnemonic | Instruction<br>Fetch | Branch<br>Addr. Read<br>J | Stack<br>Operation<br>K | Byte Data<br>Access<br>L | Word Data<br>Access<br>M | Internal<br>Operation<br>N | |-------------|--------------------------|----------------------|---------------------------|-------------------------|--------------------------|--------------------------|----------------------------| | MOV | MOV.B @Rs, Rd | 1 | <u> </u> | 1 | | IVI | IN . | | WOV | MOV.B @(d:16, Rs),<br>Rd | | | 1 | | | | | | MOV.B @Rs+, Rd | 1 | | 1 | | | 2 | | | MOV.B @aa:8, Rd | 1 | | 1 | | | | | | MOV.B @aa:16, Rd | 2 | | 1 | | | | | | MOV.B Rs, @Rd | 1 | | | 1 | | | | | MOV.B Rs, @(d:16, Rd) | 2 | | | 1 | | | | | MOV.B Rs, @-Rd | 1 | | | 1 | | 2 | | | MOV.B Rs, @aa:8 | 1 | | | 1 | | | | | MOV.B Rs, @aa:16 | 2 | | | 1 | | | | | MOV.W #xx:16, Rd | 2 | | | | | | | | MOV.W Rs, Rd | 1 | | | | | | | | MOV.W @Rs, Rd | 1 | | | | 1 | | | | MOV.W @(d:16, Rs),<br>Rd | 2 | | | | 1 | | | | MOV.W @Rs+, Rd | 1 | | | | 1 | 2 | | | MOV.W @aa:16, Rd | 2 | | | | 1 | | | | MOV.W Rs, @Rd | 1 | | | | 1 | | | | MOV.W Rs, @(d:16d) | 2 | | | | 1 | | | | MOV.W Rs, @-Rd | 1 | | | | 1 | 2 | | | MOV.W Rs, @aa:16 | 2 | | | | 1 | | | MULXU | MULXU.B Rs, Rd | 1 | | | | | 12 | | NEG | NEG.B Rd | 1 | | | | | | | NOP | NOP | 1 | | | | | | | NOT | NOT.B Rd | 1 | | " | | | | | OR | OR.B #xx:8, Rd | 1 | -11 | -10 | -11 | 1 | | | | OR.B Rs, Rd | 1 | | | | | | | ORC | ORC #xx:8, CCR | 1 | | | | | | | ROTL | ROTL.B Rd | 1 | | | | | | | ROTR | ROTR.B Rd | 1 | | | | | | | ROTXL | ROTXL.B Rd | 1 | | | | | | | ROTXR | ROTXR.B Rd | 1 | | | | | | | | - | | | | | | | | Instruction | Mnemonic | Instruction<br>Fetch<br>I | Branch<br>Addr. Read<br>J | Stack<br>Operation<br>K | Byte Data<br>Access<br>L | Word Data<br>Access<br>M | Internal<br>Operation<br>N | |-------------|------------------|---------------------------|---------------------------|-------------------------|--------------------------|--------------------------|----------------------------| | RTE | RTE | 2 | | 2 | | | 2 | | RTS | RTS | 2 | | 1 | | | 2 | | SHAL | SHAL.B Rd | 1 | | | | | | | SHAR | SHAR.B Rd | 1 | | | | | | | SHLL | SHLL.B Rd | 1 | " | | | | , | | SHLR | SHLR.B Rd | 1 | " | | | | , | | SLEEP | SLEEP | 1 | | | | | | | STC | STC CCR, Rd | 1 | " | | | | | | SUB | SUB.B Rs, Rd | 1 | " | | | ., | | | | SUB.W Rs, Rd | 1 | | | | | | | SUBS | SUBS.W #1, Rd | 1 | | | | | | | | SUBS.W #2, Rd | 1 | | | | | | | POP | POP Rd | 1 | | 1 | | | 2 | | PUSH | PUSH Rs | 1 | | 1 | | | 2 | | SUBX | SUBX.B #xx:8, Rd | 1 | | | | | | | | SUBX.B Rs, Rd | 1 | | | | | | | XOR | XOR.B #xx:8, Rd | 1 | | | | | | | | XOR.B Rs, Rd | 1 | | | | | | | XORC | XORC #xx:8, CCR | 1 | | | | | | ## **A.4** Combinations of Instructions and Addressing Modes Table A.4 Combinations of Instructions and Addressing Modes | | | Addressing Mode | | | | | | | | | | | | | |-----------------|-------------------------------------|-----------------|-----|------|-------------|-------------|------------|-------|--------|--------|-----------|------------|----------|----| | Functions | Instructions | XX# | Rn | @ERn | @(d:16.ERn) | @(d:24.ERn) | @ERn+/@ERn | @aa:8 | @aa:16 | @aa:24 | @(d:8.PC) | @(d:16.PC) | @ @ aa:8 | I | | Data | MOV | BWL | BWL | BWL | BWL | BWL | BWL | В | BWL | BWL | - | _ | _ | _ | | transfer | POP, PUSH | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | WL | | instructions | MOVFPE,<br>MOVTPE | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Arithmetic | ADD, CMP | BWL | BWL | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | operations | SUB | WL | BWL | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | ADDX, SUBX | В | В | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | ADDS, SUBS | _ | L | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | INC, DEC | _ | BWL | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | DAA, DAS | _ | В | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | MULXU,<br>MULXS,<br>DIVXU,<br>DIVXS | _ | BW | | | | _ | _ | | | | | _ | _ | | | NEG | | BWL | _ | _ | | _ | | | _ | _ | _ | _ | _ | | | EXTU, EXTS | _ | WL | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | | Logical | AND, OR, XOR | _ | BWL | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | | operations | NOT | _ | BWL | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | | Shift operation | | _ | BWL | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | | Bit manipulat | tions | | В | В | _ | | _ | В | | _ | _ | _ | _ | _ | | Branching | BCC, BSR | | | _ | _ | | _ | | | _ | _ | _ | _ | _ | | instructions | JMP, JSR | _ | _ | 0 | | _ | _ | _ | | _ | 0 | 0 | _ | _ | | | RTS | _ | _ | _ | _ | _ | _ | _ | | 0 | _ | _ | 0 | _ | | System | TRAPA | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | 0 | | control | RTE | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | 0 | | Instructions | SLEEP | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | 0 | | | LDC | В | В | W | W | W | W | _ | W | W | _ | _ | _ | 0 | | | STC | _ | В | W | W | W | W | _ | W | W | _ | _ | _ | _ | | | ANDC, ORC,<br>XORC | В | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | NOP | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0 | | Block data tra | ansfer instructions | _ | _ | _ | _ | _ | — | _ | — | — | — | — | — | BW | ## Appendix B Internal I/O Registers ## **B.1** Register Addresses | Register Name | Abbre-<br>viation | Bits | Address | Module<br>Name | Data<br>Bus<br>Width | Access<br>State | |-------------------------------------|-------------------|------|---------|----------------|----------------------|-----------------| | Timer mode register W | TMRW | 8 | H'FF80 | Timer W | 8 | 2 | | Timer control register W | TCRW | 8 | H'FF81 | Timer W | 8 | 2 | | Timer interrupt enable register W | TIERW | 8 | H'FF82 | Timer W | 8 | 2 | | Timer status register W | TSRW | 8 | H'FF83 | Timer W | 8 | 2 | | Timer I/O control register 0 | TIOR0 | 8 | H'FF84 | Timer W | 8 | 2 | | Timer I/O control register 1 | TIOR1 | 8 | H'FF85 | Timer W | 8 | 2 | | Timer counter | TCNT | 16 | H'FF86 | Timer W | 16* <sup>1</sup> | 2 | | General register A | GRA | 16 | H'FF88 | Timer W | 16* <sup>1</sup> | 2 | | General register B | GRB | 16 | H'FF8A | Timer W | 16* <sup>1</sup> | 2 | | General register C | GRC | 16 | H'FF8C | Timer W | 16* <sup>1</sup> | 2 | | General register D | GRD | 16 | H'FF8E | Timer W | 16* <sup>1</sup> | 2 | | Flash memory control register 1 | FLMCR1 | 8 | H'FF90 | ROM | 8 | 2 | | Flash memory control register 2 | FLMCR2 | 8 | H'FF91 | ROM | 8 | 2 | | Flash memory power control register | FLPWCR | 8 | H'FF92 | ROM | 8 | 2 | | Erase block register 1 | EBR1 | 8 | H'FF93 | ROM | 8 | 2 | | Flash memory enable register | FENR | 8 | H'FF9B | ROM | 8 | 2 | | Timer control register V0 | TCRV0 | 8 | H'FFA0 | Timer V | 8 | 3 | | Timer control/status register V | TCSRV | 8 | H'FFA1 | Timer V | 8 | 3 | | Timer constant register A | TCORA | 8 | H'FFA2 | Timer V | 8 | 3 | | Timer constant register B | TCORB | 8 | H'FFA3 | Timer V | 8 | 3 | | Timer counter V | TCNTV | 8 | H'FFA4 | Timer V | 8 | 3 | | Timer control register V1 | TCRV1 | 8 | H'FFA5 | Timer V | 8 | 3 | | Timer mode register A | TMA | 8 | H'FFA6 | Timer A | 8 | 2 | | Timer counter A | TCA | 8 | H'FFA7 | Timer A | 8 | 2 | | Serial mode register | SMR | 8 | H'FFA8 | SCI3 | 8 | 3 | | Bit rate register | BRR | 8 | H'FFA9 | SCI3 | 8 | 3 | | Serial control register 3 | SCR3 | 8 | H'FFAA | SCI3 | 8 | 3 | | Register Name | Abbre-<br>viation | Bits | Address | Module<br>Name | Data<br>Bus<br>Width | Access<br>State | |---------------------------------------|-------------------|------|---------|----------------|----------------------|-----------------| | Transmit data register | TDR | 8 | H'FFAB | SCI3 | 8 | 3 | | Serial status register | SSR | 8 | H'FFAC | SCI3 | 8 | 3 | | Receive data register | RDR | 8 | H'FFAD | SCI3 | 8 | 3 | | A/D data register A | ADDRA | 16 | H'FFB0 | A/D converter | 8 | 3 | | A/D data register B | ADDRB | 16 | H'FFB2 | A/D converter | 8 | 3 | | A/D data register C | ADDRC | 16 | H'FFB4 | A/D converter | 8 | 3 | | A/D data register D | ADDRD | 16 | H'FFB6 | A/D converter | 8 | 3 | | A/D control/status register | ADCSR | 8 | H'FFB8 | A/D converter | 8 | 3 | | A/D control register | ADCR | 8 | H'FFB9 | A/D converter | 8 | 3 | | Timer control/status register WD | TCSRWD | 8 | H'FFC0 | WDT*2 | 8 | 2 | | Timer counter WD | TCWD | 8 | H'FFC1 | WDT*2 | 8 | 2 | | Timer mode register WD | TMWD | 8 | H'FFC2 | WDT*2 | 8 | 2 | | I <sup>2</sup> C bus control register | ICCR | 8 | H'FFC4 | IIC | 8 | 2 | | I <sup>2</sup> C bus status register | ICSR | 8 | H'FFC5 | IIC | 8 | 2 | | I <sup>2</sup> C bus data register | ICDR | 8 | H'FFC6 | IIC | 8 | 2 | | Second slave address register | SARX | 8 | H'FFC6 | IIC | 8 | 2 | | I <sup>2</sup> C bus mode register | ICMR | 8 | H'FFC7 | IIC | 8 | 2 | | Slave address register | SAR | 8 | H'FFC7 | IIC | 8 | 2 | | Address break control register | ABRKCR | 8 | H'FFC8 | Address break | 8 | 2 | | Address break status register | ABRKSR | 8 | H'FFC9 | Address break | 8 | 2 | | Break address register H | BARH | 8 | H'FFCA | Address break | 8 | 2 | | Break address register L | BARL | 8 | H'FFCB | Address break | 8 | 2 | | Break data register H | BDRH | 8 | H'FFCC | Address break | 8 | 2 | | Break data register L | BDRL | 8 | H'FFCD | Address break | 8 | 2 | | Port pull-up control register 1 | PUCR1 | 8 | H'FFD0 | I/O port | 8 | 2 | | Port pull-up control register 5 | PUCR5 | 8 | H'FFD1 | I/O port | 8 | 2 | | Port data register 1 | PDR1 | 8 | H'FFD4 | I/O port | 8 | 2 | | Port data register 2 | PDR2 | 8 | H'FFD5 | I/O port | 8 | 2 | | Port data register 5 | PDR5 | 8 | H'FFD8 | I/O port | 8 | 2 | | Port data register 7 | PDR7 | 8 | H'FFDA | I/O port | 8 | 2 | | Port data register 8 | PDR8 | 8 | H'FFDB | I/O port | 8 | 2 | | Register Name | Abbre-<br>viation | Bits | Address | Module<br>Name | Data<br>Bus<br>Width | Access<br>State | |-----------------------------------|-------------------|------|---------|----------------|----------------------|-----------------| | Port data register B | PDRB | 8 | H'FFDD | I/O port | 8 | 2 | | Port mode register 1 | PMR1 | 8 | H'FFE0 | I/O port | 8 | 2 | | Port mode register 5 | PMR5 | 8 | H'FFE1 | I/O port | 8 | 2 | | Port control register 1 | PCR1 | 8 | H'FFE4 | I/O port | 8 | 2 | | Port control register 2 | PCR2 | 8 | H'FFE5 | I/O port | 8 | 2 | | Port control register 5 | PCR5 | 8 | H'FFE8 | I/O port | 8 | 2 | | Port control register 7 | PCR7 | 8 | H'FFEA | I/O port | 8 | 2 | | Port control register 8 | PCR8 | 8 | H'FFEB | I/O port | 8 | 2 | | System control register 1 | SYSCR1 | 8 | H'FFF0 | Power-down | 8 | 2 | | System control register 2 | SYSCR2 | 8 | H'FFF1 | Power-down | 8 | 2 | | Interrupt edge select register 1 | IEGR1 | 8 | H'FFF2 | Interrupts | 8 | 2 | | Interrupt edge select register 2 | IEGR2 | 8 | H'FFF3 | Interrupts | 8 | 2 | | Interrupt enable register 1 | IENR1 | 8 | H'FFF4 | Interrupts | 8 | 2 | | Interrupt flag register 1 | IRR1 | 8 | H'FFF6 | Interrupts | 8 | 2 | | Wake-up interrupt flag register | IWPR | 8 | H'FFF8 | Interrupts | 8 | 2 | | Module standby control register 1 | MSTCR1 | 8 | H'FFF9 | Power-down | 8 | 2 | | Timer serial control register | TSCR | 8 | H'FFFC | IIC | 8 | 2 | Notes: 1. Only word access can be used. 2. WDT: Watchdog timer ## **B.2** Register Bits | Register<br>Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Module Name | |------------------|--------|--------|--------|--------|--------|--------|--------|--------|-------------| | TMRW | CTS | _ | BUFEB | BUFEA | _ | PWMD | PWMC | PWMB | Timer W | | TCRW | CCLR | CKS2 | CKS1 | CKS0 | TOD | TOC | ТОВ | TOA | _ | | TIERW | OVIE | _ | _ | _ | IMIED | IMIEC | IMIEB | IMIEA | _ | | TSRW | OVF | _ | _ | _ | IMFD | IMFC | IMFB | IMFA | _ | | TIOR0 | _ | IOB2 | IOB1 | IOB0 | _ | IOA2 | IOA1 | IOA0 | _ | | TIOR1 | _ | IOD2 | IOD1 | IOD0 | _ | IOC2 | IOC1 | IOC0 | _ | | TCNT | TCNT15 | TCNT14 | TCNT13 | TCNT12 | TCNT11 | TCNT10 | TCNT9 | TCNT8 | - | | | TCNT7 | TCNT6 | TCNT5 | TCNT4 | TCNT3 | TCNT2 | TCNT1 | TCNT0 | _ | | GRA | GRA15 | GRA14 | GRA13 | GRA12 | GRA11 | GRA10 | GRA9 | GRA8 | _ | | | GRA7 | GRA6 | GRA5 | GRA4 | GRA3 | GRA2 | GRA1 | GRA0 | - | | GRB | GRB15 | GRB14 | GRB13 | GRB12 | GRB11 | GRB10 | GRB9 | GRB8 | _ | | | GRB7 | GRB6 | GRB5 | GRB4 | GRB3 | GRB2 | GRB1 | GRB0 | _ | | GRC | GRC15 | GRC14 | GRC13 | GRC12 | GRC11 | GRC10 | GRC9 | GRC8 | - | | | GRC7 | GRC6 | GRC5 | GRC4 | GRC3 | GRC2 | GRC1 | GRC0 | - | | GRD | GRD15 | GRD14 | GRD13 | GRD12 | GRD11 | GRD10 | GRD9 | GRD8 | _ | | | GRD7 | GRD6 | GRD5 | GRD4 | GRD3 | GRD2 | GRD1 | GRD0 | - | | FLMCR1 | _ | SWE | ESU | PSU | EV | PV | E | Р | ROM | | FLMCR2 | FLER | _ | _ | _ | _ | _ | _ | _ | - | | FLPWCR | PDWND | _ | _ | _ | _ | _ | _ | _ | - | | EBR1 | | _ | _ | EB4 | EB3 | EB2 | EB1 | EB0 | - | | FENR | FLSHE | _ | _ | _ | _ | _ | _ | _ | - | | TCRV0 | CMIEB | CMIEA | OVIE | CCLR1 | CCLR0 | CKS2 | CKS1 | CKS0 | Timer V | | TCSRV | CMFB | CFMA | OVF | _ | OS3 | OS2 | OS1 | OS0 | - | | TCORA | TCORA7 | TCORA6 | TCORA5 | TCORA4 | TCORA3 | TCORA2 | TCORA1 | TCORA0 | - | | TCORB | TCORB7 | TCORB6 | TCORB5 | TCORB4 | TCORB3 | TCORB2 | TCORB1 | TCORB0 | - | | TCNTV | TCNTV7 | TCNTV6 | TCNTV5 | TCNTV4 | TCNTV3 | TCNTV2 | TCNTV1 | TCNTV0 | - | | TCRV1 | | _ | _ | TVEG1 | TVEG0 | TRGE | _ | ICKS0 | - | | TMA | TMA7 | TMA6 | TMA5 | _ | TMA3 | TMA2 | TMA1 | TMA0 | Timer A | | TCA | TCA7 | TCA6 | TCA5 | TCA4 | TCA3 | TCA2 | TCA1 | TCA0 | - | | SMR | COM | CHR | PE | PM | STOP | MP | CKS1 | CKS0 | SCI3 | | BRR | BRR7 | BRR6 | BRR5 | BRR4 | BRR3 | BRR2 | BRR1 | BRR0 | - | | SCR3 | TIE | RIE | TE | RE | MPIE | TEIE | CKE1 | CKE0 | - | | TDR | TDR7 | TDR6 | TDR5 | TDR4 | TDR3 | TDR2 | TDR1 | TDR0 | - | | Register<br>Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Module Name | |------------------|--------|--------|--------|--------|--------|--------|--------|--------|---------------| | SSR | TDRE | RDRF | OER | FER | PER | TEND | MPBR | MPBT | SCI3 | | RDR | RDR7 | RDR6 | RDR5 | RDR4 | RDR3 | RDR2 | RDR1 | RDR0 | _ | | ADDRA | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | A/D converter | | | AD1 | AD0 | _ | | | _ | _ | _ | _ | | ADDRB | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | _ | | | AD1 | AD0 | _ | _ | _ | _ | _ | _ | _ | | ADDRC | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | _ | | | AD1 | AD0 | _ | _ | _ | _ | _ | _ | _ | | ADDRD | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | - | | | AD1 | AD0 | _ | _ | _ | _ | _ | _ | - | | ADCSR | ADF | ADIE | ADST | SCAN | CKS | CH2 | CH1 | CH0 | - | | ADCR | TRGE | _ | _ | _ | _ | _ | _ | _ | - | | TCSRWD | B6WI | TCWE | B4WI | TCSRWE | B2WI | WDON | B0WI | WRST | WDT* | | TCWD | TCWD7 | TCWD6 | TCWD5 | TCWD4 | TCWD3 | TCWD2 | TCWD1 | TCWD0 | - | | TMWD | _ | _ | _ | _ | CKS3 | CKS2 | CKS1 | CKS0 | _ | | ICCR | ICE | IEIC | MST | TRS | ACKE | BBSY | IRIC | SCP | IIC | | ICSR | ESTP | STOP | IRTR | AASX | AL | AAS | ADZ | ACKB | _ | | ICDR | ICDR7 | ICDR6 | ICDR5 | ICDR4 | ICDR3 | ICDR2 | ICDR1 | ICDR0 | _ | | SARX | SVAX7 | SVAX6 | SVAX5 | SVAX4 | SVAX3 | SVAX2 | SVAX1 | SVAX0 | _ | | ICMR | MLS | WAIT | CKS2 | CKS1 | CKS0 | BC2 | BC1 | BC0 | _ | | SAR | SVA7 | SVA6 | SVA5 | SVA4 | SVA3 | SVA2 | SVA1 | SVA0 | | | ABRKCR | RTINTE | CSEL1 | CSEL0 | ACMP2 | ACMP1 | ACMP0 | DCMP1 | DCMP0 | Address break | | ABRKSR | ABIF | ABIE | _ | _ | _ | _ | _ | _ | _ | | BARH | BARH7 | BARH6 | BARH5 | BARH4 | BARH3 | BARH2 | BARH1 | BARH0 | _ | | BARL | BARL7 | BARL6 | BARL5 | BARL4 | BARL3 | BARL2 | BARL1 | BARL0 | _ | | BDRH | BDRH7 | BDRH6 | BDRH5 | BDRH4 | BDRH3 | BDRH2 | BDRH1 | BDRH0 | _ | | BDRL | BDRL7 | BDRL6 | BDRL5 | BDRL4 | BDRL3 | BDRL2 | BDRL1 | BDRL0 | | | PUCR1 | PUCR17 | PUCR16 | PUCR15 | PUCR14 | _ | PUCR12 | PUCR11 | PUCR10 | I/O port | | PUCR5 | _ | _ | PUCR55 | PUCR54 | PUCR53 | PUCR52 | PUCR51 | PUCR50 | _ | | PDR1 | P17 | P16 | P15 | P14 | _ | P12 | P11 | P10 | _ | | PDR2 | | _ | | _ | | P22 | P21 | P20 | _ | | PDR5 | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | _ | | PDR7 | - | P76 | P75 | P74 | | _ | | - | _ | | PDR8 | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | | | Register<br>Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Module Name | |------------------|-------|--------|-------|-------|-------|-------|--------|-------|-------------| | PDRB | PB7 | PB6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | I/O port | | PMR1 | IRQ3 | IRQ2 | IRQ1 | IRQ0 | _ | _ | TXD | TMOW | _ | | PMR5 | | | WKP5 | WKP4 | WKP3 | WKP2 | WKP1 | WKP0 | _ | | PCR1 | PCR17 | PCR16 | PCR15 | PCR14 | _ | PCR12 | PCR11 | PCR10 | _ | | PCR2 | | | _ | _ | _ | PCR22 | PCR21 | PCR20 | _ | | PCR5 | PCR57 | PCR56 | PCR55 | PCR54 | PCR53 | PCR52 | PCR51 | PCR50 | _ | | PCR7 | | PCR6 | PCR5 | PCR4 | _ | | _ | _ | _ | | PCR8 | PCR87 | PCR86 | PCR85 | PCR84 | PCR83 | PCR82 | PCR81 | PCR80 | _ | | SYSCR1 | SSBY | STS2 | STS1 | STS0 | NESEL | | _ | _ | Power-down | | SYSCR2 | SMSEL | LSON | DTON | MA2 | MA1 | MA0 | SA1 | SA0 | _ | | IEGR1 | NMIEG | | _ | | IEG3 | IEG2 | IEG1 | IEG0 | Interrupts | | IEGR2 | | | WPEG5 | WPEG4 | WPEG3 | WPEG2 | WPEG1 | WPEG0 | _ | | IENR1 | IENDT | IENTA | IENWP | | IEN3 | IEN2 | IEN1 | IEN0 | _ | | IRR1 | IRRDT | IRRTA | _ | | IRRI3 | IRRI2 | IRRI1 | IRRI0 | _ | | IWPR | | | IWPF5 | IWPF4 | IWPF3 | IWPF2 | IWPF1 | IWPF0 | _ | | MSTCR1 | | MSTIIC | MSTS3 | MSTAD | MSTWD | MSTTW | MSTTV | MSTTA | Power-down | | TSCR | _ | _ | _ | _ | _ | _ | IICRST | IICX | IIC | Note: \* WDT: Watchdog timer ## Appendix C I/O Port Block Diagrams $\overline{RES}$ goes low in a reset, and $\overline{SBY}$ goes low in a reset and in standby mode. Figure C.1 Port 1 Block Diagram (P17) Figure C.2 Port 1 Block Diagram (P16 to P14) Figure C.3 Port 1 Block Diagram (P12, P11) Figure C.4 Port 1 Block Diagram (P10) Figure C.5 Port 2 Block Diagram (P22) Figure C.6 Port 2 Block Diagram (P21) Figure C.7 Port 2 Block Diagram (P20) Figure C.8 Port 5 Block Diagram (P57, P56) Figure C.9 Port 5 Block Diagram (P55) Figure C.10 Port 5 Block Diagram (P54 to P50) Figure C.11 Port 7 Block Diagram (P76) Figure C.12 Port 7 Block Diagram (P75) Figure C.13 Port 7 Block Diagram (P74) Figure C.14 Port 8 Block Diagram (P87 to P85) Figure C.15 Port 8 Block Diagram (P84 to P81) Figure C.16 Port 8 Block Diagram (P80) Figure C.17 Port B Block Diagram (PB7 to PB0) ## Appendix D Port States in the Different Processing States **Table D.1** Port States Overview | Port | Reset | Sleep | Subsleep | Standby | Subactive | Active | |----------------------------------------------------------------------------|-------------------|----------------|----------------|-----------------|----------------|----------------| | P1 <sub>7</sub> to P1 <sub>4</sub> ,<br>P1 <sub>2</sub> to P1 <sub>0</sub> | High<br>impedance | Retained | Retained | High impedance* | Functions | Functions | | P2 <sub>2</sub> to P2 <sub>0</sub> | High<br>impedance | Retained | Retained | High impedance* | Functions | Functions | | P5 <sub>7</sub> to P5 <sub>0</sub> | High impedance | Retained | Retained | High impedance | Functions | Functions | | P7 <sub>6</sub> to P7 <sub>4</sub> | High impedance | Retained | Retained | High impedance | Functions | Functions | | P8 <sub>7</sub> to P8 <sub>0</sub> | High impedance | Retained | Retained | High impedance | Functions | Functions | | PB <sub>7</sub> to PB <sub>0</sub> | High impedance | High impedance | High impedance | High impedance | High impedance | High impedance | Note: \* High level output when MOS pull-up is in on state. # Appendix E Model Names #### Package (Package Code) | Product Ty | /pe | | QFP-64<br>(FP-64A) | QFP-64<br>(FP-64E) | SDIP-42<br>(DP-42S) | |------------|----------------------|------------------|--------------------|--------------------|---------------------| | H8/3664 | Flash memory version | Standard product | HD64F3664H | HD64F3664FP | HD64F3664BP | | | Mask ROM version | Standard product | HD6433664H | HD6433664FP | HD6433664BP | | H8/3663 | Mask ROM version | Standard product | HD6433663H | HD6433663FP | HD6433663BP | | H8/3662 | Mask ROM version | Standard product | HD6433662H | HD6433662FP | HD6433662BP | | H8/3661 | Mask ROM version | Standard product | HD6433661H | HD6433661FP | HD6433661BP | | H8/3660 | Mask ROM version | Standard product | HD6433660H | HD6433660FP | HD6433660BP | ## Appendix F Package Dimensions In case of discrepancy, the package dimensions given in the publication Hitachi Semiconductor Packages apply. Figure F.1 FP-64A Package Dimensions Figure F.2 FP-64E Package Dimensions Figure F.3 DP-42S Package Dimensions #### H8/3664 Series, H8/3664F-ZTAT<sup>TM</sup> Hardware Manual Publication Date: 1st Edition, March 2000 2nd Edition, September 2000 Published by: Electronic Devices Sales & Marketing Group Semiconductor & Integrated Circuits Hitachi, Ltd. Edited by: Technical Documentation Group Hitachi Kodaira Semiconductor Co., Ltd. Copyright ${\hbox{\oensuremath{\mathbb C}}}$ Hitachi, Ltd., 2000. All rights reserved. Printed in Japan.