MICROCOMPUTER MN101C MN101C78A/F78A LSI User's Manual Pub.No.21478-013E PanaXSeries is a trademark of Matsushita Electric Industrial Co., Ltd. The other corporation names, logotype and product names written in this book are trademarks or registered trademarks of their corresponding corporations. # Request for your special attention and precautions in using the technical information and semiconductors described in this book - (1) An export permit needs to be obtained from the competent authorities of the Japanese Government if any of the products or technologies described in this book and controlled under the "Foreign Exchange and Foreign Trade Law" is to be exported or taken out of Japan. - (2) The technical information described in this book is limited to showing representative characteristics and applied circuits examples of the products. It neither warrants non-infringement of intellectual property right or any other rights owned by our company or a third party, nor grants any license. - (3) We are not liable for the infringement of rights owned by a third party arising out of the use of the product or technologies as described in this book. - (4) The products described in this book are intended to be used for standard applications or general electronic equipment (such as office equipment, communications equipment, measuring instruments and household appliances). - Consult our sales staff in advance for information on the following applications: - Special applications (such as for airplanes, aerospace, automobiles, traffic control equipment, combustion equipment, life support systems and safety devices) in which exceptional quality and reliability are required, or if the failure or malfunction of the products may directly jeopardize life or harm the human body. - Any applications other than the standard applications intended. - (5) The products and product specifications described in this book are subject to change without notice for modification and/or improvement. At the final stage of your design, purchasing, or use of the products, therefore, ask for the most up-to-date Product Standards in advance to make sure that the latest specifications satisfy your requirements. - (6) When designing your equipment, comply with the guaranteed values, in particular those of maximum rating, the range of operating power supply voltage, and heat radiation characteristics. Otherwise, we will not be liable for any defect which may arise later in your equipment. Even when the products are used within the guaranteed values, take into the consideration of incidence of break down and failure mode, possible to occur to semiconductor products. Measures on the systems such as redundant design, arresting the spread of fire or preventing glitch are recommended in order to prevent physical injury, fire, social damages, for example, by using the products. - (7) When using products for which damp-proof packing is required, observe the conditions (including shelf life and amount of time let standing of unsealed items) agreed upon when specification sheets are individually exchanged. - (8) This book may be not reprinted or reproduced whether wholly or partially, without the prior written permission of Matsushita Electric Industrial Co., Ltd. If you have any inquiries or questions about this book or our semiconductors, please contact one of our sales offices listed at the back of this book. ## About This Manual ### ■Organization In this LSI manual, this LSI functions are presented in the following order: overview, basic CPU functions, interrupt functions, port functions, timer functions, serial functions, and other peripheral hardware functions. Each section contains overview of function, block diagram, control register, operation, and setting example. ### ■Manual Configuration Each section of this manual consists of a title, summary, main text, key information, precautions and warnings, and references. The layout and definition of each section are shown below. ### ■Finding Desired Information This manual provides three methods for finding desired information quickly and easily. - 1. Consult the index at the front of the manual to locate the beginning of each section. - 2. Consult the table of contents at the front of the manual to locate desired titles. - 3.A chapter number and its chapter title are located at the top corner of each page, and section titles are located at the bottom corner of each page. #### ■Related Manuals Note that the following related documents are available. - "MN101C Series LSI user's Manual" Describes the device hardware> - "MN101C Series Instruction Manual" - <Describes the instruction set.> - " Series C Compiler User's Manual: Usage Guide" <Describes the installation, the commands, and options of the C Compiler.> - "MN101C Series C Compiler User's Manual: Language Description" < Describes the syntax of the C Compiler.> - "MN101C Series C Compiler User's Manual: Library Reference" < Describes the standard library of the C Compiler.> - "MN101C Series Cross-assembler User's Manual" < Describes the assembler syntax and notation.> - "MN101C Series C Source Code Debugger User's Manual" <Describes the use of C source code debugger.> - About This Manual "MN101C Series PanaX Series Installation Manual" Describes the installation of C compiler, cross-assembler and C source code debugger and the procedure for bringing up the in-circuit emulator.> ### Contents Chapter 1 Overview Chapter 2 CPU Basics Chapter 3 Interrupts Chapter 4 I/O Ports Chapter 5 8-Bit Timers Chapter 6 16-Bit Timers Chapter 7 Time Base Timer/Free-running Timer Chapter 8 Remote Control Career Chapter 9 Watchdog Timer Chapter 10 Buzzer Chapter 11 Serial Interface 0 Chapter 12 Serial Interface 1 0 1 2 3 4 5 6 7 8 9 10 11 12 Chapter 13 Serial Interface 3 Chapter 14 Serial Interface 4 Chapter 15 A/D Converter Chapter 16 LCD Chapter 17 Appendix 13 14 15 16 17 Contents # 0 ### Contents | Chapter 1 Overview | I-1 | |-----------------------------------------------------------------------|-------| | 1.1 Overview | I-2 | | 1.1.1 Overview | | | 1.1.2 Product Summary | | | 1.2 Hardware Functions | I-3 | | 1.3 Pin Description | I-10 | | 1.3.1 Pin configuration | | | 1.3.2 Pin Specification | | | 1.3.3 Pin Functions | | | 1.4 Block Diagram | I-20 | | 1.4.1 Block Diagram | | | 1.5 Electrical Characteristics | I-21 | | 1.5.1 Absolute Maximum Ratings *2,*3 | | | 1.5.2 Operating Conditions [NORMAL mode:fs=fosc/2, SLOW mode:fs=fx/2] | | | 1.5.3 DC Characteristics | | | 1.5.4 A/C Converter Characteristics | | | 1.5.5 A/D Converter Characteristics | | | 1.6 Package Dimension | I-34 | | 1.7 Cautions for Circuit Setup | I-35 | | 1.7.1 General Usage | | | 1.7.2 Unused pins | | | 1.7.3 Power Supply | | | 1.7.4 Power Supply Circuit | | | Chapter 2 CPU Basics | II-1 | | 2.1 Overview | II-2 | | 2.1.1 Block Diagram | II-4 | | 2.1.2 CPU Control Registers | II-6 | | 2.1.3 Instruction Execution Controller | II-7 | | 2.1.4 Pipeline Process | II-8 | | 2.1.5 Registers for Address | II-8 | | 2.1.6 Registers for Data | II-9 | | 2.1.7 Processor Status Word | | | 2.1.8 Address Space | II-12 | | 2.1.9 Addressing Modes | | | 2.1.10 Machine Clock | | | 2.2 Memory Space | II-16 | | 2.2.1 Memory Mode | II-16 | |----------------------------------------------|--------| | 2.2.2 Single-chip Mode | II-17 | | 2.2.3 Special Function Registers | II-18 | | 2.3 Bus Interface | II-19 | | 2.3.1 Bus Controller | II-19 | | 2.3.2 Control Registers | II-20 | | 2.4 Standby Function | II-21 | | 2.4.1 Overview | | | 2.4.2 CPU Mode Control Register | | | 2.4.3 Transition between SLOW and NORMAL | | | 2.4.4 Transition to STANDBY Modes | | | 2.5 Clock Switching | II-28 | | 2.6 Reset | II-30 | | 2.6.1 Reset operation | II-30 | | 2.6.2 Oscillation Stabilization Wait time | II-32 | | Chapter 3 Interrupts | III-1 | | 3.1 Overview | III-2 | | 3.1.1 Functions | III-3 | | 3.1.2 Block Diagram | III-4 | | 3.1.3 Operation | III-5 | | 3.1.4 Interrupt Flag Setup | III-16 | | 3.2 Control Registers | III-17 | | 3.2.1 Registers List | III-17 | | 3.2.2 Interrupt Control Registers | III-19 | | 3.3 External Interrupts | III-41 | | 3.3.1 Overview | III-41 | | 3.3.2 Block Diagram | III-42 | | 3.3.3 Control Registers | III-46 | | 3.3.4 Programmable Active Edge Interrupt | III-52 | | 3.3.5 Both Edges Interrupt | III-53 | | 3.3.6 Key Input Interrupt | III-55 | | 3.3.7 Noise Filter | III-56 | | 3.3.8 AC Zero-Cross Detector | III-59 | | 3.3.9 External Interrupt At The Standby Mode | III-61 | | Chapter 4 I/O Ports | IV-1 | | 4.1 Overview | IV-2 | | 4.1.1 I/O Port Overview | IV-2 | | A 1.2 I/O Port Status at Reset | IV-2 | | 4.1.3 Control Registers | IV-3 | |------------------------------|-------------------| | 4.2 Port 1 | IV-5 | | 4.2.1 Description | IV-5 | | 4.2.2 Registers | | | 4.2.3 Block Diagram | | | 4.3 Port 2 | IV-22 | | 4.3.1 Description | IV-22 | | 4.3.2 Registers | IV-22 | | 4.3.3 Block Diagram | IV-23 | | 4.4 Port 3 | IV-24 | | 4.4.1 Description | IV-24 | | 4.4.2 Registers | IV-26 | | 4.4.3 Block Diagram | IV-33 | | 4.5 Port 5 | IV-39 | | 4.5.1 Description | IV-39 | | 4.5.2 Registers | IV-41 | | 4.5.3 Block Diagram | IV-45 | | 4.6 Port 7 | IV-49 | | 4.6.1 Description | IV-49 | | 4.6.2 Registers | IV-51 | | 4.6.3 Block Diagram | IV-58 | | 4.7 Port 9 | IV-66 | | 4.7.1 Description | IV-66 | | 4.7.2 Registers | IV-67 | | 4.7.3 Block Diagram | IV-71 | | 4.8 Port A | IV-72 | | 4.8.1 Description | IV-72 | | 4.8.2 Registers | IV-74 | | 4.8.3 Block Diagram | IV-78 | | 4.9 Real Time Output Control | IV-82 | | 4.9.1 Registers | IV-82 | | 4.9.2 Operation | IV-82 | | apter 5 8-bit Timers | V-1 | | 5.1 Overview | V-2 | | 5.1.1 Functions | | | 5.1.2 Block Diagram | | | 5.2 Control Registers | V-7 | | 5 9 1 Pagistars | $\mathbf{V}_{-}7$ | | 5.2.2 Timer Prescaler Registers | V-9 | |----------------------------------------|-------| | 5.2.3 Programmable Timer Registers | V-12 | | 5.2.4 Timer Mode Registers | V-14 | | 5.3 Prescaler | V-19 | | 5.3.1 Prescaler Operation | V-19 | | 5.3.2 Setup Example | | | 5.4 8-bit Timer | V-21 | | 5.4.1 8-bit Timer Operation | V-21 | | 5.4.2 Setup Example | V-24 | | 5.5 8-bit Event Count | V-26 | | 5.5.1 Operation | V-26 | | 5.5.2 Setup Example | V-29 | | 5.6 8-bit Timer Pulse Output | V-31 | | 5.6.1 Operation | V-31 | | 5.6.2 Setup Example | V-32 | | 5.7 8-bit PWM Output | V-34 | | 5.7.1 Operation | V-34 | | 5.7.2 PWM Output with Additional Pulse | V-37 | | 5.7.3 Setup Example | V-39 | | 5.8 Serial Transfer Clock Output | V-41 | | 5.8.1 Operation | V-41 | | 5.8.2 Setup Example | V-42 | | 5.9 Simple Pulse Width Measurement | V-43 | | 5.9.1 Operation | V-43 | | 5.9.2 Setup Example | V-44 | | 5.10 Cascade Connection | V-46 | | 5.10.1 Operation | | | 5.10.2 Setup Example | V-48 | | | | | Chapter 6 16-bit Timers | VI-1 | | 6.1 Overview | | | 6.1.1 Functions | VI-2 | | 6.1.2 Block Diagram | VI-4 | | 6.2 Control Registers | | | 6.2.1 Registers | | | 6.2.2 Programmable Timer Registers | | | 6.2.3 Timer Mode Registers | VI-16 | | 6.3 Operation | | | 6.3.1 Operation | VI-24 | | 6.3.2 Setup Example | VI-28 | |---------------------------------------------------------------------------------|-------| | 6.4 16-bit Event Count | VI-29 | | 6.4.1 Operation | | | 6.4.2 Setup Example | | | 6.5 16-bit Timer Pulse Output | VI-35 | | 6.5.1 Operation | VI-35 | | 6.5.2 Setup Example | VI-37 | | 6.6 16-bit Standard PWM Output (Only duty can be changed consecutively) | VI-39 | | 6.6.1 Operation | VI-39 | | 6.6.2 Setup Example | VI-42 | | 6.7 16-bit High Precision PWM Output (Cycle/Duty can be changed consecutively) | VI-44 | | 6.7.1 Operation | VI-44 | | 6.7.2 Setup Example | VI-47 | | 6.8 16-bit Timer Capture | | | 6.8.1 Operation | VI-49 | | 6.8.2 Setup Example | VI-55 | | 6.9 16-bit High Precision IGBT Output (Cycle/Duty can be changed consecutively) | VI-57 | | 6.9.1 Operation | VI-57 | | 6.9.2 Setup Example | VI-62 | | 6.10 16-bit Standard IGBT Output (Only duty can be changed consecutively) | | | 6.10.1 Operation | | | 6.10.2 Setup Example | VI-70 | | 6.11 Dead Time IGBT Output | | | 6.11.1 Operation | | | 6.11.2 Setup Example | VI-76 | | 6.12 16-bit Timer Cascade Connection | VI-79 | | 6.12.1 Operation | VI-79 | | 6.12.2 Setup Example (Timer Operation) | VI-81 | | 6.12.3 Setup Example (PWM Operation) | VI-83 | | Chapter 7 Time Base Timer / Free-running Timer | VII-1 | | 7.1 Overview | VII-2 | | 7.1.1 Functions | VII-2 | | 7.1.2 Block Diagram | VII-4 | | 7.2 Control Registers | VII-5 | | 7.2.1 Control Registers | VII-5 | | 7.2.2 Programmable Timer Registers | VII-6 | | 7.2.3 Timer 6 Enable Registers | | | 7.2.4 Timer Mode Registers | VII-8 | | 7.3 8-bit Free-running Timer | VII-9 | |----------------------------------------------------------------------|--------| | 7.3.1 Operation | VII-9 | | 7.3.2 Setup Example | VII-13 | | 7.4 Time Base Timer | VII-15 | | 7.4.1 Operation | | | 7.4.2 Setup Example | | | · · · · · · · · · · · · · · · · · · · | | | Chapter 8 Remote Control Carrier Functions | VIII-1 | | 8.1 Overview | VIII-2 | | 8.1.1 Functions | VIII-2 | | 8.1.2 Block Diagram | VIII-3 | | 8.2 Control Registers | VIII-4 | | 8.2.1 Control Registers | | | 8.2.2 Remote Control Carrier Output Control Register | | | 8.3 Operations | VIII-6 | | 8.3.1 Operations | | | 8.3.2 Setup Examples | | | Chapter 9 Watchdog Timer | IX-1 | | 9.1 Overview | IX-2 | | 9.1.1 Functions | IX-2 | | 9.1.2 Block Diagram | IX-3 | | 9.2 Control Register | IX-4 | | 9.2.1 Control Registers | | | 9.2.2 Watchdog Timer Control Register | | | 9.3 Operation | IX-5 | | 9.3.1 Operation | IX-5 | | 9.3.2 Setup Example | IX-7 | | Chapter 10 Buzzer | X-1 | | 10.1 Overview | X-2 | | 10.1.1 Functions | | | 10.1.2 Block Diagram | | | 10.2 Control Register | X-4 | | 10.2.1 Registers | | | 10.2.2 Oscillation Stabilization Wait Time Control Register (DLYCTR) | | | 10.3 Operation | X-6 | | 10.3.1 Operation | X-6 | |-------------------------------------------|--------| | 10.3.2 Setup Example | | | Chapter 11 Serial interface 0 | XI-1 | | -<br>11.1 Overview | VI 9 | | 11.1 Functions | | | 11.1.2 Block Diagram | | | 11.2 Control Registers | VI 5 | | 11.2.1 Registers | | | 11.2.2 Data Buffer Registers | | | 11.2.3 Mode Registers | | | 11.3 Operation | XI-13 | | 11.3.1 Clock Synchronous Serial Interface | | | 11.3.2 Setup Example | | | 11.3.3 UART Serial Interface | | | 11.3.4 Setup Example | XI-60 | | Chapter 12 Serial interface 1 | XII-1 | | 12.1 Overview | XII-2 | | 12.1.1 Functions | XII-2 | | 12.1.2 Block Diagram | XII-4 | | 12.2 Control Registers | XII-5 | | 12.2.1 Registers | XII-5 | | 12.2.2 Data Buffer Registers | XII-6 | | 12.2.3 Mode Registers | XII-7 | | 12.3 Operation | XII-13 | | 12.3.1 Clock Synchronous Serial Interface | XII-13 | | 12.3.2 Setup Example | XII-33 | | 12.3.3 UART Serial Interface | XII-42 | | 12.3.4 Setup Example | XII-59 | | Chapter 13 Serial Interface 3 | XIII-1 | | 13.1 Overview | XIII-2 | | 13.1.1 Functions | | | 13.1.2 Block Diagram | | | 13.2 Control Registers | XIII-4 | | 13.2.1 Registers List | | | 13.2.2 Data Buffer Register | | | 13.2.3 Data Register | XIII-5 | | 13.2.4 Serial interface 3 Mode Register | XIII-6 | |--------------------------------------------------------|---------| | 13.3 Operation | XIII-11 | | 13.3.1 Clock Synchronous Serial Interface | XIII-11 | | 13.3.2 Setup Example | XIII-28 | | 13.3.3 Single Master IIC Serial Interface | XIII-37 | | 13.3.4 Setup Example | | | Chapter 14 Serial Interface 4 | XIV-1 | | 14.1 Overview | XIV-2 | | 14.1.1 Functions | XIV-2 | | 14.1.2 Block Diagram | XIV-3 | | 14.1.3 Control Registers | XIV-4 | | 14.1.4 Data Buffer Register | XIV-5 | | 14.1.5 Mode Register | XIV-6 | | 14.2 Operation | XIV-9 | | 14.2.1 Setup Example of the Slave IIC Serial Interface | XIV-11 | | Chapter 15 A/D Converter | XV-1 | | 15.1 Overview | XV-2 | | 15.1.1 Functions | | | 15.1.2 Block Diagram | | | 15.2 Control Registers | XV-4 | | 15.2.1 Registers | XV-4 | | 15.2.2 Control Registers | XV-5 | | 15.2.3 Data Buffers | XV-7 | | 15.3 Operation | XV-8 | | 15.3.1 Setup | XV-10 | | 15.3.2 Setup Example | XV-12 | | 15.3.3 Cautions | XV-14 | | Chapter 16 LCD | XVI-1 | | 16.1 Functions | XVI-2 | | 16.1.1 Functions | XVI-2 | | 16.1.2 LCD Operation in Standby Mode | XVI-3 | | 16.1.3 Maximum Pixels | XVI-4 | | 16.1.4 Switching I/O ports and LCD segment pins | XVI-4 | | 16.1.5 Switching I/O Ports and LCD Voltage¶ | XVI-4 | | 16.1.6 Block Diagram | XVI-5 | | 16.2 Control Registers | XVI-6 | | 16.2.1 Registers | XVI-6 | |--------------------------------------------------|---------| | 16.2.2 Mode Control Register 1 (LCDMD1) | XVI-7 | | 16.2.3 Mode Control Register 2 (LCDMD2) | XVI-8 | | 16.2.4 Output Control Register 1 (LCCTR1) | XVI-9 | | 16.2.5 Output Control Register 2 (LCCTR2) | XVI-10 | | 16.2.6 Output Control Register 3 (LCCTR3) | XVI-11 | | 16.2.7 Segment Output Latch | XVI-12 | | 16.3 Operation | XVI-13 | | 16.3.1 Operation | XVI-13 | | 16.3.2 Power Supply | XVI-14 | | 16.3.3 Frame Cycle | XVI-19 | | 16.3.4 Setup Example of the LCD Driver Circuit | XVI-20 | | 16.4 Display | XVI-21 | | 16.4.1 Static | XVI-21 | | 16.4.2 Setup Example (Static) | XVI-23 | | 16.4.3 1/2duty | XVI-24 | | 16.4.4 Setup Example (1/2 duty) | XVI-26 | | 16.4.5 1/3 duty | XVI-27 | | 16.4.6 Setup Example (1/3 duty) | | | 16.4.7 1/4 duty | XVI-30 | | 16.4.8 Setup Example (1/4 duty) | XVI-32 | | Chapter 17 Appendix | XVII-1 | | 17.1 Flash EEPROM | XVII-2 | | 17.1.1 Overview | XVII-2 | | 17.2 PROM Writer Mode | XVII-4 | | 17.2.1 Overview | XVII-4 | | 17.3 Onboard Serial Programming Mode | XVII-5 | | 17.3.1 Overview | XVII-5 | | 17.3.2 Circuit Requirements for the Target Board | XVII-6 | | 17.3.3 Built-in Hardware for Onboard Programming | XVII-7 | | 17.3.4 MN101CF78A Clock on the Target Board | XVII-8 | | 17.4 Special Function Registers List | XVII-9 | | 17.5 Instruction Set | XVII-28 | | 17.6 Instruction Map | XVII-34 | # Chapter 1 Overview ### 1.1 Overview #### 1.1.1 Overview The MN101C series of 8-bit single-chip microcomputers incorporate multiple types of peripheral functions. This chip series is well suited for camera, VCR, MD, TV, CD, LD, printer, telephone, home automation, pager, air conditioner, PPC, remote control, fax machine, music instrument and other applications. This LSI brings to embedded microcomputer applications flexible, optimized hardware configurations and a simple efficient instruction set. The MN101C78A has an internal 32 KB of ROM and 1.5 KB of RAM. Peripheral functions include 4 external interrupts, 18 internal interrupts including NMI, 9 timer counters, 4 sets of serial interfaces, A/D converter, watchdog timer, buzzer output, and remote control output. The configuration of this microcomputer is well suited for application as a system controller in a camera, timer selector for VCR, CD player, or MD. With two oscillation system (max. 10 MHz/32 kHz) contained on the chip, the system clock can be switched to high frequency input (high speed mode), or to low frequency input (low speed mode). The system clock is generated by dividing the oscillation clock. The best operation clock for the system can be selected by switching its frequency by software. High speed mode has the normal mode which is based on 2-cycle clock (fosc/2) and the double speed mode which is based on the same cycle clock with fosc. A machine cycle (min. instructions execution) in the normal mode is 250 ns when fosc is 8 MHz, and when fosc is 10 MHz, a machine cycle is 200 ns. A machine cycle in the double speed mode is 125 ns when fosc is 8 MHz, and 100 ns when fosc is 10 MHz. Two types of packages are available, 48-pin TQFP and 44-pin QFP. ### 1.1.2 Product Summary This manual describes the following models of the MN101C78 series. These products have identical functions. However, MN101C78A is described mainly. Table:1.1.1 Product Summary | Model | ROM Size | RAM Size | Classification | |--------------|----------|----------|----------------------| | MN101C78A*1 | 32 KB | 1.5 KB | Mask ROM version | | MN101C789*2 | 24 KB | 1.5 KB | Mask ROM version | | MN101CF78A*1 | 32 KB | 1.5 KB | Flash EEPROM version | - 1 Under development - \*2 Under consideration ## 1.2 Hardware Functions #### Functions ROM capacity: 32768x8 bit \*1 RAM capacity: 1536x8 bit \*1 \*1 Differs depending upon the model. Refer to [Chapter 1 1-1-2 Product Summary] - Package: QFP44 (10 mm square, 0.8 mm pitch) TQFP48 (7 mm square, 0.5 mm pitch) - Machine cycle: High speed mode <fs=fosc/2, fosc/1> 0.125 ms / -, 8 MHz (2.7 V to 3.6 V) 0.25 ms / 8 MHz, 4 MHz (2.3 V to 3.6 V) \*2 $\,$ 0.50 ms / 4 MHz, 2 MHz (1.8 V to 3.6 V) $^{*}$ 2 Low speed mode <fs=fx / 2> 62.5 ms / 32 kHz (1.8 V to 3.6 V) \*2 \*2 The guaranteed operating range for Flash EEPROM version MN1010CF78A is 2.7 V to 3.6 V. - Internal clock gear: Operation speed of internal system clock is variable by changing the frequency. (2, 4, 16, 32, 64, 128 dividing) - Oscillating circuit: Two oscillation circuits (high speed / low speed) - Operation modes: NORMAL mode SLOW mode HALT mode STOP mode (The operation clock can be switched in each model) - Operating voltage: 1.8 V to 3.6 V (Flash version of TQFP48, MN101CF78A is 2.7 V to 3.6 V) - Operating temperature: -40 C to +85 C - Interrupt: 22 levels <External interrupts> Edge selectable. IRQ0: External interrupt (AC zero cross detector. With/Without noise filter) IRQ1: External interrupt (AC zero cross detector. With/Without noise filter) IRQ2: External interrupt (Both edges selectable IRQ3 – external interrupt) IRQ3: (Key scan interrupt only) <Timer interrupts> TM0IRQ: Timer 0 interrupt (8-bit timer) TM1IRQ: Timer 1 interrupt (8-bit timer) TM2IRQ: Timer 2 interrupt (8-bit timer) TM3IRQ: Timer 3 interrupt (8-bit timer) TM7IRQ: Timer 7 interrupt (16-bit timer) T7OC2IRQ: Timer 7 compare register 2 interrupt (16-bit timer) TM8IRQ: Timer 8 interrupt (16-bit timer) T8OC2IRQ: Timer 8 compare register 2 interrupt (16-bit timer) TM6IRQ: Timer 6 interrupt (8-bit timer) TBIRQ: Time base timer interrupt #### <Serial interface interrupts> SC0RIRQ: Serial interface 0 interrupt (UART reception) SC0TIRQ: Serial interface 0 interrupt (UART transmission, synchronous) SC1RIRQ: Serial interface 1 interrupt (UART reception) ${\tt SC1TIRQ: Serial\ interface\ 1\ interrupt\ (UART\ transmission,\ synchronous)}$ SC3IRQ: Serial interface 3 interrupt (Single master IIC, synchronous) SC4IRQ: Serial interface 4 interrupt (Slave IIC) <Watchdog timer interrupt> NMI: Non-maskable interrupt <A/D conversion end interrupt> ADIRQ: A/D conversion interrupt - A/D converter: 10-bit x 7 channels - Timer counter: 9 timers All timer counters generate interrupt Timer 0 (8-bit timer for general use) Square wave output, PWM output, Event count, Simple pulse width measurement, Clock source: fosc, fosc/4, fosc/16, fosc/32, fosc/64, fs/2, fs/4, fx, external clock P50 of the large current pin (TM0OA) or P15 (TM0OB) for PWM output Timer 1 (8-bit timer for general use or UART baud rate timer) Square wave output, Event count, Cascade connection to timer 0 Clock source: fosc, fosc/4, fosc/16, fosc/64, fosc/128, fs/2, fs/8, fx, external clock Timer 2 (8-bit timer for general use or UART baud rate timer) Square wave output, PWM output, Event count, Simple pulse width measurement Clock source: fosc, fosc/4, fosc/16, fosc/32, fosc/64, fs/2, fs/4, fx, external clock Added pulse (2-bit) system PWM P52 of the large current pin (TM2OA) or P16 (TM2OB) for PWM output Timer 3 (8-bit timer for general use) Square wave output, Event count, Cascade connection to timer2 Clock source: fosc, fosc/4, fosc/16, fosc/64, fosc/128, fs/2, fs/8, fx, external clock Timer 6 (8-bit timer for general use) Combined with time base timer, it can be set to measure one minute intervals. Clock source: fosc, fs, fx, time base output (1/2<sup>12</sup> or 1/2<sup>13</sup>) Timer 7 (16-bit timer for general use) Square wave output, P51 of the large-current pin (TM7O) for PWM output and IGBT control output (Duty/Cycle continuous variable), Event count, Pulse width measurement, Input capture, Cascade connection to timer 8 (32-bit timer, 32-bit PWM, input capture can be used) Clock source: 1/1, 1/2, 1/4, 1/16 of any one of fosc, fx, or external clock Timer 8 (16-bit timer double buffering) Square wave output, P53 of the large-current pin (TM8O) for PWM output (Duty continuous variable), Event count, pulse width measurement, Input capture Time base timer Clock source: fosc, fx Interrupt enable for source clock at the dividing output of 1/27, 1/28, 1/29, 1.210, 1/213, 1/215 Watchdog timer Watchdog timer frequency can be selected from $fs/2^{16}$ , $fs/2^{18}$ , $fs/2^{20}$ - Buzzer output, Inverted buzzer output: Output frequency can be selected from fosc/2<sup>9</sup>, fosc/2<sup>10</sup>, fosc/2<sup>11</sup>, fosc/2<sup>13</sup>, fosc/2<sup>14</sup>, fx/2<sup>3</sup>, fx/2<sup>4</sup>. - Remote control carrier output: Based on the timer 0 and timer 3 output, a remote control carrier with duty cycle of 1/2 or 1/3 can be output. - Clock output: OSC oscillation source or system clock output can be selected. Clock source: 1/1, 1/2, 1/4, 1/16 of any one of fosc, fx, or external clock #### - Serial interface: 4 types Serial interface 0, 1: 2 channels CH0: Duplex UART / Synchronous serial interface - Transfer clock: focs/2, focs/4, focs/16, focs/64, fs/2, fs/4, 1/2 of timer 1 (timer 2) output - Timer 1 (or timer2) is used as baud rate timer at UART. - MSB/LSB can be selected as the first bit to be transferred. An arbitrate transfer size from 1 to 8 bits can be selected. - It can be used as parity check, overrun error, framing error detection, or 2 channels serial interface. CH1: Duplex UART / Synchronous serial interface - Transfer clock: focs/2, focs/4, focs/16, focs/64, fs/2, fs/4, 1/2 of timer 1 (timer 2) output - Timer 1 (or timer2) is used as baud rate timer at UART. - MSB/LSB can be selected as the first bit to be transferred. An arbitrate transfer size from 1 to 8 bits can be selected. - It can be used as parity check, overrun error, framing error detection, or 2 channels serial interface. - Serial interface 1 I/O (SBO1, SBI1, SBT1) can be switched to P15 to P17 or PA5 to PA7. (48 pin version only) - Serial interface 0 I/O (SBO0, SBI0, SBT0) can be switched to P75 to P77 or PA0 to PA2. (44 pin version/ 48 version) #### Serial interface 3: 1 channel Single master IIC / Synchronous serial interface - Single master handling IIC communication enable (with ACK, 9 bits are transferred) - Transfer clock: focs/2, focs/4, focs/16, focs/32, focs/64, fs/2, fs/4, timer 2 (timer 3) output - MSB/LSB can be selected as the first bit to be transferred. An arbitrate transfer size from 1 to 8 bits can be selected. #### Serial interface 4: 1 channel IIC slave interface - IIC high-speed transfer mode (communication speed: 400 kbps) - 7-bit or 10-bit of slave address can be set. - General call communication mode handling (SCL pin, SDA pin can be switched to P10, P11, or P76, P77) - LED driver: 4 pins LCD driver pins: Segment output 12 pins max. (SEG0 to SEG11) SEG0 to SEG11 are switchable to I/O ports in unit of 1 pin. [Note: At reset, SEG0 to SEG11 are input pors.] Common output pins: 4 pins COM0 to COM3 are switchable to I/O port in 1 pin unit. Display mode selection Static 1/2 duty, 1/2 bias 1/3 duty, 1/3 bias 1/4 duty, 1/4 bias LCD driver clock The source clock is the main clock (fosc): $$1/2^{18}$$ , $1/2^{17}$ , $1/2^{16}$ , $1/2^{15}$ , $1/2^{14}$ , $1/2^{13}$ , $1/2^{12}$ , $1/2^{11}$ The source clock is the sub-clock (fx) LCD power supply Available at VDD>VLC1 External supply voltage is supplied by VLC1, VLC2, VLC3 pins or voltage applied to VLC1 is divided by internal resistance and supplied to VLC2 and VLC3 pins | - Port: | | 48 pin | 44 pin | |---------|-----------------------------------------------------------|-----------------|-----------------| | | | version | version | | | I/O ports | 39 pins | 35 pins | | | | (dual function) | (dual function) | | | LED (large current) driver pin | 4 pins | 44 pins | | | (switchable to timer output) | | | | | LCD power supply pin | 3 pins | 3 pins | | | A/D input pin | 1 pin | 1 pin | | | A/D input/ Serial interface pin | 6 pins | 3 pins | | | Timer I/O / LCD driver/ Remote control carrier output pin | 1 pin | 1 pin | | | Timer output/ LCD driver/ Serial interface pin | 2 pins | 2 pins | | | Timer I/O /LCD driver/ Serial interface pin | 1 pin | 1 pin | | | Timer I/O /Buzzer output/ LCD driver pin | 1 pin | 1 pin | | | Timer I/O /inverted buzzer output/ LCD driver pin | 1 pin | 1 pin | | | IIC slave pin | 2 pins | 2 pins | | | Key input/ LCD driver pin | 3 | 3 | | | Key input/ LCD driver/ PWM output pin | 2 | 2 | | | Key input/ LCD driver/ Serial interface pin | 1 | 1 | | | Key input/ LCD driver/ Serial interface/ IIC slave pin | 2 | 2 | | | Common output pin | 1 | 1 | | | Common output/ Serial interface pin | 3 | 3 | | | External interrupt pin | 3 | 3 | | | (2 pins are used as zero cross input pin) | | | | | I/O ports | 1 | - | | | XI pin | 1 | 1 | | | Special pin | 10 | 10 | | | Analog reference voltage input pin | 1 | 1 | | | Operation mode input pin | 1 | 1 | | | Reset input pin | 1 | 1 | | | Oscillation pin (1 pin is used as I/O pin) | 4 | 4 | | | Power supply pin | 3 | 3 | | | | | | ### - Pin switching: | <u>Serial</u> | interface I | /O | |---------------|-------------|----| | | | | | | Option 1 | Option 2 | Option 3 | |-------------------------|----------------------------|--------------------------|---------------------| | Serial interface 0 | SBT0A | SBT0B | - | | Synchronous/ UART | SBO0A/TXD0A | SBO0B/TXD0B | | | Cynonionous/ CART | STI0A/RXD0A | STI0B/RXD0B | | | | STIONINADON | *UART for onboard serial | | | | | | | | | | programming | | | Serial interface 1 | SBT1A | SBT1B | - | | Synchronous/ UART | SBO1A/TXD1A | SBO1B/TXD1B | | | | STI1A/RXD1A | STI1B/RXD1B | | | | | *44 pin version is not | | | | | available | | | Serial interface 3 | SBT3 | - | - | | Synchronous/ IIC single | SBT03 | | | | master | SBI3 | | | | Serial interface 4 | SDA4A | SDA4B | - | | IIC slave | SCL4A | SCL4B | | | | *D-Wire for onboard serial | | | | | programming | | | | Timer I/O | | | | | | Option 1 (I/O) | Option 2 (output 1) | Option 3 (output 2) | | Timer 0 | TM0IO | TM0OA | TM0OB | | Timer 1 | TM1IO | - | - | | Timer 2 | TM2IO | TM2OA | TM2OB | | Timer 3 | TM3IO | - | - | | Timer 7 | TM7IO | TM7O | - | | Timer 8 | TM8IO | TM8O | - | | | | | | # 1.3 Pin Description ### 1.3.1 Pin configuration Figure:1.3.1 Pin Configuration (48TQFP: TOP VIEW) Figure:1.3.2 Pin Configuration (44QFP: TOP VIEW) ## 1.3.2 Pin Specification Table:1.3.1 Pin Specification | Pins | Special F | unctions | I/O | Direction<br>Control | Pin<br>Control | Functions Description | | |--------|------------|----------|--------|----------------------|----------------|---------------------------------------|---------------------------------------------------| | P10 | SDA4A | | in/out | P1DIR0 | P1PLU0 | SDA4A: IIC4 Data I/O | | | P11 | SCL4A | | in/out | P1DIR1 | P1PLU1 | SCL4A: IIC4 Clock I/O | | | P12 | TM8IO | BUZZER | in/out | P1DIR2 | P1PLU2 | TM8IO: Timer 8 I/O | BUZZER: Buzzer output | | P13 | TM7IO | NBUZZER | in/out | P1DIR3 | P1PLU3 | TM7IO: Timer 7 I/O | NBUZZER: Buzzer reverse output | | | CLKOU<br>T | | | | | CLKOUT: Frequency output | | | P14 | TM0IO | RMOUT | in/out | P1DIR4 | P1PLU4 | TM0IO: Timer 0 I/O | RMOUT: Remote control carrier output | | | SEG11 | | | | | SEG11: Segment output | | | P15 | ТМ00В | SB01A | in/out | P1DIR5 | P1PLU5 | TMOOB: Timer 8 I/O | SB01A: Serial interface transmission data output | | | TXD1A | SEG10 | | | | TXD1A: UART1 transmission data output | SEG10: Segment output | | P16 | TM2IO | SBI1A | in/out | P1DIR6 | P1PLU6 | TM2IO: Timer 2 I/O | SBI1A: Serial interface 1 reception data input | | | RXD1A | SEG9 | in/out | | | RXD1A: UART1 reception data input | SEG9: Segment output | | P17 | TM2OB | SBT1A | in/out | P1DIR7 | P1PLU7 | TM2OB: Timer 2 output | SBT1A: Serial interface 1 clock I/O | | | SEG8 | | | | | SEG8: Segment output | | | P27 | NRST | | in | - | - | NRST: Reset | | | P30 | COM0 | | in/out | P3DIR0 | P3PLU0 | COM0: LCD common output | | | P31 | SBI3 | COM1 | in/out | P3DIR1 | P3PLU1 | COM1: LCD common output | SBI3: Serial interface 3 reception data input | | P32 | SBT3 | SCL3 | in/out | P3DIR2 | P3PLU2 | COM2: LCD common output | SBT3: Serial interface 3 clock I/O | | | COM2 | | | | | SCL3: IIC3 clock output | | | P33 | SBO3 | SDA3 | in/out | P3DIR3 | P3PLU3 | COM3: LCD common output | SBO3: Serial interface 3 transmission data output | | | СОМЗ | | | | | SDA3: Serial data I/O | | | P34 | VLC3 | | in/out | | | VLC3: LCD power | | | P35 | VLC2 | | in/out | | | VLC2: LCD power | | | P36 | VLC1 | | in/out | - | - | VLC1: LCD power | | | P37 *1 | | | in/out | P3DIR7 | P3PLU7 | | | | P50 | TM0OA | LED0 | in/out | P5DIR0 | P5PLU0 | TM0OA: Timer 0 output | LED0: LED driver pin 0 | | P51 | TM7O | LED1 | in/out | P5DIR1 | P5PLU1 | TM70: Timer 7 output | LED1: LED driver pin 1 | | P52 | TM2OA | LED2t | in/out | P5DIR2 | P5PLU2 | TM2OA: Timer 2 output | LED2: LED driver pin 2 | | P53 | TM8O | LED3 | in/out | P5DIR3 | P5PLU3 | TM8O: Timer 8 output | LED3: LED driver pin 3 | | P54 | IRQ0 | ACZ0 | in/out | P5DIR4 | P5PLU4 | IRQ0: External interrupt 0 | ACZ0: Zero cross input 0 | | P55 | IRQ1 | ACZ1 | in/out | P5DIR5 | P5PLU5 | IRQ1: External interrupt 1 | ACZ1: Zero cross input 1 | | P56 | IRQ2 | | in/out | P5DIR6 | P5PLU6 | IRQ2: External interrupt 2 | | | P70 | TM1IO | KEY0 | in/out | P7DIR0 | P7PLU0 | TM1IO: Timer 1 I/O | KEYO: Key interrupt input 0 | | | SEG7 | | | | | SEG7: Segment output | | | P71 | TM3IO | KEY1 | in/out | P7DIR1 | P7PLU1 | TM3IO: Timer 1 I/O | KEY1: Key interrupt input 1 | | | SEG6 | | | | | SEG6: Segment output | | | P72 | KEY2 | SEG5 | in/out | P7DIR2 | P7PLU2 | KEY2: Key interrupt input 2 | SEG5: Segment output | | P73 | KEY3 | SEG4 | in/out | P7DIR3 | P7PLU3 | KEY3: Key interrupt input 3 | SEG4: Segment output | | P74 | KEY4 | SEG3 | in/out | P7DIR4 | P7PLU4 | KEY4: Key interrupt input 4 | SEG3: Segment output | | Pins | Special F | unctions | I/O | Direction<br>Control | Pin<br>Control | Functions Description | | |-----------|-----------|----------|--------|----------------------|----------------|----------------------------------------------------|---------------------------------------| | P75 | SBO0B | TXD0B | in/out | P7DIR5 | P7PLU5 | SBO0B: Serial interface 0 transmission data output | TXD0B: UART0 transmission data output | | | KEY5 | SEG2 | | | | KEY5: Key interrupt input 5 | SEG2: Segment output | | P76 | SBIOB | RXDOB | in/out | P7DIR6 | P7PLU6 | SBI0B: Serial interface 0 reception data input | RXD0B: UART0 reception data input | | | SDA4B | KEY6 | | | | SDA4B:IIC4 data I/O | KEY6: KEY interrupt input 6 | | | SEG1 | | | | | SEG1: Segment output | | | P77 | SBT0B | SCL4B | in/out | P7DIR7 | P7PLU7 | SBT0B: Serial interface 0 clock I/O | SCL4B: IIC4 clock I/O | | | KEY7 | SEG0 | | | | KEY7: Key interrupt input 7 | SEG0: Segment 0 output | | P90 | XI | | in | P9DIR0 | P9PLU0 | XI: Low speed frequency input pin | | | PA0 | SBO0A | TXD0A | in/out | PADIR0 | PAPLU0 | SBO0A: Serial interface 0 data output | TXD0A: UART0 transmission data output | | | AN0 | | | | | AN0: Analog 0 input | | | PA1 | SBI0A | RXD0A | in/out | PADIR1 | PAPLU1 | SBI0A: Serial interface 0 data input | RXD0A: UART0 reception data input | | | AN1 | | | | | AN1: Analog 1 input | | | PA2 | SBT0A | AN2 | in/out | PADIR2 | PAPLU2 | SBT0A: Serial interface 0 clock I/O | AN2: Analog 2 input | | PA3 | AN3 | | in/out | PADIR3 | PAPLU3 | AN3: Analog 3 input | | | PA4<br>*1 | AN4 | | in/out | PADIR4 | PAPLU4 | AN4: Analog 4 input | | | | SBI1B | RXD1B | | | | SBI1B: Serial interface 1 data input | RXD1B: UART1 reception data input | | PA5<br>*1 | SBO1B | TXD1B | in/out | PADIR5 | PAPLU5 | SBO1B: Serial interface 1 transmission data output | TXD1B: UART1 transmission data output | | | AN5 | | | | | AN5: Analog 5 input | | | PA6<br>*1 | SBT1B | AN6 | in/out | PADIR6 | PAPLU6 | SBT1B: Serial interface 1 clock I/O | AN6: Analog 6 input | <sup>\* 1</sup> Not available for 44 pin QFP package ### 1.3.3 Pin Functions Table:1.3.2 Pin Functions | Name | TQFP 48<br>Pin No. | QFP44<br>Pin No. | I/O | Other Function | Function | Description | |------------------------------------------------------|----------------------------------------------|----------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>SS</sub><br>V <sub>DD</sub><br>Vref + | 5<br>8, 23<br>15 | 5<br>8, 20<br>15 | - | | Power supply pins | Supply 1.8 V to 3.6 V to $V_{DD}$ and 0 V to $V_{SS}$ . For MN101CF78A, supply 2.7 V to 3.6 V to $V_{DD}$ | | OSC1<br>OSC2 | 7<br>6 | 7<br>6 | Input<br>Output | | Clock input pins<br>Clock output pins | Connect these oscillation pins to ceramic or crystal oscillators for high-frequency clock operation. If the clock is an external input, connect it to OSC1 and leave OSC2 open. The chip will not operate with an external clock when using either the STOP or SLOW modes. | | XI<br>XO | 9 10 | 9 10 | Input<br>Output | P90 | Clock input pins<br>Clock output pins | Connect these oscillation pins to crystal oscillators for low-frequency clock operation. If the clock is an external input, connect it to XI and leave XO open. When using the STOP mode, the chip will not operate with an external clock. If these pins are not used, connect XI to V <sub>SS</sub> and leave XO open. | | NRST | 12 | 12 | Input | P27 | Reset pins<br>[Active low] | This pin resets the chip when power is turned on, is allocated as P27 and contains an internal pull-up resistor (Type. 35 kw). Setting this pin "L" level initialize the internal state of the device. Thereafter, setting the input to "H" level releases the reset. The hardware waits for the system clock to stabilize, then processes the reset interrupt. Also, if "0" is written to P27 and the reset is initiated by software, "L" level will be output. The output has an N-ch open-drain configuration. If a capacitor is to be inserted between NRST and $\rm V_{SS}$ , it is recommended that a discharge diode be placed between NRST and $\rm V_{DD}$ . | | P10<br>P11<br>P12<br>P13<br>P14<br>P15<br>P16<br>P17 | 13<br>14<br>27<br>28<br>29<br>30<br>31<br>32 | 13<br>14<br>24<br>25<br>26<br>27<br>28<br>29 | I/O | SDA4A<br>SCL4A<br>TM8IO, BUZZER<br>TM7IO, NBUZZER, CLKOUT<br>TM0IO, RMOUT, SEG11<br>TM0OB, SBO1A, TXD1A,<br>SEG10<br>TM2IO, SBI1A, RXD1A, SEG9<br>TM2OB, SBI1A, SEG8 | I/O port 0 | 8-bit COMS tri-state I/O port. Each bit can be set individually as either an input or output by the P1DIR register. A pull-up / pull-down resistor for each bit can be selected individually by the P1PLU register. A pull-up / pull-down resistor for each port can be selected individually by the SELUD register. (However, pull-up and pull-down resistors cannot be mixed.) At reset, the input mode is selected and P10, P11 are pull-up resistor enable ("H" output), P12 to P17 are pull-up resistor disable (output"H", "Hi-Z"). | | MMOD | 11 | 11 | Input | | Memory mode setting pins | Input always "L" level. It is used for Flash programming only. | | P27 | 12 | 12 | Input | NRST | I/O port 2 | Port P27 has an N-ch open-drain configuration. When "0" is written and the reset is initiated by software, "L" level will be output. | | | TOED 40 | OED44 | 1 | | | | |---------------------------------------------------------|----------------------------------------------|----------------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Name | TQFP 48<br>Pin No. | QFP44<br>Pin No. | I/O | Other Function | Function | Description | | P30<br>P31<br>P32<br>P33<br>P34<br>P35<br>P36<br>P37 *1 | 41<br>42<br>43<br>44<br>45<br>46<br>47<br>48 | 38<br>39<br>40<br>41<br>42<br>43<br>44 | | COM0<br>SBI3, COM1<br>SBT3, SCL3, COM2<br>SBO3, SDA3, COM3<br>VLC3<br>VLC2<br>VLC1 | I/O port 3 | 8-bit COMS tri-state I/O port. Each bit can be set individually as either an input or output by the P3DIR register. A pull-up resistor for each bit can be selected individually by the P3PLU register. At reset, the input mode is selected and P37is pull-up resistor enable ("H" output), P31 to P37 are pull-up resistor disable (output "H", "Hi-Z"). | | P50<br>P51<br>P52<br>P53<br>P54<br>P55<br>P56 | 1<br>2<br>3<br>4<br>24<br>25<br>26 | 1<br>2<br>3<br>4<br>21<br>22<br>23 | I/O | TM0OA, LED0<br>TM7O, LED1<br>TM2OA, LED2<br>TM8O, LED3<br>IRQ0, ACZ0<br>IRQ1, ACZ1<br>IRQ2 | I/O port 5 | 7-bit COMS tri-state I/O port. Each bit can be set individually as either an input or output by the P5DIR register. A pull-up resistor for each bit can be selected individually by the P5PLU register. Also, at output, LED direct drive is enabled for P50 to P53. At reset, the input mode is selected and pull-up resistors are disabled (output "H", "Hi-Z"). | | P70<br>P71<br>P72<br>P73<br>P74<br>P75<br>P76 | 33<br>34<br>35<br>36<br>37<br>38<br>39<br>40 | 30<br>31<br>32<br>33<br>34<br>35<br>36<br>37 | I/O | TM1IO, KEY0, SEG7<br>TM3IO, KEY1, SEG6<br>KEY2, SEG5<br>KEY3, SEG4<br>KEY4, SEG3<br>SBO0B, TXD0B, KEY5, SEG2<br>SBI0B, RXD0B, SDA4B,<br>KEY6, SEG1<br>SBT0B, SCL4B, KEY7, SEG0 | I/O port 7 | 8-bit COMS tri-state I/O port. Each bit can be set individually as either an input or output by the P7DIR register. A pull-up / pull-down resistor for each bit can be selected individually by the P7PLU register. A pull-up / pull-down resistor for each port can be selected individually by the SELUD register. (However, pull-up and pull-down resistors cannot be mixed.) At reset, the input mode is selected and pull-up resistors are disabled (output "H", "Hi-Z"). | | P90 | 9 | 9 | I/O | XI | I/O port 9 | 8-bit COMS tri-state I/O port. Each bit can be set individually as either an input or output by the P9DIR register. A pull-up / pull-down resistor for each bit can be selected individually by the P9PLU register. Also, by XSEL register, the pin can be switched to oscillation input pin which connects to crystal oscillators for low-frequency clock operation. If the clock is an external input, connect it to XI and leave XO open. At the STOP mode, the chip will not operate with an external clock. At reset, the input mode is selected and pull-up resistors are enabled ("H" output). | | PA0<br>PA1<br>PA2<br>PA3<br>PA4 *1<br>PA5 *1<br>PA6 *1 | 16<br>17<br>18<br>19<br>20<br>21<br>22 | 16<br>17<br>18<br>19 | I/O | AN0, SBO0A, TXD0A<br>AN1, SBI0A, RXD0A<br>AN2, SBT0A<br>AN3<br>AN4, SBI1B, RXD1B<br>AN5, SBO1A, TXD1B<br>AN6, SBT1B | I/O port A | 7-bit COMS tri-state I/O port. Each bit can be set individually as either an input or output by the P7DIR register. At reset, the input mode is selected and pullup resistors are disabled (high impedance output). | | SBO0A<br>SBO0B<br>SBO1A<br>SBO1B *1<br>SBO3 | 16<br>38<br>30<br>21<br>44 | 16<br>35<br>27<br>41 | I/O | PA0, AN0, TXD0A<br>P75, KEY5, RXD0B, SEG2<br>P15, TXD1A, TM0OB, SEG10<br>PA5, AN5, TXD1B<br>P33, COM3 | Serial interface<br>transmission data<br>output pins | Transmission data output pins for serial interface 0, 1, 3. The output configuration, either COMS pushpull or Nch open-drain can be selected at the P10DC, P3ODC, P7ODC, PAODC registers. Pull-up and pull-down registers can be selected by the P1PLUD, P3PLU, P7PLUD, PAPLU registers. Select the output mode at the PADIR registers and serial data output mode by serial mode register 1 (SC0MD1, SC1MD1, SC3MD1). These can be used as normal I/O pins when the serial interface is not used. | | Name | TQFP 48<br>Pin No. | QFP44<br>Pin No. | I/O | Other Function | Function | Description | |---------------------------------------------|----------------------------|----------------------|--------|------------------------------------------------------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SBIOA<br>SBIOB<br>SBI1A<br>SBI1B *1<br>SBI3 | 17<br>39<br>31<br>20<br>42 | 17<br>36<br>28<br>39 | Input | PA1, SBI0A, AN1<br>P76, SBI0B, SEG1, KEY6<br>P16, TM2IO, SBI1A, SEG9<br>PA4, AN4, DBI1B<br>P31, COM1 | Serial interface<br>reception data<br>output pins | Reception data output pins for serial interface 0, 1, 3. Pull-up and pull-down resistors can be selected by the P1PLUD, P3PLU, P7PLUD, PAPLU registers. Select input mode by the P1DIR, P3DIR, P7DIR, PADIR registers and serial input mode by the serial mode register 1 (SC0MD1, SC1MD1, SC3MD1). These can be used as normal I/O pins when the serial interface is not used. | | SBT0A<br>SBT0B<br>SBT1A<br>SBT1B *1<br>SBT3 | 18<br>40<br>32<br>22<br>43 | 18<br>37<br>29<br>40 | I/O | PA2, AN2<br>P77, KEY7, SCL4B, SEG0<br>P17, TM2OB, SEG8<br>PA6, AN6<br>P32, SCL3, COM2 | Serial interface<br>clock I/O pins | Clock I/O pins for serial interface 0, 1, 3. The output configuration, either COMS pushpull or Nch open-drain can be selected at the P1ODC, P3ODC, P7ODC, PAODC registers. Pull-up and pull-down registers can be selected by the P1PLUD, P3PLU, P7PLUD, PAPLU registers. Select clock I/O for each communication mode by the P1DIR, P3DIR, P7DIR, PADIR, PADIR registers and the serial mode register 1 (SC0MD1, SC1MD1, SC3MD1) These can be used as normal I/O pins when the serial interface is not used. | | TXD0A<br>TXD0B<br>TXD1A<br>TXD1B *1 | 16<br>38<br>30<br>21 | 16<br>35<br>27 | Output | PA0, SB00A, AN0<br>P75,SB00B, SEG2, KEY5<br>P15, TM00B, SB01B, SEG10<br>PA5, AN5, SB01B | UART<br>transmission data<br>output pins | Transmission data output pin for serial interface 0, 1 in UART mode The output configuration, either COMS pushpull or Nch open-drain can be selected at the P10DC, P70DC, PAODC registers. Pull-up and pull-down registers can be selected by the P0PLU, P1PLUD, PAPLU registers. Select the output mode at the P1DIR, P7DIR, PADIR registers and serial data output mode by serial mode register 1 (SC0MD1, SC1MD1). These can be used as normal I/O pins when the serial interface is not used. | | RXD0A<br>RXD0B<br>RXD1A<br>RXD1B *1 | 17<br>39<br>31<br>20 | 17<br>36<br>28 | Input | PA1, SBI0A, AN1<br>P76, SBI0B, SEG1, KEY6<br>P16, TM2IO, SBI1A, SEG9<br>PA4, AN4, SBI1B | UART reception data input pins | Reception data input pin for serial interface 0, 1 in UART mode. Pull-up and pull-down registers can be selected by the P1PLUD, P7PLUD, PAPLU registers. Select the input mode at the P1DIR, P7DIR, PADIR registers and serial input mode by serial mode register 1 (SC0MD1, SC1MD1). These can be used as normal I/O pins when the serial interface is not used. | | SDA3<br>SDA4A<br>SDA4B | 44<br>13<br>39 | 41<br>13<br>36 | Output | P33, SBBO3, COM3<br>P10<br>P76, SBI0B, RXD0B, KEY6 | IIC data output pins | Data output pin for serial interface 3, 4 in IIC mode. The output configuration, Nch open-drain can be selected by P1ODC, P3ODC, P7ODC registers and pull-up resistor can be enabled by the P1PLUD, P3PLU, P7PLU registers. Select output mode by the P1DIR, P3DIR, P7DIR registers. These can be used as normal I/O pins when the serial interface is not used. | | Name | TQFP 48<br>Pin No. | QFP44<br>Pin No. | I/O | Other Function | Function | Description | |----------------------------------|-------------------------|----------------------|--------|------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SCL3<br>SCL4A<br>SCL4B | 43<br>14<br>40 | 40<br>14<br>37 | Input | P32, SBT3, COM2<br>P11<br>P77, KEY7, SBT0B, SEG0 | IIC clock I/O pins | Clock I/O pin for serial interface 3, 4 in IIC mode. The output configuration, Nch open-drain can be selected by P1ODC, P3ODC, P7ODC registers and pull-up resistor can be enabled by the P1PLUD, P3PLUD, P7PLUD registers. Select output mode by the P1DIR, P3DIR, P7DIR registers, and select clock I/O by the serial mode register 3 (SC3MD1) and the serial I/O switching control register (SCSEL). These can be used as normal I/O pins when the serial interface is not used. | | TM0IO<br>TM1IO<br>TM2IO<br>TM3IO | 29<br>33<br>31<br>34 | 26<br>30<br>28<br>31 | I/O | P14, RMOUT, SEG11<br>P70, KEY0, SEG7<br>P16, RXD1A, SBI1A, SEG9<br>P71, KEY1, SEG6 | Timer I/O pins | Event counter clock input pin, timer output and PWM signal output pin for 8-bit timer 0 to 3. To use this pin as event clock input, configure this as input by the P1DIR register. In the input mode, pull-up / pull-down resistors can be selected by the P1PLUD, P7PLUD register. For timer output, PWM signal output, select the special function pin by the port 1 output mode register (P1OMD) and the port 7 output mode register (P7OMD), and set to the output mode by the P1DIR, P7DIR registers. These can be used as normal I/O pins when the serial interface is not used. | | TM0O<br>TM2O<br>TM2OA<br>TM2OB | 1<br>30<br>3<br>3<br>32 | 1<br>27<br>3<br>29 | Output | P50, LED0<br>P70, SB01A, TXD1A, SEG10<br>P52, LED2<br>P17, SBT1A | Timer output pins | Timer output, PWM signal output pin for 8-bit timer 0 and 2. To select timer output and PWM signal output, select the special function pin by the port 5 output mode register (P5OMD) and port 7 output mode register (P7OMD), and set to the output mode by the P5DIR, P7DIR register. These can be used as normal I/O pins when the serial interface is not used. | | RMOUT | 29 | 26 | Output | P14, TM0IO, SEG11 | Remote control<br>transmission<br>signal output pins | Output pin for remote control transmission signal with a carrier signal. For remote control carrier output, select the special function pin by the port 1 output mode register (P1OMD) and set to the output mode by the P1DIR register. At the same time, select remote control carrier output by the remote control carrier output control register (RMCTR). These can be used as normal I/O pins when the serial interface is not used. | | BUZZERA<br>NBUZZERA | 27<br>28 | 24 25 | Output | P12, TM8IO<br>P13, TM7IO, CLKOUT | Buzzer outputs | Piezoelectric buzzer driver pin. Buzzer output is available. Driving frequency can be set by the DLYCTR register. The driving frequency can be selected by the DLYCTR register. To select buzzer output for port 0, select the special function pin by the port 1 output mode register (P1OMD) and set to the output mode by the P1DIR register. At the same time, select buzzer output by the oscillation stabilization wait control register (DLYCTR). These can be used as normal I/O pins when the serial interface is not used. | | Name | TQFP 48<br>Pin No. | QFP44<br>Pin No. | I/O | Other Function | Function | Description | |--------------------------------------------------------|----------------------------------------|----------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TM7IO<br>TM8IO | 28<br>27 | 25<br>24 | I/O | P13, NBUZZER, CLKOUT<br>P12, BUZZER | Timer I/O pins | Event counter clock input pin, timer output and PWM signal output pin for 16-bit timer 7and 8. To use this pin as event clock input, configure this as input by the P1DIR register. In the input mode, pull-up / pull-down resistors can be selected by the P1PLU register. For timer output, PWM signal output, select the special function pin by the port 1 output mode register (P1OMD), and set to the output mode by the P1DIR register. These can be used as normal I/O pins when the serial interface is not used. | | TM7O<br>TM8O | 2 4 | 2 4 | Output | P51, LED1<br>P53, LED3 | Timer output pins | Timer output, PWM signal output pin for 16-bit timer 7 and 8. To select timer output and PWM signal output, select the special function pin at the port 5 output mode register (P5OMD) and set to the output mode by the P5DIR register. These can be used as normal I/O pins when the serial interface is not used. | | V <sub>REF+</sub> | 15 | 15 | - | | + power supply for<br>A/D converter | Reference power supply pins for the A/D converter. Normally, the values of V <sub>REF+</sub> = V <sub>DD</sub> is used. | | AN0<br>AN1<br>AN2<br>AN3<br>AN4 *1<br>AN5 *1<br>AN6 *1 | 16<br>17<br>18<br>19<br>20<br>21<br>22 | 16<br>17<br>18<br>19 | Input | PA0, SB00A, TXD0A<br>PA1, SB10A, RXD0A<br>PA2, SBT0A<br>PA3<br>PA4, SB11B, RXD1B<br>PA5, SB01A, TXD1B<br>PA6, SBT1B | Analog input pins | Analog input pins for an 7-channel, 10-bit A/D converter. When not used for analog input, these pins can be used as normal input pins. | | IRQ0<br>IRQ1<br>IRQ2 | 24<br>25<br>26 | 21<br>22<br>23 | Input | P54, ACZ0<br>P55, ACZ1<br>P56 | External interrupt input pins | External interrupt input pins. The valid edge for IRQ0 to 2 can be selected by the IRQnICR register. IRQ1 is an external interrupt pin that is able to determine AC zero-crossings. Both edge for IRQ2 is valid for interrupt. When these are not used for interrupts, these can be used as normal input pins. | | ACZ0<br>ACZ1 | 24<br>25 | 21 22 | Input | P54, IRQ0<br>P55, IRQ1 | AC zero-cross<br>detection input<br>pins | An input pin for an AC zero-cross detection circuit. AC zero-cross detection circuit outputs a high level when the input is at an intermediate level. It outputs a low level at all other times. ACZ input signal is connected to the P54 (P55) input circuit and the IRQ0 (IRQ1) interrupt circuit. When the AC zero-cross detection circuit is not used, this pin can be used as a normal P54 (P55) input. | | KEY0<br>KEY1<br>KEY2<br>KEY3<br>KEY4<br>KEY5<br>KEY6 | 33<br>34<br>35<br>36<br>37<br>38<br>39 | 30<br>31<br>32<br>33<br>34<br>35<br>36 | Input | P70, TM1IO, SEG7<br>P71, TM3IO, SEG6<br>P72, SEG5<br>P73, SEG4<br>P74, SEG3<br>P75, SBO0B, TXD0B, SEG2<br>P76, SBI0B, RXD0B, SDA4B,<br>SEG1<br>P77, SBT0B, SCL4B, SEG0 | Key interrupt input pins | Input pins for interrupt based on ORed result of pin inputs. Key input pin for 1 bit can be selected individually by the key interrupt control register (KEYT3_1IMD, KEYT3_2IMD). When not used for KEY input, these pins can be used as a normal I/O pins. | | LED0<br>LED1<br>LED2<br>LED3 | 1<br>2<br>3<br>4 | 1<br>2<br>3<br>4 | I/O | P50, TM0OA<br>P51, TM7O<br>P52, TM2OA<br>P53, TM8O | LED drive pins | Large current output pins. When not used for LED output, these pins can be used as a normal I/O pins. | <sup>\* 1</sup> Not available for 44 pin QFP package | TQFP 48<br>Pin No. | QFP44<br>Pin No. | I/O | Other Function | Function | Description | |----------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 28 | 25 | Output | P13, TM7IO, NBUZZER | | Oscillation clock signal output pin. | | 41<br>42<br>43<br>44 | 38<br>39<br>40<br>41 | Output | P30<br>P31, SBI3<br>P32, SBT3, SCL3<br>P33, SBO3, SDA3 | LCD common output pin | These pins output the common signal with the required timing for the LCD display. Connect to the common pins of LCD display panel. When the LCD display panel is turned off, V <sub>SS</sub> is output. When the LCD functions are unused, they can be used as a normal port by setting the LCD output control register LCCTR1. | | 45<br>46<br>47 | 42<br>43<br>44 | - | P36<br>P35<br>P34 | LCD power pins | Supply for LCD power. Apply voltage: $3.6 \text{ V} \ge V_{LC1} \ge V_{LC2} \ge V_{LC3} \ge 0 \text{ V}$ When the booster voltage circuit is used, $V_{LC2}$ or $V_{LC3}$ pins are selected as the reference input pins. When the internal voltage divider circuit is used, $V_{LC1}$ pin is selected as the reference input pin. When the LCD functions are unused, $V_{LC3}$ can be used as a normal port by setting the LCD mode control register 3 (LCDMD3). | | 40<br>39<br>38<br>37<br>36<br>35<br>34<br>33<br>32<br>31<br>30 | 37<br>36<br>35<br>34<br>33<br>32<br>31<br>30<br>29<br>28<br>27 | Output | P77, SBT0B, SCL4B, KEY7 P76, SBI0B, RXD0B, SDA4B, KEY6 P75, SBO0B, TXD0B, KEY5 P74, KEY4 P73, KEY3 P72, KEY2 P71, TM3IO, KEY1 P70, TM1IO, KEY0 P17, TM2IO, SBI1A P16, TM2IO, SBI1A, RXD1A | LCD segment output pins | These pins output the segment signal with the required timing for the LCD display. Connect to the segment pins of the LCD panel. When the LCD display is turned off, V <sub>SS</sub> level is output. It can be used as a normal port by setting of the LCD output control register LCCTR1, LCCTR2, LCCTR3, LCCTR4. Segment pin and normal port are switchable by each bit from SEG0 to SEG11. | | | Pin No. 28 41 42 43 44 44 45 46 47 40 39 38 37 36 35 34 33 32 31 | Pin No. Pin No. 28 25 41 38 42 39 43 40 44 41 45 42 46 43 47 44 40 37 39 36 38 35 37 34 36 33 35 32 34 31 33 30 32 29 31 28 30 27 | Pin No. Pin No. I/O 28 25 Output 41 38 42 39 43 40 44 41 44 41 45 42 46 43 47 44 40 37 36 36 37 36 38 35 32 34 31 33 30 32 29 31 28 30 27 | Pin No. Pin No. I/O Other Function 28 25 Output P13, TM7IO, NBUZZER 41 38 Output P30 42 39 P31, SBI3 43 40 P32, SBT3, SCL3 P33, SBO3, SDA3 P35, SBO3, SDA3 46 43 P35 47 P36 P35 P34 P34 Output P77, SBT0B, SCL4B, KEY7 P76, SBI0B, RXD0B, SDA4B, KEY6 P76, SBI0B, RXD0B, SDA4B, KEY6 P76, SBI0B, RXD0B, KEY5 P74, KEY4 P75, SBO0B, TXD0B, KEY5 P74, KEY4 P73, KEY3 P72, KEY2 P73, KEY3 P72, KEY2 P71, TM3IO, KEY1 P70, TM1IO, KEY0 P17, TM2OB, SBI1A P16, TM2IO, SBI1A, RXD1A | Pin No. Pin No. I/O Other Function Function 28 25 Output P13, TM7IO, NBUZZER LCD common output pin 41 38 Output P30 LCD common output pin 42 39 P31, SBI3 P32, SBT3, SCL3 P35, SBO3, SDA3 45 42 - P36 P35 47 44 P35 P34 40 37 Output P77, SBT0B, SCL4B, KEY7 D44 79 P6, SBI0B, RXD0B, SDA4B, KEY6 P75, SBO0B, RXD0B, SDA4B, KEY6 88 35 P75, SBO0B, TXD0B, KEY5 P74, KEY4 973, KEY3 P73, KEY3 P72, KEY2 P73, KEY2 34 31 P72, KEY2 P71, TM3IO, KEY1 30 27 P71, TM2OB, SBI1A, RXD1A P16, TMZIO, SBI1A, RXD1A 29 26 P15, TM0OB, SBO1A | $<sup>^{\</sup>ast}$ 1 Not available for 44 pin QFP package ## 1.4 Block Diagram ## 1.4.1 Block Diagram Figure:1.4.1 Block Diagram \* Differs depending upon the model. [ Refer to 1.1.2 Product Summary] ## 1.5 Electrical Characteristics This LSI manual describes the standard specification. Machine cycle (system clock fs) is described based on the standard mode:1/2 of high oscillation at NORMAL mode, or on the clock frequency:1/2 of low oscillation at SLOW mode. Please ask our sales offices for the product specifications. | Model | MN101C78A | | |----------|-------------|-------------------------------------------| | | Structure | CMOS integrated circuit | | Contents | Application | General purpose | | | Function | CMOS, 8-bit, single chip micro controller | ## 1.5.1 Absolute Maximum Ratings \*2,\*3 $V_{DD}$ =1.8V to 3.6V $V_{SS}$ =0V | Para | ameter | | Symbol | Rating | Unit | |------|-------------------------------|-----------------------------|-------------------------|--------------------------------------------|------| | 1 | Power supply voltag | е | $V_{DD}$ | -0.3 to +4.6 | V | | 2 | Input clamp current | | I <sub>C</sub> | -400 to +400 | μΑ | | 3 | Input pin voltage | | V <sub>I</sub> | -0.3 to V <sub>DD</sub> + 0.3 | | | 4 | Output pin voltage | | V <sub>O</sub> | -0.3 to V <sub>DD</sub> + 0.3 | V | | 5 | I/O pin voltage | | V <sub>IO1</sub> | -0.3 to V <sub>DD</sub> + 0.3 (except ACZ) | | | 6 | | P50 to<br>P53 | I <sub>OL1</sub> (peak) | 30 | | | 7 | Peak output current | Other<br>than P50<br>to P53 | I <sub>OL2</sub> (peak) | 10 | | | 8 | | All pins | I <sub>OH</sub> (peak) | -10 | | | 9 | | P50 to<br>P53 | I <sub>OL1</sub> (avg) | 20 | mA | | 10 | Average output current *1 | Other<br>than P50<br>to P53 | I <sub>OL2</sub> (avg) | 5 | | | 11 | | All pins | I <sub>OH</sub> (avg) | -5 | | | 12 | Total output current | <sup>*</sup> 1 | I <sub>TOL</sub> | 60 | | | 13 | | | I <sub>TOH</sub> | -60 | | | 14 | Power dissipation | | P <sub>T</sub> | 400(Ta=+85°C) | mW | | 15 | Operation ambient temperature | | T <sub>opr</sub> | -40 to +85 | °C | | 16 | Storage temperature | ) | Tstg | -55 to +125 | | <sup>\*1</sup> Applied to any 100-ms period. $<sup>^{\</sup>star}2$ Connect at least one bypass capacitor of 0.1 $\mu\text{F}$ or larger between the power supply pin and the ground for latch-up prevention. <sup>\*3</sup> The absolute maximum ratings are the tolerance for the LSI to be operated properly. It does not guarantee the operation. # 1.5.2 Operating Conditions [NORMAL mode:fs=fosc/2, SLOW mode:fs=fx/2] $V_{DD}$ =1.8V to 3.6V $V_{SS}$ =0V | Dor | | Councile of | Conditions | Rating | | | I In it | |-----|----------------------------------------------|-------------------|--------------------------------------------------------------|--------|-----|------|---------| | Par | ameter | Symbol | Conditions | MIN | TYP | MAX | Unit | | Pov | ver supply voltage *4 | | 1 | | | I. | · · | | 1 | | $V_{DD1}$ | fosc ≤ 10.0 MHz<br>[Double-speed mode:fs=fosc] | 3.0 | - | 3.6 | | | 2 | | V <sub>DD2</sub> | fosc ≤ 8.5 MHz<br>[Double-speed mode:fs=fosc] | 2.7 | - | 3.6 | | | 3 | Mask ROM version<br>Power supply voltage | $V_{DD3}$ | fosc ≤ 4.25 MHz<br>[Normal mode:fs=fosc] | 1.8 | - | 3.6 | | | 4 | | $V_{DD4}$ | fosc ≤ 4.25 MHz<br>[Normal mode:fs=fosc/2] | 1.8 | - | 3.6 | | | 5 | | $V_{DD5}$ | fx = 32.768 kHz<br>[Normal mode:fs=fx/2] | 1.8 | - | 3.6 | | | 6 | | V <sub>DD6</sub> | fosc ≤ 5 MHz<br>[Double-speed mode:fs=fosc] | 3.0 | - | 3.6 | V | | 7 | Flash EEPROM version<br>Power supply voltage | V <sub>DD7</sub> | fosc ≤ 4.25 MHz<br>[Double-speed mode:fs=fosc] | 2.7 | - | 3.6 | | | 8 | | V <sub>DD8</sub> | fosc ≤ 10 MHz<br>[Normal mode:fs=fosc/2] | 3.0 | - | 3.6 | | | 9 | | V <sub>DD9</sub> | fosc ≤ 8.5 MHz<br>[Normal mode:fs=fosc/2] | 2.7 | - | 3.6 | | | 10 | | V <sub>DD10</sub> | fx = 32.768 kHz<br>[Normal mode:fs=fx/2] | 2.7 | - | 3.6 | | | 11 | Voltage to maintain RAM data | V <sub>DD11</sub> | At STOP mode | 1.8 | - | 3.6 | | | Ope | eration speed *5 | | | | | | | | 12 | | t <sub>c1</sub> | V <sub>DD</sub> =3.0 to 3.6 V<br>[Double speed mode:fs=fosc] | 0.100 | - | - | | | 13 | | t <sub>c2</sub> | V <sub>DD</sub> =2.7 to 3.6 V<br>[Double speed mode:fs=fosc] | 0.118 | - | - | | | 14 | Instruction execution time | t <sub>c3</sub> | V <sub>DD</sub> =1.8 to 3.6 V<br>[Double speed mode:fs=fosc] | 0.235 | - | - | μs | | 15 | | t <sub>c4</sub> | V <sub>DD</sub> =1.8 to 3.6 V<br>[Normal mode:fs=fosc/2] | 0.470 | - | - | | | 16 | | t <sub>c5</sub> | V <sub>DD</sub> =1.8 to 3.6 V<br>[Normal mode:fs=fx/2] | 20 | - | 62.5 | | $V_{DD}\!\!=\!\!1.8V$ to 3.6V $\;V_{SS}\!\!=\!\!0V$ $Ta=-40^{\circ}C$ to $+85^{\circ}C$ | Don | ameter | Cumbal | Conditions | Rating | | | Unit | |-----|--------------------------------|--------------------|----------------------------------------------|--------|--------|------|-----------| | Гаі | ametei | | | MIN | TYP | MAX | | | Cry | stal oscillator 1 Figure:1.5.1 | • | | • | | | | | 17 | | | V <sub>DD</sub> =Within operation power sup- | | | | | | 18 | Crystal frequency | f <sub>xtal1</sub> | ply voltage (Refer to standard rat- | 1.0 | - | 10.0 | MHz | | 19 | | | ings B1 to B5.) | | | | | | 20 | External conscitors | C <sub>11</sub> | | - | 20 | - | pF | | 21 | External capacitors | C <sub>12</sub> | | - | 20 | - | | | 22 | Internal feedback resistor | R <sub>f10</sub> | | - | 1.2 | - | $M\Omega$ | | Cry | stal oscillator 2 Figure:1.5.2 | | | | • | | | | 23 | Crystal frequency | f <sub>xtal2</sub> | V <sub>DD</sub> =1.8 V to 3.6 V | - | 32.768 | - | kHz | | 24 | External capacitors | C <sub>21</sub> | | - | 20 | - | n.E | | 25 | - External capacitors | C <sub>22</sub> | | - | 20 | - | – pF | | 26 | Internal feedback resistor | R <sub>f20</sub> | | - | 17.6 | - | ΜΩ | Figure:1.5.2 Crystal oscillator 2 Connect external capacitors that suits the used pin. When crystal oscillator or ceramic oscillator is used, the frequency is changed depending on the condenser rate. Therefore, consult the manufacturer of the pin for the appropriate external capacitor. $V_{DD}$ =1.8V to 3.6V $V_{SS}$ =0V | Dor | ramator | Cumbal | Conditions | Rating | | | Unit | |-----|---------------------------------|------------------|---------------|--------|-----|------|------| | Pai | ameter | Symbol | Conditions | MIN | TYP | MAX | Unit | | Ext | ernal clock input 1 OSC1 (OS | C2 is unco | nnected) | • | | • | • | | 27 | Clock frequency | fosc | | 1.0 | - | 10.0 | MHz | | 28 | High level pulse width *6 | t <sub>wh1</sub> | Figure:1.5.3 | 90 | - | - | | | 29 | Low level pulse width *6 | t <sub>wl1</sub> | Figure. 1.5.5 | 90 | - | - | ns | | 30 | Rising time | t <sub>wr1</sub> | Figure:1 F 2o | - | - | 10 | | | 31 | Falling time | t <sub>wf1</sub> | Figure:1.5.3s | - | - | 10 | | | Ext | ernal clock input 2 XI (XO is u | inconnecte | d) | • | | • | • | | 32 | Clock frequency | fx | | 32.768 | - | 100 | kHz | | 33 | High level pulse width *6 | t <sub>wh2</sub> | Figure:1.5.4 | 4.5 | - | - | | | 34 | Low level pulse width *6 | t <sub>wl2</sub> | Figure:1.5.4 | 4.5 | - | - | μs | | 35 | Rising time *7 | t <sub>wr2</sub> | Figure:1.5.4 | - | - | 20 | ne | | 36 | Falling time *7 | t <sub>wf2</sub> | Figure:1.5.4 | - | - | 20 | ns | <sup>\*6</sup> The clock duty rate in the standard mode should be 45% to 55%. Figure:1.5.3 OSC1 Timing Chart Figure:1.5.4 XI Timing Chart ## 1.5.3 DC Characteristics $V_{DD}\!\!=\!\!1.8V$ to 3.6V $\;V_{SS}\!\!=\!\!0V$ | Dox | rameter | Symbol | Conditions | Rating | J | | Unit | |-----|-------------------------------------------|-------------------|------------------------------------------------------------------------|---------|-----|-------|-------| | rai | ametei | Symbol | Conditions | MIN | TYP | MAX | Offic | | Pov | wer supply current *7 | [ NORMA | L mode: fs=fosc/2 SLOW mode:fs | s=fx/2] | II. | | I . | | 1 | | I <sub>DD1</sub> | fosc=10 MHz<br>[Double-speed mode:fs=fosc]<br>V <sub>DD</sub> =3.0 V | - | 2.5 | 5.5 | | | 2 | Mask ROM version<br>Power supply current | I <sub>DD2</sub> | fosc=8.5 MHz<br>[Double-speed mode:fs=fosc]<br>V <sub>DD</sub> =3.0 V | - | 2.0 | 4.0 | | | 3 | | I <sub>DD3</sub> | fosc=4.25 MHz<br>[Double-speed mode:fs=fosc]<br>V <sub>DD</sub> =3.0 V | - | 1.0 | 2.2 | mA | | 4 | | I <sub>DD4</sub> | fosc=8.5 MHz<br>[Normal mode:fs=fosc/2]<br>V <sub>DD</sub> =3.0 V | - | 1.2 | 2.6 | | | 5 | | I <sub>DD5</sub> | fosc=4.25 MHz<br>[Normal mode:fs=fosc/2]<br>V <sub>DD</sub> =3.0 V | - | 0.6 | 1.4 | | | 6 | | I <sub>DD6</sub> | fx=32.768 kHz V <sub>DD</sub> =3.0 V<br>[fs=fx/2] Ta=25 °C | - | 4 | 15 | μΑ | | 7 | | I <sub>DD7</sub> | fx=32.768 kHz V <sub>DD</sub> =3 V<br>[fs=fx/2] Ta=85 °C | - | - | 50 | μΑ | | 8 | | I <sub>DD8</sub> | fosc=5 MHz<br>[Double-speed mode:fs=fosc]<br>V <sub>DD</sub> =3.3 V | - | 2.4 | t.b.d | | | 9 | | I <sub>DD9</sub> | fosc=4.25 MHz<br>[Double-speed mode:fs=fosc]<br>V <sub>DD</sub> =3.0 V | - | 2.1 | t.b.d | ^ | | 10 | Flash EEPROM version Power supply current | I <sub>DD10</sub> | fosc=10 MHz<br>[Normal mode:fs=fosc]<br>V <sub>DD</sub> =3.3 V | - | - | t.b.d | mA | | 11 | | I <sub>DD11</sub> | fosc=8.5 MHz<br>[Normal mode:fs=fosc/2]<br>V <sub>DD</sub> =3.0 V | - | 2.3 | t.b.d | | | 12 | | I <sub>DD12</sub> | fx=32.768 kHz V <sub>DD</sub> =3.0 V<br>[fs=fx/2] Ta=25 °C | - | - | t.b.d | μΑ | | 13 | | I <sub>DD13</sub> | fx=32.768 kHz V <sub>DD</sub> =3 V<br>[fs=fx/2] Ta=85 °C | - | - | t.b.d | μΑ | $V_{DD}$ =1.8V to 3.6V $V_{SS}$ =0V | Par | Parameter | | Conditions | Rating | | | Unit | |------|----------------------------|-------------------|--------------------------------------------------|--------|-----|-----|-------| | ı aı | anicici | Symbol | Conditions | MIN | TYP | MAX | Offic | | 14 | Supply current during | I <sub>DD14</sub> | fx=32.768 kHz V <sub>DD</sub> =3 .0V<br>Ta=25 °C | - | - | 4 | μΑ | | | HALT1 mode | • | fx=32.768 kHz V <sub>DD</sub> =3.0 V | | | 40 | | | 15 | 15 | | Ta=85 °C (fosc stop) | - | - | | | | | Supply current during STOP | I <sub>DD16</sub> | V <sub>DD</sub> =3 V Ta=25 °C | - | - | 2 | | | 17 | mode | I <sub>DD17</sub> | V <sub>DD</sub> =3 V Ta=85 °C | - | - | 30 | | - \*7 Measured under conditions without load, Ta=25°C. (pull-up / pull-down resistors are unconnected.) - The supply current during operation, $I_{DD1}$ to $I_{DD5}$ and $I_{DD8}$ to $I_{DD11}$ are measured under the following conditions: - After all I/O pins are set to input mode and the oscillation is set to <NORMAL mode>, the MMOD pin is at $V_{SS}$ level, the input pins are at $V_{DD}$ level, and a 10 MHz (8.50 MHz, 5 MHz, 4.25 MHz) square wave of $V_{DD}$ and $V_{SS}$ amplitudes is input to the OSC1 pin. - The supply current during operation, I<sub>DD6</sub>, I<sub>DD7</sub>, and I<sub>DD12</sub>, I<sub>DD13</sub> are measured under the following conditions: - After all I/O pins are set to input mode and the oscillation is set to <SLOW mode>, the MMOD pin is at $V_{SS}$ level, the input pins are at $V_{DD}$ level, and a 32.768 kHz square wave of $V_{DD}$ and $V_{SS}$ amplitudes is input to the XI pin. - The supply current during HALT1 mode, $I_{DD14}$ , $I_{DD15}$ are measured under the following conditions: After all I/O pins are set to input mode and the oscillation is set to <HALT mode>, the input pins are at $V_{DD}$ level, and an 32.768 kHz square wave of $V_{DD}$ and $V_{SS}$ amplitudes is input to the XI pin. - The supply current during STOP mode, $I_{DD16}$ , $I_{DD17}$ are measured under the following conditions: After the oscillation is set to <STOP mode>, the MMOD pin is at $V_{SS}$ level, the input pins are at $V_{DD}$ level, and the OSC1 and XI pins are unconnected. $V_{DD} \!\!=\! 1.8 V$ to 3.6V $\quad V_{SS} \!\!=\! \! 0 V$ | Dor | ameter | Symbol | Conditions | Rating | | | Unit | |-----|----------------------------------|--------------------|-----------------------------------------------------------------------------------------|--------------------|-----|---------------------|----------| | Par | ameter | Symbol | Conditions | MIN | TYP | MAX | Offic | | Inp | ut pin 1 MMOD | • | | • | • | - | | | 18 | Input high voltage 1 | V <sub>IH1</sub> | | 0.8V <sub>DD</sub> | - | $V_{DD}$ | V | | 19 | Input low voltage 1 | V <sub>IL1</sub> | | 0 | - | 0.2V <sub>DD</sub> | V | | 20 | Input leakage current | I <sub>LK1</sub> | V <sub>I</sub> =0 V to V <sub>DD</sub> | - | - | ± 2 | μΑ | | Inp | ut pin 2 P54 (Schmitt trigger i | nput) | | • | | | • | | 21 | Input high voltage | V <sub>IH2</sub> | | 0.8V <sub>DD</sub> | - | $V_{DD}$ | V | | 22 | Input low voltage | V <sub>IL2</sub> | | 0 | - | 0.2V <sub>DD</sub> | V | | 23 | Input leakage current | I <sub>LK2</sub> | V <sub>I</sub> =0 V to V <sub>DD</sub> | - | - | ± 2 | μΑ | | 24 | Pull-up resistor | I <sub>RH2</sub> | V <sub>DD</sub> =3.0V V <sub>I</sub> =V <sub>SS</sub><br>Pull-up resistor ON | 30 | 100 | 300 | kΩ | | 25 | Output high voltage | V <sub>OH2</sub> | V <sub>DD</sub> =3.0 V I <sub>OH</sub> =-2.0 mA | 2.4 | - | - | ., | | 26 | Output low voltage | V <sub>OL2</sub> | V <sub>DD</sub> =3.0 V I <sub>OL</sub> =2.0 mA | - | - | 0.4 | V | | Inp | ut pin 3 P55 (Schmitt trigger ir | nput) | • | | ļ. | Į. | ļ. | | 27 | Input high voltage | V <sub>IH3</sub> | | 0.8V <sub>DD</sub> | - | $V_{DD}$ | V | | 28 | Input low voltage | $V_{IL3}$ | | 0 | - | 0.2V <sub>DD</sub> | V | | 29 | Input leakage current | I <sub>LK3</sub> | V <sub>I</sub> =0 V to V <sub>DD</sub> | - | | ± 2 | μΑ | | 30 | Pull-up resistor | I <sub>RH3</sub> | V <sub>DD</sub> =3.0 V <sub>I</sub> =V <sub>SS</sub><br>Pull-up resistor ON | 30 | 100 | 300 | kΩ | | 31 | Output high voltage | V <sub>OH3</sub> | V <sub>DD</sub> =3.0 V I <sub>OH</sub> =-2.0 mA | 2.4 | - | - | | | 32 | Output low voltage | V <sub>OL3</sub> | V <sub>DD</sub> =3.0 V I <sub>OL</sub> =2.0 mA | - | - | 0.4 | | | Inp | ut pin 4 P54, P55 (Used as A | CZ) | | | | L | I | | 33 | | V <sub>DLH42</sub> | | - | - | 1.9 | | | 34 | High level detection voltage | V <sub>DHL42</sub> | V <sub>DD</sub> =3.0 | 1.1 | - | - | 1, | | 35 | | V <sub>DHH42</sub> | Figure:1.5.5 | 2.7 | - | - | V | | 36 | Low level detection voltage | V <sub>DLL42</sub> | | - | - | 0.4 | | | 37 | Input leakage current | I <sub>LK4</sub> 2 | V <sub>I</sub> =0 V to V <sub>DD</sub> | - | - | ± 2 | _ | | 38 | Input clamp current | I <sub>C42</sub> | $V_I > V_{DD}$ $V_I < 0V$ | - | - | ± 400 | μΑ | | Inp | ut pin 5 P27 (NRST) | | | | | | | | 39 | Input high voltage | V <sub>IH5</sub> | | 0.8V <sub>DD</sub> | - | $V_{DD}$ | | | 40 | Input low voltage | V <sub>IL5</sub> | | 0 | - | 0.15V <sub>DD</sub> | V | | 41 | Pull-up resistor | I <sub>RH5</sub> | V <sub>DD</sub> =3.0V , V, V <sub>I</sub> =V <sub>SS</sub><br>Internal pull-up resistor | 30 | 100 | 300 | kΩ | | I/O | pin 6 P10 to P17, P70 to P77 | (Schmitt tr | rigger input) | 1 | 1 | ı | <u>I</u> | | 42 | Input high voltage | V <sub>IH6</sub> | | 0.8V <sub>DD</sub> | - | $V_{DD}$ | ., | | 43 | Input low voltage | V <sub>IL6</sub> | | 0 | - | 0.2V <sub>DD</sub> | V | | 44 | Input leakage current | I <sub>LK6</sub> | V <sub>I</sub> =0 V to V <sub>DD</sub> | - | - | ± 2 | μΑ | | 45 | Pull-up resistor | I <sub>RH6</sub> | V <sub>DD</sub> =3.0 V <sub>I</sub> =V <sub>SS</sub><br>Pull-up resistor ON | 30 | 100 | 300 | kΩ | $V_{DD}$ =1.8V to 3.6V $V_{SS}$ =0V | Por | ameter | Symbol | Conditions | Rating | | | Unit | |-----|----------------------------------------------------------|--------------------|-------------------------------------------------------------------------------|--------------------|-----|--------------------|---------------------------------------| | Fai | ametei | Symbol | Conditions | MIN | TYP | MAX | Offic | | 46 | Pull-down resistor | I <sub>RL6</sub> | V <sub>DD</sub> =3.0 V <sub>I</sub> =V <sub>DD</sub><br>Pull-down resistor ON | 30 | 100 | 300 | kΩ | | 47 | Output high voltage | V <sub>OH6</sub> | V <sub>DD</sub> =3.0 I <sub>OH</sub> =-2.0 mA | 2.4 | - | - | V | | 48 | Output low voltage | V <sub>OL6</sub> | V <sub>DD</sub> =3.0 I <sub>OL</sub> =2.0 mA | - | - | 0.4 | V | | I/O | pin 7 P56, PA0 to PA6, P30 to | P37 (Sch | mitt trigger input) | | | | | | 49 | Input high voltage | V <sub>IH7</sub> | | 0.8V <sub>DD</sub> | - | $V_{DD}$ | V | | 50 | Input low voltage | V <sub>IL7</sub> | | 0 | - | 0.2V <sub>DD</sub> | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | 51 | Input leakage current | I <sub>LK7</sub> | V <sub>I</sub> =0 V to V <sub>DD</sub> | - | - | ± 2 | μΑ | | 52 | Pull-up resistor | I <sub>RH7</sub> | V <sub>DD</sub> =3.0 V <sub>I</sub> =V <sub>SS</sub><br>Pull-up resistor ON | 30 | 100 | 300 | kΩ | | 53 | Output high voltage | V <sub>OH7</sub> | V <sub>DD</sub> =3.0 I <sub>OH</sub> =-2.0 mA | 2.4 | - | - | ., | | 54 | Output low voltage | V <sub>OL7</sub> | V <sub>DD</sub> =3.0 I <sub>OL</sub> =-2.0 mA | - | - | 0.4 | V | | I/O | pin 8 P50 to P53 (Schmitt trig | ger input) | | I. | | 1 | | | 55 | Input high voltage | V <sub>IH8</sub> | | 0.8V <sub>DD</sub> | - | $V_{DD}$ | V | | 56 | Input low voltage | V <sub>IL8</sub> | | 0 | - | 0.2V <sub>DD</sub> | V | | 57 | Input leakage current | I <sub>LK8</sub> | V <sub>I</sub> =0 V to V <sub>DD</sub> | - | - | ± 2 | μΑ | | 58 | Pull-up resistor | I <sub>RH8</sub> | V <sub>DD</sub> =3.0 V <sub>I</sub> =V <sub>SS</sub><br>Pull-up resistor ON | 30 | 100 | 300 | kΩ | | 59 | Output high voltage | V <sub>OH8</sub> | V <sub>DD</sub> =3.0 I <sub>OH</sub> =2.0 mA | 2.4 | - | - | | | 60 | Output low voltage (output at 2 mA) | V <sub>OL80</sub> | V <sub>DD</sub> =3.0 I <sub>OL</sub> =2.0 mA | - | - | 0.4 | V | | 61 | Output low voltage (output at 8 mA) | V <sub>OL81</sub> | V <sub>DD</sub> =3.0 I <sub>OL</sub> =8.0 mA | - | - | 0.4 | | | Dis | play output pin 1 COM0 to CC | DM3 | | | | • | | | 62 | Output impedance | Z <sub>OCOM1</sub> | V <sub>DD</sub> =3.0 I <sub>OCM</sub> =10 μA | - | - | 0.6 | V | | Dis | play output pin 2 SEG0 to SE | G11 | | | | | | | 63 | | Z <sub>OSEG1</sub> | V <sub>DD</sub> =3.0 I <sub>OCM</sub> =2 μA | - | - | 0.6 | V | | Dis | play power pin 1 V <sub>LC1</sub> , V <sub>LC2</sub> , ' | V <sub>LC3</sub> | | | | | | | 64 | | R <sub>VL1</sub> | Ta=+25°C | 142.5 | 285 | 570 | | | 65 | Internal dividing resistor | $V_{VL2}$ | (Impedance Between V <sub>LC1</sub> , V <sub>SS</sub> )<br>*11 | 15 | 30 | 60 | kΩ | <sup>\*8</sup> However, COM0 to COM3 are also used as P30 to P33. <sup>\*9</sup> However, SEG0 to SEG11 are also used as P14 to P17 and P70 to P77. <sup>\*10</sup> The summation of 3 resistors among $V_{LC1}$ and $V_{LC2}$ , $V_{LC2}$ and $V_{LC3}$ , $V_{LC3}$ and $V_{SS}$ . ## 1.5.4 A/C Converter Characteristics $V_{DD}$ =1.8V to 3.6V $V_{SS}$ =0V | Dore | nmator | Symbol | Conditions | Rating | | | Unit | |------|--------------|-----------------|-------------------|--------|-----|-----|-------| | Faic | Parameter Sy | | Symbol Conditions | | TYP | MAX | Offic | | ACZ | ACZ pin | | | | | | | | 1 | Rising time | t <sub>rs</sub> | Figure:1.5.5 | 30 | - | - | 116 | | 2 | Falling time | t <sub>fS</sub> | rigure. 1.5.5 | 30 | - | - | μs | Figure:1.5.5 XI Timing Chart ## 1.5.5 A/D Converter Characteristics $V_{DD}\!\!=\!\!1.8V$ to 3.6V $\;V_{SS}\!\!=\!\!0V$ | Parameter Syr | | Cumbal | Conditions | Rating | | | 11-4 | | |---------------|---------------------------------------------|-------------------|---------------------------------------------------------|-----------------|------|-------------------|------------|--| | Para | raidilletei | | Symbol Conditions - | | TYP | MAX | Unit | | | 1 | Resolution | | | - | - | 10 | Bits | | | 2 | Non-linearity error 1 | | V <sub>DD</sub> =3.0 V V <sub>SS</sub> =0 V | - | - | ±3 | LSB | | | 3 | Differential non-linearity error 1 | | V <sub>REF+</sub> =3.0 V<br>T <sub>AD</sub> =800 ns | - | - | ±3 | | | | 4 | Zero transition voltage | | V <sub>DD</sub> =3.0 V V <sub>SS</sub> =0 V | - | 30 | 100 | mV | | | 5 | Full-scale transition voltage | | V <sub>REF+</sub> =3.0 V<br>T <sub>AD</sub> =800 ns | 2900 | 2970 | - | | | | 6 | | | T <sub>AD</sub> =800 ns | 12.25 | - | - | | | | 7 | A/D conversion time | | fx=32.768 kHz, T <sub>AD</sub> =15.26 ms | - | - | 778.31 | | | | 8 | | | T <sub>AD</sub> =800 ns | 1.6 | - | 14.4 | ms | | | 9 | Sampling time | | fx=32.768 kHz, T <sub>AD</sub> =15.26 ms | 30.52 | - | 274.68 | | | | 10 | Reference voltage | V <sub>REF+</sub> | - | 2.0 | - | V <sub>DD</sub> | V | | | 11 | Analog input voltage | | - | V <sub>SS</sub> | - | V <sub>REF+</sub> | V | | | 12 | Analog input leakage current | | When channel is OFF<br>V <sub>ADIN</sub> =0 V to 3 V | - | - | ± 2 | | | | 13 | Reference voltage pin input leakage current | | When $V_{REF+}$ is OFF $V_{ss} \le V_{REF+} \le V_{DD}$ | - | - | ±2 | <u>μ</u> Α | | | 14 | Ladder resistance | R <sub>LADD</sub> | V <sub>REF+</sub> =3.0 V V <sub>SS</sub> =0 V | 10 | 30 | 60 | kΩ | | <sup>\*11</sup> TAD is A/D converter clock cycle. The values of 2 to 5 are guaranteed on the condition that $V_{DD}=V_{ref+}=3.0 \text{ V}$ , $V_{SS}=0 \text{ V}$ . ## 1.6 Package Dimension Package code: TQFP048-P-0707B Units: mm Figure:1.6.1 Package Dimension The external dimensions of the package are subject to change. Before using this product, please obtain product specifications from the sales offices. ## 1.7 Cautions for Circuit Setup ## 1.7.1 General Usage Connection of V<sub>DD</sub> pin and V<sub>SS</sub> pin All of the VDD and VSS pins should be connected directly to the power source and ground in the external. Put them on printed circuit board after the location of LSI (package) pin is confirmed. Connection error may lead a fusion and breakdown of a micro controller. - Cautions for Operation - 1. If you install the product close to high-field emissions (under the cathode ray tube, etc.), shield the package surface to ensure normal performance. - 2. Operation temperature should be well considered. Each product has different condition. For example, if the operation temperature is over the condition, improper operation could be occurred. - 3. Operation voltage should be also well considered. Each product has different operating range. - If the operation voltage is over the operating range, duration of the product could be shortened. - If the operation voltage is below the operating range, improper operation could be occurred. ## 1.7.2 Unused pins #### ■ Unused Pins (only for input) Insert some 10 $k\Omega$ resistor to unused pins (only for input) for pull-up or pull-down. If the input is unstable, Pch transistor and Nch transistor of input inverter are on, and through current goes to the input circuit. That increases current consumption and causes power supply noise. Figure:1.7.1 Unused Pins (only for input) Figure:1.7.2 Input Inverter Organization and Characteristics #### ■ Unused Pins (for I/O) Unused I/O pins should be set according to pins' condition at reset. If the output is high impedance (Pch / Nch transistor: output off) at reset, to stabilize input, set some $10~k\Omega$ resistor to be pull-up or pull-down. If the output is on at reset, set them open. Pins used as both LCD and port pins should be set to open to be used as LCD output pins. Figure:1.7.3 Unused I//O Pins (high impedance output at reset) ## 1.7.3 Power Supply #### ■ The Relation between Power Supply and Input Pin Voltage Input pin voltage should be supplied only after power supply is on. If this order is reversed the destruction of micro controller by a large current flow could be occurred. Figure:1.7.4 V<sub>DD</sub> and Input Pin Voltage #### ■ The Relation between V<sub>DD</sub> and Reset Input Voltage After power supply is on, reset pin voltage should be low for sufficient time before rising, in order to be recognized as a reset signal. [Refer to Chapter 1. 1.1.2 Product Summary] Figure:1.7.5 Power Supply and Reset Input Voltage ## 1.7.4 Power Supply Circuit Cautions for Setting Circuit with V<sub>DD</sub> The MOS logic such a microcomputer is high speed and high density. So, the power circuit should be designed, taking into consideration of AC line noise, ripple caused by LED driver. Figure:1.7.6 shows an example for a circuit with $\ensuremath{V_{DD}}$ (Emitter follower type). ■ An Example for a Circuit with V<sub>DD</sub> (Emitter follower type) Figure:1.7.6 An Example for a Circuit of $V_{DD}$ Supply (Emitter follower type) Chapter 1 Overview ## 2.1 Overview The MN101C CPU has a flexible and optimized hardware configuration. It is a high speed CPU with a simple and efficient instruction set. Specific features are as follows: - 1. Minimized code sizes with instruction lengths based on 4-bit increments: The series keeps code sizes down by adopting a basic instruction length of one byte and variable instruction lengths based on 4-bit increments. - 2. Minimum execution instruction time is one system clock cycle. - 3. Minimized register set that simplifies the architecture and supports C language: The instruction set has been determined, depending on the size and capacity of hardware, after on analysis of embedded application programing code and creation code by C language compiler. Therefore, the set is simple instruction using the minimal register set required for C language compiler. [" MN101C LSI User's Manual" (Architecture Instructions)] Table: 2.1.1 Basic Specifications | Structure | Load / store architecture | | | | | |---------------|------------------------------------------------|-------------------------------------------------------------------------|--|--|--| | | Six registers | Data : 8-bit x 4<br>Address : 16-bit x 2 | | | | | | Others | PC: 19-bit<br>PSW: 8-bit<br>SP: 16-bit | | | | | Instructions | Number of instructions | 37 | | | | | | Addressing modes | 9 | | | | | | Instruction length | Basic portion : 1 byte (min.<br>Extended portion : 0.5-byte x n (0£n£9) | | | | | Basic | Internal operating frequency (max) | 10 MHz | | | | | performance | Instruction execution | Min. 1 cycle | | | | | | Inter-register operation | Min. 2 cycle | | | | | | Load / store | Min. 2 cycle | | | | | | Conditional branch | 2 to 3 cycles | | | | | Pipeline | 3-stage (instruction fetch, decode, execution) | | | | | | Address space | 256 KB (max. 64 KB for data) | | | | | | | Instruction/data space | | | | | | External bus | Address | 18-bit | | | | | | Data | 8-bit | | | | | | Minimum bus cycle | 1 system clock cycle | | | | | Interrupt | Vector interrupt | 3 interrupt levels | | | | | Low-power con- | STOP mode | |----------------|-----------| | sumption mode | HALT mode | ## 2.1.1 Block Diagram Figure:2.1.1 CPU Block Diagram Table:2.1.2 Block Diagram and Function | Clock generator | Uses a clock oscillator circuit driven by an external crystal or ceramic resonator to supply clock signals to CPU blocks. | |----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Program counter | Generates addresses for the instructions to be inserted into the instruction queue. Normally incremented by sequencer indication, but may be set to branch destination address or ALU operation result when branch instructions or interrupts occur. | | Instruction queue | Stores up to 2 bytes of pre-fetched instructions. | | Instruction decoder | Decodes the instruction queue, sequentially generates the control signals needed for instruction execution, and executes the instruction by controlling the blocks within the chip. | | Instruction execution controller | Controls CPU block operations in response to the result decoded by the instruction decoder and interrupt requests. | | ALU | Executes arithmetic operations, logic operations, shift operations, and calculates operand addresses for register relative indirect addressing mode. | | Internal ROM, RAM | Assigned to the execution program, data and stack region. | | Address register | Stores the addresses specifying memory for data transfer. Stores the base address for register relative indirect addressing mode. | | Data register | Holds data for operations. Two 8-bit registers can be connected to form a 16-bit register. | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | Interrupt controller | Detects interrupt requests from peripheral functions and requests CPU shift to interrupt processing. | | Bus controller | Controls connection of CPU internal bus and CPU external bus. Includes bus usage arbitration function. | | Internal peripheral functions | Includes peripheral functions (timer, serial interface, A/D converter, D/A converter, etc.). Peripheral functions vary depending on the model. | ## 2.1.2 CPU Control Registers This LSI locates the peripheral circuit registers in memory space (0x03F00 to 0x03FFF) with memory mapped I/O. CPU control registers are also located in this memory space. Table:2.1.3 CPU Control Registers | Registerss | Address | R/W | Function | Pages | |------------|--------------------------|-----------|--------------------------------------------------------------------|----------------| | СРИМ | 0x03F00 | R/W<br>*1 | CPU mode control register | II-24<br>II-28 | | MEMCTR | 0x03F01 | R/W | Memory control register | II-20 | | NMICR | 0x03FE1 | R/W | Non - maskable interrupt control register | III-19 | | xxxICR | 0x03FE2<br>to<br>0x03FF7 | R/W | Maskable interrupt control register | III-20 to 40 | | Reserved | 0x03FFF | - | Reserved ( For reading interrupt vector data on interrupt process) | - | <sup>\*1</sup> a part of bit is for read only ### 2.1.3 Instruction Execution Controller The instruction execution controller consists of four blocks: memory, instruction queue, instruction registers, and instruction decoder. Instructions are fetched in 1-byte units, and temporarily stored in the 2-byte instruction queue. Transfer is made in 1-byte or half-byte units from the instruction queue to the instruction register to be decoded by the instruction decoder. Figure: 2.1.2 Instruction Execution Controller Configuration ### 2.1.4 Pipeline Process Pipeline process means that reading and decoding are executed at the same time on different instructions, then instructions are executed without stopping. Pipeline process makes instruction execution continual and speedy. This process is executed with instruction queue and instruction decoder. Instruction queue is buffer that fetches the second instruction in advance. That is controlled to fetch the next instruction when instruction queue is empty at each cycle on execution. At the last cycle of instruction execution, the first word (operation code) of executed instruction is stored to instruction register. At that time, the next operand or operation code is fetched to instruction queue, so that the next instruction can be executed immediately, even if register direct (da) or immediate (imm) is needed at the first cycle of the next instruction execution. But on some other instruction such as branch instruction, instruction queue becomes empty on the time that the next operation code to be executed is stored to instruction register at the last cycle. Therefore, only when instruction queue is empty, and direct address (da) or immediate data (imm) are needed, instruction queue keeps waiting for a cycle. Instruction queue is controlled automatically by hardware so that there is no need to be controlled by software. But when instruction execution time is estimated, operation of instruction queue should be into consideration. Instruction decoder generates control signal at each cycle of instruction execution by micro program control. Instruction decoder uses pipeline process to decode instruction queue at one cycle before control signal is needed. ### 2.1.5 Registers for Address Registers for address include program counter (PC), address registers (A0, A1), and stack pointer (SP) ■ Program Counter (PC) This register gives the address of the currently executing instruction. It is 19 bits wide to provide access to a 256 KB address space in half byte(4-bit increments). The LSB of the program counter is used to indicate half byte instruction. The program counter after reset is stored from the value of vector table at the address of 0x04000. Figure:2.1.3 Program Counter #### ■ Address Registers (A0, A1) These registers are used as address pointers specifying data locations in memory. They support the operations involved in address calculations (i.e. addition, subtraction and comparison). Those pointers are 2 bytes data. Transfers between these registers and memory are always in 16-bit units. Either odd or even address can be transferred. At reset, the value of address register is undefined. Figure: 2.1.4 Address Registers #### ■ Stack Pointer (SP) This register gives the address of the byte at the top of the stack. It is decremented during push operations and incremented during pop operations. Ar reset, the value of SP is undefined. Figure: 2.1.5 Stack Pointer ## 2.1.6 Registers for Data Registers for data include four data registers (D0, D1, D2, D3). ■ Data Registers (D0, D1, D2, D3) Data registers D0 to D3 are 8-bit general-purpose registers that support all arithmetic, logical and shift operations. All registers can be used for data transfers with memory. The four data registers may be paired to form the 16-bit data registers DW0 (D0+D1) and DW1 (D2+D3). At reset, the value of Dn is undefined. Figure: 2.1.6 Data Registers ## 2.1.7 Processor Status Word Processor status word (PSW) is an 8-bit register that stores flags for operation results, interrupt mask level, and maskable interrupt enable. PSW is automatically pushed onto the stack when an interrupt occurs and is automatically popped when return from the interrupt service routine. #### ■ Processor Status Word(PSW) Table:2.1.4 Processor Status Word(PSW) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|-----|-----|-----|----|----|----|----| | Flag | - | MIE | IM1 | IM0 | VF | NF | CF | ZF | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | bp | Flag | Description | |-----|------------|---------------------------------------------------------------------------------------------------------------------| | 7 | Reserved | Set always to "0". | | 6 | MIE | Maskable interrupt enable 0: All maskable interrupts are disabled. 1: (xxxLVn,xxxIE) for each interrupt is enabled. | | 5-4 | IM1<br>IM0 | Interrupt mask level Controls maskable interrupt acceptance. | | 3 | VF | Overflow flag 0: Overflow did not occur. 1: Overflow occurred. | | 2 | NF | Negative flag 0: MSB of operation results is "0". 1: MSB of operation results is "1". | | 1 | CF | Carry flag 0: A carry or a borrow from MSB did not occur. 1: A carry or a borrow from MSB occurred. | | 0 | ZF | Zero flag 0: Operation result is not "0". 1: Operation result is "0". | #### ■ Zero Flag (ZF) Zero flag (ZF) is set to "1", when all bits are '0' in the operation result. Otherwise, zero flag is cleared to "0". #### ■ Carry Flag (CF) Carry flag (CF) is set to "1", when a carry from or a borrow to the MSB occurs. Carry flag is cleared to "0", when no carry or borrow occurs. #### Negative Flag (NF) Negative flag (NF) is set to "1" when MSB is '1' and reset to "0" when MSB is '0'. Negative flag is used to handle a signed value. #### ■ Overflow Flag (VF) Overflow flag (VF) is set to "1", when the arithmetic operation results overflow as a signed value. Otherwise, overflow flag is cleared to "0". Overflow flag is used to handle a signed value. #### Interrupt Mask Level (IM1 and IM0) Interrupt mask level (IM1 and IM0) controls the maskable interrupt acceptance in accordance with the interrupt factor interrupt priority for the interrupt control circuit in the CPU. The two-bit control flag defines levels '0' to '3'. Level 0 is the highest mask level. The interrupt request will be accepted only when the level set in the interrupt level flag (xxxLVn) of the interrupt control register (xxxICR) is higher than the interrupt mask level. When the interrupt is accepted, the level is reset to IM1-IM0, and interrupts whose mask levels are the same or lower are rejected during the accepted interrupt processing. Table:2.1.5 Interrupt Mask Level and Interrupt Acceptance | | Interrupt mask level | | Priority | Acceptable interrupt level | |--------------|----------------------|-----|----------|-----------------------------------| | | IM1 | IM0 | | | | Mask level 0 | 0 | 0 | Highest | Non-maskable interrupt (NMI) only | | Mask level 1 | 0 | 1 | High | NMI, level 0 | | Mask level 2 | 1 | 0 | Low | NMI, level 0 to 1 | | Mask level 3 | 1 | 1 | Lowest | NMI, level 0 to 2 | #### ■ Maskable Interrupt Enable (MIE) Maskable interrupt enable flag (MIE) enables/disables acceptance of maskable interrupts by the CPU's internal interrupt acceptance circuit. A '1' enables maskable interrupts; a '0' disables all maskable interrupts regardless of the interrupt mask level (IM1-IM0) setting in PSW. This flag is not changed by interrupts. ### 2.1.8 Address Space The address space of this LSI is 256 KB. (max.) The instruction and data areas are not separated. The instruction area can be used as linear address space. The data area needs bank specification in every 64 KB. (The initial value is first 64 KB space). The data described in this section includes RAM data and ROM table data. The data area consists of an area of 256 bytes that supports efficient access with RAM short addressing and an area of 256 bytes that supports efficient access with I/O short addressing. The memory control register controls memory to be expanded. Figure: 2.1.7 Address Space ## 2.1.9 Addressing Modes This LSI supports the nine addressing modes. Each instruction uses a combination of the following addressing - 1) Register direct - 2) Immediate - 3) Register indirect - 4) Register relative indirect - 5) Stack relative indirect - 6) Absolute - 7) RAM short - 8) I/O short - 9) Handy These addressing modes are well-suited for C language compilers. All of the addressing modes can be used for data transfer instructions. In modes that allow half-byte addressing, the relative value can be specified in half-byte (4-bit) increments, so that instruction length can be shorter. Handy addressing reuses the last memory address accessed and is only available with the MOV and MOVW instructions. Combining handy addressing with absolute addressing reduces code size. For transfer data between memory, 8 addressing modes; register indirect, register relative indirect, stack relative indirect, absolute, RAM short, I/O short, handy can be used. For operation instruction, register direct and immediate can be used. Refer to instruction's manual for the MN101C series. This LSI is designed for 8-bit data access. It is possible to transfer data in 16-bit increments with odd or all even addresses. | Addressi | ng mode | Effective address | Explanation | |-------------------|-----------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | Register direct | Dn/DWn<br>An/SP<br>PSW | - | Directly specifies the register. Only internal registers can be specified. | | Immediate | imm4/imm8<br>imm16 | - | Directly specifies the operand or mask value appended to the instruction code. | | Register indirect | (An) | 15 0<br>An | Specifies the address using an address register. | | | (d8, An) | 15 0<br>An+d8 | Specifies the address using an address register with 8-bit displacement. | | Register relative | (d16, An) | 15 0<br>An+d16 | Specifies the address using an address register with 16-bit displacement. | | indirect | (d4, PC)<br>(branch instructions only) | 17 0 H<br>PC+d4 1 | Specifies the address using the program counter with 4-bit displacement and H bit. | | | (d7, PC) (branch instructions only) | 17 0 H<br>PC+d7 1 | Specifies the address using the program counter with 7-bit displacement and H bit. | | | (d11, PC)<br>(branch instructions only) | 17 0 H<br>PC+d11 1 | Specifies the address using the program counter with 11-bit displacement and H bit. | | | (d12, PC)<br>(branch instructions only) | 17 0 H<br>PC+d12 1 | Specifies the address using the program counter with 12-bit displacement and H bit. | | | (d16, PC) (branch instructions only) | 17 0 H<br>PC+d16 1 | Specifies the address using the program counter with 16-bit displacement and H bit. | | Stack relative | (d4, SP) | 15 0<br>SP+d4 | Specifies the address using the stack pointer with 4-bit displacement. | | indirect | (d8, SP) | 15 0<br>SP+d8 | Specifies the address using the stack pointer with 8-bit displacement. | | | (d16, SP) | 15 0<br>SP+d16 | Specifies the address using the stack pointer with 16-bit displacement. | | Absolute | (abs8) | 7 0<br>abs8 | | | | (abs12) | 11 0<br>abs12 | Specifies the address using the operand value appended to the instruction code. | | | (abs16) | 15 0<br>abs16 | Optimum operand length can be used to specify the address. | | | (abs18) (branch instructions only) | 17 0 H<br>abs18 * 1 | | | RAM short | (abs8) | 7 0<br>abs8 | Specifies an 8-bit offset from the address x'00000'. | | I/O short | (io8) | 15 0<br>IOTOP+io8 | Specifies an 8-bit offset from the top address (x'03F00') of the special function register area. | | Handy | (HA) | - | Reuses the last memory address accessed and is only available with the MOV and MOVW instructions. Combined use with absolute addressing reduces code size. | \* 1 H: half-byte bit Figure:2.1.8 Address Space ## 2.1.10 Machine Clock Machine clock is generated based on the system clock dividing the source oscillation frequency. The machine clock is the base timing for control of CPU. ■ Internal Memory Access (no wait cycle) (NORMAL mode) Figure: 2.1.9 Machine Clock (no wait cycle) Oscillation frequency of system clock differs depending on the CPUM register settings. [Chapter 2. 2.5 Clock Switching] # 2.2 Memory Space ## 2.2.1 Memory Mode ROM is the read only area and RAM is the memory area which contains readable/writable data. In addition to these, peripheral resources such as memory-mapped special registers are allocated. The MN101C series supports three memory modes (single chip mode, memory expansion mode, processor mode) in its memory model. This LSI supports one memory modes (single chip mode) in its memory model. Setting of each mode is different. In single chip mode, the system consists of only internal memory. ## 2.2.2 Single-chip Mode In single-chip mode, the system consists of only internal memory. This is the optimized memory mode and allows construction of systems with the highest performance. The single-chip mode uses only internal ROM and internal RAM. The MN101C series devices offer up to 11.75 KB of RAM and up to 224 KB of ROM. This LSI offers 1.5 KB of RAM and 32 KB of ROM. Figure: 2.2.1 Single-chip Mode The value of internal RAM is uncertain when power is applied to it. It needs to be initialized before used. ## 2.2.3 Special Function Registers The MN101C series locates the special function registers (I/O spaces) at the addresses 0x03F00 to 0x03FFF in memory space. The special function registers of this LSI are located as shown below. | | CPU Mode<br>Memory Control | | C + + C C | | | | Timer Control | | | | Serial I/F Control | | Analog I/F Control | LCD Control | 0.44000 | | |---|----------------------------|--------|-----------|----------------|----------|-------|---------------|-----------------|---------|--------|--------------------|----------|--------------------|-------------|----------|---------------| | | O<br>Mer | | J/O<br>Ti | | | | Analog | IOI | | | | | | | | | | Ь | Reserved | CLKOUT | | KEYT3_2<br>IMD | Reserved | СКЗМБ | TM8MD4 | TM7DPR1 TM7DPR2 | TM8MD3 | TXBUF1 | | | ANBUF1 | Reserved | SCORICR | Reserved | | В | | EDGDT | NFCTR | KEYT3_1<br>IMD | PAIMD | CKZMD | TM7MD4 | TM7DPR1 | TM7MD3 | RXBUF1 | | | ANBUF0 | Reserved | T70C2 | | | D | Reserved | P7ODC | PAODC | P1CNT0 | | ТМЗМD | PSCMD | TM7PR2H | TM8PR2H | SC1STR | | | ANCTR2 | Reserved | TM7ICR | | | C | Reserved | P10MD | P5OMD | P70MD | XSEL | TM2MD | RMCTR | TM7OC2H TM7PR2L | TM8PR2L | SC1MD3 | | | ANCTR1 | Reserved | TBICR | | | В | Reserved | P10DC | Reserved | P3ODC | SELUD | ТМЗОС | | ТМ7ОС2Н | ТМ8ОС2Н | SC1MD2 | SC4STR | | ANCTRO | Reserved | TM6ICR | | | Α | Reserved | PAOUT | PAIN | PADIR | PAPLUD | TM2OC | | TM70C2L | TM80C2L | SC1MDi | SC4TXB | | Reserved | Reserved | TM3ICR | | | 6 | | P9OUT | NI6d | P9DIR | P9PLUD | ТМЗВС | | TM7MD2 | TM8MD2 | SC1MD0 | SC4RXB | | Reserved | Reserved | TM2ICR | | | 8 | | | | | | TM2BC | | TM7MD1 | TM8MD1 | | SC4AD1 | Reserved | | Reserved | TM11CR | | | 7 | | P7OUT | NI24 | P7DIR | P7PLUD | CK1MD | | ТМ7ІСН | ТМ8ІСН | TXBUF0 | SC4AD0 | Reserved | | Reserved | TMOICR | T80C2<br>ICR | | 9 | | | | | | СКОМБ | | TOIZWL | TM8ICL | RXBUF0 | SC3CTR | Reserved | | Reserved | IRQ4ICR | TM8ICR | | 2 | | P5OUT | PSIN | P5DIR | P5PLU | TM1MD | | TM7PR1L TM7PR1H | TM8PR1H | SCOSTR | TXBUF3 | Reserved | | Reserved | Reserved | SC4ICR | | 4 | Reserved | | | | | TM0MD | TM6BEN | TM7PR1L | TM8PR1L | SCOMD3 | SC3TRB | Reserved | LCCTR3 | Reserved | IRQZICR | ADICR | | 3 | DLYCTR | P3OUT | P3IN | P3DIR | P3PLUD | ТМ10С | TBCLR | ТМ7ОС1Н | ТМ8ОС1Н | SC0MD2 | SC3STR | Reserved | LCCTR2 | Reserved | IRQ11CR | SC3ICR | | 2 | WDCTR | P2OUT | | | | TM0OC | TM6MD | TM7OC1L | TM8OC1L | SC0MD1 | SC3MD3 | Reserved | LCCTR1 | Reserved | IRQOICR | SC1TICR | | _ | MEMCTR | P10UT | P1IN | P1DIR | P1PLUD | TM1BC | TM6OC | ТМ7ВСН | ТМ8ВСН | SCOMDO | SC3MD1 | Reserved | LCDMD2 | Reserved | NMICR | SC1RICR | | 0 | CPUM | | | | | TM0BC | TM6BC | TM7BCL | TM8BCL | SCSEL | SC3MD0 | Reserved | LCDMD1 | Reserved | Reserved | 03FFX SCOTICR | | | 03F0X | 03F1X | 03F2X | 03F3X | 03F4X | 03F5X | 03F6X | 03F7X | 03F8X | 03F9X | 03FAX | 03FBX | 03FCX | 03FDX | 03FEX | 03FFX | Figure:2.2.2 Register Map # 2.3 Bus Interface ### 2.3.1 Bus Controller The MN101C series provides separate buses to the internal memory and internal peripheral circuits to reduce bus line loads and thus realize faster operation. There are three such buses: ROM bus, RAM bus and peripheral expansion bus (I/O bus). They connect to the internal ROM, internal RAM and internal peripheral circuits respectively. The bus control block controls the parallel operation of instruction read and data access. A functional block diagram of the bus controller is given below. Figure:2.3.1 Functional Block Diagram of the Bus Controller ## 2.3.2 Control Registers Bus interface is controlled by the memory control register (MEMCTR). #### ■ Memory Control Register (MEMCTR) Table:2.3.1 Memory Control Register (MEMCTR: 0x03F01) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|------|------|------|----------|----------|------|----------|----------| | Flag | IOW1 | IOW0 | IVBM | Reserved | Reserved | IRWE | Reserved | Reserved | | At reset | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | | Access | R/W | | | | | | | | | bp | Flag | Description | | | | | |-----|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|--| | 7-6 | IOW1<br>IOW0 | Wait cycles when accessing special register area 00: No wait cycles 01: 1 wait cycle 10: 2 wait cycles 11: 3 wait cycles | Bus cycle at 10 MHz oscillation 200 ns 300 ns 400 ns 500 ns | | | | | 5 | IVBN | Base address setting for interrupt vector table Interrupt vector base = 0x04000 Interrupt vector base = 0x00100 | | | | | | 4 | Reserved | Set always to "0"¶ | | | | | | 3 | Reserved | Set always to "1"¶ | | | | | | 2 | IRWE | Software write enable flag for interrupt request flag Software write disable Even if data is written to each interrupt control (register (xxxICR), the state of the interrupt request flag (xxxIR) will not change. | | | | | | 1-0 | Reserved | Set always to "11" | | | | | The IOW1-IOW0 wait settings affect accesses to the special registers located at the addresses 0x3F00-0x3FFF. After reset, MEMCTR specifies the fixed wait cycle mode with three wait cycles. Wait setting of IOW is a function, which CPU supports for special use, for example, when special function register or I/O is expanded to external. For this LSI, wait cycle setting is not always necessary. Select "no-wait cycle" for high performance system construction. # 2.4 Standby Function ### 2.4.1 Overview This LSI has two sets of system clock oscillator (high speed oscillation, low speed oscillation) for two CPU operating modes (NORMAL and SLOW), each with two standby modes (HALT and STOP). Power consumption can be decreased with using those modes. Figure: 2.4.1 Transition Between Operation Modes #### ■ HALT Modes (HALT0, HALT1) The CPU stops operating. But both of the oscillators remain operational in HALT0 and only the high-frequency oscillator stops operating in HALT1. An interrupt returns the CPU to the previous CPU operating mode that is, to NORMAL from HALT0 or to SLOW from HALT1. ■ STOP Modes (STOP0, STOP1) The CPU and both of the oscillators stop operating. An interrupt restarts the oscillators and, after allowing time for them to stabilize, returns the CPU to the previous CPU operating mode - that is, to NORMAL from STOP0 or to SLOW from STOP1. #### SLOW Mode This mode executes the software using the low-frequency clock. Since the high-frequency oscillator is turned off, the device consumes less power while executing the software. #### ■ IDLE Mode This mode allows time for the high-frequency oscillator to stabilize when the software is changing from SLOW to NORMAL mode. To reduce power dissipation in STOP and HALT modes, it is necessary to check the stability of both the output current from pins and port level of input pins. For output pins, the output level should match the external level or direction control should be changed to input mode. For input pins, the external level should be fixed. This LSI has two system clock oscillation circuits. OSC is for high-frequency operation (NORMAL mode) and XI is for low-frequency operation (SLOW mode). Transition between NORMAL and SLOW modes or to standby mode is controlled by the CPU mode control register (CPUM). Reset and interrupts are the return factors from standby mode. A wait period is inserted for oscillation stabilization at reset and when returning from STOP mode, but not when returning from HALT mode. High/low-frequency oscillation mode is automatically returned to the same state as existed before entering standby mode. To stabilize the synchronization at the moment of switching clock speed between high speed oscillation (fosc) and low speed oscillation (fx), fosc should be set to 2.5 times or higher Set the bp0 of XSEL register before changing to the low speed oscillation mode. P90 can be used as the low speed oscillation, as well. Set the low speed oscillation selection register (XSEL) for SLOW mode setting. ■ Low Speed Oscillation Selection Register (XSEL) Table:2.4.1 Low Speed Oscillation Selection Register (XSEL: 0x03F4C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|---|------| | Flag | - | - | - | - | - | - | - | XSEL | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Accesst | R | | | | | | | R/W | | bp | Flag | Description | |-----|------|----------------------------------------------------------------------------------| | 7-1 | - | - | | 0 | XSEL | P90, I/O port low speed oscillation selection 0:I/O port 1:Low speed oscillation | Set the bp0 of XSEL register before changing to the low speed oscillation mode. ## 2.4.2 CPU Mode Control Register Transition from one mode to another mode is controlled by the CPU mode control register (CPUM). <sup>\*</sup> Status in NORMAL mode and HALT mode differ depending upon the XSEL. XSEL=0 Halt XSEL=1 Oscillation Figure: 2.4.2 Operating Mode and Clock Oscillation (CPUM: 0x3F00) The procedure for transition from NORMAL to HALT or STOP mode is given below. - (1) If the return factor is a maskable interrupt, set the MIE flag in the PSW to "1" and set the interrupt mask (IM) to a level permitting acceptance of the interrupt. - (2) Clear the interrupt request flag (xxxIR) in the maskable interrupt control register (xxxICR), set the interrupt enable flag (xxxIR) for the return factor, and set the IE flag in the PSW. - (3) Set CPUM to HALT or STOP mode. Do not change the setting of standby functions (STOP flag, HALT flag, OSC1 flag, OSC2 flag) at the same time with the setting of clock switching functions (OSCDBL flag, OSCSEL1 flag, OSCSEL0 flag). Set the IRWE flag of the memory control register (MEMCTR) to clear interrupt request flag by software. ### 2.4.3 Transition between SLOW and NORMAL This LSI has two CPU operating modes, NORMAL and SLOW. Transition from SLOW to NORMAL requires passing through IDLE mode. A sample program for transition from NORMAL to SLOW mode is given below. ``` Program 1 MOV x'3', D0 ; Set SLOW mode. MOV D0, (CPUM) ``` Transition from NORMAL to SLOW mode, when the low-frequency clock has fully stabilized, can be done by writing to the CPU mode control register. In this case, transition through IDLE is not needed. For transition from SLOW to NORMAL mode, the program must maintain the idle state until high-frequency clock oscillation is fully stable. In IDLE mode, the CPU operates on the low-frequency clock. For transition from SLOW to NORMAL, oscillation stabilization waiting time is required same as that after reset. Software must count that time. We recommend selecting the oscillation stabilization time after consulting with oscillator manufacturers. Sample program for transition from SLOW to NORMAL mode is given below. ``` Program 2 MOV x'1', D0 ; Set IDLE mode. MOV D0, (CPUM) ``` ``` Program 3 MOV x'0B', D0 ; A loop to keep approx. 6.7ms with low-frequency clock (32 kHz) LOOP ADD -1, D0 ; operation when changed to high-frequency clock (10 MHz). BNE LOOP ; SUB D0, D0 ; MOV D0,(CPUM) ; Set NORMAL mode. ``` ### 2.4.4 Transition to STANDBY Modes The program initiates transitions from a CPU operating mode to the corresponding STANDBY (HALT/STOP) modes by specifying the new mode in the CPU mode control register (CPUM). Interrupts initiate the return to the former CPU operating mode. Before initiating a transition to a STANDBY mode, however, the program must - (1) Set the maskable interrupt enable flag (MIE) in the processor status word (PSW) to '0' to disable all maskable interrupts temporarily. - (2) Set the interrupt enable flags (xxxIE) in the interrupt control registers (xxxICR) to '1' or '0' to specify which interrupts do and do not initiate the return from the STANDBY mode. Set MIE '1' to enable those maskable interrupts. Figure: 2.4.3 Transition to/from STANDBY Mode If the interrupt is enabled but interrupt priority level of the interrupt to be used is not equal to or higher than the mask level in PSW before transition to HALT or STOP mode, it is impossible to return to CPU operation mode by maskable interrupt. Set the bp0 of XSEL register before changing to the low speed oscillation mode. #### Transition to HALT modes The system transfers from NORMAL mode to HALT0 mode, and from SLOW mode to HALT1 mode. The CPU stops operating, but the oscillators remain operational. There are two ways to leave a HALT mode: a reset or an interrupt. A reset produces a normal reset; an interrupt, an immediate return to the CPU state prior to the transition to the HALT mode. The watchdog timer, if enabled, resumes counting. Program 4 MOV x'4', D0 ; Set HALT mode. MOV D0, (CPUM) NOP ; After written in CPUM, some NOP NOP ; instructions (three or less) are NOP ; executed. #### ■ Transition to STOP mode The system transfers from NORMAL mode to STOP0 mode, and from SLOW mode to STOP1 mode. In both cases, oscillation and the CPU are both halted. There are two ways to leave a STOP mode: a reset or an interrupt. When it changed to the stop mode, watchdog timer counter is cleared. Restart counting at the recovery and the oscillation stabilization wait is done. The count is continued after the recovery to CPU operation mode. Program 5 MOV x'8', D0 ; Set HALT mode. MOV D0, (CPUM) NOP ; After written in CPUM, some NOP NOP ; instructions (three or less) are NOP ; executed. Insert three NOP instructions right after the instruction of the transition to HALT, STOP mode. Set the bp0 of XSEL register before changing to the low speed oscillation mode. # 2.5 Clock Switching This LSI can select the best operation clock for system by switching clock cycle division factor by program. Division factor is determined by both flags of the CPU mode control register (CPUM) and the Oscillator frequency control register (OSCMD). At the highest-frequency, CPU can be operated in the same clock cycle to the external clock hence providing wider operating frequency range. ■ CPU Mode Control Register (CPUM) Table:2.5.1 CPU Mode Control Register (CPUM: 0x03F00) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|---------|---------|--------|------|------|------|------| | Flag | RESERV<br>ED | OSCSEL1 | OSCSEL0 | OSCDBL | STOP | HALT | OSC1 | OSC0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | | | | |-----|--------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7 | RESERVED | Set always to "0". | | | | | 6-5 | OSCSEL1<br>OSCSEL0 | Clock Frequency 00: 1 01: 4 10: 16 11: 64 | | | | | 4 | OSCDBL | Internal System Clock 0: Standard (Input the oscillation clock cycle divided by 2) 1: 2x-speed (Input the oscillation clock cycle) | | | | See Figure: 2.4.2 for setup of bp3-0 flags of the CPU mode control register (CPUM). Figure:2.5.1 Clock Switching Circuit | OSCSEL1 | OSCSEL0 | OSCDBL | Oscillating frequency | |---------|---------|--------|-----------------------| | 0 | 0 | 0 | 2 | | 0 | 0 | 1 | 1 | | 0 | 1 | 0 | 8 | | 0 | 1 | 1 | 4 | | 1 | 0 | 0 | 32 | | 1 | 0 | 1 | 16 | | 1 | 1 | 0 | 128 | | 1 | 1 | 1 | 64 | Figure:2.5.2 Setting Division Factor at NORMAL mode by combination of OSCSEL and OSCDBL Do not change the setting of standby functions (STOP flag, HALT flag, OSC1 flag, OSC2 flag) at the same time with the setting of clock switching functions (OSCDBL flag, OSCSEL1 flag, OSCSEL0 flag). OSCDBL flag, OSCSEL1 flag and OSCSEL0 flag can be changed at the same time. # 2.6 Reset ## 2.6.1 Reset operation The CPU contents are reset and registers are initialized when the NRST pin is pulled to low. Initiating a Reset There are two methods to initiate a reset. (1) Drive the NRST pin low. NRST pin should be held "low" for more than OSC 4 clock cycles (100 ns at a 10 MHz). Figure: 2.6.1 Minimum Reset Pulse Width (2) Setting the P2OUT7 flag of the P2OUT register to "0" outputs low level at P27 (NRST) pin. And transferring to reset by program (software reset) can be executed. If the internal LSI is reset and register is initiated, the P2OUT7 flag becomes "1" and reset is released. When NRST pin is connected to low power voltage detection circuit that gives pulse for enough low level time at sudden unconnected. And reset can be generated even if NRST pin is held "low" for less than OSC 4 clock cycles, take notice of noise. ### Sequence at Reset - (1) When reset pin comes to high level from low level, the internal 14-bit counter (It can be used as watchdog timer, too.) starts its operation by system clock. The period from starting its count from its overflow is called oscillation stabilization wait time. - (2) During reset, internal register and special function register are initiated. - (3) After oscillation stabilization wait time, internal reset is released and program is started from the address written at address 0x4000 at interrupt rector table. Figure:2.6.2 Reset Released Sequence ### 2.6.2 Oscillation Stabilization Wait time Oscillation stabilization wait time is the period from the stop of oscillation circuit to the stabilization for oscillation. Oscillation stabilization wait time is automatically inserted at releasing from reset and at recovering from STOP mode. At recovering from STOP mode the oscillation stabilization wait time control register (DLYCTR) is set to select the oscillation stabilization wait time. At releasing from reset, oscillation stabilization wait time is fixed. The timer that counts oscillation stabilization wait time is also used as a watchdog timer. That is used as a runaway detective timer at anytime except at releasing from reset and at recovering from STOP mode. Watchdog timer is initiated at reset and at STOP mode and starts counting from the initialize value (0x0000) when system clock (fs) is as clock source. ■ Block Diagram of Oscillation Stabilization Wait Time (watchdog timer) Figure: 2.6.3 Block Diagram of Oscillation Stabilization Wait Time (watchdog timer) ### ■ Oscillation Stabilization Wait Time Control Register (DLYCTR) Table:2.6.1 Oscillation Stabilization Wait Time Control Register (DLYCTR: 0x03F03) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|-------|-------|-------|-------|-------|---|---| | Flag | BUZOE | BUZS2 | BUZS1 | BUZS0 | DLYS1 | DLYS0 | - | - | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | - | - | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | BUZOE | Output selection 0: Port data output 1: Buzzer output | | 6-4 | BUZS2<br>BUZS1<br>BUZS0 | Buzzer output frequency selection 000: fosc/2 <sup>14</sup> 001: fosc/2 <sup>13</sup> 010: fosc/2 <sup>12</sup> 011: fosc/2 <sup>11</sup> 100: fosc/2 <sup>10</sup> 101: fosc/2 <sup>9</sup> 110: fx/2 <sup>4</sup> 111: fx/2 <sup>3</sup> | | 3-2 | DLYS1<br>DLYS0 | Oscillation stabilization wait period selection 00: fs/2 <sup>14</sup> 01: fs/2 <sup>10</sup> 10: fs/2 <sup>6</sup> *1 11: fs/2 *1 | | 1-0 | - | - | <sup>\*1</sup> Do not use in high-speed operation (NORMAL mode). Use in low-speed operation (SLOW mode). #### ■ Control the Oscillation Stabilization Wait Time At recovering from STOP mode, the bit 3-2 (DLYS1, DLYS0) of the oscillation stabilization wait time control register can be set to select the oscillation stabilization wait time from 214, 210, 26, 22 x system clock. The DLYCTR register is also used for controlling of buzzer functions. At releasing from reset, the oscillation stabilization wait time is fixed to " $2^{14}$ x system clock". System clock is determined by the CPU mode control register (CPUM). Table: 2.6.2 Oscillation Stabilization Wait Time | DLYS1 | DLYS0 | Oscillation stabilization wait time | |-------|-------|-------------------------------------| | 0 | 0 | 2 <sup>14</sup> x System clock | | 0 | 1 | 2 <sup>10</sup> x System clock | | 1 | 0 | 2 <sup>6</sup> x System clock *1 | | 1 | 1 | 2 <sup>2</sup> x System clock *1 | <sup>\*1</sup> Do not use in high-speed operation (NORMAL mode). Use in low-speed operation (SLOW mode). ## 3.1 Overview This LSI speeds up interrupt response with circuitry that automatically loads the branch address to the corresponding interrupt service routine from an interrupt vector table:reset, non-maskable interrupts (NMI), 4 external interrupts, and 17 internal interrupts (peripheral function interrupts). For interrupts other than reset, the interrupts processing sequence consists of interrupt request, interrupt acceptance, and hardware processing. After the interrupt is accepted, the program counter (PC) and processor status word (PSW) and handy addressing data (HA) are saved onto the stack. And an interrupts handler ends by restoring, using the POP instruction and other means, the contents of any registers used during processing and then executing the return from interrupt (RTI) instruction to return to the point at which execution was interrupted. Max. 12 machine cycles before execution, and max 11 machine cycles after execution. Each interrupt has a interrupt control register, which controls the interrupts. Interrupt control register consists of the interrupt level field (LV1 to 0), interrupt enable flag (IE), and interrupt request flag (IR). Interrupt request flag (IR) is set to "1" by an interrupt request, and cleared to "0" by the interrupt acceptance. This flag is managed by hardware, but can be rewritten by software. Interrupt enable flag (IE) is the flag that enables interrupts in the group. There is no interrupt enable flag in non-maskable interrupt (NMI). Once this interrupt request flag is set, it is accepted without any conditions. Interrupts enable flag is set in maskable interrupt. Interrupt enable flag of maskable interrupt is valid when the maskable interrupt enable flag (MIE flag) of PSW is "1". Maskable interrupts have had vector numbers by hardware, but their priority can be changed by setting interrupts level field. There are three hierarchical interrupt levels. If multiple interrupts have the same priority, the one with the lowest vector number takes priority. Maskable interrupts are accepted when its level is higher than the interrupt mask level (IM1 to 0) of PSW. Non-maskable interrupts are always accepted, regardless of the interrupt mask level. ## 3.1.1 Functions Table:3.1.1 Interrupt Functions | Interrupt type | Reset (interrupt) | Non-maskable interrupt | Maskable interrupt | | | | |-------------------------------|-------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Vector number | 0 | 1 | 2 to 23 | | | | | Table address | 0x04000 | 0x04004 | 0x04008 to 0x0405C | | | | | Starting address | Address specified by vector address | | | | | | | Interrupt level | - | - | Can be set to levels 0 to 2 by software | | | | | Interrupt factor | External RST pin input | Errors detection, PI interrupt | External pin input internal peripheral function | | | | | Generated operation | Direct input to CPU core | Input to CPU core from non-maskable interrupt control register (NMICR) | Input interrupt request level set in interrupt level flag (xxxL Vn) of maskable interrupt control register (xxxICR) to CPU core. | | | | | Accept operation | Always accepts | Always accepts | Acceptance only by the interrupt control of the register (xxxICR) and the interrupt mask level in PSW. | | | | | Machine cycles until accepted | 12 | 12 | 12 | | | | | PWS status after acceptance | All flags are cleared to "0" | The interrupt mask level flag in PSW is cleared to "00" | Values of the interrupt level flag (xxxLVn) are set to the interrupt mask level (masking all interrupt requests with the same or the lower priority). | | | | ## 3.1.2 Block Diagram Figure:3.1.1 Interrupt Block Diagram ## 3.1.3 Operation #### ■ Interrupt Processing Sequence For interrupts other than reset, the interrupt processing sequence consists of interrupt request, interrupt acceptance, and hardware processing. The program counter (PC) and processor status word (PSW) and hard addressing data (HA) are saved onto the stack, and program is branched to the address specified by the corresponding interrupt vector. An interrupt handler ends by restoring the contents of any registers used during processing and then executing the return from interrupt (RTI) instruction to return to the point at which execution was interrupted. Figure:3.1.2 Interrupt Processing Sequence (maskable interrupts) ## ■ Interrupt Group and Vector Addresses ### Table:3.1.2 shows the list of interrupt vector addresses and interrupt group. Table:3.1.2 Interrupt Vector Addresses and Interrupt Group | Vector<br>number | Vector<br>addresses | Interrupt group (interrupt factor) | | Control register (address) | | |------------------|---------------------|----------------------------------------|---------------|----------------------------|---------| | 0 | 0x04000 | Reset | - | - | - | | 1 | 0x04004 | Non-maskable interrupt | NMI | NMICR | 0x03FE1 | | 2 | 0x04008 | External interrupt 0 | IRQ0 | IRQ0ICR | 0x03FE2 | | 3 | 0x0400C | External interrupt 1 | IRQ1 | IRQ1ICR | 0x03FE3 | | 4 | 0x04010 | External interrupt 2 | IRQ2 | IRQ2ICR | 0x03FE4 | | 5 | 0x04014 | Reserved | - | - | 0x03FE5 | | 6 | 0x04018 | External interrupt 4 | IRQ4 | IRQ4ICR | 0x03FE6 | | 7 | 0x0401C | Timer 0 interrupt | TM0IRQ | IRQ0ICR | 0x03FE7 | | 8 | 0x04020 | Timer 1 interrupt | TM1IRQ | IRQ1ICR | 0x03FE8 | | 9 | 0x04024 | Timer 2 interrupt | TM2IRQ | TM2ICR | 0x03FE9 | | 10 | 0x04028 | Timer 3 interrupt | TM3IRQ | TM3ICR | 0x03FEA | | 11 | 0x0402C | Timer 6 interrupt | TM6IRQ | TM6ICR | 0x03FEB | | 12 | 0x04030 | Time base interrupt | TBIRQ | TBICR | 0x03FEC | | 13 | 0x04034 | Timer 7 interrupt | TM7IRQ | TM7ICR | 0x03FED | | 14 | 0x04038 | Timer 7 compere 2-match inter-<br>rupt | T7OC2IR<br>Q | T7OC2ICR | 0x03FEE | | 15 | 0x0403C | Serial 0 UART reception inter-<br>rupt | SC0RIR<br>Q | SC0RICR | 0x03FEF | | 16 | 0x04040 | Serial 0 UART transmission interrupt | SC0TIR<br>Q | SC0TICR | 0x03FF0 | | 17 | 0x04044 | Serial 1 UART reception inter-<br>rupt | SC1RIR<br>Q | SC1RICR | 0x03FF1 | | 18 | 0x04048 | Serial 1 UART transmission interrupt | SC1TIR<br>Q | SC1TICR | 0x03FF2 | | 19 | 0x0404C | Serial 3 interrupt | SC3IRQ | SC3ICR | 0x03FF3 | | 20 | 0x04050 | A/D conversion interrupt | ADIRQ | ADICR | 0x03FF4 | | 21 | 0x04054 | Serial 4 interrupt | SC4IRQ | SC4ICR | 0x03FF5 | | 22 | 0x04058 | Timer 8 interrupt | TM8IRQ | TM8ICR | 0x03FF6 | | 23 | 0x0405C | Timer 8 compare 2-match interrupt | TM8OC2<br>IRQ | TM8OC2IC<br>R | 0x03FF7 | ### ■ Interrupt Level and Priority This LSI allocated vector numbers and interrupt control registers (except reset interrupt) to each interrupt. The interrupt level (except reset interrupt, non-maskable interrupt) can be set by software, per each interrupt group. There are three hierarchical interrupt levels. If multiple interrupts have the same priority, the one with the lowest vector number takes priority. For example, if a vector 3 set to level 1 and a vector 4 set to level 2 request interrupt simultaneously, vector 3 will be accepted. Figure:3.1.3 Example of Interrupt Level #### ■ Determination of Interrupt Acceptance The following is the procedure from interrupt request input to acceptance. - 1. The interrupt request flag (xxxR) in the corresponding external interrupt control register (IRQnICR) and internal interrupt control register (xxxICR) are set to "1". - 2. An interrupt request is input to the CPU. (If the interrupt enable flag (xxxIE) of the same register is "1".) - 3. The interrupt request signal is set for each interrupt. The interrupt level (IL) is input to the CPU. - 4. The interrupt request is accepted. (If IL has higher priority than IM and MIE is "1".) - 5. Acceptance of an interrupt does not reset the corresponding interrupt enable flag (xxxIE) to "0". Figure: 3.1.4 Determination of Interrupt Acceptance Acceptance of an interrupt does not reset the corresponding interrupt enable flag (xxxIE) to "0". MIE = "0" and interrupts are disabled when: - MIE in the PSW is reset to "0" by a program - · Reset is detected. MIE = "1" and interrupts are enabled when: • MIE in the PSW is set to "1" by a program The interrupt mask level (IM = IM1 - IM0) in the processor status word (PSW) changes when: - The program alters it directly, - A reset initializes it to 0 (00b), - Maskable interrupt is accepted (the interrupt level becomes the interrupt mask level). - Execution of the RTI instruction at the end of an interrupt service routine restores the processor status word (PSW) and thus the previous interrupt mask level. The MN101C series does not reset the maskable interrupt enable (MIE) flag of the processor status word (PSW) to "0" when accepting interrupts. Non-maskable interrupts have priority over maskable ones. #### ■ Interrupt Acceptance Operation When accepting an interrupt, this LSI hardware saves the handy address register, the return address from the program counter, and the processor status word (PSW) to the stack and branches program to the interrupt handler using the starting address in the vector table. The following is the hardware processing sequence invoked by interrupt acceptance. 1. the stack pointer (SP) is updated. $$(SP-6) \rightarrow (SP)$$ 2. The contents of the handy address register (HA) are saved to the stack. Upper half of HA $\rightarrow$ (SP + 5) Lower half of HA $\rightarrow$ (SP + 4) 3. The contents of the program counter (PC) -i.e., the return address- are saved to the stack. PC bits 18, 17, and $0 \rightarrow (SP + 3)$ PC bits $16-9 \rightarrow (SP + 2)$ PC bits $8-1 \rightarrow (SP + 1)$ 4. The contents of the PSW are saved to the stack. $PSW \rightarrow (SP)$ - 5. The interrupt level (xxxLVn) for the interrupt is copied to the interrupt mask (IMn) in the PSW. Interrupt level (xxxLVn) $\rightarrow$ IMn - 6. The hardware branches program to the address in the vector table. Figure:3.1.5 Stack Operation during Interrupt Acceptance #### ■ Interrupt Return Operation An interrupt handler ends by restoring the contents of any registers saved to the stack during processing by the POP instruction and other means, and the RTI instruction restores the program to the point at execution was interrupted. The following is the processing sequence invoked by the RTI instruction. - 1. The contents of the PSW are restored from the stack. (SP) - 2. The contents of the program counter (PC) -i.e., then return address- are restored from the stack. (SP + 1 to SP + 3) - 3. The contents of the handy address register (HA) are restored from the stack. (SP + 4, SP+ 5) - 4. The stack pointer is updated. (SP +6 $\rightarrow$ SP) - 5. Execution branches program to the address in the program counter. The handy address register is an internal register used by the handy addressing function. The hardware saves its contents to the stack to prevent the interrupt from interfering with operation of the function. Registers such as data register, or address register are not saved, so that PUSH instruction from program should be used to save them onto stack, if necessary. The address bp6 to bp2, when program counter (PC) are saved to the stack, are reserved. Do not change it by program. #### Maskable Interrupt Figure: 3.1.6 shows the processing flow when a second interrupt with a lower priority level (xxxLV1 - xxxLV0 = "10") arrives during the processing of the with a higher priority level (xxxLV1 - xxxLV0 = "00"). Parentheses () indicates hardware processing. Figure:3.1.6 Processing Sequence for Maskable Interrupts <sup>\*1</sup> If during the processing of the first interrupt, an interrupt request with an interrupt level (IL) numerically lower than the interrupt mask (IM) arrives, it is accepted as a nested interrupt. If IL > IM, however, the interrupt is not accepted. <sup>\*2</sup> The second interrupt, postponed because its interrupt level (IL) was numerically greater than the interrupt mask (IM) for the first interrupt service routine, is accepted when the first interrupt handler returns. #### ■ Multiplex Interrupt of Maskable Interrupt When this LSI accepts an interrupt, it automatically disables acceptance of subsequent interrupts with the same or lower priority level. When the hardware accepts an interrupt, it copies the interrupt level (xxxLVn) for the interrupt to the interrupt mask (IM) in the PSW. As a result, subsequent interrupts with the same or lower priority levels are automatically masked. Only interrupts with higher priority levels are accepted. The net result is that interrupts are normally processed in decreasing order of priority. It is, however, possible to alter this arrangement. - 1. To disable interrupt nesting - Reset the MIE bit in the PSW to "0". - Raise the priority level of the interrupt mask (IM) in the PSW. - 2. To enable interrupts with lower priority than the currently accepted interrupt - Lower the priority level or the interrupt mask (IM) in the PSW. Multiplex interrupts are only enables for interrupts with levels higher than the PSW interrupt mask level (IM). It is possible to forcibly rewrite IM to accept an interrupt with a priority lower than the interrupt being processed, but the careful of stack overflow. Do not operate the maskable interrupt control register (xxxICR) when multiple interrupts are enabled. If operation is necessary, first clear the PSW MIE flag. ### Multiple Interrupt of Non-maskable On the acceptance of nim interrupt, when other nmi interrupt factor is generated, this interrupt is processed right away. Also, when the same nmi interrupt factor is generated before nmi interrupt flag is be soft cleared, it is not accepted. (Unless nmi interrupt clears the flag by the soft, the following same nmi interrupt is not accepted and <sup>\*</sup> When nmi interrupt A=IRQNWDG, nmi interrupt B=IRQNPG Figure:3.1.7 shows the processing sequence of the multiple interrupt. (multiple interrupt:xxxLV1 to 0 = "10", xxxLV1 to 0 = "00") Figure:3.1.7 Processing Sequence for Non-Maskable Multiple Interrupt ### 3.1.4 Interrupt Flag Setup #### ■ Interrupt Request Flag (IR) Setup by the Software The interrupt request flag is operated by the hardware. That is set to "1" when any interrupt factor is generated, and cleared to "0" when the interrupt is accepted. If you want to operate it by the software, the IRWE flag of MEMCTR should be set to "1". #### ■ Interrupt Flag Setup Procedure A setup procedure of the interrupt request flag set by the hardware and the software shows as follows; | Setup Procedure | Description | |---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Disable all maskable interrupts. PSW bp6:MIE =0 | (1) Clear the MIE flag of PSW to disable all maskable interrupts. This is necessary, especially when the interrupt control register is changed. | | (2) Select the interrupt factor. | (2) Select the interrupt doctor such as interrupt edge selection, or timer interrupt cycle change. | | (3) Enable the interrupt request flag to be rewritten. MEMCTR(0¥03F01) bp2:IRWE =1 | (3) Set the IRWE flag of MEMCTR to enable the interrupt request flag to be rewritten. This is necessary only when the interrupt request flag is changed by the software. | | (4) Rewrite the interrupt request flag. xxxICR bp0:xxxIR | (4) Rewrite the interrupt request flag (xxxIR) of the interrupt control register (xxxICR). | | (5) Disable the interrupt request flag to be rewritten. MEMCTR(0¥03F01) bp2:IRWE =0 | (5) Clear the IRWE flag so that interrupt request flag can not be rewritten by the software. | | (6) Set the interrupt level. xxxICR bp7-6:xxxLV1-0 PSW bp5-4:IM1-0 | (6) Set the interrupt level by the xxxLV1 - 0 flag of the interrupt control register (xxxICR). Set the IM1 - 0 flag of PSW then the interrupt acceptance level of CPU should be changed. | | (7) Enable the interrupt. xxxICR bp1:xxxIE =1 | (7) Set the xxxIE flag of the interrupt control register (xxxICR) to enable the interrupt. | | (8) Enable all maskable interrupts. PSW bp6:MIE =1 | (8) Enable all maskable interrupts. PSW bp6:MIE =1 | # 3.2 Control Registers # 3.2.1 Registers List Table:3.2.1 Interrupt Control Registers | Register | Address | R/W | Functions | Page | |----------|---------|-----|-----------------------------------------------------------------------------------------|--------| | NMICR | 0x03FE1 | R/W | Non-maskable interrupt control register | III-19 | | IRQ0ICR | 0x03FE2 | R/W | External interrupt 0 control register | III-20 | | IRQ1ICR | 0x03FE3 | R/W | External interrupt 1 control register | III-21 | | IRQ2ICR | 0x03FE4 | R/W | External interrupt 2 control register | III-22 | | IRQ4ICR | 0x03FE6 | R/W | External interrupt 4 control register | III-23 | | TM0ICR | 0x03FE7 | R/W | Timer 0 interrupt control register (Timer 0 compare-match) | III-24 | | TM1ICR | 0x03FE8 | R/W | Timer 1 interrupt control register (Timer 1 compare-match) | III-25 | | TM2ICR | 0x03FE9 | R/W | Timer 2 interrupt control register (Timer 2 compare-match) | III-26 | | TM3ICR | 0x03FEA | R/W | Timer 3 interrupt control register (Timer 3 compare-match) | III-27 | | TM6ICR | 0x03FEB | R/W | Timer 6 interrupt control register (Timer 6 compare-match) | III-28 | | TBICR | 0x03FEC | R/W | Time base interrupt control register (Time base period) | III-29 | | TM7ICR | 0x03FED | R/W | Timer 7 interrupt control register (Timer 7 compare-match) | III-30 | | T7OC2ICR | 0x03FEE | R/W | Timer 7 compare register 2-match interrupt control register | III-31 | | SC0RICR | 0x03FEF | R/W | Serial 0 UART reception interrupt control register (SC0UART reception completion) | III-32 | | SC0TICR | 0x03FF0 | R/W | Serial 0 UART transmission interrupt control register (SC0UART transmission completion) | III-33 | | SC1RICR | 0x03FF1 | R/W | Serial 1 UART reception interrupt control register (SC1UART reception completion) | III-34 | | SC1TICR | 0x03FF2 | R/W | Serial 1 UART transmission interrupt control register (SC1UART transmission completion) | III-35 | | SC3ICR | 0x03FF3 | R/W | Serial 3 interrupt control register (SC3 transfer completion) | III-36 | | ADICR | 0x03FF4 | R/W | A/D conversion interrupt control register (A/D conversion completion) | III-37 | | SC4ICR | 0x03FF5 | R/W | Serial 4 interrupt control register (SC4 transmission completion) | III-38 | | T8ICR | 0x03FF6 | R/W | Timer 8 interrupt control register (Timer 8 compare-match) | III-39 | | T8OC2ICR | 0x03FF7 | R/W | Timer 8 compare register 2-match interrupt control register | III-40 | If the interrupt level flag (xxxLVn) is set to "level 3", its vector is disabled, regardless of interrupt enable flag and interrupt request flag. Writing to the interrupt control register should be done after that all maskable interrupts are set to be disable by the MIE flag of the PSW register. ### 3.2.2 Interrupt Control Registers The interrupt control registers include the non-maskable interrupt control register (NMICTR), the external interrupt control register and the internal interrupt control registers (xxxICR). ■ Non-maskable Interrupt Control Register (NMICR:0x03FE1) The non-maskable interrupt control register (NMICTR) is stored the non maskable interrupt request. When the non-maskable interrupt request is generated, the interrupt is accepted regardless of the interrupt mask level (IMn) of PSW. The hardware then branches program to the address stored at location 0x04004 in the interrupt vector table. The watchdog timer overflow interrupt request flag (WDIR) is set to "1" when the watchdog timer overflows. The program interrupt request flag (PIR) is set to "1" when the undefined instruction is executed. Setting PIR or WDIR flag to be "1" enable non-maskable interrupt request to be set compulsory. Table:3.2.2 Non-maskable Interrupt Control Register (NMICR:0x03FE1) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|---|---|---|---|--------|---------|----------| | Flag | - | - | - | - | - | IRQNPG | IRQNWDG | Reserved | | At reset | - | - | - | - | - | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|----------|--------------------------------------------------------------------------------------| | 7-3 | - | - | | 2 | IRQNPG | Program interrupt request flag 0:No interrupt request 1:Interrupt request generated | | 1 | IRQNWDG | Watchdog interrupt request flag 0:No interrupt request 1:Interrupt request generated | | 0 | Reserved | Set always to "0" | When the undefined instruction is going to be executed, this LSI generates the non-maskable interrupt at the same time of the setting of the program interrupt request flag IRQNPG. When the setting of the IRQNPG flag is confirmed by the non-maskable interrupt process program, the softreset is recommended by outputting "0" to the reset pin (P27). #### ■ External Interrupt 0 Control Register (IRQ0ICR) The external interrupt 0 control register (IRQ0ICR) controls interrupt level of the external interrupt 0, valid edge, interrupt enable and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.3 External Interrupt 0 Control Register (IRQ0ICR:0x03FE2) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|-------|---|---|---|--------|--------| | Flag | IRQ0LV1 | IRQ0LV0 | REDG0 | - | - | - | IRQ0IE | IRQ0IR | | At reset | 0 | 0 | 0 | - | - | - | 0 | 0 | | Access | R/W | • | • | • | | • | • | | | bp | Flag | Description | |-----|--------------------|---------------------------------------------------------------------------------------------------------------------------| | 7-6 | IRQ0LV1<br>IRQ0LV0 | Interrupt level flag The CPU has interrupt levels from 0 to 3. This flag sets the interrupt level for interrupt requests. | | 5 | REDG0 | Interrupt valid edge flag (at the standby mode) 0:Falling edge (low level) 1:Rising edge (high level) | | 4-2 | - | - | | 1 | IRQ0IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | IRQ0IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ External Interrupt 1 Control Register (IRQ1ICR) The external interrupt 1 control register (IRQ1ICR) controls interrupt level of external interrupt 1, valid edge, interrupt enable and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.4 External Interrupt 1 Control Register (IRQ1ICR:0x03FE3) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|-------|---|---|---|--------|--------| | Flag | IRQ1LV1 | IRQ1LV0 | REDG1 | - | - | - | IRQ1IE | IRQ1IR | | At reset | 0 | 0 | 0 | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|--------------------|---------------------------------------------------------------------------------------------------------------------------| | 7-6 | IRQ1LV1<br>IRQ1LV0 | Interrupt level flag The CPU has interrupt levels from 0 to 3. This flag sets the interrupt level for interrupt requests. | | 5 | REDG1 | Interrupt valid edge flag (at the standby mode) 0:Falling edge (low level) 1:Rising edge (high level) | | 4-2 | - | - | | 1 | IRQ1IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | IRQ1IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ External Interrupt 2 Control Register (IRQ2ICR) The external interrupt 2 control register (IRQ2ICR) controls interrupt level of external interrupt 2, valid edge, interrupt enable and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSE is "0". Table:3.2.5 External Interrupt 2 Control Register (IRQ2ICR:0x03FE4 | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|-------|---|---|---|--------|--------| | Flag | IRQ2LV1 | IRQ2LV0 | REDG2 | - | - | - | IRQ2IE | IRQ2IR | | At reset | 0 | 0 | 0 | - | - | - | 0 | 0 | | Access | R/W | ₹/W | | | | | | | | bp | Flag | Description | |-----|--------------------|---------------------------------------------------------------------------------------------------------------------------| | 7-6 | IRQ2LV1<br>IRQ2LV0 | Interrupt level flag The CPU has interrupt levels from 0 to 3. This flag sets the interrupt level for interrupt requests. | | 5 | REDG2 | Interrupt valid edge flag (at the standby mode) 0:Falling edge (low level) 1:Rising edge (high level) | | 4-2 | - | - | | 1 | IRQ2IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | IRQ2IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ External Interrupt 4 Control Register (IRQ1ICR:0x03FE3) The external interrupt 4 control register (IRQ4ICR) controls interrupt level of external interrupt 4, valid edge, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.6 External Interrupt 4 Control Register (IRQ4ICR:0x03FE6) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---|---|---|---|--------|--------| | Flag | IRQ4LV1 | IRQ4LV0 | - | - | - | - | IRQ4IE | IRQ4IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|--------------------|---------------------------------------------------------------------------------------------------------------------------| | 7-6 | IRQ4LV1<br>IRQ4LV0 | Interrupt level flag The CPU has interrupt levels from 0 to 3. This flag sets the interrupt level for interrupt requests. | | 5-2 | - | - | | 1 | IRQ4IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | IRQ4IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 0 Interrupt Control Register (TM0ICR) The timer 0 interrupt control register (TM0ICR) controls interrupt level of timer 0 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) or PSW is "0". Table:3.2.7 Timer 0 Interrupt Control Register (TM0ICR:0x03FE7) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | TM0LV1 | TM0LV0 | - | - | - | - | TM0IE | TM0IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TM0LV1<br>TM0LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TMOIE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TM0IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 1 Interrupt Control Register (TM1ICR) The timer 1 interrupt control register (TM1ICR) controls interrupt level of timer 1 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) or PSW is "0". Table:3.2.8 Timer 1 Interrupt Control Register (TM1ICR:0x03FE8) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | TM1LV1 | TM1LV0 | - | - | - | - | TM1IE | TM1IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | • | | • | | • | • | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TM1LV1<br>TM1LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TM1IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TM1IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 2 Interrupt Control Register (TM2ICR) The timer 2 interrupt control register (TM2ICR) controls interrupt level of timer 2 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) or PSW is "0". Table:3.2.9 Timer 2 Interrupt Control Register (TM2ICR:0x03FE9) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | TM2LV1 | TM2LV0 | - | - | - | - | TM2IE | TM2IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TM2LV1<br>TM2LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TM2IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TM2IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 3 Interrupt Control Register (TM3ICR) The timer 3 interrupt control register (TM3ICR) controls interrupt level of timer 3 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) or PSW is "0". Table:3.2.10 Timer 3 Interrupt Control Register (TM3ICR:0x03FEA) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | TM3LV1 | TM3LV0 | - | - | - | - | TM3IE | TM3IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TM3LV1<br>TM3LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TM3IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TM3IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 6 Interrupt Control Register (TM6ICRB) The timer 6 interrupt control register (TM6ICR) controls interrupt level of timer 6 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) or PSW is "0". Table:3.2.11 Timer 6 Interrupt Control Register (TM6ICR:0x03FEB) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | TM6LV1 | TM6LV0 | - | - | - | - | TM6IE | TM6IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TM6LV1<br>TM6LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TM6IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TM6IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Time Base Interrupt Control Register (TBICR) The time base interrupt control register (TBICR) controls interrupt level of time base interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.12 Time Base Interrupt Control Register (TBICR:0x03FEC) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|-------|---|---|---|---|------|------| | Flag | TBLV1 | TBLV0 | - | - | - | - | TBIE | TBIR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|----------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TBLV1<br>TBLV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TBIE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TBIR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 7 Interrupt Control Register (TM7ICR) The timer 7 interrupt control register (TM7ICR) controls interrupt level of timer 7 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.13 Timer 7 Interrupt Control Register (TM7ICR:0x03FED) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | TM7LV1 | TM7LV0 | - | - | - | - | TM7IE | TM7IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TM7LV1<br>TM0LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TM7IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TM7IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 7 Compare Register 2-match Interrupt Control Register (T7OC2ICR) The timer 7 compare register 2-match interrupt control register (T7OC2ICR) controls interrupt level of timer 7 compare register 2-match interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.14 Timer 7 Compare Register 2-match Interrupt Control Register (T7OC2ICR:0x03FEE) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|---|---|---|---|---------|---------| | Flag | T7OC2LV<br>1 | T7OC2LV<br>0 | - | - | - | - | T7OC2IE | T7OC2IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | • | | | | • | • | | | bp | Flag | Description | |-----|----------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | T7OC2LV1<br>T7OC2LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | T7OC2IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | T7OC2IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Serial 0 UART Reception Interrupt Control Register (SC0RICR) The serial 0 UART reception interrupt control register (SC0RICR) controls interrupt level of timer 0 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.15 Serial 0 UART Reception Interrupt Control Register (SC0RICR:0x03FEF) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---|---|---|---|--------|--------| | Flag | SC0RLV1 | SC0RLV0 | - | - | - | - | SC0RIE | SC0RIR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC0RLV1<br>SC0RLV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | SC0RIE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | SC0RIR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Serial 0 UART Transmission Interrupt Control Register (SC0TICR) The serial 0 UART transmission interrupt control register (SC0TICR) controls interrupt level of timer 0 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.16 Serial 0 UART Transmission Interrupt Control Register (SC0TICR:0x03FF0) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---|---|---|---|--------|--------| | Flag | SC0TLV1 | SC0TLV0 | - | - | - | - | SC0TIE | SC0TIR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | • | • | • | | • | • | | | bp | Flag | Description | |-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC0TLV1<br>SC0TLV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | SCOTIE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | SCOTIR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Serial 1 UART Reception Interrupt Control Register (SC1RICR) The serial 1 UART reception interrupt control register (SC1RICR) controls interrupt level of timer 0 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.17 Serial 1 UART Reception Interrupt Control Register (SC1RICR:0x03FF1) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---|---|---|---|--------|--------| | Flag | SC1RLV1 | SC1RLV0 | - | - | - | - | SC1RIE | SC1RIR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC1RLV1<br>SC1RLV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | SC1RIE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | SC1RIR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Serial 1 UART Transmission Interrupt Control Register (SC1TICR) The serial 1 UART transmission interrupt control register (SC1TICR) controls interrupt level of timer 0 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.18 Serial 0 UART Transmission Interrupt Control Register (SC0TICR:0x03FF2) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---|---|---|---|--------|--------| | Flag | SC1TLV1 | SC1TLV0 | - | - | - | - | SC1TIE | SC1TIR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | • | • | • | • | | | | bp | Flag | Description | |-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC1TLV1<br>SC1TLV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | SC1TIE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | SC1TIR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Serial 3 Interrupt Control Register (SC3ICR) The serial 3 interrupt control register (SC3ICR) controls interrupt level of serial 3 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.19 Serial 3 Interrupt Control Register (SC3ICR:0x03FF3) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | SC3LV1 | SC3LV0 | - | - | - | - | SC3IE | SC3IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC3LV1<br>SC3LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | SC3IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | SC3IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ A/D Conversion Interrupt Control Register (ADICR) The A/D conversion interrupt control register (ADICR) controls interrupt level of A/D conversion interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.20 A/D Conversion Interrupt Control Register (ADICR:0x03FF4) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|-------|---|---|---|---|------|------| | Flag | ADLV1 | ADLV0 | - | - | - | - | ADIE | ADIR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|----------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | ADLV1<br>ADLV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | ADIE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | ADIR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Serial 4 Interrupt Control Register (SC4ICR) The serial 4 interrupt control register (SC4ICR) controls interrupt level of serial 4 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.21 Serial 4 Interrupt Control Register (SC4ICR:0x03FF5) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | SC4LV1 | SC4LV0 | - | - | - | - | SC4IE | SC4IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | • | | • | | • | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC4LV1<br>SC4LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | SC4IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | SC4IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 8 Interrupt Control Register (TM8ICR) The timer 8 interrupt control register (TM8ICR) controls interrupt level of timer 8 interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.22 Timer 8 Interrupt Control Register (TM8ICR:0x03FF6) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|---|---|---|-------|-------| | Flag | TM8LV1 | TM8LV0 | - | - | - | - | TM8IE | TM8IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TM8LV1<br>TM8LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | TM8IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | TM8IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | #### ■ Timer 8 Compare Register 2-match Interrupt Control Register (T8OC2ICR) The timer 8 compare register 2-match interrupt control register (T8OC2ICR) controls interrupt level of timer 8 compare register 2-match interrupt, interrupt enable flag and interrupt request. Interrupt control register should be operated when the maskable interrupt enable flag (MIE) of PSW is "0". Table:3.2.23 Timer 8 Compare Register 2-match Interrupt Control Register (T8OC2ICR:0x03FF7) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|---|---|---|---|---------|---------| | Flag | T8OC2LV<br>1 | T8OC2LV<br>0 | - | - | - | - | T8OC2IE | T8OC2IR | | At reset | 0 | 0 | - | - | - | - | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|----------------------|--------------------------------------------------------------------------------------------------------------------------------| | 7-6 | T8OC2LV1<br>T8OC2LV0 | Interrupt level flag This 2-bit flag sets the interrupt level by assigning an interrupt level of 0 to 3 to interrupt requests. | | 5-2 | - | - | | 1 | T8OC2IE | Interrupt enable flag 0:Disable interrupt 1:Enable interrupt | | 0 | T8OC2IR | Interrupt request flag 0:No interrupt request 1:Interrupt request generated | # 3.3 External Interrupts There are 4 external interrupts in this LSI. The circuit (external interrupt interface), operates the external interrupt input signal, is built-in between the external interrupt input pin and the external interrupt block. This external interrupt interface can manage to do with any kind of external interrupts. #### 3.3.1 Overview Table:3.3.1 shows the list of functions which external interrupts 0 to 2 and 4 are used. Table:3.3.1 External Interrupt Functions | | External interrupt input pin | Programmab<br>le active<br>edge | Both edges interrupt | Noise filter<br>built-in | AC zero<br>cross<br>detection | Key input interrupt | |---------------------------|------------------------------|---------------------------------|----------------------|--------------------------|-------------------------------|---------------------| | External inter-<br>rupt 0 | P54 | 0 | - | О | О | - | | External inter-<br>rupt 1 | P55 | 0 | - | 0 | 0 | - | | External inter-<br>rupt 2 | P56 | 0 | О | - | - | - | | External inter-<br>rupt 3 | - | - | - | - | - | О | Because the external interrupt event and the AC zero-cross is acknowledged by the rising of the system clock, the pulse which is shorter than the system clock cycle is neglected. System $clock \times 2$ for the interrupt factor generation is needed at the maximum against the external interrupt event from the pin because all synchronous circuits are inserted. # 3.3.2 Block Diagram ■ External Interrupt 0 Interface Block Diagram Figure:3.3.1 External Interrupt 0 Interface Block Diagram #### ■ External Interrupt 1 Interface Block Diagram Figure:3.3.2 External Interrupt 1 Interface Block Diagram #### ■ External Interrupt 2 Interface Block Diagram Figure:3.3.3 External Interrupt 2 Interface Block Diagram #### ■ External Interrupt 4 Interface Block Diagram Figure:3.3.4 External Interrupt 4 Interface Block Diagram # 3.3.3 Control Registers The external interrupt input signals, which passed through each internal interrupt interface 0 to 2 and 4 generate interrupt requests. External interrupt 0 to 2 and 4 interface are controlled by the external interrupt control register (IRQnICR). External interrupt interface 0 to 1 are controlled by the noise filter control register (NFCTR) and the prescaler control register (PSCMD), and external interrupt interface 2 is controlled by the both edges interrupt control register (EDGDT), and external interrupt interface 4 is controlled by the key interrupt control register 1 (KEYT3\_1IMD) and the key interrupt control register 2 (KEYT3\_2IMD). Table:3.3.2 shows the list of registers, which control external interrupt 0 to 2 and 4. Table:3.3.2 External Interrupt Control Register | External interrupt | Register | Address | R/W | Function | Page | |--------------------|----------------|---------|-----|---------------------------------------|--------| | External inter- | IRQ0ICR | 0x03FE2 | R/W | External interrupt 0 control register | III-20 | | rupt 0 | NFCTR | 0x03F2E | R/W | Noise filter control register | III-48 | | | PSCMD | 0x03F6D | R/W | Prescaler control register | III-47 | | External inter- | IRQ1ICR | 0x03FE3 | R/W | External interrupt 1 control register | III-21 | | rupt 1 | NFCTR | 0x03F2E | R/W | Noise filter control register | III-48 | | | PSCMD | 0x03F6D | R/W | Prescaler control register | III-47 | | External inter- | IRQ2ICR | 0x03FE4 | R/W | External interrupt 2 control register | III-22 | | rupt 2 | EDGDT | 0x03F1E | R/W | Both edges interrupt control register | III-53 | | External inter- | IRQ4ICR | 0x03FE6 | R/W | External interrupt 4 control register | III-23 | | rupt 4 | KEYT3_1I<br>MD | 0x03F3E | R/W | Key interrupt control register 1 | III-50 | | | KEYT3_2I<br>MD | 0x03F3F | R/W | Key interrupt control register 2 | III-51 | R/W:Readable/Writable #### ■ Prescaler Control Register (PSCMD) Prescaler control register enables or disables the prescaler count. Prescaler is used when the dividing clock of fs base is used at IRQ0, IRQ1. Table:3.3.3 Prescaler Control Register (PSCMD:0x03F6D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|---|---|---|---|---|---|-------| | Flag | - | - | - | - | - | - | - | PSCEN | | At reset | - | - | - | - | - | - | - | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | | | | |-----|-------|--------------------------------------------------------|--|--|--| | 7-1 | - | - | | | | | 0 | PSCEN | Prescaler count control 0:Disable count 1:Enable count | | | | # ■ Noise Filter Control Register (NFCTR) The noise filter control register (NFCTR) sets the noise remove function to IRQ0 and IRQ1 and also selects the sampling cycle of noise remove function. And this register also sets the AC zero cross detection function to IRQ1. Table:3.3.4 Noise Filter Control Register (NFCTR:0x03F2E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|---------|---------|-------|-------|---------|---------|-------| | Flag | P55IM | NF1SCK1 | NF1SCK0 | NF1EN | P54IM | NF0SCK1 | NF0SCK0 | NF0EN | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|--------------------|---------------------------------------------------------------------------------------------------------| | 7 | P55IM | ACZ input enable flag 0:Disable ACZ input 1:Enable ACZ input | | 6-5 | NF1SCK1<br>NF1SCK0 | IRQ1/noise sampling period 00:fosc 01:fosc/2 <sup>7</sup> 10:fosc/2 <sup>8</sup> 11:fosc/2 <sup>9</sup> | | 4 | NF1ENM | IRQ1/noise filter setup 0:Noise filter OFF 1:Noise filter ON | | 3 | P54IM | ACZ0 input enable flag 0:ACZ0 interrupt disable 1:ACZ0 interrupt enable | | 2-1 | NF0SCK1<br>NF0SCK0 | IRQ0/noise sampling period 00:fosc 01:fosc/2 <sup>7</sup> 10:fosc/2 <sup>8</sup> 11:fosc/2 <sup>9</sup> | | 0 | NF0ENM | IRQ0/noise filter setup 0:Noise filter OFF 1:Noise filter ON | #### ■ Both Edges Interrupt Control Register (EDGDT) The both edges interrupt control register (EDGDT) selects interrupt edges of IRQ2. Interrupts are generated at both edges, or at single edge. The external interrupt control register (IRQ2ICR) specifies whether interrupts are generated. Table:3.3.5 Both Edges Interrupt Control Register (EDGDT:0x03F1E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|---|---|---|---|---------|---|---| | Flag | - | - | - | - | - | EDGSEL1 | - | - | | At reset | - | - | - | - | - | 0 | - | - | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|---------|---------------------------------------------------------------------------------------------------------------------| | 7-3 | - | - | | 2 | EDGSEL1 | IRQ2 both edges interrupt selection 0:Programmable active edge interrupt selection 1:Both edges interrupt selection | | 1-0 | - | - | # ■ Key Interrupt Control Register 1 (KEYT3\_1IMD) The key interrupt control register 1 selects if key interrupt is accepted. Also, this register assigns KEY input to key interrupt in 2-bit unit. Table:3.3.6 Key Interrupt Control Register 1 (KEYT3\_1IMD:0x03F3E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|---|---|---|----------------|----------------|----------------|----------------| | Flag | KEYT3SE<br>L | - | - | - | KEYT3_1<br>EN3 | KEYT3_1<br>EN2 | KEYT3_1<br>EN1 | KEYT3_1<br>EN0 | | At reset | 0 | - | - | - | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------|----------------------------------------------------------------------| | 7 | KEYT3SEL | Key interrupt control 0:Key interrupt disable 1:Key interrupt enable | | 6-4 | - | - | | 3 | KEYT3_1EN3 | KEY3 interrupt selection 0:Disable 1:Enable | | 2 | KEYT3_1EN2 | KEY2 interrupt selection 0:Disable 1:Enable | | 1 | KEYT3_1EN1 | KEY1 interrupt selection 0:Disable 1:Enable | | 0 | KEYT3_1EN0 | KEY0 interrupt selection 0:Disable 1:Enable | ## ■ Key Interrupt Control Register 2 (KEYT3\_2IMD) The key interrupt control register 2 assigns KEY input to key interrupt in 1-bit unit. Table:3.3.7 Key Interrupt Control Register 2 (KEYT3\_2IMD:0x03F3F) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|---|---|---|----------------|----------------|----------------|----------------| | Flag | - | - | - | - | KEYT3_2<br>EN3 | KEYT3_2<br>EN2 | KEYT3_2<br>EN1 | KEYT3_2<br>EN0 | | At reset | - | - | - | - | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------|---------------------------------------------| | 7-4 | - | - | | 3 | KEYT3_2EN3 | KEY7 interrupt selection 0:Disable 1:Enable | | 2 | KEYT3_2EN2 | KEY6 interrupt selection 0:Disable 1:Enable | | 1 | KEYT3_2EN1 | KEY5 interrupt selection 0:Disable 1:Enable | | 0 | KEYT3_2EN0 | KEY4 interrupt selection 0:Disable 1:Enable | #### 3.3.4 Programmable Active Edge Interrupt ■ Programmable Active Edge Interrupts (External interrupts 0 to 2) The programmable active edge interrupt can select the rising/falling edge about the signal which is input from the external interrupt input pin and generate the interrupt at the selected edge. Also, if the value which is set to the external interrupt valid edge specify flag and the level of the external interrupt pin are matched, it is possible from the standby mode. At the standby mode, if the value that is set to the external interrupt valid specified flag and the external interrupt pin level are matched, the interrupt is generated. (refer to Figure:3.3.1 to Figure:3.3.5.) [Chapter 3 3.3.9. External Interrupt At the Standby Mode] ■ Programmable Active Edge Interrupt Setup Example (External interrupt 0 to 2) External interrupt 0 (IRQ0) is generated at the rising edge of the input signal from P54. The table below shows a setup example of IRQ0. | Setup Procedure | Description | |----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Specify the interrupt active edge IRQ0ICR(0x03FE2) bp5ÅFREDG0 =1 | (1) Set the REDG0 flag of the external interrupt 0 control register (IRQ0ICR) to "1" to specify the rising edge as the active edge for interrupts. | | (2) Set the interrupt level IRQ0ICR (0x03FE2) bp7-6:IRQ0LV1-0 =10 | (2) Set the interrupt priority level in the IRQ0LV1 to 0 flag of the IRQ0ICR register. | | (3) Enable the interrupt IRQ0ICR (0x03FE2) bp1:IRQ0IE =1 | (3) Set the IRQ0IE flag of the IRQ0ICR register to "1" enable the interrupt. | External interrupt 0 is generated at the rising edge of the input signal from P54. The interrupt request flag can be set at switching the interrupt edge, so specify the interrupt valid edge before the interrupt permission. The external interrupt pin is recommended to be pull-up in advance. ## 3.3.5 Both Edges Interrupt ■ Both Edges Interrupt (External interrupt 2) Both edges interrupt can generate interrupt at both the falling edge and the rising edge by the input signal from external input pins. CPU also can be returned from standby mode. At the standby mode, if the value that is set to the external interrupt valid specified flag and the external interrupt pin level are matched, the interrupt is generated. (refer to Figure:3.3.1 to Figure:3.3.5.) [Chapter 3 3.3.9. External Interrupt At the Standby Mode ■ Both Edges Interrupt Setup Example (External interrupt 2) External interrupt 2 (IRQ2) is generated at the both edges of the input signal from P56 pin. The table below shows a setup example of IRQ2. | Setup Procedure | Description | | |--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | (1) Select the both edges interrupt<br>EDGDT (0x03F2E)<br>bp2:EDGSEL2 =1 | (1) Set the EDGSEL flag of the both edges interrupt control register (EDGDT) to "1" to select the both edges interrupt. | | | (2) Set the interrupt level IRQ2ICR (0x03FE3) bp7-6:IRQ2LV1-0 =10 | (2) Set the interrupt level by the IRQ2LV1 to 0 flag of the IRQ2ICR register. The interrupt request flag of the IRQ2ICR register may be set, so make sure to clear the interrupt request flag (IRQ2IR). [Chapter 3. 3.1.4 Interrupt flag setup] | | | (3) Enable the interrupt IRQ2ICR (0x03FE3) bp1:IRQ2IE =1 | (3) Set the IRQ2IE flag of the IRQ2ICR register to "1" to enable the interrupt. | | At the both edges of the input signal from P56 pin, an external interrupt 2 is generated. When the both edges interrupt is selected, the interrupt request is generated at the both edge, regardless of the REDGn flag of the external interrupt control register (IRQnICR). The interrupt request flag may be set at switching the interrupt edge. So, clear the interrupt request flag before the interrupt acceptance. Also, select the both edges interrupt before the interrupt acceptance. The external interrupt pis is recommended to be pull-up, in advance. #### 3.3.6 Key Input Interrupt ■ Key Input Interrupt (External interrupt 4) This LSI can set port 7 (P70 to P77) pin by 1 bit to key input pin. An interrupt can be generated at the falling edge, if at least 1 key input pin outputs low level. (Standby mode can be recovered by the key interrupt.) Key input pin should be pull-up in advance. ■ Key Input Interrupt Setup Example (External interrupt 4) After P70 to P73 of port 4 are set to key input pins and key is input (low level), the external interrupt 4 (IRQ4) is generated. An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the key input to input<br>P7DIR (0x03F34)<br>bp3-0:P7DIR3-0 =0000 | (1) Set the P7DIR3 to 0 flag of the port 7 direction control register (P7DIR) to "0000" to set P70 to P73 pins to input pins. | | (2) Set the pull-up resistor<br>P7PLU (0x03F44)<br>bp3-0:P7PLU3-0 =1111 | (2) Set the P7PLU3 to 0 flag of the port 7 pull-up resistor control register (P7PLU) to "1111" to add the pull-up resistors to P70 to P73 pins. | | (3) Select the key input interrupt KEYT3_1IMD (0x03F3E) bp7:KEYT3_1SEL =1 | (3) Set the KEYT3SEL flag of the key interrupt control register (KEYT3_1IMD) to "1" to enable the key interrupt. | | (4) Select the key input pin KEYT3_1IMD (0x03F3E) bp1-0:KEYT3_1EN2-1 =11 | (4) Set the KEYT3_1EN1 to 0 of the key interrupt control register (KEYT3_1IMD) to "1111" to set P70 to P73 pins to key input pins. | | (5) Set the interrupt level IRQ4ICR (0x03FE6) bp7-6:IRQ4LV1-0 =10 | (5) Set the interrupt level by the IRQ4LV1 to 0 flag of the IRQ4ICR register. If the interrupt request flag has been already set, clear the request flag. [Chapter 3 3.1.4. Interrupt Flag Setup] | | (6) Enable the interrupt IRQ4ICR (0x03FE6) bp1:IRQ4IE =1 | (6) Set the IRQ4IE flag of the IRQ4ICR register to "1" to enable the interrupt. | <sup>\*</sup>Above (3) and (4) can be set at the same time. If there is at least one input signal, from the P70 to P73 pins, shows low level, the external interrupt 4 is generated at the falling edge. The key input should be setup before the interrupt is accepted. #### 3.3.7 Noise Filter ■ Noise Filter (External interrupts 0 and 1) Noise filter reduce noise by sampling the input waveform from the external interrupt pins (IRQ0, IRQ1). Its sampling cycle can be selected from 4 types (fosc, fosc/2<sup>7</sup>, fosc/2<sup>8</sup>, fosc/2<sup>9</sup>) ■ Noise Remove Selection (External interrupts 0 and 1) Noise remove function can be selected by setting the NFnEN flag of the noise filter control register (NFCTR) to "1". Table:3.3.8 Addition of Noise Remove Function | NFnEN | IRQ input (P54) | IRQ input (P55) | |-------|-----------------------|-----------------------| | 0 | IRQ0 noise filter OFF | IRQ1 noise filter OFF | | 1 | IRQ0 noise filter ON | IRQ1 noise filter ON | ■ Sampling Cycle Setup (External interrupts 0 and 1) The sampling cycle of noise remove function can be set by the NFnSCK2 to 0 flag of the NFCTR register. Table:3.3.9 Sampling Cycle / Time of Noise Remove Function | NFnCKS1 | NFnCKS0 | Sampling cycle | fs=10 MHz, fx/32.768 kHz | | | |---------|---------|---------------------|--------------------------|----------|--| | | 0 | fosc | 10 MHz | 100 ns | | | 0 | 1 | fosc/2 <sup>7</sup> | 78.125 kHz | 12.80 μs | | | 0 | | fosc/2 <sup>8</sup> | 39.062 kHz | 25.60 μs | | | | 1 | fosc/2 <sup>9</sup> | 19.521 kHz | 51.20 μs | | #### ■ Noise Remove Function Operation (External interrupts 0 and 1) After sampling the input signal to the external interrupt pins (IRQ0, IRQ1) with the set sampling time, if the same level comes continuously three times, that level is sent to the inside of LSI. If the same level does not come continuously three times, the previous level is sent. It means that only the signal with the amplitude of longer than "Sampling time $\times$ 3 sampling clock" can pass through the noise filter, and other signals with amplitude shorter than this are removed, because those are regarded as noise. Figure:3.3.5 Noise Remove Function Operation Noise filter cannot be used at STOP mode and HALT mode. Noise filter can be uses at the SLOW mode. However, sampling timing gets slow extremely. #### ■ Noise Filter Setup Example (External interrupt 0 and 1) Noise remove function is added to the input signal from P54 pin to generate the external interrupt 0 (IRQ0) at the rising edge. The sampling clock is set to $fosc/2^7$ , and the operation state is fs = 10 MHz. An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Specify the interrupt valid edge IRQ0ICR (0x03FE2) bp5:REDG0 =1 | (1) Set the REDG0 flag of the external interrupt 0 control register (IRQ0ICR) to "1" to specify the interrupt valid edge to the rising edge. | | (2) Select the sampling clock NFCTR (0x03F2E) bp2-1:NF0SCK1-0 =01 | (2) Select the sampling clock to fosc/2 <sup>7</sup> by the NF0SCK1 to 0 flag of the noise filter control register (NFCTR). | | (3) Set the noise filter operation NFCTR (0x03F2E) bp0:NF0EN =1 | (3) Set the NF0EN flag of the NFCTR register to "1" to add the noise filter operation. | | (4) Set the interrupt level IRQ0ICR (0x03FE2) bp7-6:IRQ0LV1-0 =10 | (4) Set the interrupt level by the IRQ0LV1 to 0 flag of the IRQ0ICR register. If the interrupt request flag has been already set, clear the request flag. [Chapter 3 3.1.4. Interrupt Flag Setup] | | (5) Enable the interrupt IRQ0ICR (0x03FE2) bp1:IRQ0IE =1 | (5) Set the IRQ0IE flag of the IRQ0ICR register to "1" to enable the interrupt. | <sup>\*</sup>Above (2) and (3) can be set at the same time. The input signal from P54 pin outputs the interrupt factor at the edge that is followed to the programmable active edge after passing through the noise filter. The noise filter should be setup before the interrupt is enabled. The external interrupt pins are recommended to be pull-up in advance. #### 3.3.8 AC Zero-Cross Detector This LSI has AC zero-cross detector circuit. The P54 / ACZ0 and P55/ACZ1 pins are the input pins of AC zero-cross detector circuit. AC zero-cross detector circuit output the high level when the input level is at the middle, and outputs the low level at other level. AC Zero-Cross Detector (External interrupt 0 and 1) AC zero-cross detector set the IRQ1 pin to the high level when the input signal (P54 / ACZ0, P55/ACZ1 pins) is at intermediate range by AC zero-cross detector circuit. At the other level, IRQ1 pin set to the low level. AC zero-cross detector is set by setting the P55IM flag of the noise filter control register (NFCTR) to "1". Also, it is possible to recover from the standby mode. Figure:3.3.6 AC Line Waveform and IRQ1 Generation Timing Actual IRQ1 interrupt request is generated several times at crossing the AC line waveform and the intermediate level (point A and B). So, the filtering operation by the program is needed. The interrupt request is generated at the rising edge of the AC zero-cross detector signal. The interrupt request is output at "H" level of the AC zero-cross detector signal at the standby mode. #### ■ AC Zero-Cross Detector Setup Example (External interrupt 0 and 1) AC zero-cross detector generates the external interrupt 1 (IRQ1) by using P55/ACZ1 pin. An example of the setup procedure, with a description of each step is shown below. If the input level signal which is input from P55/ACZ1 pin cross with the intermediate level, the external interrupt 1 is generated. | Setup Procedure | Description | |---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select the AC zero-cross detector signal NFCTR (0x03F2E) bp7:P55IM =1 | (1) Set the P21IM flag of the noise filter control register (NFCTR) to "1" to select the AC zero-cross detector signal as the external interrupt 1 generation factor. | | (2) Set the interrupt level IRQ1ICR (0x03FE3) bp7-6:IRQ1LV1-0 =10 | (2) Set the interrupt level by the IRQ1LV1 to 0 flag of the IRQ1ICR register. If the interrupt request flag has been already set, clear the interrupt flag. [Chapter 3 3.1.4. Interrupt Flag Setup] | | (3) Enable the interrupt IRQ1ICR (0x03FE3) bp1:IRQ1IE =1 | (3) Set the IRQ1IE flag of the IRQ1ICR register to "1" to enable the interrupt. | When the input level of the input signal from P55/ACZ1 pin crosses with the intermediate level, the external interrupt 1 is generated. #### 3.3.9 External Interrupt At The Standby Mode ■ External Interrupt at the Standby Mode (External interrupt 0 to 2) It is possible to recover from the standby mode by the external interrupt. At the standby mode, an interrupt is generated when the value set to the external interrupt valid edge specify flag matches the external interrupt pin level. Therefore, be aware of the value of the external interrupt valid edge specify flag and the external interrupt pin level at the transition to the standby mode. If the value set to the external interrupt valid edge specify flag matches the external interrupt pin level at the transition to the standby mode, it recovers from the standby mode right away. Setup Examples of the External Interrupt at the Standby Mode Recovery from STOP mode can be done by generation of the external interrupt 0 (IRQ0) by the low level signal input from P54. An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Specify the interrupt valid edge IRQ0ICR (0x03FE2) bp5:REDG0 =0 | (1) Set the REDG0 of the external interrupt 0 control register (IRQ0ICR) to "0" to specify the interrupt valid edge to the rising edge. | | (2) Set the external interrupt pin The external interrupt 0 pin is pulled-up in advance. | (2) The value of the REDG0 flag of the IRQ0ICR register and the external interrupt pin level is different. | | (3) Set the interrupt level IRQ0ICR (0x03FE2) bp7-6:IRQ0LV1-0 =10 | (3) Set the interrupt level by the IRQ0LV1 to 0 flag of the IRQ0ICR register. If the interrupt request has been already set, clear the interrupt request flag (IRQ0IR). | | (4) Enable the interrupt IRQ0ICR (0x03FE2) bp1:IRQ0IE =1 | (4) Set the IRQ0IE flag of the IRQ0ICR register to "1" to enable the interrupt. | | (5) Set the STOP mode<br>CPUM (0x03F00)<br>bp3:STOP =1 | (5) Transfer to the STOP mode by setting STOP flag of the CPU mode control register (CPUM) to "1". [Chapter 2 2.4.4. Transition to Standby Modes] | When the low level signal is input to P54 and the value of the external interrupt valid edge specify flag (REDG0) matches the external interrupt 0, the external interrupt 0 is accepted and recover from the STOP mode. Chapter 3 Interrupts # 4.1 Overview ## 4.1.1 I/O Port Overview A total of 40 pins on this LSI, including those shared with special function pins, are allocated for the I/O ports of port 1, port 2, port 3, port 5, port 7, port 9 and port A. ## 4.1.2 I/O Port Status at Reset Table:4.1.1 I/O port status at reset (single chip mode) | Port | I/O mode | Pull-up/Pull-down resistor | I/O port, special functions | |--------|------------|-----------------------------------------------------------------------------------------|-----------------------------| | Port 1 | Input mode | P17 to P12:<br>No pull-up/pull-down resistor<br>P11, P10:<br>Pull-up/pull-down resistor | I/O port | | Port 2 | Input mode | P27:Pull-up resistor | I/O port | | Port 3 | Input mode | P30 to P36: No pull-up resistor<br>P37: Pull-down resistor | I/O port | | Port 5 | Input mode | No pull-up resistor | I/O port | | Port 7 | Input mode | No pull-up/pull-down resistor | I/O port | | Port 9 | Input mode | P90: Pull-down resistor | I/O port | | Port A | Input mode | PA3 to PA0: No pull-up resistor<br>PA6 to PA4: Pull-down resistor | I/O port | ## 4.1.3 Control Registers Port 1, port 2, port3, port5, port 7, port 9 and port A are controlled by the data output register (PnOUT), the data input register (PnIN), the I/O direction control register (PnDIR), the pull-up resistor control register (PnPLU) or the pull-up/pull-down resistor control register (PnPLUD) and registers that control special function pin (PnOMD, PnIMD, PnSYO, PnSEV, PnCNT0, PnODC). Table: 4.1.2 shows the registers to control port 1, port 2, port3, port5, port 7, port 9 and port A; Table:4.1.2 I/O Port Control Registers List | Register | Address | R/W | Function | Page | |----------|---------|-----|----------------------------------------------------|-------| | P1OUT | 0x03F11 | R/W | Port 1 output register | IV-7 | | P1IN | 0x03F21 | R | Port 1 input register | IV-8 | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | P1PLUD | 0x03F41 | R/W | Port 1 pull-up/pull-down resistor control register | IV-9 | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | P1ODC | 0x03F1B | R/W | Port 1 Nch open-drain control register | IV-11 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-11 | | P1CNT0 | 0x03F3D | R/W | Port 1 real time output control register 0 | IV-11 | | CLKOUT | 0x03F1F | R/W | Clock output control register | IV-13 | | P2OUT | 0x03F12 | R/W | Port 2 output register | IV-22 | | P3OUT | 0x03F13 | R/W | Port 3 output register | IV-26 | | P3IN | 0x03F23 | R | Port 3 input register | IV-27 | | P3DIR | 0x03F33 | R/W | Port 3 direction control register | IV-27 | | P3PLUD | 0x03F43 | R/W | Port 3 pull-up/pull-down resistor control register | IV-28 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-29 | | P3ODC | 0x03F3B | R/W | Port 3 Nch open-drain control register | IV-30 | | P5OUT | 0x03F15 | R/W | Port 5 output register | IV-41 | | P5IN | 0x03F25 | R | Port 5 input register | IV-42 | | P5DIR | 0x03F35 | R/W | Port 5 direction control register | IV-42 | | P5PLU | 0x03F45 | R/W | Port 5 pull-up resistor control register | IV-43 | | P5OMD | 0x03F2C | R/W | Port 5 output mode register | IV-44 | | P7OUT | 0x03F17 | R/W | Port 7 output register | IV-51 | | P7IN | 0x03F27 | R | Port 7 input register | IV-52 | | P7DIR | 0x03F37 | R/W | Port 7 direction control register | IV-52 | | P7PLUD | 0x03F47 | R/W | Port 7 pull-up resistor control register | IV-53 | | P7OMD | 0x03F3C | R/W | Port 7 output mode register | IV-53 | | P7ODC | 0x03F1D | R/W | Port 7 Nch open-drain control register | IV-54 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-54 | | P9OUT | 0x03F19 | R/W | Port 9 output register | IV-67 | | Register | Address | R/W | Function | Page | |----------|---------|-----|----------------------------------------------------|-------| | P9IN | 0x03F29 | R | Port 9 input register | IV-68 | | P9DIR | 0x03F39 | R/W | Port 9 direction control register | IV-68 | | P9PLUD | 0x03F49 | R/W | Port 9 pull-up/pull-down resistor control register | IV-69 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-69 | | XSEL | 0x03F4C | R/W | Port9 oscillation switching register | IV-70 | | PAOUT | 0x03F1A | R/W | Port A output register | IV-74 | | PAIN | 0x03F2A | R | Port A input register | IV-75 | | PADIR | 0x03F3A | R/W | Port A direction control register | IV-75 | | PAPLUD | 0x03F4A | R/W | Port A pull-up/pull-down resistor control register | IV-76 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-77 | | PAIMD | 0x03F4E | R/W | Port A input mode register | IV-76 | | PAODC | 0x03F2D | R/W | PortA Nch open-drain control register | IV-77 | R/W = Readable/Writable R = Readable only ## 4.2 Port 1 #### 4.2.1 Description #### ■ General Port Setup To output data to pin, set the control flag of the port 1 direction control register (P1DIR) to "1" and write the value of the port 1 output register (P1OUT). To read input data of pin, set the control flag of the port 1 direction control register (P1DIR) to "0" and read the value of the port 1 input register (P1IN). Each bit can be set individually as either an input or output by the port 1 I/O direction control register (P1DIR). The control flag of the port 1 direction control register (P1DIR) is set to "1" for output mode, and "0" for input mode. Each bit can be set individually if pull-up or pull-down resistor is added or not, by the port 1 pull-up/pull-down resistor control register (P1PLUD). Set the control flag of the port 1 pull-up/pull-down resistor control register (P1PLUD) to "1" to add pull-up or pull-down resistor. Port 1 can be selected to add pull-up resistor or pull-down resistor by bp0 of the pull-up/pull-down resistor selection register (SELUD). Each bit can be selected individually as input mode by the port 1 input mode register (P1IMD). The control flag of the port 1 input mode register (P1IMD) is set to "1" to output the special function data, and "0" to use as the general port. For P10, P11, P15 and P17, each bit can be selected individually as Nch open-drain output by the port 1 Nch open-drain control register (P1ODC). The control flag of the port 1 Nch open-drain control register (P1ODC) is set to "1" for Nch open-drain output, and "0" for push-pull output. #### ■ Special Function Pin Setup P10 is used as the transmission/reception data I/O pin of IIC4, as well. When the SELI2C flag of the serial interface 4 addressing register 1 (SC4AD1) is "1", P10 is the serial transmission/reception data I/O pin. Push-pull output or Nch open-drain output can be selected by setting the Port 1 Nch open-drain control register (P1ODC). P11 is used as the clock input pin of IIC, as well. When the SCLI2C flag of the serial interface 4 addressing register 1 (SC4AD1) is "1", P11 is the serial clock input pin. Push-pull output or Nch open-drain output can be selected by setting the Port 1 Nch open-drain control register (P1ODC). P12 is used as I/O pin of the timer 8, as well. The output mode can be selected by bp1 of the port 1 output mode register (P1OMD) by each bit. The bp1 of the port 1 output mode register (P1OMD) is set to "1" to output the special function data, and "0" to use as the general port. P13 is used as I/O pin of the timer 7, as well. The output mode can be selected by bp3 of the port 1 output mode register (P1OMD) by each bit. The bp3 of the port 1 output mode register (P1OMD) is set to "1" to output the special function data, and "0" to use as the general port. P14 is used as I/O pin of the timer 0 and as output pin of the remote control carrier, as well. The output mode can be selected by bp4 of the port 1 output mode register (P1OMD) by each bit. The bp4 of the port 1 output mode register (P1OMD) is set to "1" to output the special function data, and "0" to use as the general port. P15 is used as the output pin of the timer 0, as well. The output mode can be selected by bp5 of the port 1 output mode register (P1OMD) by each bit. The bp5 of the port 1 output mode register (P1OMD) is set to "1" to output the special function data, and "0" to use as the general port. P16 is used as I/O pin of the timer 2, as well. The output mode can be selected by bp6 of the port 1 output mode register (P1OMD) by each bit. The bp6 of the port 1 output mode register (P1OMD) is set to "1" to output the special function data, and "0" to use as the general port. P17 is used as the output pin of the timer 0, as well. The output mode can be selected by bp7 of the port 1 output mode register (P1OMD) by each bit. The bp7 of the port 1 output mode register (P1OMD) is set to "1" to output the special function data, and "0" to use as the general port. P13 is used as the output pin of the system clock, as well. The output mode can be selected by bp0 of the clock output control register (CLKOUT) by each bit. The bp0 of the clock output control register (CLKOUT) is set to "1" to output the special function data, and "0" to use as the general port. P12, P14, P16 have the functions of the real time output control and can switch pin output to "0", "1", "Hi-impedance (Hi-z)" at the event generation timing of the falling edge of the external interrupt 0. The real time control is the function which can change the output signal without the interposition with synchronized to the interrupt event. P12 is used as buzzer output pin, as well. When the bp7 of the oscillation stabilization wait control register (DLYCTR) is set to "1" and the bp1, bp0 of the port 1 output mode register (P1OMD) are set to "01", buzzer output is enabled. P13 is used as inverse buzzer output pin, as well. When the bp7 of the oscillation stabilization wait control register (DLYCTR) is set to "1" and the bp3, bp2 of the port 1 output mode register (P1OMD) are set to "01", inverse buzzer output is enabled. P15 is used as the output pin of the serial 1 transmission data and UART1 transmission data, as well. When the SC1SBOS flag of the serial interface 1 mode register 1 (SC1MD1) is "1", P15 is the serial data output pin. Pushpull output or Nch open-drain output can be selected by setting the Port 1 Nch open-drain control register (P1ODC). P16 is used as the input pin of the serial 1 reception data and UART1 reception data, as well. P17 is used as the serial 1 clock I/O pin, as well. When the SC1SBTS flag of the serial interface 1 mode register 1 (SC1MD1) is "1", P17 is the serial clock output pin. Push-pull output or Nch open-drain output can be selected by setting the Port 1 Nch open-drain control register (P1ODC). The I/O of the serial 4 can be selected as P10, P11, or P76, P77 by setting the serial selection register (SCSEL). The SC4SL flag of the serial selection register (SCSEL) is set to "0", P10, P11 are selected, to "1", P76, P77 are selected. The I/O of the serial 1 can be selected as P15 to P17, or PA4 to PA6 by setting the serial selection register (SCSEL). The SC4SL flag of the serial selection register (SCSEL) is set to "0", P15 to P17 are selected, to "1", PA4 to PA6 are selected. P14 is used as LCD segment output pin, as well. The SEG11 pin selection can be done by setting the bp7 flag (LC2SL7) flag of the LCD output control register 2 (LCCTR2) to "1". Port and segment switching can be selected by each bit. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P15 is used as LCD segment output pin, as well. The SEG10 pin selection can be done by setting the bp6 flag (LC2SL6) flag of the LCD output control register 2 (LCCTR2) to "1". Port and segment switching can be selected by each bit. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P16 is used as LCD segment output pin, as well. The SEG9 pin selection can be done by setting the bp5 flag (LC2SL5) flag of the LCD output control register 2 (LCCTR2) to "1". Port and segment switching can be selected by each bit. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P17 is used as LCD segment output pin, as well. The SEG8 pin selection can be done by setting the bp4 flag (LC2SL4) flag of the LCD output control register 2 (LCCTR2) to "1". Port and segment switching can be selected by each bit. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. # 4.2.2 Registers Table: 4.2.1 shows registers that control the port 1. Table:4.2.1 Port 1 Control Register | Registers | Address | R/W | Function | Page | |-----------|---------|-----|----------------------------------------------------|-------| | P1OUT | 0x03F11 | R/W | Port 1 output register | IV-7 | | P1IN | 0x03F21 | R | Port 1 input register | IV-8 | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | P1PLU | 0x03F41 | R/W | Port 1 pull-up/pull-down resistor control register | IV-9 | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | P1ODC | 0x03F1B | R/W | Port 1 Nch open-drain control register | IV-11 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-11 | | P1CNT0 | 0x03F3D | R/W | Port 1 real time output control register 0 | IV-12 | | CLKOUT | 0x03F1F | R/W | Clock output control register | IV-13 | | LCCTR2 | 0x03FC3 | R/W | LCD output control register | IV-14 | | SCSEL | 0x03F90 | R/W | Serial I/O pin switching control register | IV-15 | #### R/W:Readable/Writable ■ Port 1 Output Register (P1OUT:0x03F11) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | P1OUT7 | P1OUT6 | P1OUT5 | P1OUT4 | P1OUT3 | P1OUT2 | P1OUT1 | P1OUT0 | | At reset | х | х | х | х | х | х | х | х | | Access | R/W | bp | Flag | Description | |---------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P10UT7<br>P10UT6<br>P10UT5<br>P10UT4<br>P10UT3<br>P10UT2<br>P10UT1<br>P10UT0 | Output data 0:Output L(VSS level) 1:Output H(VDD level) | ## ■ Port 1 Input Register (P1IN:0x03F21) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|-------|-------|-------|-------|-------|-------|-------| | Flag | P1IN7 | P1IN6 | P1IN5 | P1IN4 | P1IN3 | P1IN2 | P1IN1 | P1IN0 | | At reset | х | х | х | х | х | х | 1 | 1 | | Access | R | R | R | R | R | R | R | R | | bp | Flag | Description | |---------------------------------|----------------------------------------------------------------------|--------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P1IN7<br>P1IN6<br>P1IN5<br>P1IN4<br>P1IN3<br>P1IN2<br>P1IN1<br>P1IN0 | Input data 0:Pin is L(VSS level) 1:Pin is H(VDD level) | #### ■ Port 1 Direction Control Register (P1DIR:0x03F31) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | P1DIR7 | P1DIR6 | P1DIR5 | P1DIR4 | P1DIR3 | P1DIR2 | P1DIR1 | P1DIR0 | | At reset | х | х | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |---------------------------------|------------------------------------------------------------------------------|-----------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P1DIR7<br>P1DIR6<br>P1DIR5<br>P1DIR4<br>P1DIR3<br>P1DIR2<br>P1DIR1<br>P1DIR0 | I/O mode selection 0:Input mode 1:Output mode | ## ■ Port 1 Pull-up/Pull-down Resistor Control Register (P1PLUD:0x03F41) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | P1PLUD7 | P1PLUD6 | P1PLUD5 | P1PLUD4 | P1PLUD3 | P1PLUD2 | P1PLUD1 | P1PLUD0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Access | R/W | bp | Flag | Description | |---------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P1PLUD7<br>P1PLUD6<br>P1PLUD5<br>P1PLUD4<br>P1PLUD3<br>P1PLUD2<br>P1PLUD1<br>P1PLUD0 | Pull-up/pull-down resistor selection 0:Not added 1:Added | ## ■ Port 1 Output Mode Register (P1OMD:0x03F1C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|-------------|--------|--------| | Flag | P1OMD7 | P1OMD6 | P1OMD5 | P1OMD4 | P1OMD3 | NBUZSE<br>L | P1OMD2 | BUZSEL | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |----|-------------|----------------------------------------------------------| | 7 | P1OMD7 | I/O port, TM2OB selection 0:I/O port 1:TM2OB | | 6 | P1OMD6 | I/O port, TM2IO selection 0:I/O port 1:TM2IO | | 5 | P1OMD5 | I/O port, TM0OB selection 0:I/O port 1:TM0OB | | 4 | P1OMD4 | I/O port, TM0IO/RMOUT selection 0:I/O port 1:TM0IO/RMOUT | | 3 | P1OMD3 | P13 I/O port, TM7IO, NBUZZER selection | | 2 | NBUZSE<br>L | 1X:TM7IO<br>01:NBUZZER | | 1 | P1OMD2 | P12 I/O port, TM8IO, BUZZER selection | | 0 | BUZSEL | 1X:TM8IO<br>01:BUZZER<br>00:I/O port | ## ■ Port 1 Nch Open-drain Control Register (S1ODC:0x03F1B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|---|--------|---|---|---|--------|--------| | Flag | P17ODC | - | P15ODC | - | - | - | P11ODC | P100DC | | At reset | 0 | - | 0 | - | - | - | 0 | 0 | | Access | R/W | - | R/W | - | - | - | R/W | R/W | | bp | Flag | Description | |---------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P170DC<br>-<br>P150DC<br>-<br>-<br>-<br>P110DC<br>P100DC | Nch open-drain output selection 0:Push-pull output 1:Nch open-drain output) | #### ■ Pull-up/pull-down Resistor Selection Register (SELUD:0x03F4B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|-------|-------|-------|-------|-------| | Flag | - | - | - | PADWN | P3DWN | P9DWN | P7DWN | P1DWN | | At reset | - | - | - | 1 | 1 | 1 | 0 | 0 | | Access | - | - | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |----|-------|-----------------------------------------------------------| | 7 | - | - | | 6 | - | - | | 5 | - | - | | 4 | PADWN | Port A pull-up/pull-down selectionl 0:Pull-up 1:Pull-down | | 3 | P3DWN | Port 3 pull-up/pull-down selectionl 0:Pull-up 1:Pull-down | | 2 | P9DWN | Port 9 pull-up/pull-down selectionl 0:Pull-up 1:Pull-down | | 1 | P9DWN | Port 7 pull-up/pull-down selectionl 0:Pull-up 1:Pull-down | | 0 | P9DWN | Port 1 pull-up/pull-down selectionl 0:Pull-up 1:Pull-down | ## ■ Port 1 Real Time Output Control Register 0 (P1CNT0:0x03F3D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---------|---------|---------|---------|---------|---------| | Flag | - | - | P1CNT05 | P1CNT04 | P1CNT03 | P1CNT02 | P1CNT01 | P1CNT00 | | At reset | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | Access | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |-----|--------------------|--------------------------------------------------------------------------------------------------------------------------| | 7 | - | - | | 5 4 | P1CNT05<br>P1CNT04 | P16 real time control 00:I/O port (real time control disabled) 01:"1" (High) output 10:"0" (Low) output 11:"Hi-z" output | | 3 2 | P1CNT03<br>P1CNT02 | P14 real time control 00:I/O port (real time control disabled) 01:"1" (High) output 10:"0" (Low) output 11:"Hi-z" output | | 1 0 | P1CNT01<br>P1CNT00 | P12 real time control 00:I/O port (real time control disabled) 01:"1" (High) output 10:"0" (Low) output 11:"Hi-z" output | ## ■ Clock Output Control Register 0 (P1CNT0:0x03F3D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---------|-------|--------|-------| | Flag | - | - | - | - | SCHMITT | PDOWN | CLKSEL | OUTEN | | At reset | - | - | - | - | 0 | 0 | 0 | 0 | | Access | - | - | - | - | R/W | R/W | R/W | R/W | | bp | Flag | Description | |-----|---------|------------------------------------------------------------------------------------------------------| | 7-4 | - | - | | 3 | SCHMITT | Port 1, Port 3, Port A input level switching 0:VIH=0.8 VDD VIL=0.2 VDD 1:VIH=0.54 VDD VIL=0.3 VDD | | 2 | PDOWN | Clock output capability 0:general port output capability 1:No capability | | 1 | CLKSEL | Clock type selection 0:System clock (fx) 1:High speed oscillation (fosc)/ Low speed oscillation (fx) | | 0 | OUTEN | Clock output permission 0:No 1:Oscillation output | ## ■ LCD Output Control Register 2 (LCCTR2:X'3FC3', R/W) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | LC2SL7 | LC2SL6 | LC2SL5 | LC2SL4 | LC2SL3 | LC2SL2 | LC2SL1 | LC2SL0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |----|--------|-----------------------------------------| | 7 | LC2SL7 | SEG11/P14 selection 0:P14 1:SEG11 | | 6 | LC2SL6 | SEG10/P15 selection<br>0:P15<br>1:SEG10 | | 5 | LC2SL5 | SEG9/P16 selection<br>0:P16<br>1:SEG9 | | 4 | LC2SL4 | SEG8/P17 selection 0:P17 1:SEG8 | | 3 | LC2SL3 | SEG7/P70 selection<br>0:P70<br>1:SEG7 | | 2 | LC2SL2 | SEG6/P71 selection<br>0:P71<br>1:SEG6 | | 1 | LC2SL1 | SEG5/P72 selection<br>0:P72<br>1:SEG5 | | 0 | LC2SL0 | SEG4/P73 selection<br>0:P73<br>1:SEG4 | ## ■ Serial Input/output pin switching Control Register (SCSEL:0x03F90) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|-------------|-------------|-------|---|-------|-------| | Flag | - | - | TEMPSC<br>2 | TEMPSC<br>1 | SC4SL | - | SC1SL | SC0SL | | At reset | - | - | 0 | 0 | 0 | - | 0 | 0 | | Access | - | - | R/W | R/W | R/W | - | R/W | R/W | | bp | Flag | Description | |-----|----------------------------|-----------------------------------------------------------------------------------------------------| | 7-6 | - | - | | 5-4 | TEMPSC<br>2<br>TEMPSC<br>1 | Timer 2 output dividing switch 00:Timer 2 output 01:Timer2 output/2 10:Reserved 11:Timer 2 output/8 | | 3 | SC4SL | Serial port 4 I/O pin switch 0:A (Port A) 1:B (Port 3) | | 2 | - | - | | 1 | SC1SL | Serial port 1 I/O pin switch 0:A (Port A) 1:B (Port 1) | | 0 | SC0SL | Serial port 0 I/O pin switch 0:A (Port A) 1:B (Port 7) | # 4.2.3 Block Diagram Figure: 4.2.1 Block Diagram (P10) Figure:4.2.2 Block Diagram (P11) Figure: 4.2.3 Block Diagram (P12) Figure: 4.2.4 Block Diagram (P13) Figure:4.2.5 Block Diagram (P14) <sup>\*</sup> At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure:4.2.6 Block Diagram (P15) \* At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure:4.2.7 Block Diagram (P16) <sup>\*</sup> At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure:4.2.8 Block Diagram (P17) <sup>\*</sup> At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. # 4.3 Port 2 # 4.3.1 Description #### ■ General Port Setup P27 is reset pin. When the software is reset, write "0" to the bp7 of the port 2 output register (P2OUT). Also, P27 is always added pull-up resistor. ## 4.3.2 Registers Table: 4.3.1 shows the registers that control the port 2. Table:4.3.1 Port 2 Control Register | Registers | Address | R/W | Function | Page | |-----------|---------|-----|------------------------|-------| | P2OUT | 0x03F12 | R/W | Port 2 output register | IV-22 | #### R/W:Readable/Writable ■ Port 2 Output Register (P2OUT:0x03F12) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|---|---|---|---|---|---|---| | Flag | P2OUT7 | - | - | - | - | - | - | - | | At reset | 1 | - | - | - | - | - | - | - | | Access | R/W | - | - | - | - | - | - | - | | bp | Flag | Description | |---------------------------------|--------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P2OUT7 | Output data 0:Output L(VSS level) 1:Output H(VDD level) | # 4.3.3 Block Diagram Figure:4.3.1 Block Diagram (P27) # 4.4 Port 3 ## 4.4.1 Description #### ■ General Port Setup To output data to pin, set the control flag of the port 3 direction control register (P3DIR) to "1" and write the value of the port 3 output register (P3OUT). To read input data of pin, set the control flag of the port 3 direction control register (P3DIR) to "0" and read the value of the port 3 input register (P3IN). Each bit can be set individually as either an input or output by the port 3 I/O direction control register (P3DIR). The control flag of the port 3 direction control register (P3DIR) is set to "1" for output mode, and "0" for input mode. Each bit can be set individually if pull-up/pull-down resistor is added or not, by the port 3 pull-up/pull-down resistor control register (P3PLUD). Set the control flag of the port 3 pull-up/pull-down resistor control register (P3PLUD) to "1" to add pull-up resistor. Port 3 can be selected to add pull-up resistor or pull-down resistor by bp3 of the pull-up/pull-down resistor selection register (SELUD). For P32 and P33, each bit can be selected individually as Nch open-drain output by the port 3 Nch open-drain control register (P3ODC). The control flag of the port 3 Nch open-drain control register (P3ODC) is set to "1" for Nch open-drain output, and "0" for push-pull output. #### ■ Special Function Setup P31 is used as the serial 3 reception data input pin and IIC3 reception data input pin, as well. P32 is used as the serial 3 clock I/O pin, as well. When SC3SBTS flag of the serial interface 3 mode register 1 (SC3MD1) is "1", P32 is the serial clock output pin. Push-pull output or Nch open-drain output can be selected by setting the Port 3 Nch open-drain control register (P3ODC). P33 is used as the output pin of the serial 3 transmission data and IIC3 transmission data, as well. When SC3SBTS flag of the serial interface 3 mode register 1 (SC3MD1) is "1", P32 is the serial data output pin. Pushpull output or Nch open-drain output can be selected by setting the Port 3 Nch open-drain control register (P3ODC). P30 is used as the LCD common output pin COM0, as well. The COM0 pin selection can be done by setting the bit 0 flag (COMSL0) flag of the LCD output control register 1 (LCCTR1) to "1". At common output, it is forcefully set to input mode and pull-up resistor is disabled. P31 is used as the LCD common output pin COM1, as well. The COM1 pin selection can be done by setting the bit 1 flag (COMSL1) flag of the LCD output control register 1 (LCCTR1) to "1". At common output, it is forcefully set to input mode and pull-up resistor is disabled. P32 is used as the LCD common output pin COM2, as well. The COM2 pin selection can be done by setting the bit 2 flag (COMSL0) flag of the LCD output control register 1 (LCCTR1) to "1". At common output, it is forcefully set to input mode and pull-up resistor is disabled. P33 is used as the LCD common output pin COM3, as well. The COM3 pin selection can be done by setting the bit 3 flag (COMSL0) flag of the LCD output control register 1 (LCCTR1) to "1". At common output, it is forcefully set to input mode and pull-up resistor is disabled. P34 is used as voltage pin of the LCD driver circuit and VLC3, as well. The VLC3 pin selection can be done by setting the bit 2 flag (VLC3SL) of the LCD output control register 3 (LCCTR3) to "1". P35 is used as voltage pin of the LCD driver circuit and VLC3, as well. The VLC2 pin selection can be done by setting the bit 1 flag (VLC2SL) of the LCD output control register 3 (LCCTR3) to "1". P36 is used as voltage pin of the LCD driver circuit and VLC1, as well. The VLC1 pin selection can be done by setting the bit 0 flag (VLC1SL) of the LCD output control register 3 (LCCTR3) to "1". # 4.4.2 Registers Table:4.4.1 shows the registers that control the port 3. Table:4.4.1 Port 3 Control Register | Registers | Address | R/W | Function | Page | |-----------|---------|-----|-----------------------------------------------|-------| | P3OUT | 0x03F13 | R/W | Port 3 output register | IV-26 | | P3IN | 0x03F23 | R | Port 3 input register | IV-27 | | P3DIR | 0x03F33 | R/W | Port 3 direction control register | IV-27 | | P3PLUD | 0x03F43 | R/W | Port 3 pull-up/pull-down control register | IV-28 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-29 | | P3ODC | 0x03F3B | R/W | Port 3 Nch open-drain control register | IV-30 | | LCCTR1 | 0x03FC2 | R/W | LCD output control register 1 | IV-31 | | LCCTR3 | 0x03FC4 | R/W | LCD output control register 3 | IV-32 | #### R/W:Readable/Writable ■ Port 3 Output Register (P3OUT:0x03F13) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | P3OUT7 | P3OUT6 | P3OUT5 | P3OUT4 | P3OUT3 | P3OUT2 | P3OUT1 | P3OUT0 | | At reset | х | х | х | х | х | х | х | х | | Access | R/W | bp | Flag | Description | |---------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P3OUT7<br>P3OUT6<br>P3OUT5<br>P3OUT4<br>P3OUT3<br>P3OUT2<br>P3OUT1<br>P3OUT0 | Output data 0:Output L(VSS level) 1:Output H(VDD level) | ### ■ Port 3 Input Register (P3IN:0x03F23) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|-------|-------|-------|-------|-------|-------|-------| | Flag | P3IN7 | P3IN6 | P3IN5 | P3IN4 | P3IN3 | P3IN2 | P3IN1 | P3IN0 | | At reset | 1 | х | х | х | х | х | х | х | | Access | R | R | R | R | R | R | R | R | | bp | Flag | Description | |---------------------------------|----------------------------------------------------------------------|--------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P3IN7<br>P3IN6<br>P3IN5<br>P3IN4<br>P3IN3<br>P3IN2<br>P3IN1<br>P3IN0 | Input data 0:Pin is L(VSS level) 1:Pin is H(VDD level) | #### ■ Port 3 Direction Control Register (P3DIR:0x03F33) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | P3DIR7 | P3DIR6 | P3DIR5 | P3DIR4 | P3DIR3 | P3DIR2 | P3DIR1 | P3DIR0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |---------------------------------|------------------------------------------------------------------------------|-----------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P3DIR7<br>P3DIR6<br>P3DIR5<br>P3DIR4<br>P3DIR3<br>P3DIR2<br>P3DIR1<br>P3DIR0 | I/O mode selection 0:Input mode 1:Output mode | ### ■ Port 3 Pull-up Resistor Control Register (P3PLU:0x03F43) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | P3PLUD7 | P3PLUD6 | P3PLUD5 | P3PLUD4 | P3PLUD3 | P3PLUD2 | P3PLUD1 | P3PLUD0 | | At reset | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |---------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P3PLUD7<br>P3PLUD6<br>P3PLUD5<br>P3PLUD4<br>P3PLUD3<br>P3PLUD2<br>P3PLUD1<br>P3PLUD0 | Pull-up/pull-down resistor selection 0:Not added 1:Added | ## ■ Pull-up/pull-down Resistor Selection Register (SELUD:0x03F4B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|-------|-------|-------|-------|-------| | Flag | - | - | - | PADWN | P3DWN | P9DWN | P7DWN | P1DWN | | At reset | - | - | - | 1 | 1 | 1 | 0 | 0 | | Access | - | - | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |----|-------|-----------------------------------------------------------| | 7 | - | - | | 6 | - | - | | 5 | - | - | | 4 | PADWN | Port A Pull-up/pull-down selection 0:Pull-up 1:Pull-downd | | 3 | P3DWN | Port 3 Pull-up/pull-down selection 0:Pull-up 1:Pull-downd | | 2 | P9DWN | Port 9 Pull-up/pull-down selection 0:Pull-up 1:Pull-downd | | 1 | P7DWN | Port 7 Pull-up/pull-down selection 0:Pull-up 1:Pull-downd | | 0 | P1DWN | Port 1 Pull-up/pull-down selection 0:Pull-up 1:Pull-downd | ### ■ Port 3 Nch Open-drain Control Register (P3ODC:0x03F3B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|--------|--------|---|---| | Flag | - | - | - | - | P33ODC | P32ODC | - | - | | At reset | - | - | - | - | 0 | 0 | - | - | | Access | - | - | - | - | R/W | R/W | - | - | | bp | Flag | Description | |---------------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>-<br>-<br>-<br>-<br>P33ODC<br>P32ODC<br>-<br>- | Nch open-drain output selection<br>0:Push/pull output<br>1:Nch open drain output | ## ■ LCD output Control Register (LCCTR1:X'3FC2', R/W) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | LC1SL3 | LC1SL2 | LC1SL1 | LC1SL0 | COMSL3 | COMSL2 | COMSL1 | COMSL0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |----|--------|-----------------------------| | 7 | LC1SL3 | SEG3/P74<br>0:P74<br>1:SEG3 | | 6 | LC1SL2 | SEG2/P75<br>0:P75<br>1:SEG2 | | 5 | LC1SL1 | SEG1/P76<br>0:P74<br>1:SEG1 | | 4 | LC1SL0 | SEG0/P77<br>0:P77<br>1:SEG3 | | 3 | COMSL3 | COM3/P33<br>0:P33<br>1:COM3 | | 2 | COMSL2 | COM2/P32<br>0:P32<br>1:COM2 | | 1 | COMSL1 | COM1/P31<br>0:P31<br>1:COM1 | | 0 | COMSLO | COM0/P30<br>0:P30<br>1:COM0 | ## ■ LCD Output Control Register 3 (LCCTR3:X'3FC4', R/W) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|--------|--------|--------| | Flag | - | - | - | - | - | LC3SL2 | LC3SL1 | LC3SL0 | | At reset | - | - | - | - | - | 0 | 0 | 0 | | Access | - | - | - | - | - | R/W | R/W | R/W | | bp | Flag | Description | |-----|--------|-----------------------------| | 7-3 | - | - | | 2 | LC3SL2 | VLC3/P34<br>0:P34<br>1:VLC3 | | 1 | LC3SL1 | VLC2/P35<br>0:P35<br>1:VLC2 | | 0 | LC3SL0 | VLC1/P36<br>0:P36<br>1:VLC1 | ## 4.4.3 Block Diagram Figure:4.4.1 Block Diagram (P30) \* At common output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and common output is executed by the common output control. Figure: 4.4.2 Block Diagram (P31) $<sup>^{*}</sup>$ At common output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and common output is executed by the common output control. Figure: 4.4.3 Block Diagram (P32) <sup>\*</sup> At common output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and common output is executed by the common output control. Figure:4.4.4 Block Diagram (P33) \* At common output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and common output is executed by the common output control. Figure: 4.4.5 Block Diagram (P34) Figure: 4.4.6 Block Diagram (P35) Figure: 4.4.7 Block Diagram (P36) Figure: 4.4.8 Block Diagram (P37) # 4.5 Port 5 #### 4.5.1 Description #### ■ General Port Setup To output data to pin, set the control flag of the port 5 direction control register (P5DIR) to "1" and write the value of the port 5 output register (P5OUT). To read input data of pin, set the control flag of the port 5 direction control register (P5DIR) to "0" and read the value of the port 5 input register (P5IN). Each bit can be set individually as either an input or output by the port 5 I/O direction control register (P5DIR). The control flag of the port 5 direction control register (P5DIR) is set to "1" for output mode, and "0" for input mode. Each bit can be set individually if pull-up resistor is added or not, by the port 5 pull-up resistor control register (P5PLU). Set the control flag of the port 5 pull-up resistor control register (P5PLU) to "1" to add pull-up resistor. Each bit can be selected individually as output mode by the port 5 output mode regiser (P5OMD). The port 5 output mode register (P5OMD) is set to "1" to output the special function data, and "0" for the general port. #### ■ Special Function Pin Setup P50 is uses as output pin of the timer 0. The output mode can be selected by each bit by bp0 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" to output the special function data, and "0" for general port. P51 is uses as output pin of the timer 7. The output mode can be selected by each bit by bp1 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" to output the special function data, and "0" for general port. P52 is uses as output pin of the timer 2. The output mode can be selected by each bit by bp2 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" to output the special function data, and "0" for general port. P53 is uses as output pin of the timer 8. The output mode can be selected by each bit by bp3 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" to output the special function data, and "0" for general port. P54 is used as the external interrupt pin, as well. P55 is used as the external interrupt pin, as well. P56 is used as the external interrupt pin, as well. P54 is used as input pin of the AC zero-cross 0, as well. To read out the data of AC zero-cross, set the bp3 of the noise filter control register (NFCTR) to "1", and read out the value of port 5 input register (P5IN). P55 is used as input pin of the AC zero-cross 1, as well. To read out the data of AC zero-cross, set the bp7 of the noise filter control register (NFCTR) to "1", and read out the value of port 5 input register (P5IN). P50 is used as output pin of LED0, as well. Each bit can be selected as output mode by bp4 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" for output pin of large current (Nch-Tr.), and "0" to use as output pin of general current. The timer 0 output or the general port output can be set to large current with the combination of bp0 of the port 5 output mode register (P5OMD). P51 is used as output pin of LED1, as well. Each bit can be selected as output mode by bp5 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" for output pin of large current (Nch-Tr.), and "0" to use as output pin of general current. The timer 0 output or the general port output can be set to large current with the combination of bp1 of the port 5 output mode register (P5OMD). P52 is used as output pin of LED2, as well. Each bit can be selected as output mode by bp6 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" for output pin of large current (Nch-Tr.), and "0" to use as output pin of general current. The timer 0 output or the general port output can be set to large current with the combination of bp2 of the port 5 output mode register (P5OMD). P53 is used as output pin of LED3, as well. Each bit can be selected as output mode by bp7 of the port 5 output mode register (P5OMD). The port 5 output mode register (P5OMD) is set to "1" for output pin of large current (Nch-Tr.), and "0" to use as output pin of general current. The timer 0 output or the general port output can be set to large current with the combination of bp3 of the port 5 output mode register (P5OMD). # 4.5.2 Registers Table:4.5.1 shows the registers that control the port 5. Table:4.5.1 Port 5 Control Register | Registers | Address | R/W | Function | Page | |-----------|---------|-----|------------------------------------------|-------| | P5OUT | 0x03F15 | R/W | Port 5 output register | IV-41 | | P5IN | 0x03F25 | R | Port 5 input register | IV-42 | | P5DIR | 0x03F35 | R/W | Port 5 direction control register | IV-42 | | P5PLU | 0x03F45 | R/W | Port 5 pull-up resistor control register | IV-43 | | P5OMD | 0x03F2C | R/W | Port 5 output mode register | IV-44 | #### R/W:Readable/Writable ■ Port 5 output register (P5OUT:0x03F15) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|--------|--------|--------|--------|--------|--------|--------| | Flag | - | P5OUT6 | P5OUT5 | P5OUT4 | P5OUT3 | P5OUT2 | P5OUT1 | P5OUT0 | | At reset | - | х | х | х | х | х | х | х | | Access | - | R/W | bp | Flag | Description | |---------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>P5OUT6<br>P5OUT5<br>P5OUT4<br>P5OUT3<br>P5OUT2<br>P5OUT1<br>P5OUT0 | Output data 0:Output L(VSS level) 1:Output H(VDD level) | ### ■ Port 5 Input Register (P5IN:0x03F25) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|-------|-------|-------|-------|-------|-------|-------| | Flag | - | P5IN6 | P5IN5 | P5IN4 | P5IN3 | P5IN2 | P5IN1 | P5IN0 | | At reset | - | х | х | х | х | х | х | х | | Access | - | R | R | R | R | R | R | R | | bp | Flag | Description | |---------------------------------|------------------------------------------------------------------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>P5IN6<br>P5IN5<br>P5IN4<br>P5IN3<br>P5IN2<br>P5IN1<br>P5IN0 | Input data 0:Pin is L(VSS level) 1:Pin is H(VDD level)s | #### ■ Port 5 Direction Control Register (P5DIR:0x03F35) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|--------|--------|--------|--------|--------|--------|--------| | Flag | - | P5DIR6 | P5DIR5 | P5DIR4 | P5DIR3 | P5DIR2 | P5DIR1 | P5DIR0 | | At reset | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | - | R/W | bp | Flag | Description | |---------------------------------|-------------------------------------------------------------------------|-----------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>P5DIR6<br>P5DIR5<br>P5DIR4<br>P5DIR3<br>P5DIR2<br>P5DIR1<br>P5DIR0 | I/O mode selection 0:Input mode 1:Output mode | ### ■ Port 5 Pull-up Resistor Control Register (P5PLU:0x03F45) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|--------|--------|--------|--------|--------|--------|--------| | Flag | - | P5PLU6 | P5PLU5 | P5PLU4 | P5PLU3 | P5PLU2 | P5PLU1 | P5PLU0 | | At reset | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | - | R/W | bp | Flag | Description | |---------------------------------|-------------------------------------------------------------------------|----------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>P5PLU6<br>P5PLU5<br>P5PLU4<br>P5PLU3<br>P5PLU2<br>P5PLU1<br>P5PLU0 | Pull-up/pull-down resistor selection 0:Not added 1:Added | ### ■ Port 5 Output Mode Register (P5OMD:0x03F2C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | P5LED3 | P5LED2 | P5LED1 | P5LED0 | P5OMD3 | P5OMD2 | P5OMD1 | P5OMD0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |----|--------|-------------------------------------------------------------------| | 7 | P5LED3 | I/O port, LED3 selection 0:I/O port 1:LED3 (large current output) | | 6 | P5LED2 | I/O port, LED2 selection 0:I/O port 1:LED2 (large current output) | | 5 | P5LED1 | I/O port, LED1 selection 0:I/O port 1:LED1 (large current output) | | 4 | P5LED0 | I/O port, LED0 selection 0:I/O port 1:LED0 (large current output) | | 3 | P5OMD3 | I/O port, TM8O selection 0:I/O port 1:TM8O | | 2 | P5OMD2 | I/O port, TM2O selection 0:I/O port 1:TM2O | | 1 | P5OMD1 | I/O port, TM7O selection 0:I/O port 1:TM7O | | 0 | P5OMD0 | I/O port, TM0O selection 0:I/O port 1:TM0O | ## 4.5.3 Block Diagram Figure: 4.5.1 Block Diagram (P50) Figure: 4.5.2 Block Diagram (P51) Figure: 4.5.3 Block Diagram (P52) Figure: 4.5.4 Block Diagram (P53) Figure: 4.5.5 Block Diagram (P54) Figure: 4.5.6 Block Diagram (P55) Figure:4.5.7 Block Diagram (P56) ## 4.6 Port 7 #### 4.6.1 Description #### ■ General Port Setup To output data to pin, set the control flag of the port 7 direction control register (P7DIR) to "1" and write data to the port 7 output register (P7OUT). To read input data of pin, set the control flag of the port 7 direction control register (P7DIR) to "0" and read the value of the port 7 input register (P7IN). Each bit can be set individually to either an input or output by the port 7 direction control register (P7DIR). The control flag of the port 7 direction control register (P7DIR) is set to "1" for output mode, and "0" for input mode. Each bit can be set individually if pull-up/pull-down resistor is added or not, by the port 7 pull-up/pull-down resistor control register (P7PLUD). Set the control flag of the port 7 pull-up/pull-down resistor control register (P7PLUD) to "1" to add pull-up resistor. Port 7 can be selected to add pull-up resistor or pull-down resistor by bp1 of the pull-up/pull-down resistor selection register (SELUD). Each bit can be selected individually as output mode by the port 7 output mode register (P7OMD). The control flag of the port 7 output mode register (P7OMD) is set to "1" to output the special function data, and "0" to use as the general port. For P75, P76 and P77, each bit can be selected individually as Nch open-drain output by the port 7 Nch open-drain control register (P7ODC). The control flag of the port 7 Nch open-drain control register (P7ODC) is set to "1" for Nch open-drain output, and "0" for push-pull output. #### ■ Special Function Pin Setup P70 can be used as the timer 1 I/O pin, as well. Each bit can be selected individually as output mode by the bp0 of the port 7 output mode register (P7OMD). When the bp0 of the port 7 output mode register (P7OMD) is set to "1" for the special function data output, and "0" to use as the general port. P71 can be used as the timer 3 I/O pin, as well. Each bit can be selected individually as output mode by the bp1 of the port 7 output mode register (P7OMD). When the bp1 of the port 7 output mode register (P7OMD) is set to "1" for the special function data output, and "0" to use as the general port. P75 can be used as output pin of the serial 0 transmission data and UART0 transmission data, as well. When SC0SBOS flag of the serial interface 0 mode register 1 (SC0MD1) is set to "1", P75 is the serial data output pin. Push-pull output or Nch open-drain output can be selected by setting the port 7 Nch open-drain control register (P7ODC). P76 can be used as input pin of the serial 0 reception data and UART0 reception data, as well. P77 can be used as the serial 0 clock input pin, as well. When the SC0SBTS flag of the serial interface 0 mode register 1 (SC0MD1) is set to "1", P77 is the serial clock output pin. Push-pull output or Nch open-drain output can be selected by setting the port 7 Nch open-drain control register (P7ODC). P70 can be used as the key interrupt input pin, as well. P71 can be used as the key interrupt input pin, as well. P72 can be used as the key interrupt input pin, as well. P73 can be used as the key interrupt input pin, as well. P74 can be used as the key interrupt input pin, as well. P75 can be used as the key interrupt input pin, as well. P76 can be used as the key interrupt input pin, as well. P77 can be used as the key interrupt input pin, as well. P70 can be used as the LCD segment output pin, as well. The SEG7 pin selection can be done by setting the bp3 flag (LC2SL3) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P71 can be used as the LCD segment output pin, as well. The SEG6 pin selection can be done by setting the bp2 flag (LC2SL2) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P72 can be used as the LCD segment output pin, as well. The SEG5 pin selection can be done by setting the bp1 flag (LC2SL1) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P73 can be used as the LCD segment output pin, as well. The SEG4 pin selection can be done by setting the bp0 flag (LC2SL0) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P74 can be used as the LCD segment output pin, as well. The SEG3 pin selection can be done by setting the bp7 flag (LC1SL3) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P75 can be used as the LCD segment output pin, as well. The SEG2 pin selection can be done by setting the bp6 flag (LC1SL2) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P76 can be used as the LCD segment output pin, as well. The SEG1 pin selection can be done by setting the bp5 flag (LC1SL1) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P77 can be used as the LCD segment output pin, as well. The SEG0 pin selection can be done by setting the bp4 flag (LC1SL0) of the LCD output control register 2 (LCCTR2) to "1". Port/segment switching can be selected by 2 bits. At segment output, it is forcefully set to input mode and pull-up resistor is disabled. P76 can be used as the IIC4 transmission/reception data I/O pin, as well. When SELI2C flag of the serial interface 4 addressing register 1 is set to "1", P76 is the serial data I/O pin. Push-pull output or Nch open-drain output can be selected by setting the port 7 Nch open-drain control register (P7ODC). P77 can be used as the serial 4 clock I/O pin, as well. When SELI2C flag of the serial interface 4 addressing register 1 (SC4AD1) is set to "1", P77 is the serial clock I/O pin. Push-pull output or Nch open-drain output can be selected by setting the port 7 Nch open-drain control register (P7ODC). Serial 0 I/O pin can be selected as PA0 to PA2, or P75 to P77 by setting the serial selection register (SCSEL). When the SC0SL flag of the serial selection register (SCSEL) is set to "0", PA0 to PA2 are selected, to "1", P75 to P77 are selected. For serial 4 I/O pin, when the serial selection register (SCSEL) is "0" for P10, P11, "1" for P76, P77. # 4.6.2 Registers Table: 4.6.1 shows the registers that control the port 7. Table:4.6.1 Port 7 Control Register | Registers | Address | R/W | Function | Page | |-----------|---------|-----|----------------------------------------------------|-------| | P7OUT | 0x03F17 | R/W | Port 7output register | IV-51 | | P7IN | 0x03F27 | R | Port 7 input register | IV-52 | | P7DIR | 0x03F37 | R/W | Port 7 direction control register | IV-52 | | P7PLUD | 0x03F47 | R/W | Port 7 pull-up/pull-down resistor control register | IV-53 | | P7OMD | 0x03F3C | R/W | Port 7 output mode register | IV-53 | | P7ODC | 0x03F1D | R/W | Port 7 Nch open-drain control register | IV-54 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor control register | IV-54 | | SCSEL | 0x03F90 | R/W | Serial I/O pin switching control register | IV-55 | | LCCTR1 | 0x03FC2 | R/W | LCD output control register 1 | IV-56 | | LCCTR2 | 0x03FC3 | R/W | LCD output control register 2 | IV-57 | #### R/W:Readable/Writable ■ Port 7 output register (P7OUT:0x03F17) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | P7OUT7 | P7OUT6 | P7OUT5 | P7OUT4 | P7OUT3 | P7OUT2 | P7OUT1 | P7OUT0 | | At reset | х | х | х | х | х | х | х | х | | Access | R/W | bp | Flag | Description | |---------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P7OUT7<br>P7OUT6<br>P7OUT5<br>P7OUT4<br>P7OUT3<br>P7OUT2<br>P7OUT1<br>P7OUT0 | Output data 0:Output L(VSS level) 1:Output H(VDD level) | ## ■ Port 7 Input Register (P7IN:0x03F27) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|-------|-------|-------|-------|-------|-------|-------| | Flag | P7IN7 | P7IN6 | P7IN5 | P7IN4 | P7IN3 | P7IN2 | P7IN1 | P7IN0 | | At reset | х | х | х | х | х | х | х | х | | Access | R | R | R | R | R | R | R | R | | bp | Flag | Description | |---------------------------------|----------------------------------------------------------------------|--------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P7IN7<br>P7IN6<br>P7IN5<br>P7IN4<br>P7IN3<br>P7IN2<br>P7IN1<br>P7IN0 | Input data 0:Pin is L(VSS level) 1:Pin is H(VDD level) | #### ■ Port 7 Direction Control Register (P7DIR:0x03F37) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | P7DIR7 | P7DIR6 | P7DIR5 | P7DIR4 | P7DIR3 | P7DIR2 | P7DIR1 | P7DIR0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |---------------------------------|------------------------------------------------------------------------------|-----------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P7DIR7<br>P7DIR6<br>P7DIR5<br>P7DIR4<br>P7DIR3<br>P7DIR2<br>P7DIR1<br>P7DIR0 | I/O mode selection 0:Input mode 1:Output mode | ### ■ Port 7 Pull-up/pull-down Resistor Control Register (P7PLUD:0x03F47) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | P7PLUD7 | P7PLUD6 | P7PLUD5 | P7PLUD4 | P7PLUD3 | P7PLUD2 | P7PLUD1 | P7PLUD0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |---------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P7PLUD7<br>P7PLUD6<br>P7PLUD5<br>P7PLUD4<br>P7PLUD3<br>P7PLUD2<br>P7PLUD1<br>P7PLUD0 | Pull-up/pull-down resistor selection 0:Not added 1:Added | #### ■ Port 7 Output Mode Register (P7OMD:0x03F3C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|--------|--------| | Flag | - | - | - | - | - | - | P7OMD1 | P7OMD0 | | At reset | - | - | - | - | - | - | 0 | 0 | | Access | - | - | - | - | - | - | R/W | R/W | | bp | Flag | Description | |-----|--------|----------------------------------------------| | 7-2 | - | - | | 1 | P7OMD1 | I/O port, TM3IO selection 0:I/O port 1:TM3IO | | 0 | P7OMD0 | I/O port, TM1IO selection 0:I/O port 1:TM1IO | ### ■ Port 7 Nch Open-drain Control Register (P7ODC:0x03F1D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|---|---|---|---|---| | Flag | P77ODC | P76ODC | P75ODC | - | - | - | - | - | | At reset | 0 | 0 | 0 | - | - | - | - | - | | Access | R/W | R/W | R/W | - | - | - | - | - | | bp | Flag | Description | |---------------------------------|---------------------------------------------------|----------------------------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | P7PLUD7<br>P7PLUD6<br>P7PLUD5<br>-<br>-<br>-<br>- | Nch open-drain output selection 0:Push-pull output 1:Nch open-drain output | #### ■ Pull-up/pull-down Resistor Selection Register (SELUD:0x03F4B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|-------|-------|-------|-------|-------| | Flag | - | - | - | PADWN | P3DWN | P9DWN | P7DWN | P1DWN | | At reset | - | - | - | 1 | 1 | 1 | 0 | 0 | | Access | - | - | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |----|-------|----------------------------------------------------------| | 7 | - | - | | 6 | - | - | | 5 | - | - | | 4 | PADWN | Port A pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 3 | P3DWN | Port 3 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 2 | P9DWN | Port 9 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 1 | P7DWN | Port 7 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 0 | P1DWN | Port 1 pull-up/pull-down selection 0:Pull-up 1:Pull-down | ### ■ Serial I/O Pin Switching Control Register (SCSEL:0x03F90) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------------|---------|-------------|--------|-------|-----|-------|-------| | Flag | TMPSC1<br>2 | TMPSC11 | TMPSC0<br>2 | TMPSC0 | SC4SL | - | SC1SL | SC0SL | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|----------------------------|---------------------------------------------------------------------------------------------------------------------| | 7-6 | TMPSC1<br>2<br>TMPSC11 | Serial 1 used timer 2 output dividing switching selection X0:Timer 2 output 01:Timer 2 output/2 11:Timer 2 output/8 | | 5-4 | TMPSC0<br>2<br>TMPSC0<br>1 | Serial 0 used timer 2 output dividing switching selection X0:Timer 2 output 01:Timer 2 output/2 11:Timer 2 output/8 | | 3 | SC4SL | Serial 4 I/O pin switching selection<br>0:P10, P11<br>1:P76, P77 | | 2 | - | - | | 1 | SC1SL | Serial 1 I/O pin switching selection<br>0:P15 to P17<br>1:PA4 to PA6 | | 0 | SC0SL | Serial 0 I/O pin switching selection<br>0:PA0 to PA2<br>1:P75 to P77 | ## ■ LCD Output Control Register 1 (LCCTR1:X'3FC2', R/W) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | LC1SL3 | LC1SL2 | LC1SL1 | LC1SL0 | COMSL3 | COMSL2 | COMSL1 | COMSL0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |----|--------|---------------------------------------| | 7 | LC1SL3 | SEG3/P74 selection<br>0:P74<br>1:SEG3 | | 6 | LC1SL2 | SEG2/P75 selection<br>0:P75<br>1:SEG2 | | 5 | LC1SL1 | SEG1/P76 selection<br>0:P76<br>1:SEG1 | | 4 | LC1SL0 | SEG0/P77 selection<br>0:P77<br>1:SEG0 | | 3 | COMSL3 | COM3/P33 selection<br>0:P33<br>1:COM3 | | 2 | COMSL2 | COM2/P32 selection<br>0:P32<br>1:COM2 | | 1 | COMSL1 | COM1/P31 selection<br>0:P31<br>1:COM1 | | 0 | COMSLO | COM0/P30 selection<br>0:P30<br>1:COM0 | ## ■ LCD Output Control Register 2 (LCCTR2:X'3FC3', R/W) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | LC2SL7 | LC2SL6 | LC2SL5 | LC2SL4 | LC2SL3 | LC2SL2 | LC2SL1 | LC2SL0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |----|--------|-----------------------------------------| | 7 | LC2SL7 | SEG11/P14 selection 0:P14 1:SEG11 | | 6 | LC2SL6 | SEG10/P15 selection<br>0:P15<br>1:SEG10 | | 5 | LC2SL5 | SEG9/P16 selection 0:P16 1:SEG9 | | 4 | LC2SL4 | SEG8/P17 selection 0:P17 1:SEG8 | | 3 | LC2SL3 | SEG7/P70 selection<br>0:P70<br>1:SEG7 | | 2 | LC2SL2 | SEG6/P71 selection<br>0:P71<br>1:SEG6 | | 1 | LC2SL1 | SEG5/P72 selection<br>0:P72<br>1:SEG5 | | 0 | LC2SL0 | SEG4/P73 selection<br>0:P73<br>1:SEG4 | ## 4.6.3 Block Diagram Figure: 4.6.1 Block Diagram (P70) \* At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure: 4.6.2 Block Diagram (P71) \* At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure: 4.6.3 Block Diagram (P72) \* At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure: 4.6.4 Block Diagram (P73) \* At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure: 4.6.5 Block Diagram (P74) $^{*}$ At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure: 4.6.6 Block Diagram (P75) \* At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure: 4.6.7 Block Diagram (P76) $^{*}$ At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. Figure: 4.6.8 Block Diagram (P77) \* At segment output, port I/O direction control is forcefully set to input mode, pull-up resistor is disabled and segment output is executed by the segment output control. # 4.7 Port 9 ### 4.7.1 Description ### ■ General Port Setup To output data to pin, set the control flag of the port 9 direction control register (P9DIR) to "1" and write data to the port 9 output register (P9OUT). To read input data of pin, set the control flag of the port 9 direction control register (P9DIR) to "0" and read the value of the port 9 input register (P9IN). Each bit can be set individually to either an input or output by the port 9 direction control register (P9DIR). The control flag of the port 9 direction control register (P9DIR) is set to "1" for output mode, and "0" for input mode. Each bit can be set individually if pull-up/pull-down resistor is added or not, by the port 9 pull-up/pull-down resistor control register (P9PLU). Set the control flag of the port 9 pull-up/pull-down resistor control register (P9PLU) to "1" to add pull-up resistor. Pull-up resistor or pull-down resistor can be added to port 9 by setting the bp2 flag of the pull-up/pull-down resistor selection resister (SELUD). ### ■ Special Function Pin Setup P90 can be used as low-speed oscillation, as well. When the XISEL flag of the low-speed oscillation selection register (XSEL) is set to "1", P90 can be used as low-speed oscillation. # 4.7.2 Registers Table:4.7.1 shows the registers that control the port 9. Table:4.7.1 Port 9 Control Register | Registers | Address | R/W | Function | Page | |-----------|---------|-----|----------------------------------------------------|-------| | P9OUT | 0x03F19 | R/W | Port 9 output register | IV-67 | | P9IN | 0x03F29 | R | Port 9 input register | IV-68 | | P9DIR | 0x03F39 | R/W | Port 9 direction control register | IV-68 | | P9PLUD | 0x03F49 | R/W | Port 9 pull-up/pull-down resistor control register | IV-69 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-69 | | XSEL | 0x03F4C | R/W | Port 9 oscillation switching register | IV-70 | ### R/W:Readable/Writable ■ Port 9 output register (P9OUT:0x03F19) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|---|--------| | Flag | - | - | - | - | - | - | - | P9OUT0 | | At reset | - | - | - | - | - | - | - | х | | Access | - | - | - | - | - | - | - | R/W | | bp | Flag | Description | |---------------------------------|-----------------------------------------------------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>P9OUT0 | Output data 0:Output L(VSS level) 1:Output H(VDD level) | ## ■ Port 9 Input Register (P9IN:0x03F29) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|---|-------| | Flag | - | - | - | - | - | - | - | P9IN0 | | At reset | - | - | - | - | - | - | - | 0 | | Access | - | - | - | - | - | - | - | R//W | | bp | Flag | Description | |---------------------------------|------------------------------------------|--------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>-<br>-<br>-<br>-<br>-<br>-<br>P9IN0 | Input data 0:Pin is L(VSS level) 1:Pin is H(VDD level) | ### ■ Port 9 Direction Control Register (P9DIR:0x03F39) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|---|--------| | Flag | - | - | - | - | - | - | - | P9DIR0 | | At reset | - | - | - | - | - | - | - | 0 | | Access | - | - | - | - | - | - | - | R/W | | bp | Flag | Description | |---------------------------------|-----------------------------------------------------|-----------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>P9DIR0 | I/O mode selection 0:Input mode 1:Output mode | ## ■ Port 9 Pull-up/pull-down Resistor Control Register (P9PLUD:0x03F49) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|---|---------| | Flag | - | - | - | - | - | - | - | P9PLUD0 | | At reset | - | - | - | - | - | - | - | 1 | | Access | - | - | - | - | - | - | - | R/W | | bp | Flag | Description | |---------------------------------|-------------------------------------------------|----------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>P9PLUD0 | Pull-up/pull-down resistor selection 0:Not added 1:Added | ### ■ Pull-up/pull-down Resistor Selection Register (SELUD:0x03F4B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|-------|-------|-------|-------|-------| | Flag | - | - | - | PADWN | P3DWN | P9DWN | P7DWN | P1DWN | | At reset | - | - | - | 1 | 1 | 1 | 0 | 0 | | Access | - | - | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |----|-------|----------------------------------------------------------| | 7 | - | - | | 6 | - | - | | 5 | - | - | | 4 | PADWN | Port A pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 3 | P3DWN | Port 3 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 2 | P9DWN | Port 9 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 1 | P7DWN | Port 7 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 0 | P1DWN | Port 1 pull-up/pull-down selection 0:Pull-up 1:Pull-down | # ■ Port 9 Oscillation Switching Register (XSEL:0x03F4C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|---|------| | Flag | - | - | - | - | - | - | - | XSEL | | At reset | - | - | - | - | - | - | - | 0 | | Access | - | - | - | - | - | - | - | R/W | | bp | Flag | Description | |-----|------|------------------------------------------------------------------| | 7-1 | - | - | | 0 | - | XI dual-purpose selection 0:P90 1:low-speed oscillation input XI | # 4.7.3 Block Diagram Figure: 4.7.1 Block Diagram (P90) # 4.8 Port A ### 4.8.1 Description #### ■ General Pin Setup To output data to pin, set the control flag of the port A direction control register (PADIR) to "1" and write data to the port 8 output register (PAOUT). To read input data of pin, set the control flag of the port A direction control register (PADIR) to "0" and read the value of the port A input register (PAIN). Each bit can be set individually to either an input or output by the port A direction control register (PADIR). The control flag of the port A direction control register (PADIR) is set to "1" for output mode, and "0" for input mode. Each bit can be set individually if pull-up/pull-down resistor is added or not, by the port A pull-up/pull-down resistor control register (PAPLUD). Set the control flag of the port A pull-up/pull-down resistor control register (PAPLUD) to "1" to add pull-up/pull-down resistor. The bp4 of the pull-up/pull-down resistor selection register (SELUD) select if pull-up resistor or pull-down resistor is added. Each bit can be selected individually as input mode by the portA input mode register (PAIMD). The control flag of the portA input mode register (PAIMD) is set to "1" to input the special function data and 1 is read out from the portA input register (PAIN), and "0" to use as the general port. For PAO, PA2, PA5 and PA6, each bit can be selected individually as Nch open-drain output by the port A Nch open-drain control register (PAODC). When the port A Nch open-drain control register (PAODC) is set to "1" for Nch open-drain output and to "0" for push-pull output. #### ■ Special Function Pin Setup PA0 is used as ouput pin of the serial 0 transmission data and UART0 transmission data, as well. When the SC0SBOS flag of the serial interface 0 mode register 1 (SC0MD1) is set to "1", PA0 is the serial data output pin. Push-pull output or Nch open-drain output can be selected by setting the port A Nch open-drain control register (PAODC). PA1 can be used as input pin of the serial 0 reception data and UART0 reception data, as well. PA2 can be used as the serial 0 clock I/O pin, as well. When the SC0SBTS flag of the serial interface 0 mode register 1 (SC0MD1) is set to "1", PA2 is the serial clock output pin. Push-pull output or Nch open-drain output can be selected by setting the port A Nch open-drain control register (PAODC). PA4 can be used as input pin of the serial 1 reception data and UART1 reception data, as well. PA5 is used as ouput pin of the serial 1 transmission data and UART1 transmission data, as well. When the SC1SBOS flag of the serial interface 1 mode register 1 (SC1MD1) is set to "1", PA5 is the serial data output pin. Push-pull output or Nch open-drain output can be selected by setting the port A Nch open-drain control register (PAODC). PA6 can be used as the serial 1 clock I/O pin, as well. When the SC1SBOS flag of the serial interface1 mode register 1 (SC1MD1) is set to "1", PA2 is the serial clock output pin. Push-pull output or Nch open-drain output can be selected by setting the port A Nch open-drain control register (PAODC). PAO is used as input pin for analog, as well. Each bit can be set individually as an input by the port A input mode register (PAIMD). When it is used as analog input pin, set the port A input mode register to "1". Then, the value of the port A input register is read to be "1". PA1 is used as input pin for analog, as well. Each bit can be set individually as an input by the port A input mode register (PAIMD). When it is used as analog input pin, set the port A input mode register to "1". Then, the value of the port A input register is read to be "1". PA2 is used as input pin for analog, as well. Each bit can be set individually as an input by the port A input mode register (PAIMD). When it is used as analog input pin, set the port A input mode register to "1". Then, the value of the port A input register is read to be "1". PA3 is used as input pin for analog, as well. Each bit can be set individually as an input by the port A input mode register (PAIMD). When it is used as analog input pin, set the port A input mode register to "1". Then, the value of the port A input register is read to be "1". PA4 is used as input pin for analog, as well. Each bit can be set individually as an input by the port A input mode register (PAIMD). When it is used as analog input pin, set the port A input mode register to "1". Then, the value of the port A input register is read to be "1". PA5 is used as input pin for analog, as well. Each bit can be set individually as an input by the port A input mode register (PAIMD). When it is used as analog input pin, set the port A input mode register to "1". Then, the value of the port A input register is read to be "1". PA6 is used as input pin for analog, as well. Each bit can be set individually as an input by the port A input mode register (PAIMD). When it is used as analog input pin, set the port A input mode register to "1". Then, the value of the port A input register is read to be "1". Serial 0 I/O pin can be selected to either PA0 to PA2 or P75 to P77. When the SC0SL flag of the serial selection register (SCSEL) is set to "0", PA0 to PA2 are selected, to "1", P75 to P77 are selected. For serial 1 I/O pin, either P15 to P17 or PA4 to PA6 can be selected by setting the serial selection register (SCSEL). When the SC1SL flag of the serial selection register (SCSEL) is set to "0" for P15 to P17, to "1" for PA4 to PA6. # 4.8.2 Registers Table:4.8.1 shows the registers that control the port A. Table:4.8.1 Port A Output Control Register | Registers | Address | R/W | Function | Page | |-----------|---------|-----|----------------------------------------------------|-------| | PAOUT | 0x03F1A | R/W | Port A output register | IV-74 | | PAIN | 0x03F2A | R | Port A input register | IV-75 | | PADIR | 0x03F3A | R/W | Port A direction control register | IV-75 | | PAPLUD | 0x03F4A | R/W | Port A pull-up/pull-down resistor control register | IV-76 | | SELUD | 0x03F4B | R/W | Pull-up/pull-down resistor selection register | IV-77 | | PAIMD | 0x03F4E | R/W | Port A input mode register | IV-76 | | PAODC | 0x03F2D | R/W | Port A Nch open-drain control register | IV-77 | ### R/W: Readable/Writable ■ Port A output register (PAOUT:0x03F1A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|--------|--------|--------|--------|--------|--------|--------| | Flag | - | PAOUT6 | PAOUT5 | PAOUT4 | PAOUT3 | PAOUT2 | PAOUT1 | PAOUT0 | | At reset | - | х | х | х | х | х | х | Х | | Access | - | R/W | bp | Flag | Description | |---------------------------------|--------------------------------------------------|---------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | PAOUT6 PAOUT5 PAOUT4 PAOUT3 PAOUT2 PAOUT1 PAOUT0 | Output data 0:Output L(VSS level) 1:Output H(VDD level) | ## ■ Port A Input Register (PAIN:0x03F2A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|-------|-------|-------|-------|-------|-------|-------| | Flag | - | PAIN6 | PAIN5 | PAIN4 | PAIN3 | PAIN2 | PAIN1 | PAIN0 | | At reset | - | 1 | 1 | 1 | х | х | х | х | | Access | - | R | R | R | R | R | R | R | | bp | Flag | Description | |---------------------------------|-------------------------------------------|--------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | PAIN6 PAIN5 PAIN4 PAIN3 PAIN2 PAIN1 PAIN0 | Input data 0:Pin is L(VSS level) 1:Pin is H(VDD level) | ### ■ Port A Direction Control Register (PADIR:0x03F3A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|--------|--------|--------|--------|--------|--------|--------| | Flag | - | PADIR6 | PADIR5 | PADIR4 | PADIR3 | PADIR2 | PADIR1 | PADIR0 | | At reset | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | - | R/W | bp | Flag | Description | |---------------------------------|----------------------------------------------------------------------|-----------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | - PADIR6<br>PADIR5<br>PADIR4<br>PADIR3<br>PADIR2<br>PADIR1<br>PADIR0 | I/O mode selection 0:Input mode 1:Output mode | ## ■ Port A Pull-up/pull-down Resistor Control Register (PAPLUD:0x03F4A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---------|---------|---------|---------|---------|---------|---------| | Flag | - | PAPLUD6 | PAPLUD5 | PAPLUD4 | PAPLUD3 | PAPLUD2 | PAPLUD1 | PAPLUD0 | | At reset | - | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | Access | - | R/W | bp | Flag | Description | |---------------------------------|--------------------------------------------------------------------------------|----------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | -<br>PAPLUD6<br>PAPLUD5<br>PAPLUD4<br>PAPLUD3<br>PAPLUD2<br>PAPLUD1<br>PAPLUD0 | Pull-up/pull-down resistor selection 0:Not added 1:Added | ### ■ Port A Input Mode Register (PAIMD:0x03F4E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|--------|--------|--------|--------|--------|--------|--------| | Flag | - | PAIMD6 | PAIMD5 | PAIMD4 | PAIMD3 | PAIMD2 | PAIMD1 | PAIMD0 | | At reset | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | - | R/W | bp | Flag | Description | |---------------------------------|----------------------------------------------------------------------|--------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | - PAIMD6<br>PAIMD5<br>PAIMD4<br>PAIMD3<br>PAIMD2<br>PAIMD1<br>PAIMD0 | Analog input selection 0:I/O port 1:Analog input | ## ■ Port A Nch Open-drain Control Register (PAODC:0x03F2D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|--------|--------|---|---|--------|---|--------| | Flag | - | PAODC6 | PAODC5 | - | - | PAODC2 | - | PAODC0 | | At reset | - | 0 | 0 | - | - | 0 | - | 0 | | Access | - | R/W | R/W | - | - | R/W | - | R/W | | bp | Flag | Description | |---------------------------------|-----------------------------|----------------------------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1 | PAODC6 PAODC5 PAODC2 PAODC0 | Nch open-drain output selection 0:Push-pull output 1:Nch open-drain output | ### ■ Pull-up/pull-down Resistor Selection Register (SELUD:0x03F4B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|-------|-------|-------|-------|-------| | Flag | - | - | - | PADWN | P3DWN | P9DWN | P7DWN | P1DWN | | At reset | - | - | - | 1 | 1 | 1 | 0 | 0 | | Access | - | - | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |----|-------|----------------------------------------------------------| | 7 | - | - | | 6 | - | - | | 5 | - | - | | 4 | PADWN | Port A pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 3 | P3DWN | Port 3 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 2 | P9DWN | Port 9 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 1 | P7DWN | Port 7 pull-up/pull-down selection 0:Pull-up 1:Pull-down | | 0 | P1DWN | Port 1 pull-up/pull-down selection 0:Pull-up 1:Pull-down | # 4.8.3 Block Diagram Figure: 4.8.1 Block Diagram (PA0) Figure: 4.8.2 Block Diagram (PA1) Figure: 4.8.3 Block Diagram (PA2) Figure: 4.8.4 Block Diagram (PA3) Figure:4.8.5 Block Diagram (PA4) Figure: 4.8.6 Block Diagram (PA5) Figure: 4.8.7 Block Diagram (PA6) # 4.9 Real Time Output Control P12, P14, P16 have the real time output function that can switch pin output at the falling edge event of the external interrupt 0 pin (P54/IRQ0). The real time control is the function that can change the timer output signal (PWM output, timer pulse output, remote control career output) synchronized with the external event without the interposition. Switchable output values at the event generation are "0", "1", "Hi-impedance (Hi-z)". ### 4.9.1 Registers Table: 4.9.1 shows the real time output control registers of port 1. Table: 4.9.1 Real Time Output Control Registers | | Register | Address | R/<br>W | Function | Page | |--------|----------|---------|---------|----------------------------------------------------|-------| | Port 1 | P1OUT | 0x03F11 | R/<br>W | Port 1 output register | IV-7 | | | P1DIR | 0x03F31 | R/<br>W | Port 1 direction control register | IV-8 | | | P1PLUD | 0x03F41 | R/<br>W | Port 1 pull-up/pull-down resistor control register | IV-9 | | | P1OMD | 0x03F39 | R/<br>W | Pull-up/pull-down resistor selection register | IV-9 | | | P1CNT0 | 0x03F3D | R/<br>W | Port 1 real time output control register | IV-11 | ## 4.9.2 Operation ### ■ Real Time Output Pin Setup The real time output pin setup should be done at the port 1 output control register (P1CNTO). Selectable pins are P12, P14, P16 and each of them can be specified by each bit. The output mode should be selected at the port 1 direction control register (P1DIR). The pin output that is switched at the falling edge event of the external interrupt 0 pin (P54/IRQ0) is "0", "1", "Hi-impedance". Port is input mode at the hi-impedance. The real time control is the function that changes the timer output signal (PWM output, timer pulse output remote control career output) synchronized with the external event. It is also available to normal port output. When I/O port (real time control disabled) is selected at the port 1 output control register (P1CNT0), if switching event is generated, the value is not be changed. Set this mode when it is used as the general port. #### ■ Real Time Output Control Operation After the setup of the port 1 output control register (P1CNT0), selected function at the port 1 output mode register (P1OMD) is output to the pin until the falling edge is generated at the external interrupt 0 pin (P54/IRQ0). When the falling edge is generated, pin output is switched to the set value. The falling edge event is taken in the edge event hold function that is shown below and the setup value of the port 1 output control register (P1CNT0) is held until that information is cleared. ■ Real Time Output Release (Clearance of edge event hold function) After the event generation, when the write operation is done to the port 1 output register (P1OUT), the information of the edge event hold function is cleared and all output pins are reset to the output data before the event generation. The event is generated again, it is switched to the setup value of the port 1 output control register (P1CNT0). When the real time control is canceled, set the port 1 output control register (P1CNT0) to I/O port (real time control disabled). Regardless of the setup at the external interrupt 0 control register (IRQ0ICR), valid edge of IRQ0 is only the falling edge. When the real time output control function is used, writing operation should be done to the port 1 output register (P1OUT) in advance and clear the information of the edge event hold function. ### ■ Timing of Real Time Output Control P1CNT0 setvalue:"0" (Low) output Figure: 4.9.1 Timing of Real Time Output Control Chapter 4 I/O Ports # 5.1 Overview This LSI contains one general purpose 8-bit timers (Timer 0) and three 8-bit timers combined baud rate timers (Timer 1, Timer 2, Timer 3). Timer 0 and timer 1 or timer 2 and timer 3 can be used as 16-bit timer with cascade connection. In a cascade connection, timer 0 and timer 2 form the "timer 0", or the lower 8 bits of 16-bit counter, and timer 1 and timer 3 form the "timer 1", or the upper 8 bits. 8-bit timer contains two prescalers which can use at the same time. Each prescaler counts fosc, fs as the base clock. Configurations of hard ware are shown below. Prescaler 0 (fosc base) 7 bits Prescaler Prescaler 1 (fs base) 3 bits Prescaler Prescaler 0 outputs fosc/4, fosc/16, fosc/32, fosc/64, fosc/128. Prescaler 1 outputs fs/2, fs/4, fs/8. Fosc or fs can be selected as the clock source for each timer by using the prescaler. ### 5.1.1 Functions Table:5.1.1 shows functions that can be used with each timer. Table:5.1.1 Timer Functions | | 1 | 1 | | | |------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------| | | Timer 0<br>(8-bit) | Timer 1<br>(8-bit) | Timer 2<br>(8-bit) | Timer 3<br>(8-bit) | | Interrupt source | TM0IRQ | TM1IRQ | TM2IRQ | TM3IRQ | | Timer operation | О | О | О | 0 | | Event count | TM0IO input<br>(P14) | TM1IO input<br>(P70) | TM2IO input<br>(P16) | TM3IO input<br>(P71) | | Timer pulse output | TM0IO output<br>(P14) | TM1IO output<br>(P70) | TM2IO output<br>(P16) | TM3IO output<br>(P71) | | PWM output | TM0IO output pin (P14) | - | TM2IO output pin<br>(P16) | - | | Additional pulse method PWM output | 0 | - | 0 | - | | Timer output to large current pin | TM0OA output pin<br>(P50I | - | TM2OA output pin (P52) | - | | Serial transfer clock output | - | Serial 0 | Serial 0, 2 | Serial 2 | | Pulse width measurement | External interrupt 0 (P54/IRQ0) | - | External interrupt 2 (P56/IRQ2) | - | | Cascade connection | 0 | 1 | О | , | | Clock source | fosc<br>fosc/4<br>fosc/16<br>fosc/32<br>fosc/64<br>fs/2<br>fs/4<br>fx<br>TM0IO input | fosc<br>fosc/4<br>fosc/16<br>fosc/64<br>fosc/128<br>fs/2<br>fs/8<br>fx<br>TM1IO input | fosc<br>fosc/4<br>fosc/16<br>fosc/32<br>fosc/64<br>fs/2<br>fs/4<br>fx<br>TM2IO input | fosc<br>fosc/4<br>fosc/16<br>fosc/64<br>fosc/128<br>fs/2<br>fs/8<br>fx<br>TM3IO input | fosc:Machine clock (High frequency oscillation) fx:Machine clock (Low frequency oscillation) - -When timer 3 is used as a baud rate timer for serial function, it cannot be uses as a general timer. - -Pulse width measurement function is not available at cascade connection (16-bit counter). - -At cascade connection (16-bit counter), when the clock source is fx and TMnIO input is selected, set the synchronous fx and synchronous TMnIO input. This function is not available when clock source is fx and TMnIO input is selected at cascade connection. fs:System clock [Chapter 2. 2.5 Clock Switching] # 5.1.2 Block Diagram ### ■ Prescaler Block Diagram Figure:5.1.1 Prescaler Block Diagram ### ■ Timer 0 and 1 Block Diagram Figure:5.1.2 Timer 0 and 1 Block Diagram ### ■ Timer 2 and 3 Block Diagram Figure:5.1.3 Timer 2 and 3 Block Diagram # 5.2 Control Registers Timer 0 to 3 consist of the binary counter (TMnBC) and the compare register (TMnOC). And they are controlled by the mode register (TMnMD). When the prescaler output is selected as the count clock source of timer 0 to 3, they should be controlled by the prescaler selection register (CKnMD). # 5.2.1 Registers Table:5.2.1 shows registers that control timer 0 to timer 3. Table:5.2.1 8-bit Timer Control Registers | | Register | Address | R/W | Function | Page | |---------|----------|---------|-----|--------------------------------------|--------| | Timer 0 | TM0BC | 0x03F50 | R | Timer 0 binary counter | V-13 | | | TM0OC | 0x03F52 | R/W | Timer 0 compare register | V-12 | | | TM0MD | 0x03F54 | R/W | Timer 0 mode register | V-14 | | | CK0MD | 0x03F56 | R/W | Timer 0 prescaler selection register | V-9 | | | TM0ICR | 0x03FE7 | R/W | Timer 0 interrupt control register | III-24 | | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | | P5OMD | 0x03F2C | R/W | Port 5 output mode register | IV-44 | | | P5DIR | 0x03F35 | R/W | Port 5 direction control register | IV-42 | | Timer 1 | TM1BC | 0x03F51 | R | Timer 1 binary counter | V-13 | | | TM1OC | 0x03F53 | R/W | Timer 1 compare register | V-12 | | | TM1MD | 0x03F55 | R/W | Timer 1 mode register | V-15 | | | CK1MD | 0x03F57 | R/W | Timer 1 prescaler selection register | V-10 | | | TM1ICR | 0x03FE8 | R/W | Timer 1 interrupt control register | III-25 | | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | | P7OMD | 0x03F3C | R/W | Port 7 output mode register | IV-53 | | | P7DIR | 0x03F37 | R/W | Port 7 direction control register | IV-52 | | | Register | Address | R/W | Function | Page | |---------|----------|---------|-----|--------------------------------------|--------| | Timer 2 | TM2BC | 0x03F58 | R | Timer 2 binary counter | V-13 | | | TM2OC | 0x03F5A | R/W | Timer 2 compare register | V-12 | | | TM2MD | 0x03F5C | R/W | Timer 2 mode register | V-16 | | | CK2MD | 0x03F5E | R/W | Timer 2 prescaler selection register | V-11 | | | TM2ICR | 0x03FE9 | R/W | Timer 2 interrupt control register | III-17 | | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | | P5OMD | 0x03F2C | R/W | Port 5 output mode register | IV-44 | | | P5DIR | 0x03F35 | R/W | Port 5 direction control register | IV-42 | | Timer 3 | ТМ3ВС | 0x03F59 | R | Timer 3 binary counter | V-13 | | | ТМЗОС | 0x03F5B | R/W | Timer 3 compare register | V-12 | | | TM3MD | 0x03F5D | R/W | Timer 3 mode register | V-17 | | | CK3MD | 0x03F5F | R/W | Timer 3 prescaler selection register | V-11 | | | TM3ICR | 0x03FEA | R/W | Timer 3 interrupt control register | III-27 | | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | | P7OMD | 0x03F3C | R/W | Port 7 output mode register | IV-10 | | | P7DIR | 0x03F37 | R/W | Port 7 direction control register | IV-8 | R/W:Readable / Writable R:Readable only # 5.2.2 Timer Prescaler Registers Timer prescaler selection register selects the count clock for 8-bit timer. The register which selects prescaler output is consisted by the timer prescaler selection register (CKnMD). ■ Timer 0 prescaler selection register (CK0MD:0x03F56) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|-------------|-------------|----------|---------|---------|--------| | Flag | - | - | TM0ADD<br>1 | TM0ADD<br>0 | TM0ADDEN | TM0PSC1 | TM0PSC0 | TM0BAS | | At reset | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|------------------------------|----------------------------------------------------------------------------------------------------------------------| | 7-6 | - | - | | 5-4 | TM0ADD1<br>TM0ADD0 | Additional pulse position (within PWM 4 periods) 00: None 01:2nd period 10:1st, 3rd periods 11:1st, 2nd, 3rd periods | | 3 | TMOADDEN | Additional pulse method PWM output control 0:Disabled (8-bit PWM output) 1:Enabled | | 2-0 | TM0PSC1<br>TM0PSC0<br>TM0BAS | Clock source selection<br>000:fosc/4<br>010:fosc/16<br>100:fosc/32<br>110:fosc/64<br>X01:fs/2<br>X11:fs/4 | ## ■ Timer 1 Prescaler Selection Register (CK1MD:0x03F57) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|-----|-----|-----|---------|---------|--------| | Flag | - | - | - | - | - | TM1PSC1 | TM1PSC0 | TM1BAS | | At reset | - | - | - | - | - | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|------------------------------|------------------------------------------------------------------------------------------| | 7-3 | - | - | | 2-0 | TM1PSC1<br>TM1PSC0<br>TM1BAS | Clock source selection 000:fosc/4 010:fosc/16 100:fosc/64 110:fosc/128 X01:fs/2 X11:fs/8 | ## ■ Timer 2 Prescaler Selection Register (CK2MD:0x03F5E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|-------------|-------------|----------|---------|---------|--------| | Flag | - | - | TM2ADD<br>1 | TM2ADD<br>0 | TM2ADDEN | TM2PSC1 | TM2PSC0 | TM2BAS | | At reset | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|------------------------------|----------------------------------------------------------------------------------------------------------------------| | 7-6 | - | - | | 5-4 | TM2ADD1<br>TM2ADD0 | Additional pulse position (within PWM 4 periods) 00: None 01:2nd period 10:1st, 3rd periods 11:1st, 2nd, 3rd periods | | 3 | TM0ADDEN | Additional pulse method PWM output control 0:Disabled (8-bit PWM output) 1:Enabled | | 2-0 | TM2PSC1<br>TM2PSC0<br>TM2BAS | Clock source selection<br>000:fosc/4<br>010:fosc/16<br>100:fosc/32<br>110:fosc/64<br>X01:fs/2<br>X11:fs/4 | ## ■ Timer 3 Prescaler Selection Register (CK3MD:0x03F5F) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|-----|-----|-----|---------|---------|--------| | Flag | - | - | - | - | - | TM3PSC1 | TM3PSC0 | TM3BAS | | At reset | - | - | - | - | - | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|------------------------------|------------------------------------------------------------------------------------------| | 7-3 | - | - | | 2-0 | TM3PSC1<br>TM3PSC0<br>TM3BAS | Clock source selection 000:fosc/4 010:fosc/16 100:fosc/64 110:fosc/128 X01:fs/2 X11:fs/8 | # 5.2.3 Programmable Timer Registers Each of timer 0 to 3 has 8-bit programmable timer registers. Programmable timer register consists of compare register and binary counter. Compare register is 8-bit register which stores the value to be compared to binary counter are stocked. ■ Timer 0 Compare Register (TM0OC:0x03F52) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | TM0OC7 | TM0OC6 | TM0OC5 | TM0OC4 | TM0OC3 | TM0OC2 | TM0OC1 | TM0OC0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ### ■ Timer 1 Compare Register (TM1OC:0x03F53) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|-------|--------|--------|--------| | Flag | TM1OC7 | TM1OC6 | TM1OC5 | TM1OC4 | T10C3 | TM1OC2 | TM1OC1 | TM1OC0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ### ■ Timer 2 Compare Register (TM2OC:0x03F5A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|-------|--------|--------|--------| | Flag | TM2OC7 | TM2OC6 | TM2OC5 | TM2OC4 | T2OC3 | TM2OC2 | TM2OC1 | TM2OC0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ### ■ Timer 3 Compare Register (TM3OC:0x03F5B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|-------|--------|--------|--------| | Flag | TM3OC7 | TM3OC6 | TM3OC5 | TM3OC4 | T3OC3 | TM3OC2 | TM3OC1 | TM3OC0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W Binary counter is 8-bit up counter. If any data is written to compare register the counting is stopped and binary counter is cleared to 0x00. ### ■ Timer 0 Binary Counter (TM0BC:0x03F50) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | TM0BC7 | TM0BC6 | TM0BC5 | TM0BC4 | TM0BC3 | TM0BC2 | TM0BC1 | TM0BC0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | ### ■ Timer 1 Binary Counter (TM1BC:0x03F51) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | TM1BC7 | TM1BC6 | TM1BC5 | TM1BC4 | TM1BC3 | TM1BC2 | TM1BC1 | TM1BC0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | ### ■ Timer 2 Binary Counter (TM2BC:0x03F58) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | TM2BC7 | TM2BC6 | TM2BC5 | TM2BC4 | TM2BC3 | TM2BC2 | TM2BC1 | TM2BC0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | ### ■ Timer 3 Binary Counter (TM3BC:0x03F59) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | ТМЗВС7 | TM3BC6 | TM3BC5 | TM3BC4 | TM3BC3 | TM3BC2 | TM3BC1 | TM3BC0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | ## 5.2.4 Timer Mode Registers Timer mode register is readable/writable register that controls timer 0 to 3. ■ Timer 0 Mode Register (TM0MD:0x03F54) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|--------|--------|--------|-------|--------|--------|--------| | Flag | - | TM0POP | TM0MOD | TM0PWM | TM0EN | TM0CK2 | TM0CK1 | TM0CK0 | | At reset | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | 7 | - | - | | 6 | TM0POP | Output signal start polarity selection 0:Timer output L→H, PWM H→L 1:Timer output H→H, PWM L→H | | 5 | TM0MOD | Pulse width measurement control 0:Normal timer operation 1:P54 pulse width measurement | | 4 | TM0PWM | Timer 0 operation mode selection 0:Normal timer operation 1:PWM operation | | 3 | TM0EN | Timer 0 count control 0:Halt the count 1:Operate the count | | 2-0 | TM0CK2<br>TM0CK1<br>TM0CK0 | Clock source selection X00:fosc X01:TM0PSC (Prescaler output) 010:fx 011:Synchronous fx 110:TM0IO input 111:Synchronous TM0IO output | ### ■ Timer 1 Mode Register (TM1MD:0x03F55) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|-----|--------|-------|--------|--------|--------| | Flag | - | - | - | TM1CAS | TM1EN | TM1CK2 | TM1CK1 | TM1CK0 | | At reset | - | - | - | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------| | 7-5 | - | - | | 4 | TM1CAS | Timer 1 operation mode selection 0:Normal timer operation 1:Cascade connection | | 3 | TM1EN | Timer 1 count control 0:Halt the count 1:Operate the count | | 2-0 | TM1CK2<br>TM1CK1<br>TM1CK0 | Clock source selection X00:fosc X01:TM1PSC (Prescaler output) 010:fx 011:Synchronous fx 110:TM1IO input 111:Synchronous TM0IO input | ### ■ Timer 2 Mode Register (TM2MD:0x03F5C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|--------|--------|--------|-------|--------|--------|--------| | Flag | - | TM2POP | TM2MOD | TM2PWM | TM2EN | TM2CK2 | TM2CK1 | TM2CK0 | | At reset | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | 7 | - | - | | 6 | TM2POP | Output signal start polarity selection<br>0:Timer output L→H, PWM H→L<br>1:Timer output H→H, PWM L→H | | 5 | TM2MOD | Pulse width measurement control 0:Normal timer operation 1:P56 pulse width measurement | | 4 | TM2PWM | Timer 2 operation mode selection 0:Normal timer operation 1:PWM operation | | 3 | TM2EN | Timer 2 count control 0:Halt the count 1:Operate the count | | 2-0 | TM2CK2<br>TM2CK1<br>TM2CK0 | Clock source selection X00:fosc X01:TM2PSC (Prescaler output) 010:fx 011:Synchronous fx 110:TM2IO input 111:Synchronous TM2IO output | ### ■ Timer 3 Mode Register (TM3MD:0x03F5D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|-----|--------|-------|--------|--------|--------| | Flag | - | - | - | TM3CAS | TM3EN | TM3CK2 | TM3CK1 | TM3CK0 | | At reset | - | - | - | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|----------------------------|------------------------------------------------------------------------------------------------------------------------------| | 7-5 | - | - | | 4 | TM3CAS | Timer 3 operation mode selection 0:Normal timer operation 1:Cascade connection | | 3 | TM3EN | Timer 3 count control 0:Halt the count 1:Operate the count | | 2-0 | TM3CK2<br>TM3CK1<br>TM3CK0 | Clock source selection X00:fosc X01:TM3PSC (Prescaler output) 010:Synchronous fx 110:TM3IO input 111:Synchronous TM3IO input | ### ■ Port 1 Output Mode Register (P1OMD:0x03F1C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|---------|--------|--------| | Flag | P1OMD7 | P1OMD6 | P1OMD5 | P1OMD4 | P1OMD3 | NBUZSEL | P1OMD2 | BUZSEL | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |----|---------|----------------------------------------------------------| | 7 | P1OMD7 | I/O port, TM2OB selection 0:I/O port 1:TM2OB | | 6 | P1OMD6 | I/O port, TM2IO selection 0:I/O port 1:TM2IO | | 5 | P1OMD5 | I/O port, TM0OB selection 0:I/O port 1:TM0OB | | 4 | P1OMD4 | I/O port, TM0IO/RMOUT selection 0:I/O port 1:TM0IO/RMOUT | | 3 | P1OMD3 | I/O port, TM7IO selection 0:I/O port 1:TM7IO | | 2 | NBUZSEL | I/O port, NBUZZER selection 0:I/O port 1:NBUZZER | | 1 | P1OMD2 | I/O port, TM8IO selection 0:I/O port 1:TM8IO | | 0 | BUZSEL | I/O port, BUZZER selection 0:I/O port 1:BUZZER | ## 5.3 Prescaler ### 5.3.1 Prescaler Operation ■ Prescaler Operation (Prescaler 0 to 1) Prescaler 0, prescaler 1 are each free-run counter of 7 bits, 3 bits and output the dividing clock of the reference clock. This count up operation starts automatically when any TMnEN flags of 8-bit timer are set to "1" and operate the timer n counting. Also, it stops automatically when all TMnEN flags of 8-bit timer are set to "0" and stop all timer counting. ■ Count Timing of Prescaler Operation (Prescaler 0 to 1) Prescaler 0 counts up at the falling edge of fosc. Prescaler 1 counts up at the rising edge of fs. Peripheral Functions Peripheral functions which can use the prescaler output dividing clock, or registers which control the dividing clock selections are shown below. | Timer 0 Count Clock | CK0MD | |---------------------|-------| | Timer 1 Count Clock | CK1MD | | Timer 2 Count Clock | CK2MD | | Timer 3 Count Clock | CK3MD | Start the timer operation after the prescaler setup. Also, at the timer, the prescaler output should be set up by the timer mode register. The prescaler starts counting at the start of the timer operation. ### 5.3.2 Setup Example ### ■ Prescaler Operation Setup Example fs/2 clock which is output from the prescaler 1 is selected to the count clock of the timer 0. A setup procedure example, with a description of each step in shown below: | Setup Procedure | Description | |---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | (1) Select the prescaler output<br>CK0MD(0x03F56)<br>bp2-1 :TM0PSC1-0 =X0<br>bp0 :TM0BAS =1 | (1) Select fs/2 to the prescaler output by the TM0PSC 1 to 0, TM0BAS flag of the timer 0 prescaler selection register. | At the timer, prescaler output selection should be set up by the timer mode register. # 5.4 8-bit Timer ### 5.4.1 8-bit Timer Operation Timer operation can constantly generates interrupts. ■ 8-bit Timer Operation (Timer 0, 1, 2, and 3) The generation cycle of timer interrupts is set by the clock source selection and the setting value of the compare register (TMnOC), in advance. If the binary counter (TMnBC) reaches the setting value of the compare register, an interrupt is generated at the next count clock, then binary counter is cleared and counting is restarted from 0x00. Table shows clock source that can be selected by timer. | Clock source | per Count | Timer 0<br>(8-bit) | Timer 1<br>(8-bit) | Timer 2<br>(8-bit) | Timer 3<br>(8-bit) | |----------------------------|-----------|--------------------|--------------------|--------------------|--------------------| | fosc | 100 ns | 0 | 0 | 0 | 0 | | fosc/4 | 400 ns | 0 | 0 | 0 | 0 | | fosc/16 | 1.6 μs | 0 | 0 | 0 | 0 | | fosc/32 | 3.2 μs | 0 | - | 0 | - | | fosc/64 | 6.4 μs | 0 | 0 | 0 | 0 | | fosc/128 | 12.8 μs | - | 0 | - | 0 | | fs/2 | 400 ns | 0 | 0 | 0 | 0 | | fs/4 | 800 ns | 0 | - | 0 | - | | fs/8 | 1.6 μs | - | 0 | - | 0 | | fx | 30.5 μs | 0 | 0 | 0 | 0 | | face 40 MHz fr. 20 700 HJz | | | | | | fosc=10 MHz fx=32.768 kHz fs=fosc/2=5 MHz When fs/2, fs/4, fs/8 are used as clock source, they are counted at the rising of the count clock and when others are used, they are counted at the falling of the count clock. #### ■ Count Timing of Timer Operation (Timer 0, 1, 2, and 3) Binary counter counts up with selected clock source as a count clock. The basic operation of the whole function of 8-bit timer is as follows: Figure: 5.4.1 Count Timing of Timer Operation (Timer 0, 1, 2, and 3) - (A)If the value is written to the compare register during the TMnEN flag is stopped ("0"), the binary counter is cleared to 0x00, at the writing cycle. - (B)If the TMnEN flag is operated ("1"), the binary counter is started to count. - (C)If the binary counter reaches the value of the compare register, the interrupt request flag is set at the next count clock, then the binary counter is cleared to 0x00 and the counting is restarted. - (D)Even if the compare register is rewritten during the TMnEN flag is enabled ("1"), the binary counter is not changed. - (E)If the TMnEN flag is stopped ("0"), the binary counter is stopped. When the binary counter reaches the value in the compare register, the interrupt request flag is set and the binary counter is cleared, at the next count clock. So set the compare register as: Compare register setting = (count till the interrupt request -1) If the compare register is set to smaller than the binary counter during the count operation, the following operations occur by the values of binary counter and compare register. - 1. When using as the 8-bit timer, binary counter counts up until overflow once. - 2. When using as the 16-bit timer with cascade connection, if the upper 8 bit value of binary counter reaches the upper 8 bit value of compare register, binary counter counts up until overflow once. - 3. When using as the 16-bit timer with cascade connection, if the upper 8 bit value of binary counter reaches the upper 8 bit value of compare register, binary counter is cleared as the lower 8 bit of binary counter overflows. If the interrupt is enabled, the timer interrupt request flag should be cleared before timer is started. When a timer interrupt request flag is generated, up to 3 system clock is required for the next flag generation. Even if the binary counter reaches the value in the compare register, a timer interrupt request flag is not generated. When fx is used as the clock source, clear the binary counter before starting the timer operation. Also, when 0x00 is set to the compare register, use the synchronous fx. When fx is used as the count clock source and the compare register is rewritten during the count operation, it may not operate properly. To prevent, use synchronous fx. When synchronous fx is used as the count clock source, binary counter may reach to unexpected value. To prevent, select synchronous fx input. ### 5.4.2 Setup Example ■ Timer Operation Setup Example (Timer 0, 1, 2, and 3) Timer function can be set by using timer 0 that generates the constant interrupt. Interrupt is generated every 250 cycles (200 $\mu$ s) by selecting fs/2 (at fs=2.5 MHz operation) as a clock source. A setup procedure example, with a description of each step is shown below. | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter TM0MD(0x03F54) bp3 :TM0EN =0 | (1) Set the TM0EN flag of the timer 0 mode register (TM0MD) to "0" to stop the counting of the timer 0. | | (2) Disable the interrupt TM0ICR(0x03FE7) bp1 :TM0IE =0 | (2) Set the TM0IE flag of the TM0ICR register to "0" to disable the interrupt. | | (3) Select the normal timer operation TM0MD(0x03F54) bp4 :TM0PWM =0 bp5 :TM0MOD =0 | (3) Set the TM0PWM flag and the TM0MOD flag of the TM0MD register to "0" to select the normal timer operation. | | (4) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =X01 | (4) Select the prescaler output to the clock source by the TM0CK2 to 0 flag of the TM0MD register. | | (5) Select and enable the prescaler output CK0MD(0x03F56) bp2-1 :TM0PSC1-0 =X0 bp0 :TM0BAS =1 | (5) Select fs/2 to the prescaler output by the TM0PSC 1 to 0 flag and TM0BAS flag of the timer 0 prescaler selection register (CK0MD). | | (6) Set the cycle of the interrupt generation TM0OC (0x03F52) =0xF9 | (6) Set the value of the interrupt generation cycle to the timer 0 compare register (TM0OC). The cycle is 250, so that the setting value is set to 249 (0x49). At that time, the timer 0 binary counter (TM0BC) is initialized to 0x00. | | (7) Set the interrupt level TM0ICR(0x03FE7) bp7-6:TM0LV1-0 =10 | (7) Set the interrupt level by the TM0LV1 to 0 flag of the timer 0 interrupt control register (TM0ICR). If the interrupt request flag may be already set, clear the request flag. [Chapter 3 3.1.4. Interrupt Flag Setup] | | (8) Enable the interrupt TM0ICR (0x03FE7) bp1 :TM0IE =1 | (8) Set the TM0IE flag of the TM0ICR register to "1" to enable the interrupt. | | (9) Start the timer operation TM0MD(0x03F54) bp3 :TM0EN =1 | (9) Set the TM0EN flag of the TM0MD register to "1" to operate the timer 0. | The TM0BC starts to count up from 0x00. When the TM0BC reaches the setting value of the TM0OC register, the timer 0 interrupt request flag is set at the next count clock, then the value of the TM0BC becomes 0x00 and restart to count up. When the TMnEN flag of the TMnMD register is changed at the same time to other bit, binary counter may start to count up by the switching operation. Do not operate the TMnEN flag and the TMnCK 2 to 0 flag of the TMnMD register at the same time. That may lead the malfunction. Count clock source should be changed when the timer interrupt is disabled. # 5.5 8-bit Event Count ### 5.5.1 Operation Event count operation has 2 types; TMnIO input and synchronous TMnIO input, according to the clock source selection. ■ 8-bit Event Count Operation (Timer 0, 1, 2, and 3) Event count operation means that the binary counter (TMnBC) counts the input signal from external to the TMnIO pin. If the value of the binary counter reaches the setting value of the compare register (TMnOC), interrupts can be generated at the next count clock. Table: 5.5.1 Event Count Input Clock | | Timer 0 | Timer 1 | Timer 2 | Timer 3 | |-------------|-------------|-------------|-------------|-------------| | Event input | TM0IO input | TM1IO input | TM2IO input | TM3IO input | | | (P14) | (P70) | (P16) | (P71) | | | Synchronous | Synchronous | Synchronous | Synchronous | | | TM0IO input | TM1IO input | TM2IO input | TM3IO input | ■ Count Timing of TMnIO Input (Timer 0, 1, 2, and 3) When TMnIO input is selected, TMnIO is input to the count clock of the timer n. The binary counter is started to count up at the falling edge of the TMnIO input signal. Figure:5.5.1 Count Timing of TMnIO Input (Timer 0, 1, 2, and 3) When the TMnIO input is used as the count clock source, the value of the binary counter may reach to an unexpected value. To prevent, select synchronous TM0IO input. When TMnIO is used as the count clock source and the compare register is rewritten during the count operation, it may not operate properly. To prevent, use synchronous TMnIO. When the TMnIO input is selected for count clock source and the value of the timer n binary counter is read out during operation, incorrect value at count up may be read out. To prevent this, use the event count by synchronous TMnIO input, as the following page. When the event input (TMnIO input) is used, clear the binary count before the timer operation. Also, when 0x00 is set to the compare register, use the event count by the synchronous TMnIO input, as the following page. Timer can be recovered from STOP mode only at the TMnIO input. When TMnIO input is used at STOP mode, fs should be selected for the count clock and set the value to TMnOC, then select TMnIO input. When the event input (TMnIO) is selected as the count clock source, and the compare register is rewritten during the timer operation, the operation of the corresponding cycle to the value cannot be guaranteed during the transition period. For proper timer operation with an expected cycle, stop the timer, rewrite the compare register, then start the timer operation. ### ■ Count Timing of Synchronous TMnIO Input (Timer 0, 1, 2, and 3) If the synchronous TMnIO input is selected, the synchronous circuit output signal is inputted to the timer n count clock. The synchronous circuit output signal is synchronization with the falling edge of the system clock derived the TMnIO input signal. Figure: 5.5.2 Count Timing of Synchronous TMnIO Input (Timer 0, 1, 2, and 3) When the synchronous TMnIO input is selected as the count clock source, the timer n counter counts up in synchronization with system clock, therefore the correct value is always read out. ### 5.5.2 Setup Example ■ Event Count Setup Example (Timer 0, 1, 2, and 3) If the falling edge of the TMnIO input pin signal is detected 5 times, an interrupt is generated. A setup procedure example, with a description of each step is shown below. | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM0MD(0x03F54)<br>bp3 :TM0EN =0 | (1) Set the TM0EN flag of the timer 0 mode register to "0" to stop timer 0 counting. | | (2) Enable the interrupt TM0ICR(0x03FE7) bp1 :TM0IE =0 | (2) Set the TM0IE flag of the TM0ICR register to "0" to disable the interrupt. | | (3) _Set the special function pin to input<br>P1DIR(0x03F31)<br>bp0 :P1DIR0 =0 | (3) Set the P1DIR0 flag of the port 1 direction control register (P1DIR) to "0" to set P10 pin to input mode. [Chapter 4. I/O Port Function] | | (4) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =X01 | (4) Select the prescaler output to the clock source by the TM0CK2 to 0 flag of the TM0MD register. | | (5) Select and enable the prescaler output CK0MD(0x03F56) bp2-1 :TM0PSC1-0 =X0 bp0 :TM0BAS =1 | (5) Select the fs/2 to the prescaler output by the TM0PSC1 to 0 flag and the TM0BAS flag of the timer 0 prescaler selection register (CK0MD). | | (6) set the interrupt generation cycle TM0OC (0x03F52) =0x04 | (6) Set the interrupt generation cycle to the timer 0 compare register (TM0OC). Counting is 5, so the setting value should be 4. At the time, the timer 0 binary counter (TM0BC) is initializes to 0x00. | | (7) Select the normal timer operation TM0MD(0x03F54) bp4 :TM0PWM =0 bp5 :TM0MOD =0 | (7) Set the TM0PWM flag and the TM0MOD flag of the TM0MD register to "0" to select the normal timer operation. | | (8) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =110 | (8) Select the TM0IO input to the clock source by the TM0CK2 to 0 flag of the TM0MD register. | | (9) Set the interrupt level TM0ICR(0x03FE7) bp7-6:TM0LV1-0 =10 | (9) Set the interrupt level by the TM0LV1 to 0 flag of the<br>timer 0 interrupt control register (TM0ICR).<br>If the interrupt request flag may be already set, clear<br>the request flag.<br>[Chapter 3 3.1.4. Interrupt Flag Setup] | | Setup Procedure | Description | |---------------------------------------------------------------|--------------------------------------------------------------------------------| | (10) Enable the interrupt TM0ICR(0x03FE7) bp1 :TM0IE =1 | (10) Set the TM0IE flag of the TM0ICR register to "1" to enable the interrupt. | | (11) Start the event count<br>TM0MD(0x03F54)<br>bp3 :TM0EN =1 | (11) Set the TM0EN flag of the TM0MD register to "1" to operate the timer 0. | Every time TM0BC detects the falling edge of TM0IO input, TM0BC counts up from 0x00. When TM0BC reaches the setting value of TM0OC register, the timer 0 interrupt request flag is set at the next count clock, then the value of TM0BC becomes 0x00 and counting up is restarted. # 5.6 8-bit Timer Pulse Output ### 5.6.1 Operation The TMnIO pin can output a pulse signal at any frequency. ■ Operation of Timer Pulse Output (Timer 0, 1, 2, and 3) The timers can output signals of $2 \times$ cycle of the setup value in the compare register (TMnOC). Output pins are as follows; Table: 5.6.1 Timer Pulse Output Pin | | Timer 0 | Timer 1 | Timer 2 | Timer 3 | |------------------|---------|---------|---------|---------| | Pulse output pin | TM0IO | TM1IO | TM2IO | TM3IO | | | output | output | output | output | | | (P14) | (P70) | (P16) | (P71) | ■ Count Timing of Timer Pulse Output (Timer 0, 1, 2, and 3) Figure:5.6.1 Count Timing of Timer Pulse Output (Timer 0, 1, 2, and 3) • The TMnIO pin outputs signals of $2 \times$ cycle of the setup value in the compare register. If the binary counter reaches the compare register, and the binary counter is cleared to 0x00, TMnIO output (timer output) is inverted. ### 5.6.2 Setup Example ■ Timer Pulse Output Setup Example (Timer 0, 1, 2, and 3) TM0IO pin outputs 50 kHz pulse by using timer 0. For this, select fs/2 for clock source, and set a 1/2 cycle (100 kHz) for the timer 0 compare register (at fs = 10 MHz). An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM0MD(0x03F54)<br>bp3 :TM0EN =0 | (1) Set the TM0EN flag of the timer 0 mode register (TM0MD) to "0" to stop timer 0 counting. | | (2) Set the special function pin to the output mode P1OMD(0x03F1C) bp0 :P1OMD0 =1 P1DIR (0x03F31) bp0 :P1DIR0 =1 | (2) Set the P10MD0 flag of the port 1 output mode register (P10MD) to "0" to set P10 pin to the special function pin. Set the TM0MOD flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. [Chapter 4. I/O Port Function] | | (3) Select the normal timer operation TM0MD(0x03F54) bp4 :TM0PWM =0 bp5 :TM0MOD =0 | (3) Set the TM0MOD flag of the TM0MD register to "0" to select the normal timer operation. | | (4) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =X01 | (4) Select the prescaler output to the clock source by the TM0CK2 to 0 flag of the TM0MD register. | | (5) Select and enable the prescaler output CK0MD(0x03F56) bp2-1 :TM0PSC1-0 =X0 bp0 :TM0BAS =1 | (5) Select fs/2 to the prescaler output by the TM0PSC 1 to 0 flag and TM0BAS flag of the timer 0 prescaler selection register (CK0MD). | | (6) Set the timer pulse output cycle TM0OC (0x03F52) =0x31 | (6) Set the timer 0 compare register (TM0OC) to the 1/2 of the timer pulse output cycle. The setting value should be 50-1=49 (0x31), for 100 kHz to be divided by 5 MHz. At that time, the timer 0 binary counter (TM0BC) is initialized to 0x00. | | (7) Start the timer operation TM0MD(0x03F54) bp3 :TM0EN =1 | (7) Set the TM0EN flag of the TM0MD register to "1" to operate the timer 0. | TM0BC counts up from 0x00. If TM0BC reaches the setting value of the TM0OC register, then TM0BC is cleared to 0x00, TM0IO output signal is inverted and TM0BC restarts to count up from 0x00. If any data is written to compare register when the binary counter is stopped, timer output is reset to "L". If any data is written to compare register when the binary counter is stopped, timer output is reset to "L". [Compare register] Compare register=Timer pulse output / (Selection clock cycle $\times$ 2)–1 # 5.7 8-bit PWM Output The TMnIO pin outputs the PWM waveform, which is determined by the match timing for the compare register and the overflow timing of the binary counter. ### 5.7.1 Operation ■ Operation of 8-bit PWM Output (Timer 0 and 2) The PWM waveform with an arbitrary duty cycle is generated by setting the duty cycle of PWM period to the compare register (TMnOC). The cycle is the period from the full count to the overflow of the 8-bit timer. Table: 5.7.1 shows PWM output pins; Table:5.7.1 Output Pins of PWM Output | | Timer 0 | Timer 2 | |----------------|------------------------|------------------------| | PWM output pin | TM0IO output pin (P14) | TM2IO output pin (P16) | ### ■ Count Timing of PWM Output (at Normal) (Timer 0 and 2) Figure: 5.7.1 Count Timing of PWM Output (at Normal) PWM source waveform when TMnPOP flag is set to "0" - (A) is "H" while counting up from 0x00 to the value stored in the compare register. - (B) is "L" after the match to the value in the compare register, then the binary counter continues counting up till the overflow. ■ Count Timing of PWM Output (when the compare register is 0x00) (Timer 0 and 2) Here is the count timing when the compare register is set to 0x00. Figure:5.7.2 Count Timing of PWM Output (when compare register is 0x00) When TMnEN flag is stopped ("0"), PWM output is "H". ■ Count Timing of PWM Output (when the compare register is 0xFF) (Timer 0 and 2) Here is the count timing when the compare register is set to 0xFF. Figure:5.7.3 Count Timing of PWM Output (when compare register is 0xFF) ### 5.7.2 PWM Output with Additional Pulse ■ PWM Output with Additional Pulse Method (Timer 0 and 2) In the additional pulse method, an additional bit is added to the 8-bit basic PWM output. The bit0 to 3 can be added during 4 cycle of basic PWM output. Whether or not, and to which the additional bit is added during 4 cycles of basic PWM output can be controlled with the timer 0 mode register (TM0MD bit 6, 7) and the timer 2 mode register (TM2MD bit 6, 7). ■ Setting the position of the Additional Pulses The positions of the additional pulse is set in the timer 0 prescaler selection register (CK0MD) and the timer 2 prescaler selection register (CK2MD) at the bit 5, 4. When the CK0MD and the CK2MD register bit 5 and 4 are set as '00', no additional pulse is added to the basic PWM cycle. When set as '11', 3 out of the 4 periods in the basic PWM cycle are each added with an additional bit pulse. Table:5.7.2 shows the relationship between values of CK0MD and CK2MD bits 5 and 4, and the additional pulses. Figure: 5.7.4 shows the relationship between values of CK0MD and CK2MD bits 6 and 7, and the position of the additional pulses. Table:5.7.2 | CKnMD register set value | | Additional pulse position | | |--------------------------|------|---------------------------------|--| | bit7 | bit6 | PWM basic wave form (4-periods) | | | 0 | 0 | No additional pulse | | | 0 | 1 | 2 period | | | 1 | 0 | 1 and 3 period | | | 1 | 1 | 1, 2 and 3 period | | Interrupt generates at the 4th cycles of the basic waveform. Figure:5.7.4 ### 5.7.3 Setup Example ### ■ PWM Output Setup Example (Timer 0 and 2) The 1/4 duty cycle PWM output waveform is output from the TM0IO output pin at 19.53 Hz by using the timer 0. Fs/2 oscillates at 5 MHz. Cycle period of PWM output waveform is decided by the overflow of the binary counter. "H" period of the PWM output waveform is decided by the setting value of the compare register. An example setup procedure, with a description of each step is shown below. Figure: 5.7.5 Output Waveform of TM0IO Output Pin | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM0MD(0x03F54)<br>bp3 :TM0EN =0 | (1) Set the TM0EN flag of the timer 0 mode register (TM0MD) to "0" to stop the timer 0 counting. | | (2) iSelect the special function pin to output P1OMD(0x03F1C) bp0 :P1OMD0 =1 P1DIR(0x03F31) bp0 :P1DIR0 =1 | (2) Set the P10MDO flag of the port 1 output mode register (P10MD) to "1" to set P10 pin to the special function pin. Set the P1DIR0 flag of the port 1 direction control register (P1DIR) to "1" for the output mode. [Chapter 4. I/O Ports] | | (3) Select the PWM operation TM0MD(0x03F54) bp4 :TM0PWM =1 bp5 :TM0MOD =0 bp6 :TM0POP =0 | (3) Set the TM0PWM flag of the TM0MD register to "1" and the TM0MOD flag to "0" to select the PWM operation. | | (4) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =X01 | (4) Select the prescaler output to the clock source by the TM0CK2 to 0 flag of the TM0MD register. | | (5) Select and enable the prescaler output CK0MD(0x03F56) bp2-1 :TM0PSC1-0 =X0 bp0 :TM0BAS =1 | (5) Select fs/2 to the prescaler output by the TM0PSC1 to 0 and TM0BAS flag of the timer 0 prescaler selection register. | | Setup Procedure | Description | |---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (6) Set the period of PWM "H" output<br>TM0OC (0x03F52) =0x40 | (6) Set the "H" period of PWM output to the timer 0 compare register (TM0OC). The setting value is set to 256/4=64 (0x40), because it should be the 1/4 duty of the full count (256). At that time, the timer 0 binary counter (TM0BC) is initialized to 0x00. | | (7) Start the timer operation TM0MD(0x03F54) bp3 :TM0EN =1 | (7) Set the TM0EN flag of the TM0MD register to "1" to operate the timer 0. | The initial setting of PWM output is changed from "L" output to "H" output at the selection of PWM operation by the TMnPWM flag of the TMnMD register. # 5.8 Serial Transfer Clock Output ## 5.8.1 Operation Serial transfer clock can be created by using the timer output signal. Serial transfer clock operation by 8-bit timer (Timer 1, 2, and 3) - Timer 1:Serial 0 - Timer 2:Serial 0, Serial 2 - Timer 3:Serial 2 - Timing of Serial Transfer Clock (Timer 1, 2, and 3) Figure:5.8.1 Timing of Serial Transfer Clock (Timer 1, 2, and 3) - The serial transfer clock is the 1/2 of the frequency set to the compare register. - For the baud rate calculation and the serial interface setup, refer to chapters for Serial Interface. ### 5.8.2 Setup Example #### ■ Serial Transfer Clock Setup Example (Timer 2) How to create a transfer clock for half duplex UART (Serial 0) using with the timer 2 is shown below. The baud rate is selected to be 300 bps, the source clock of timer 2 is selected to be fs/2 (at fs=2 MHz). An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM2MD(0x03F5C)<br>bp3 :TM2EN =0 | (1) Set the TM2EN flag of the timer 2 mode register (TM2MD) to "0" to stop the timer 2 counting. | | (2) Select the normal timer operation TM2MD(0x03F5C) bp4 :TM2PWM =0 bp5 :TM2MOD =0 | (2) Set the TM2PWM flag and the TM2MOD flag of the TM2MD register to "0" to select the normal timer operation. | | (3) Select the count clock source<br>TM2MD(0x0F5C)<br>bp2-0 :TM2CK2-0 =X01 | (3) Select the prescaler output to the clock source by the TM2CK2 to 0 flag of the TM2MD register. | | (4) Select and enable the prescaler output CK2MD(0x0F5E) bp2-1 :TM2PSC1-0 =X0 bp0 :TM2BAS =1 | (4) Select fs/2 to the prescaler output by the TM2PSC1 to 0 flag and the TM2BAS flag of the timer 2 prescaler selection register. | | (5) Set the baud rate<br>TM2OC (0x0F5A) =0xCF | (5) Set the timer 2 compare register (TM2OC) such a value<br>that the baud rate comes to 300 bps.<br>At that time, the timer 2 binary counter (TM2BC) is<br>initialized to 0x00. | | (6) Start the timer operation TM2MD(0x0F5C) bp3 :TM2EN =1 | (6) Set the TM2EN flag of the TM2MD register to "1" to operate the timer 2. | - TM2BC counts up from 0x00. Timer 2 output is the clock of the serial interface 0 at transmission and reception. - For the setup value of the compare register and the setup of the serial interface operation, refer to Chapter 11 Serial interface 0. # 5.9 Simple Pulse Width Measurement ### 5.9.1 Operation Timer measures the "L" duration of the pulse signal input from the external interrupt pin. ■ Simple Pulse Width Measurement Operation by 8-bit Timer (Timer 0, 2) When the input signal of the external interrupt pin (simple pulse width) is "L", the binary counter of the timer counts up. Pulse width "L" period can be measured by reading the count of timer. 8-bit timers that have the simple pulse width measurement function are the timer 0, and 2. Table: 5.9.1 Simple Pulse Width Measurement Able Pins | | Timer 0 | Timer 2 | |-------------------------------------------|---------------------------------|------------------------------------| | Simple pulse width measurement enable pin | External interrupt 0 (P54/IRQ0) | External interrupt 2<br>(P56/IRQ2) | ■ Count Timing of Simple Pulse Width Measurement (Timer 0, 2) Figure: 5.9.1 Count Timing of Measurement of Simple Pulse Width - External interrupt IRQ(n) is synchronized by the count clock source. - After the external interrupt IRQ(n) is set to "H", count operation continues until the falling edge of the next count clock source. When the low speed clock (fx) and the event count (TMnIO) are selected as the clock source, the value of the binary counter cannot be guaranteed. When measuring pulse width, do not select fx and TMnIO as the clock source. ### 5.9.2 Setup Example ■ Setup Example of Simple Width Measurement by 8-bit Timer (Timer 0, 2) The pulse width of "L" period of the external interrupt 0 (IRQ0) input signal is measured by the timer 0. The clock source of the timer 0 is selected to fs/2. A setup procedure example, with a description of each step is shown below. | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM0MD(0x03F54)<br>bp3 :TM0EN =0 | (1) Set the TM0EN flag of the timer 0 mode register (TM0MD) to "0" to stop the timer 0 counting. | | (2) Set the pulse width measurement operation TM0MD(0x03F54) bp4 :TM0PWM =0 bp5 :TM0MOD =1 | (2) Set the TM0PWM flag of the TM0MD register to "0" and TM0MOD flag to "1" to enable the timer operation during "L" period to be measured. | | (3) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =X01 | (3) Select the prescaler output to the clock source by the TM0CK2 to 0 flag of the TM0MD register. | | (4) Select and enable the prescaler output CK0MD(0x03F56) bp2-1 :TM0PSC1-0 =X0 bp0 :TM0BAS =1 | (4) Select fs/2 to the prescaler output by the TM0PSC1 to 0 flag and the TM0BAS flag of the timer 0 prescaler selection register (CK0MD). | | (5) Set the compare register TM0OC (0x03F52) =x'FF' | (5) Set the timer 0 compare register (TM0OC) to the bigger value than the cycle of fs/2 / "L" period of measured pulse width. At that time, the timer 0 binary counter (TM0BC) is initialized to 0x00. | | (6) Set the interrupt level IRQ0ICR(0x03FE2) bp7-6:IRQ0LV1-0="XX" | (6) Set the interrupt level by the IRQ0LV1 to 0 flag of the external interrupt 0 control register (IRQ0ICR). If the interrupt request flag is already set, clear all interrupt request flags. [Chapter 3. 3.1.4 Interrupt Flag Setup] | | (7) Set the interrupt valid edge IRQ0ICR(0x03FE2) bp5 :REDG0 =1 | (7) Set the REDG0 flag of the IRQ0ICR register to "1" to specify the interrupt valid edge to the rising edge. | | (8) Enable the interrupt IRQ0ICR(0x03FE2) bp1 :IRQ0IE =1 | (8) Set the IRQ0IE flag of the IRQ0ICR register to "1" to enable the interrupt. | | (9) Enable the timer operation TM0MD(0x03F54) bp3 :TM0EN =1 | (9) Set the TM0EN flag of the TM0MD register to "1" to enable the timer 0 operation. | • TM0BC starts to count up with negative edge of the external interrupt 0 (IRQ0) input as a trigger. Timer 0 continues to count up during "L" period of IRQ0 input, then stop the counting with positive edge of IRQ0 input as a trigger. At the same time, reading the value of TM0BC by interrupt handling can detects "L" period. When using TMnIO input or fx as the count clock source, the value of the binary counter may be wrong at the count stop. To prevent this, use the clock source that is synchronized with fosc or fx. # 5.10 Cascade Connection ## 5.10.1 Operation Cascading timers 0 and 1, or timers 2 and 3 forms a 16-bit timer. ■ 8-bit Timer Cascade Connection Operation (Timer 0+1, Timer 2+3) Timer 0 and timer 1, or timer 2 and timer 3 are combined to be a 16-bit timer. Cascading timer is operated at the clock source of timer 0 or timer 2 which are lower 8 bits. Table:5.10.1 Timer Functions at Cascade Connection | | Timer 0+Timer1<br>(16-bit) | Timer 2+Timer 3<br>(16-bit) | |------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------| | Interrupt source | TM1IRQ | TM3IRQ | | Timer operation | 0 | 0 | | Event count | O<br>TM0IO input | O<br>TM2IO input | | PWM output | - | - | | Clock source | fosc<br>fosc/4<br>fosc/16<br>fosc/32<br>fosc/64<br>fs/2<br>fs/4<br>fx<br>TM0IO input | fosc<br>fosc/4<br>fosc/16<br>fosc/32<br>fosc/64<br>fs/2<br>fs/4<br>fx<br>TM2IO input | fosc:Machine clock (High frequency oscillation) fx:Machine clock (Low frequency oscillation) fs:System clock [Chapter 2. 2.5 Clock Switching] • At cascade connection, the binary counter and the compare register are operated as a 16-bit register. At operation, set the TMnEN flag of the upper and lower 8-bit timers to "1" to be operated. Also, select the clock source by the lower 8-bit timer. Other setup and count timing is the same to the 8-bit timer at independently operation. When timer 0 and timer 1 are used in cascade connection, timer 1 is used as an interrupt request flag. Timer pulse output of timer 0 is "L" fixed output. An interrupt request of timer 0 is not generated, but the timer 0 interrupt should be disabled. When timer 2 and timer 3 are used in cascade connection, timer 3 is used as an interrupt request flag. Timer pulse output of timer 2 is "L" fixed output. An interrupt request of timer 2 is not generated, but the timer 2 interrupt should be disabled. At cascade connection, when the clear of the binary counter is needed by rewriting the compare register, set the TMnEM flag of both the upper 8-bit timer and the lower 8-bit timer to "0" to stop counting. To read out the binary counter during the timer operation, the correct value may not be read out if it changes from lower 8 bit of upper 8 bit as it is treated as 8-bits of data in LSI internally. Stop the timer and read out to get the correct value. ### 5.10.2 Setup Example ■ Cascade Connection Timer Setup Example (Timer 0 + Timer 1) Setting example of timer function that an interrupt is constantly generated by cascade connection of the timer 0 and the timer 1, as a 16-bit timer is shown. An interrupt is generated 2500 times every 1 ms by selecting source clock fs/2 (fs=5 MHz at operation). An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter TM0MD(0x03F54) bp3 :TM0EN =0 TM1MD(0x03F55) bp3 :TM1EN =0 | (1) Set the TM0EN flag of the timer 0 mode register (TM0MD) to "0", the TM1EN flag of the timer 1 mode register to "0" to stop the timer 0 and the timer 1 counting. | | (2) Select the normal lower timer operation TM0MD(0x03F54) bp4 :TM0PWM =0 bp5 :TM0MOD =0 | (2) Set the TM0PWM flag and the TM0MOD flag of the TM0MD register to "0" to select the normal timer 0 operation. | | (3) Set the cascade connection<br>TM1MD(0x03F55)<br>bp4 :TM1CAS =1 | (3) Set the TM1CAS flag of the TM1MD register to "0" to connect the timer 1 and the timer 0 to the cascade. | | (4) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =X01 | (4) Select the prescaler to the clock source by the TM0CK2 to 0 flag of the TM0MD register. | | (5) Select and enable the prescaler output CK0MD(0x03F56) bp2-1 :TM0PSC1-0 =X0 bp0 :TM0BAS =1 | (5) Select fs/2 to the prescaler output by the TM0PSC1 to 0<br>flag and the TM0BAS flag of the timer 0 prescaler<br>selection register (CK0MD). | | (6) Set the interrupt generation cycle TMnOC(0x03F52,0x03F53) =0x09C3 | (6) Set the timer 1 compare register + timer 0 compare register (TM1OC + TM0OC) to the interrupt generation cycle (0x09C3:2500 cycles -1). At that time, timer 1 binary counter + timer 0 binary counter (TM1BC + TM0BC) are initialized to 0x000. | | (7) Disable the lower timer interrupt TM0ICR(0x03FE7) bp1 :TM0IE =0 | (7) Set the TM0IE flag of the timer 0 interrupt control register (TM0ICR) to "0" to disable the interrupt. | | (8) Set the level of the upper timer interrupt TM1ICR(0x03FE8) bp7-6 :TM1LV1-0 =10 | <ul> <li>(8) Set the interrupt level by the TM1LV1 to 0 flag of the timer 1 interrupt control register (TM1ICR).</li> <li>If any interrupt request flag may be already set, clear all request flags.</li> <li>[Chapter 3. 3.1.4 Interrupt Flag Setup]</li> </ul> | | Setup Procedure | Description | |-------------------------------------------------------------------------|-------------------------------------------------------------------------------| | (9) Enable the upper timer interrupt TM1ICR(0x03FE8) bp1 :TM1IE =1 | (9) Set the TM1IE flag of the TM1ICR register to "1" to enable the interrupt. | | (10) Start the upper timer operation TM1MD(0x03F55) bp3 :TM1EN =1 | (10) Set the TM1EN flag of the TM1MD register to "1" to operate the timer 1. | | (11) Start the lower timer operation<br>TM0MD(0x03F54)<br>bp3 :TM0EN =1 | (11) Set the TM0EN flag of the TM0MD register to "1" to operate the timer 0. | • TM1BC + TM0BC counts up from 0x0000 as a 16-bit timer. When TM1BC + TM0BC reaches the set value of TM1BC + TM0BC register, the timer 1 interrupt request flag is set at the next count clock, and the value of TM1BC + TM0BC becomes 0x0000 and restarts count up. Use a 16-bit access instruction to set the (TM1OC + TM0OC) register. Start the upper timer operation before the lower timer operation. Chapter 5 8-bit Timers # 6.1 Overview This LSI contains two general-purpose 16-bit timers (Timer 7, Timer 8). The 16-bit timer has compare register with double buffer. Timer 7 (High precision 16-bit timer) contains 2 sets of compare registers with double buffering and 2 sets of independent interrupt functions such as Timer 7 interrupt and Timer 7 compare register 2-match interrupt. Timer 8 (High precision 16-bit timer) contains 2 sets of compare registers with double buffering and 2 sets of independent interrupt functions such as Timer 8 interrupt and Timer 8 compare register 2-match interrupt. ### 6.1.1 Functions #### Table: 6.1.1 shows the functions of each timer. Table:6.1.1 16-bit Timer functions | | Timer 7<br>(High precision 16-bit timer) | Timer 8<br>(High precision 16-bit timer) | |-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|------------------------------------------| | Input source | TM7IRQ<br>T70C2IRQ | TM8IRQ<br>T8OC2IRQ | | Timer operation | 0 | 0 | | Event count | O TM7IO input | OTM8IO input | | Timer pulse output | O TM7IO output / TM7O output | O TM8IO output / TM8O output | | PWM output (duty is changeable) | O TM7IO output / TM7O output | O TM8IO output / TM8O output | | High precision PWM output (duty/ cycle are changeable) | O TM7IO output / TM7O output | O TM8IO output / TM8O output | | IGBT output (duty is changeable) | O TM7IO output / TM7O output,<br>TM8IO output / TM8O output | × | | High precision IGBT output (duty/ cycle are changeable) | O TM7IO output / TM7O output,<br>TM8IO output / TM8O output | × | | Capture function | 0 | 0 | | Pulse width measurement | 0 | 0 | | 32-bit cascade connection Timer operation, Event count, PWM output, High precision PWM output, Capture function | 0 | | | | | , | |--------------|----------------------------|----------------------------| | Clock source | fosc | fosc | | | fosc/2 | fosc/2 | | | fosc/4 | fosc/4 | | | fosc/16 | fosc/16 | | | fs | fs | | | fs/2 | fs/2 | | | fs/4 | fs/4 | | | fs/16 | fs/16 | | | TM7IO input | TM8IO input | | | TM7IO input/2 | TM8IO input/2 | | | TM7IO input/4 | TM8IO input/4 | | | TM7IO input/16 | TM8IO input/16 | | | synchronous TM7IO input | synchronous TM8IO input | | | synchronous TM7IO input/2 | synchronous TM8IO input/2 | | | synchronous TM7IO input/4 | synchronous TM8IO input/4 | | | synchronous TM7IO input/16 | synchronous TM8IO input/16 | fosc:Machine clock (High frequency oscillation) fs:System clock [Chapter 2. 2.5 Clock Switching] ### 6.1.2 Block Diagram ### ■ Timer 7 Block Diagram Figure:6.1.1 Timer 7 Block Diagram ### ■ Timer 8 Block Diagram Figure:6.1.2 Timer 8 Block Diagram # 6.2 Control Registers Timer 7 contains the binary counter (TM7BC), the compare register 1 (TM7OC1) with its double buffer preset register 1 (TM7PR1), the compare register 2 (TM7OC2) with its double buffer preset register 2 (TM7PR2), the capture register (TM7IC), the dead time preset register 1 (TM7DPR1) and the dead time preset register 2 (TM7DPR2). Timer 7 is controlled by the mode register 1 (TM7MD1), the mode register 2 (TM7MD2), the mode register 3 (TM7MD3), and the mode register 4 (TM7MD4). Timer 8 contains the binary counter (TM8BC), the compare register 1 (TM8OC1) with its double buffer preset register 1 (TM8PR1), the compare register 2 (TM8OC2) with its double buffer preset register 2 (TM8PR2) and the capture register (TM8IC). Timer 8 is controlled by the mode register 1 (TM8MD1), the mode register 2 (TM8MD2), the mode register 3 (TM8MD3) and and the mode register 4 (TM8MD4). ## 6.2.1 Registers $Table \hbox{:} 6.2.1 \hbox{ shows the registers that control timer 7}.$ Table:6.2.1 16-bit Timer Control Registers (1/2) | | Register | Address | R/W | Function | Page | |---------|----------|---------|-----|-------------------------------------------------------------|--------| | Timer 7 | TM7BCL | 0x03F70 | R | Timer 7 binary counter (lower 8 bits) | VI-11 | | | ТМ7ВСН | 0x03F71 | R | Timer 7 binary counter (upper 8 bits) | VI-11 | | | TM7OC1L | 0x03F72 | R | Timer 7 compare register 1 (lower 8 bits) | VI-9 | | | TM7OC1H | 0x03F73 | R | Timer 7 compare register 1 (upper 8 bits) | VI-9 | | | TM7PR1L | 0x03F74 | R/W | Timer 7 preset register 1 (lower 8 bits) | VI-10 | | | TM7PR1H | 0x03F75 | R/W | Timer 7 preset register 1 (upper 8 bits) | VI-10 | | | TM7ICL | 0x03F76 | R | Timer 7 capture register 1 (lower 8 bits) | VI-11 | | | TM7ICH | 0x03F77 | R | Timer 7 capture register 1 (upper 8 bits) | VI-11 | | | TM7MD1 | 0x03F78 | R/W | Timer 7 mode register 1 | VI-16 | | | TM7MD2 | 0x03F79 | R/W | Timer 7 mode register 2 | VI-17 | | | TM7OC2L | 0x03F7A | R | Timer 7 compare register 2 (lower 8 bits) | VI-9 | | | TM7OC2H | 0x03F7B | R | Timer 7 compare register 2 (upper 8 bits) | VI-9 | | | TM7PR2L | 0x03F7C | R/W | Timer 7 preset register 2 (lower 8 bits) | VI-10 | | | TM7PR2H | 0x03F7D | R/W | Timer 7 preset register 2 (upper 8 bits) | VI-10 | | | TM7MD3 | 0x03F8E | R/W | Timer 7 mode register 3 | VI-18 | | | TM7MD4 | 0x03F6E | R/W | Timer 7 mode register 4 | VI-19 | | | TM7ICR | 0x03FED | R/W | Timer 7 interrupt control register | III-30 | | | T7OC2ICR | 0x03FEE | R/W | Timer 7 compare register 2 match interrupt control register | III-31 | | | P1OMD | 0x03FIC | R/W | Port 1 output mode register | IV-10 | | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | | P5OMD | 0x03F2C | R/W | Port 5 output mode register | IV-44 | | | P5DIR | 0x03F35 | R/W | Port 5 direction control register | IV-42 | | | TM7DPR1 | 0x03F7E | R/W | Dead time preset register 1 | VI-12 | | | TM7DPR2 | 0x03F7F | R/W | Dead time preset register 2 | VI-12 | Table:6.2.2 shows the registers that control timer 8. Table:6.2.2 16-bit Timer Control Registers (2/2) | | Register | Address | R/W | Function | Page | |---------|-----------------------------|---------|-----|-------------------------------------------------------------|--------| | Timer 8 | TM8BCL | 0x03F80 | R | Timer 8 binary counter (lower 8 bits) | VI-15 | | | TM8BCH | 0x03F81 | R | Timer 8 binary counter (upper 8 bits) | VI-15 | | | TM8OC1L | 0x03F82 | R | Timer 8 compare register 1 (lower 8 bits) | VI-13 | | | TM8OC1H | 0x03F83 | R | Timer 8 compare register 1 (upper 8 bits) | VI-13 | | | TM8PR1L | 0x03F84 | R/W | Timer 8 preset register 1 (lower 8 bits) | VI-14 | | | TM8PR1H | 0x03F85 | R/W | Timer 8 preset register 1 (upper 8 bits) | VI-14 | | | TM8ICL | 0x03F86 | R | Timer 8 capture register 1 (lower 8 bits) | VI-15 | | | TM8ICH | 0x03F87 | R | Timer 8 capture register 1 (upper 8 bits) | VI-15 | | | TM8MD1 0x03F8 TM8MD2 0x03F8 | | R/W | Timer 8 mode register 1 | VI-20 | | | | | R/W | Timer 8 mode register 2 | VI-21 | | | TM8OC2L | 0x03F8A | R | Timer 8 compare register 2 (lower 8 bits) | VI-13 | | | TM8OC2H | 0x03F8B | R | Timer 8 compare register 2 (upper 8 bits) | VI-13 | | | TM8PR2L | 0x03F8C | R/W | Timer 8 preset register 2 (lower 8 bits) | VI-14 | | | TM8PR2H | 0x03F8D | R/W | Timer 8 preset register 2 (upper 8 bits) | VI-14 | | | TM8MD3 | 0x03F8F | R/W | Timer 8 mode register 3 | VI-22 | | | TM8MD4 | 0x03F6F | R/W | Timer 8 mode register 4 | VI-23 | | | TM8ICR | 0x03FF6 | R/W | Timer 8 interrupt control register | III-39 | | | T8OC2ICR | 0x03FF7 | R/W | Timer 8 compare register 2 match interrupt control register | III-40 | | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | | P5OMD | 0x03F2C | R/W | Port 5 output mode register | IV-44 | | | P5DIR | 0x03F35 | R/W | Port 5 direction control register | IV-42 | ### 6.2.2 Programmable Timer Registers Timer 7 has a set of 16-bit programmable timer registers, which contains a compare register, a preset register, a binary counter and a capture register. Each register has 2 sets of 8-bit register. Operate these registers by 16-bit access. A compare register is a 16-bit register which stores comparative value of the compare register and the binary counter. #### ■ Timer 7 Compare Register 1 (TM7OC1) Table:6.2.3 Timer 7 Compare Register 1 Lower 8 bits (TM7OC1L:0x03F72) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7OC1L<br>7 | TM7OC1L<br>6 | TM7OC1L<br>5 | TM7OC1L<br>4 | TM7OC1L<br>3 | TM7OC1L<br>2 | TM7OC1L<br>1 | TM7OC1L<br>0 | | At reset | Х | X | X | Х | Х | X | X | X | | Access | R | | | | | | | | Table: 6.2.4 Timer 7 Compare Register 1 Upper 8 bits (TM7OC1H:0x03F73) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7OC1<br>H7 | TM7OC1<br>H6 | TM7OC1<br>H5 | TM7OC1<br>H4 | TM7OC1<br>H3 | TM7OC1<br>H2 | TM7OC1<br>H1 | TM7OC1<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | #### ■ Timer 7 Compare Register 2 Lower 8 bits (TM7OC2) Table: 6.2.5 Timer 7 Compare Register 2 Lower 8 bits (TM7OCS2L:0x03F7A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7OC2L<br>7 | TM7OC2L<br>6 | TM7OC2L<br>5 | TM7OC2L<br>4 | TM7OC2L<br>3 | TM7OC2L<br>2 | TM7OC2L<br>1 | TM7OC2L<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | Table:6.2.6 Timer 7 Compare Register 2 Upper 8 bits (TM7OCS2H:0x03F7B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7OC2<br>H7 | TM7OC2<br>H6 | TM7OC2<br>H5 | TM7OC2<br>H4 | TM7OC2<br>H3 | TM7OC2<br>H2 | TM7OC2<br>H1 | TM7OC2<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | • | • | • | • | • | | | Timer 7 preset registers 1 and 2 are buffer registers of the compare registers 1, 2 of timer 7. If the set value is written to the timer 7 preset registers 1, 2 when the counting is stopped, the same set value is loaded to the timer 7 compare register. If set value is written to the timer 7 preset registers 1, 2 during counting, the set value of the timer 7 preset registers 1, 2 is loaded to the timer 7 compare registers 1, 2 at the timing that the timer 7 binary counter is cleared. Also, If the set value is written to the timer 7 preset register 1 and 2 during IGBT operation, the set value of the timer 7 preset register is loaded to the timer 7 compare register at the timing that the IGBT is disabled. #### ■ Timer 7 Preset Register 1 (TM7PR1) Table:6.2.7 Timer 7 Preset Register 1 Lower 8 bits (TM7PR1L:0x03F74) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7PR1L<br>7 | TM7PR1L<br>6 | TM7PR1L<br>5 | TM7PR1L<br>4 | TM7PR1L<br>3 | TM7PR1L<br>2 | TM7PR1L<br>1 | TM7PR1L<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | • | • | • | • | • | | • | Table:6.2.8 Timer 7 Preset Register 1 Upper 8 bits (TM7PR1H:0x03F75) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7PR1<br>H7 | TM7PR1<br>H6 | TM7PR1<br>H5 | TM7PR1<br>H4 | TM7PR1<br>H3 | TM7PR1<br>H2 | TM7PR1H<br>1 | TM7PR1<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | • | • | • | | | | | #### ■ Timer 7 Preset Register 2 (TM7PR2) Table:6.2.9 Timer 7 Preset Register 2 Lower 8 bits (TM7PR2L:0x03F7C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7PR2L<br>7 | TM7PR2L<br>6 | TM7PR2L<br>5 | TM7PR2L<br>4 | TM7PR2L<br>3 | TM7PR2L<br>2 | TM7PR2L<br>1 | TM7PR2L<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | | | | | | | | Table:6.2.10 Timer 7 Preset Register 2 Upper 8 bits (TM7PR1H:0x03F7D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7PR2<br>H7 | TM7PR2<br>H6 | TM7PR2<br>H5 | TM7PR2<br>H4 | TM7PR2<br>H3 | TM7PR2<br>H2 | TM7PR2H<br>1 | TM7PR2<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | | | • | | • | | | Binary counter is a 16-bit up counter. If any data is written to a preset register when the counting is stopped, the binary counter is cleared to 0x0000. At IGBT setting, when IGBT operation is stopped, the binary counter is cleared to 0x0000. Also, by setting the register, the binary counter is cleared to 0x0000 at capture. #### ■ Timer 7 Binary Counter (TM7BC) Table:6.2.11 Timer 7 Binary Counter Lower 8 bits (TM7BCL:0x03F70) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TM7BCL7 | TM7BCL6 | TM7BCL5 | TM7BCL4 | TM7BCL3 | TM7BCL2 | TM7BCL1 | TM7BCL0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | Table:6.2.12 Timer 7 Binary Counter Upper 8 bits (TM7BCH:0x03F71) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------------|-------------|-------------|-------------|-------------|-------------|---------|-------------| | Flag | TM7BCH<br>7 | TM7BCH<br>6 | TM7BCH<br>5 | TM7BCH<br>4 | TM7BCH<br>3 | TM7BCH<br>2 | TM7BCH1 | TM7BCH<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Χ | | Access | R | | | | | | | | Input capture register is a register that holds the value loaded from a binary counter by a capture trigger. A capture trigger is generated by an input signal from an external interrupt pin, the timer 0 interrupt, the timer 1 interrupt and when an arbitrary value is written to an input capture register (Directly writing to the register by program is disabled.). ### ■ Timer 7 Input Capture Register (TM7IC) Table:6.2.13 Timer 7 Input Capture Register Lower 8 bits (TM7ICL;0x03F76) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TM7ICL7 | TM7ICL6 | TM7ICL5 | TM7ICL4 | TM7ICL3 | TM7ICL2 | TM7ICL1 | TM7ICL0 | | At reset | Х | X | Х | Х | Х | Х | Х | X | | Access | R | | | | | | | | Table:6.2.14 Timer 7 Input Capture Register Upper 8 bits (TM7ICH;0x03F77) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|-------------| | Flag | TM7ICH7 | TM7ICH6 | TM7ICH5 | TM7ICH4 | TM7ICH3 | TM7ICH2 | TM7ICH1 | TM7ICH<br>0 | | At reset | Х | Х | Х | X | Х | X | Х | Х | | Access | R | | | | | | | | ### ■ Timer 7 Dead Time Preset Register 1 (TM7DPR1) Table:6.2.15 Timer 7 Dead Time Preset Register 1 (TM7DPR1:0x03F7E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|---------|--------------| | Flag | TM7DPR<br>17 | TM7DPR<br>16 | TM7DPR<br>15 | TM7DPR<br>14 | TM7DPR<br>13 | TM7DPR<br>12 | TM7DPR1 | TM7DPR<br>10 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | • | • | • | • | • | • | | ### ■ Timer 7 Dead Time Preset Register 2 (TM7DPR2) Table:6.2.16 Timer 7 Dead Time Preset Register 2 (TM7DPR2:0x03F7F) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------| | Flag | TM7IDPR<br>27 | TM7IDPR<br>26 | TM7IDPR<br>25 | TM7IDPR<br>24 | TM7IDPR<br>23 | TM7IDPR<br>22 | TM7IDPR<br>21 | TM7IDPR<br>20 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | | | | | | | | Timer 8 has a set of 16-bit programmable timer registers, which contains a compare register, a preset register, a binary counter and a capture register. Each register has 2 sets of 8-bit register. Operate these registers by 16-bit access. A compare register is a 16-bit register which stores comparative value of the compare register and the binary counter. #### ■ Timer 8 Compare register 1 (TM8OC1) Table:6.2.17 Timer 8 Compare register 1 Lower 8 bits (TM8OC1L:0x03F82) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM8OC1L<br>7 | TM8OC1L<br>6 | TM8OC1L<br>5 | TM8OC1L<br>4 | TM8OC1L<br>3 | TM8OC1L<br>2 | TM8OC1L<br>1 | TM8OC1L<br>0 | | At reset | Х | X | X | X | X | Х | Х | Х | | Access | R | | | | | | | | Table:6.2.18 Timer 8 Compare register 1 Upper 8 bits (TM8OC1H:0x03F83) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM8OC1<br>H7 | TM8OC1<br>H6 | TM8OC1<br>H5 | TM8OC1<br>H4 | TM8OC1<br>H3 | TM8OC1<br>H2 | TM8OC1<br>H1 | TM8OC1<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | ### ■ Timer 8 Compare Register 2 (TM8OC2) Table:6.2.19 Timer 8 Compare Register 2 Lower 8bits (TM8OC2L:0x03F8A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM8OC2L<br>7 | TM8OC2L<br>6 | TM8OC2L<br>5 | TM8OC2L<br>4 | TM8OC2L<br>3 | TM8OC2L<br>2 | TM8OC2L<br>1 | TM8OC2L<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | Table:6.2.20 Timer 8 Compare Register 2 Upper 8bits (TM8OC2H:0x03F8B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM7OC2<br>H7 | TM7OC2<br>H6 | TM7OC2<br>H5 | TM7OC2<br>H4 | TM7OC2<br>H3 | TM7OC2<br>H2 | TM7OC2<br>H1 | TM7OC2<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | Timer 8 preset register 1 and 2 are buffer registers of the compare registers 1, 2 of timer 8. If the set value is written to the timer 8 preset registers 1, 2 when the counting is stopped, the same set value is loaded to the timer 7 compare register. If set value is written to the timer 8 preset registers 1, 2 during counting, the set value of the timer 8 preset registers 1, 2 is loaded to the timer 8 compare registers 1, 2 at the timing that the timer 8 binary counter is cleared. ### ■ Timer 8 Preset Register 1 (TM8PR1) Table:6.2.21 Timer 8 Preset Register 1 Lower 8 bits (TM8PR1L:0x03F84) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM8PR1L<br>7 | TM8PR1L<br>6 | TM8PR1L<br>5 | TM8PR1L<br>4 | TM8PR1L<br>3 | TM8PR1L<br>2 | TM8PR1L<br>1 | TM8PR1L<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | | | | | | | | Table:6.2.22 Timer 8 Preset Register 1 Upper 8 bits (TM8PR1H:0x03F85) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM8PR1<br>H7 | TM8PR1<br>H6 | TM8PR1<br>H5 | TM8PR1<br>H4 | TM8PR1<br>H3 | TM8PR1<br>H2 | TM8PR1H<br>1 | TM8PR1<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | X | Χ | | Access | R/W | | | | | | | | #### ■ Timer 8 Preset Register 2 (TM8PR2) Table:6.2.23 Timer 8 Preset Register 2 Lower 8 bits (TM8PR2L:0x03F8C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM8PR2L<br>7 | TM8PR2L<br>6 | TM8PR2L<br>5 | TM8PR2L<br>4 | TM8PR2L<br>3 | TM8PR2L<br>2 | TM8PR2L<br>1 | TM8PR2L<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | | | | | | | | Table:6.2.24 Timer 8 Preset Register 2 Upper 8 bits (TM8PR2H:0x03F8D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | Flag | TM8PR2<br>H7 | TM8PR2<br>H6 | TM8PR2<br>H5 | TM8PR2<br>H4 | TM8PR2<br>H3 | TM8PR2<br>H2 | TM8PR2H<br>1 | TM8PR2<br>H0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W | | | | | | | | Binary counter is a 16-bit up counter. If any data is written to a preset register when the counting is stopped, the binary counter is cleared to 0x0000. During the timer counting, the binary counter is cleared to 0x0000 at capture by setting the register. #### ■ Timer 8 Binary Counter (TM8BC) Table:6.2.25 Timer 8 Binary Counter Lower 8 bits (TM8BCL:0x03F80) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TM8BCL7 | TM8BCL6 | TM8BCL5 | TM8BCL4 | TM8BCL3 | TM8BCL2 | TM8BCL1 | TM8BCL0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | Table:6.2.26 Timer 8 Binary Counter Upper 8 bits (TM8BCH:0x03F81) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------------|-------------|-------------|-------------|-------------|-------------|---------|-------------| | Flag | TM8BCH<br>7 | TM8BCH<br>6 | TM8BCH<br>5 | TM8BCH<br>4 | TM8BCH<br>3 | TM8BCH<br>2 | TM8BCH1 | TM8BCH<br>0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Χ | | Access | R | | | | | | | | Input capture register is a register that holds the value loaded from a binary counter by a capture trigger. A capture trigger is generated by an input signal from an external interrupt pin, the timer 0 interrupt, the timer 1 interrupt and when an arbitrary value is written to an input capture register (Directly writing to the register by program is disabled.). #### ■ Timer 8 Input Capture Register (TM8IC) Table:6.2.27 Timer 8 Input Capture Register Lower 8 bits (TM8ICL:0x03F86) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TM8ICL7 | TM8ICL6 | TM8ICL5 | TM8ICL4 | TM8ICL3 | TM8ICL2 | TM8ICL1 | TM8ICL0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | Table:6.2.28 Timer 8 Input Capture Register Upper 8 bits (TM8ICH:0x03F87) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TM8ICH7 | TM8ICH6 | TM8ICH5 | TM8ICH4 | TM8ICH3 | TM8ICH2 | TM8ICH1 | TM8ICH0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | | | | | | | | ## 6.2.3 Timer Mode Registers This is a readable/writable register that controls timer 7. ■ Timer 7 Mode Register 1(TM7MD1) Table:6.2.29 Timer 7 Mode Register 1(TM7MD1:0x03F78) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|----------|--------------|-------|-------|--------|--------|--------|--------| | Flag | Reserved | T7ICEDG<br>1 | TM7CL | TM7EN | TM7PS1 | TM7PS0 | TM7CK1 | TM7CK0 | | At reset | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|----------------------------------------------------------------------------------------| | 7 | Reserved | Set always "0". | | 6 | T7ICEDG1 | Capture trigger edge selection 0:Falling edge 1:Rising edge | | 5 | TM7CL | Timer output reset signal 0:Operate timer output 1:Disable timer output | | 4 | TM7EN | Timer 7 count control 0:Halt the count 1:Operate the count | | 3-2 | TM7PS1<br>TM7PS0 | Count clock selection 00:1/1 of clock 01:1/2 of clock 10:1/4 of clock 11:1/16 of clock | | 1-0 | TM7CK1<br>TM7CK0 | Clock source selection 00:fosc 01:fs 10:TM7IO input 11:Synchronous TM7IO input | ### ■ Timer 7 Mode Register 2 (TM7MD2) ### Table:6.2.30 Timer 7 Mode Register 2 (TM7MD2:0x03F79) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|-------------|--------|--------|---------|--------|--------|--------| | Flag | T7ICEDG<br>0 | T7PWMS<br>L | TM7BCR | TM7PWM | TM7IRS1 | T7ICEN | T7ICT1 | T7ICT0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | T7ICEDG0 | Capture trigger edge selection 0:Select the both edges 1:Select the specified edge | | 6 | T7PWMSL | PWM mode selection 0:Set duty by OC1 1:Set duty by OC2 | | 5 | TM7BCR | Timer 7 count clear factor selection 0:Full count OVF 1:Match of BC and OC1 | | 4 | TM7PWM | Timer output waveform selection 0:Output timer 1:Output PWM | | 3 | TM7IRS1 | Timer 7 interrupt factor selection 0:Counter clear 1:Match of BC and OC1 | | 2 | T7ICEN | Input capture operation enable flag 0:Disable capture operation 1:Enable capture operation | | 1-0 | T7ICT1<br>T7ICT0 | Capture trigger selection 00:External interrupt 0 input signal 01:External interrupt 1 input signal 10:External interrupt 2 input signal 11:Disable | ### ■ Timer 7 Mode Register 3 (TM7MD3) Table:6.2.31 Timer 7 Mode Register 3 (TM7MD3:0x03F8E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|----------|--------------|--------------|--------------|--------------|---------|---------| | Flag | TM7CKS<br>MP | Reserved | TM7CKE<br>DG | T7IGBTT<br>R | T7IGBTD<br>T | T7IGBTE<br>N | T7IGBT1 | T7IGBT0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TM7CKSMP | Capture sampling selection 0:Count clock 1:fs | | 6 | Reserved | Set always "0". | | 5 | TM7CKEDG | TM7IO count edge selection 0:Rising edge 1:Both edges | | 4 | T7IGBTTR | IGBT trigger level selection 0:H 1:L | | 3 | T7IGBTDT | IGBT dead timer insert timing 0:Falling edge standard 1:Rising edge standard | | 2 | T7IGBTEN | IGBT operation enable 0:Disable 1:Enable | | 1-0 | T7IGBT1<br>T7IGBT0 | IGBT/timer startup factor selection 01:External interrupt 0 input signal 10:Externa interrupt 1 input signal 11:External interrupt 2 input signal 00:Timer 7 count operation | When IGBT is not selected, set as T7IGBTEN=0 T7IGBT1-0=00 ### ■ Timer 7 Mode Register 4 (TM7MD4) Table:6.2.32 Timer 7 Mode Register 4 (TM7MD4:0x03F6E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|---|---|---------------|-------------|---|--------|--------------| | Flag | - | - | - | T7ONES<br>HOT | T7NODE<br>D | - | T7ICT2 | T7CAPCL<br>R | | At reset | - | - | - | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|---------------|-------------------------------------------------------------------| | 7-5 | - | - | | 4 | T7ONESHO<br>T | One shot pulse selection 0:Continuous pulse 1:One shot pulse | | 3 | T7NODED | Dead time selection 0:With dead time 1:Without dead time | | 2 | - | - | | 1 | T7ICT2 | Capture trigger selection 0:Timer 0 interrupt 1:Timer 1 interrupt | | 0 | T7CAPCLR | BC clearance at capture 0:Clear 1:Unclear | T7CAPCLR flag is effective when timer is operating. The binary counter is uncleared when capturing at timer stop. ### This is a readable/writable register that controls timer 8. ### ■ Timer 8 Mode Register 1(TM8MD1) Table:6.2.33 Timer 8 Mode Register 1(TM8MD1:0x03F88) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|----------|--------------|-------|-------|--------|--------|--------|--------| | Flag | Reserved | T8ICEDG<br>1 | TM8CL | TM8EN | TM8PS1 | TM8PS0 | TM8CK1 | TM8CK0 | | At reset | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|------------------|----------------------------------------------------------------------------------------| | 7 | Reserved | Set always "0" | | 6 | T8ICEDG1 | Capture trigger edge selection 0:Falling edge 1:Rising edge | | 5 | TM8CL | Timer output reset signal 0:Operate timer output 1:Disable timer output (Reset) | | 4 | TM8EN | Timer 8 count control 0:Halt the count 1:Operate the count | | 3-2 | TM8PS1<br>TM8PS0 | Count clock selection 00:1/1 of clock 01:1/2 of clock 10:1/4 of clock 11:1/16 of clock | | 1-0 | TM8CK1<br>TM8CK0 | Clock source selection 00:fosc 01:fs 10:TM8IO input 11:Synchronous TM8IO input | ### ■ Timer 8 Mode Register 2 (TM8MD2) ### Table:6.2.34 Timer 8 Mode Register 2 (TM8MD2:0x03F89) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|--------------|--------|--------|---------|---------|---------|---------| | Flag | T8ICEDG<br>0 | TM8PWM<br>SL | TM8BCR | TM8PWM | TM8IRS1 | TM8ICEN | TM8ICT1 | TM8ICT0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | T8ICEDG0 | Capture trigger edge selection 0:Select the both edges 1:Select the specified edge | | 6 | TM8PWMS<br>L | PWM mode selection 0:Set duty by OC1 1:Set duty by OC2 | | 5 | TM8BCR | Timer 8 count clear factor selection 0:Full count OVF 1:Match of BC and OC1 | | 4 | TM8PWM | Timer output waveform selection 0:Output timer 1:Output PWM | | 3 | TM8IRS1 | Timer 8 interrupt factor selection 0:Counter clear 1:Match of BC and OC1 | | 2 | TM8ICEN | Input capture operation enable flag 0:Disable capture operation 1:Enable capture operation | | 1-0 | TM8ICT1<br>TM8ICT0 | Capture trigger selection 00:External interrupt 0 input signal 01:External interrupt 1 input signal 10:External interrupt 2 input signal 11:Timer interrupt | ### ■ Timer 8 Mode Register 3 (TM8MD3) ### Table:6.2.35 Timer 8 Mode Register 3 (TM8MD3:0x03F8F) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------------|---|---|--------------|--------|-------------|-------------|--------| | Flag | TM8CKS<br>MP | - | - | TM8CKE<br>DG | TM8SEL | TM8PWM<br>F | TM8PWM<br>O | TM8CAS | | At reset | 0 | - | - | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |----|----------|------------------------------------------------------------------------------| | 7 | TM8CKSMP | Capture sampling selection 0:Count clock 1:fs | | 6 | - | - | | 5 | - | - | | 4 | TM8CKEDG | TM8IO count edge selection 0:Falling edge 1:Both edges | | 3 | TM8SEL | Timer 8 output selection 0:Timer 8 output 1:IGBT output | | 2 | TM8PWMF | PWM output selection at timer 8 stopped 0:L 1:H | | 1 | TM8PWMO | Timer 8 PWM output polarity selection 0:Normal turn 1:Reverse turn | | 0 | TM8CAS | Cascade selection 0:Timer 7, Timer 8 independence 1:Timer 7, Timer 8 cascade | ### ■ Timer 8 Mode Register 4 (TM8MD4) Table:6.2.36 Timer 8 Mode Register 4 (TM8MD4:0x03F6F) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|---|---|---|---|---|--------|--------------| | Flag | - | - | - | - | - | - | T8ICT2 | T8CAPCL<br>R | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | | | | | | | | bp | Flag | Description | |-----|----------|-------------------------------------------------------------------| | 7-2 | - | - | | 1 | T8ICT2 | Capture trigger selection 0:Timer 0 interrupt 1:Timer 1 interrupt | | 0 | T8CAPCLR | BC clearance at capture 0:Cleart 1:Unclear | T7CAPCLR flag is effective when timer is operating. The binary counter is uncleared when capturing at timer stop. # 6.3 Operation ### 6.3.1 Operation The timer operation can constantly generate interrupts. 16-bit Timer Operation (Timer 7, Timer 8) The generation cycle of an timer interrupt is set by the clock source selection and the set value of the compare register 1 (TMnOC1), in advance. When the binary counter (TMnBC) reaches the set value of the compare register 1, an interrupt is generated at the next count clock. There are 2 sources to be selected to clear the binary counter; the TMnOC1 compare match and the full count overflow. After the binary counter is cleared, the counting up is restarted from 0x0000. Table:6.3.1 16-bit Timer Interrupt Source and Binary Counter Clear Source (Timer 7, Timer 8) | TM7MD2 register | | Interrupt source | Binary counter clear source | |-----------------|-------------|----------------------|-----------------------------| | TM7IRS1 flag | TM7BCR flag | | | | 1 | 1 | TM7OC1 compare match | TM7OC1 compare match | | 0 | 1 | TM7OC1 compare match | TM7OC1 compare match | | 1 | 0 | TM7OC1 compare match | Full count overflow | | 0 | 0 | Full count overflow | Full count overflow | | TM8MD2 register | | Interrupt source | Binary counter clear source | | TM8IRS1 flag | TM8BCR flag | | | | 1 | 1 | TM8OC1 compare match | TM8OC1 compare match | | 0 | 1 | TM8OC1 compare match | TM8OC1 compare match | | 1 | 0 | TM8OC1 compare match | Full count overflow | | 0 | 0 | Full count overflow | Full count overflow | Timer n can generate another set of an independent interrupt (timer n compare register 2 match interrupt) by the set value of the timer n compare register 2 (TMnOC2). At the time of the interrupt, the binary counter is cleared as the above setup. The compare register is double buffer type. So, when the value of the preset registers is changed during the counting, the changed value is stored to the compare register when the binary counter is cleared. This function can change the compare register value constantly, without disturbing the cycle during timer operation (Reload function). When the CPU reads the 16-bit binary counter (TMnBC), the read data is handled in 8-bits units even if it is a 16-bit MOVW instruction. As a result, it will read the data incorrectly if a carry from the lower 8 bits to the upper 8 bits occurs during counting operation. To read the correct value of the 16-bit counting (TMnBC), use the writing program function to the input capture register (TMnIC). By writing to the TMnIC, the counting data of TMnBC can be stored to TMnIC to read out the correct counting value during timer operation. [Chapter 6.8.1. Operation] To count properly, do not switch the count clock on the timer operation. To switch the count clock, stop the timer operation. Table:6.3.2shows the clock source that can be selected. Table:6.3.2 Clock Source at Timer Operation (Timer 7, Timer 8) | Clock source | 1 count time | |--------------------------------|--------------| | fosc | 100 ns | | fosc/2 | 200 ns | | fosc/4 | 400 ns | | fosc/16 | 1.6 μs | | fs | 200 ns | | fs/2 | 400 ns | | fs/4 | 800 ns | | fs/16 | 1.6 μs | | fosc=10 MHz<br>fs=fosc/2=5 MHz | | #### Count Timing of Timer Operation (Timer 7, Timer 8) The binary counter counts up with the selected clock source as the count clock. The basic operation of whole 16-bit timer functions is as below. Figure:6.3.1 Count Timing of Timer Operation (Timer 7, Timer 8) - (A)When a data is written to the preset register while the TMnEN flag is stopped ("0"), the same value is loaded during the writing cycle and the binary counter is cleared to 0x0000. - (B)When TMnEN flag is ("1"), the binary counter starts counting. The counting starts at the rising edge of the count clock. - (C) Even if the preset register is rewritten when the TMnEN flag is ("1"), the binary counter is not changed. - (D)When the binary counter reaches value of compare register 1, the set value of the preset register is loaded to the compare register at the next count clock. And the interrupt request flag is set at the next count clock, and the binary counter is cleared to 0x0000 to restart counting up. - (E)When the TMnEN flag is ("0"), the binary counter is stopped. When the binary counter reaches the value of the compare register, the interrupt request flag is set to the next count clock, and the binary counter is cleared. So, set the compare register as: (the set value of the compare register) = (the counts till the interrupt generation-1) When the timer n compare register 2 match interrupt is generated and TMnOC1 compare match is selected as a binary counter clear source, the set value of the compare register 2 should be smaller than the set value of the compare register. On the interrupt service routine, clear the timer interrupt request flag before the timer is started. When the binary counter is used as a free-counter that counts 0x0000 to 0xFFFF, set 0xFFFF to the compare register or set the TM7BCR flag of the TM7MD2 register to "0". When the TMnEN flag of the TMnMD register is changed with other bits, the binary counter may count up by switching operation. Set up 16-bit timer counter clock should be done when the timer interrupt is disabled. When the binary counter is read out on the timer operation, it is regarded as the data by 8 bits unit in LSI. So, when the digit is raised from lower 8 bits to upper 8 bits, correct value cannot be read out. Stop the timer to read out the correct value. ### 6.3.2 Setup Example #### ■ Timer Operation Setup Example Timer 7 generates an interrupt constantly for timer function. Fosc/2 (fosc=10 MHz at operation) is selected as a clock source to generate an interrupt every 1000 cycles (200 ms). An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter TM7MD1(0x03F78) bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD) to "0" to stop the timer 7 counting. | | (2) Disable the interrupt TM7ICR(0x03FED) bp1:TM7IE =0 | (2) Set the TM7IE flag of the TM7CIR register to "0" to disable the interrupt. | | (3) Select the timer clear source<br>TM7MD2(0x03F79)<br>bp5:TM7BCR =1 | (3) Set the TM7BCR flag of the timer 7 mode register 2 (TM7MD2) to "1" to select the compare match to the binary counter clear source. | | (4) Select the count clock source<br>TM7MD1 (0x03F78)<br>bp1-0:TM7CK1-0 =00<br>bp3-2:TM7PS1-0 =01 | (4) Select fosc to the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Besides, select 1/2 fosc to the count clock source by the TM7PS1 to 0 flag. | | (5) Select IGBT/timer startup factor<br>TM7MD3(0x03F8E)<br>bp1-0:T7IGBT1-0=00 | (5) Set IGBT/timer startup factor to timer 7 count operation. | | (6) Set the interrupt generation cycle TM7PR1(0x03F75,0x03F74) =0x03E7 | (6) Set the interrupt generation cycle to the timer 7 preset register 1 (TM7PR1). The cycle is 1000. The set value should be 1000-1=999 (0x03E7). At the time, the same value is loaded to the timer 7 compare register 1 (TM7OC1), and the timer 7 binary counter (TM7BC) is initialized to 0x0000. | | (7) Set the interrupt level TM7ICR(0x03FED) bp7-6:TM7LV1-0 =10 | (7) Set the interrupt level by the TM7LV1 to 0 flag of the timer 7 interrupt control register (TM7lCR). If the interrupt request flag is already set, clear the request flag. [Chapter 3 3.1.4. Interrupt Flag Setup] | | (8) Enable the interrupt TM7ICR (0x03FED) bp1:TM7IE =1 | (8) Set the TM7IC flag of the TM7ICR register to "1" to enable the interrupt. | | (9) Start the timer operation TM7MD1 (0x03F78) bp4:TM7EN =1 | (9) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | TM7BC counts up from 0x0000. When TM7BC reaches the set value of the TM7OC1 register, the timer 7 interrupt request flag is set at the next count clock and the TM7BC becomes 0x0000 and counts up again. # 6.4 16-bit Event Count ### 6.4.1 Operation Event count operation has 2 types; TMnIO input and synchronous TMnIO input. These can be selected as the count clock. Each type can select 1/1, 1/2, 1/4, or 1/16 as a count clock source. Also, it is possible to select the count edge. (the falling edge and the both edge at the normal operation are selectable) ■ 16-bit Event Count Operation (Timer 7, Timer 8) The binary counter (TMnBC) counts the external signal input to the TMnIO pin. If the binary counter reaches the set value of the compare register (TMnOC), an interrupt can be generated at the next count clock. Table:6.4.1 | | Timer 7 | Timer 8 | |-------------|-------------------------|-------------------------| | Event input | TM7IO input (P13) | TM8IO input (P12) | | | Synchronous TM7IO input | Synchronous TM8IO input | #### ■ Count Timing of TMnIO Input When TMnIO input is selected, TMnIO input signal is input to the timer n count clock. The binary counter counts up at the falling edge of the TMnIO input signal or TMnIO input signal that passed the divider. Figure: 6.4.1 Count Timing TMnIO Input (Timer 7, Timer 8) If the binary counter is read out during operation, incorrect data at counting up may be read. Also, the binary counter may have unexpected value at the timer stopped. To prevent this, use the event count by the synchronous TMnIO input, which is shown in the following page. When using TMnIO input, after selecting fs as the count clock first, then set each mode register and preset register. After that, operate the timer on selecting TMnIO input. Do not write any data to the preset register on the operation. Only TMnIO input can recover from STOP mode in 16-bit timer. When using the event input (TMnIO input), clear the binary counter before starting the timer operation. Also, when setting 0x00000 to the compare register, use the event count by TMnIO input which is shown below. When the event input (TMnIO input) is selected as the count clock source, even if the set value is written to the preset register at the timer stop, the same set value may not be loaded to the compare register. To prevent this, select the system clock (fx) for the count clock source once, write the set value to the preset register, then select the event input (TMnIO) as the clock source to start the timer operation. The binary counter should not be read out after the timer operation is stopped when setting the event input (TMnIO input) as the count clock source as the binary counter may reach to an unexpected value. #### ■ Count Timing of Synchronous TMnIO Input (Timer 7, Timer 8) If the synchronous TMnIO input is selected, the synchronizing circuit output signal is input to the timer n count clock. The synchronizing circuit output signal is changed at the falling edge of the system clock after the TMnIO input signal is changed. The binary counter counts up at the falling edge of the synchronizing circuit output signal or the synchronizing circuit output signal that passed through the division circuit. Figure: 6.4.2 Count Timing of Synchronous TMnIO Input (Timer 7, Timer 8) The timer n binary counter counts up the binary counter at the signal in synchronization with the system clock so that correct value is read out from the timer n binary counter. ### Count Timing of TMnIO Input (Both edges selected) When TMnIO input is selected, TMnIO input signal is input to the timer n count clock. The binary counter counts up at the falling edge of the TMnIO input signal or TMnIO input signal that passed the divider. Figure: 6.4.3 Count Timing TMnIO Input (Timer 7, Timer 8) When both edges are selected, they are counted only at the normal operation (high-speed oscillation). Input from TMnIO should be done the waveform which has more than 2 times cycle than fosc (when duty ratio is 50%). If the waveform which has less cycle is input, it may not be counted correctly. ### 6.4.2 Setup Example ### ■ Event Count Setup Example When the falling edge of the TM7IO input pin signal is detected 5 times using timer 7, an interrupt is generated. An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM7MD1 (0x03F78)<br>bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | (2) Disable the interrupt TM7ICR(0x03FED) bp1:TM7IE =0 | (2) Set the TM7IE flag of the TM7ICR register to "0 "to disable the interrupt. | | (3) Set the special function pin to input<br>P1DIR (0x03F31)<br>bp3:P1DIR3 =0 | (3) Set the P1DIR3 flag of the port 1 direction control register (P1DIR) to "0" to set P13 pin to the input mode. Add pull-up/pull-down resistor, if necessary. [Chapter 4 I/O ports] | | (4) Select the count clock source<br>TM7MD1(0x03F78)<br>bp1-0:TM7CK1-0 =01<br>bp3-2:TM7PS1-0 =00 | (4) Select fs to the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Besides, select 1/1 to the count clock source by the TM7PS1 to 0 flag. | | (5) Select IGBT/timer startup factor<br>TM7MD3(0x03F8E)<br>bp1-0:T7IGBT1-0=00 | (5) Set IGBT/timer startup factor to timer 7 count operation. | | (6) Set the interrupt generation cycle TM7PR1(0x03F75,0x03F74) =0x0004 | (6) Set the interrupt generation cycle to the timer 7 preset register 1 (TM7PR1). The set value should be 4, because the counting is 5 times. At that time, the same value is loaded to the timer 7 compare register 1 (TM7OC1), and the timer 7 binary counter (TM7BC) is initialized to 0x0000. | | (7) Select the timer clear source<br>TM7MD2 (0x03F79)<br>bp5:TM7BCR =1 | (7) Set the TM7BCR flag of the timer 7 mode register 2 (TM7MD2) to "1" to select the compare match as a binary counter clear source. | | (8) Select the count clock source<br>TM7MD1 (0x03F78)<br>bp1-0:TM7CK1-0 =10<br>bp3-2:TM7PS1-0 =00 | (8) Select TM7IO to the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Besides, select 1/1(no dividing) to the count clock source by the TM7PS1 to 0 flag. | | (9) Set the interrupt level TM7ICR (0x03FED) bp7-6:TM7LV1-0 =10 | (9) Set the interrupt level by the TM7LV1 to 0 flag of the<br>timer 7 interrupt control register (TM7ICR). If the<br>interrupt request flag is already set, clear the request<br>flag.<br>[Chapter 3 3.1.4. Interrupt Flag Setup] | | Setup Procedure | Description | |----------------------------------------------------------------|--------------------------------------------------------------------------------| | (10) Enable the interrupt TM7ICR (0x03FED) bp1:TM7IE =1 | (10) Set the TM7IE flag of the TM7ICR register to "1" to enable the interrupt. | | (11) Start the event count<br>TM7MD1 (0x03F78)<br>bp4:TM7EN =1 | (11) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | Every time TM7BC reaches the falling edge of the TM7IO input, it counts up from 0x0000. When the TM7BC reaches the set value of the TM7OC1 register, the timer 7 interrupt request flag is set at the next count clock, and the value of TM7BC becomes 0x0000 to restart counting up. Allow the setup procedures (4) to (8) to have the correct operation. # 6.5 16-bit Timer Pulse Output # 6.5.1 Operation TMnIO pin can output a pulse signal with a arbitrary frequency. ■ 16-bit Timer Pulse Output Operation (Timer 7, Timer 8) These timers can output $2 \times \text{cycle}$ signal, compared with the set value of the compare register 1 (TMnOC1) and the 16-bit full count. Output pins are as follows. Table:6.5.1 Timer Pulse Output Pin | | Timer 7 | Timer 8 | |------------------|-----------------------|-----------------------| | Pulse output pin | TM7IO output<br>(P13) | TM8IO output<br>(P12) | | | TM7O output<br>(P51) | TM8O output<br>(P53) | Table:6.5.2 shows the timer interrupt generation sources and the flags that control the timer pulse output cycle. Table:6.5.2 16-bit Timer Interrupt Generation Source and Timer Pulse Output Cycle (Timer 7, Timer 8) | TM7MD2 register | | Interrupt source | Timer pulse output cycle | |-----------------|-------------|----------------------|--------------------------| | TM7IRS1 flag | TM7BCR flag | | | | 1 | 1 | TM7OC1 compare match | Set value of TM7OC1 × 2 | | 0 | 1 | TM7OC1 compare match | Set value of TM7OC1 × 2 | | 1 | 0 | TM7OC1 compare match | Full count of TM7BC × 2 | | 0 | 0 | Full count over flow | Full count of TM7BC × 2 | | TM8MD2 register | | Interrupt source | Timer pulse output cycle | | TM8IRS1 flag | TM8BCR flag | | | | 1 | 1 | TM8OC1 compare match | Set value of TM8OC1 × 2 | | 0 | 1 | TM8OC1 compare match | Set value of TM8OC1 × 2 | | 1 | 0 | TM8OC1 compare match | Full count of TM8BC × 2 | | 0 | 0 | Full count over flow | Full count of TM8BC × 2 | Figure: 6.5.1 Count Timing of Timer Pulse Output (Timer 7, Timer 8) TMnIO output pin outputs $2 \times$ cycle, compared with the value of the compare register 1. If the binary counter reaches the compare value or full count overflow is occurred, the binary counter is cleared to 0x0000, and the TMnIO output (timer output) is inverted. In the initial state after releasing reset, the timer pulse output is reset, and low output is fixed. Therefore, release the reset of the timer pulse output by setting the TMnCL flag of the TMnMD1 register to "0". Regardless of whether the binary counter is stopped or operated, the timer output is "L", when the TMnCL flag of the TMnMD1 register is set to "1". Reset release of the timer pulse output should be done when the timer count is stopped. When the prescaler is operated by the timer pulse output, set the prescaler dividing rate after the reset release of the timer pulse output. # 6.5.2 Setup Example # ■ Timer Pulse Output Setup Example TM7IO output pin outputs a 50 kHz pulse using timer 7. For this, select fosc as the clock source and set 1/2 cycle (50 kHz) to the timer 7 compare register (at fosc=10 MHz). An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counting TM7MD1 (0x03F78) bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | (2) Set the special function pin P10MD (0x03F1C) bp3:P10MD3 =1 bp2:NBUZSEL=1 P1DIR (0x03F31) bp3:P1DIR3 =1 | (2) Set the P1OMD3 flag of the port 1 output mode register (P1OMD) to "1", the NBUZSEL flag to "1" to set P13 as the special function pin. Set the P1DIR3 flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. [Chapter 4 I/O Ports] | | (3) Set the timer pulse<br>TM7MD2 (0x03F79)<br>bp4:TM7PWM =0 | (3) Set the TM7PWM flag of the timer 7 mode register 2 (TM7MD2) to "0" to select the timer pulse output. | | (4) Select the timer clear source<br>TM7MD2 (0x03F79)<br>bp5:TM7BCR =1 | (4) Set the TM7BCR flag of the TM7MD2 register to "1" to select the compare match as the binary counter clear source. | | (5) Release the reset of the timer pulse<br>TM7MD1 (0x03F78)<br>bp5:TM7CL =0 | (5) Set the TM7CL flag of the TM7MD1 register to "0" to enable the pulse output. | | (6) Select the count clock source<br>TM7MD1 (0x03F78)<br>bp1-0:TM7CK1-0 =00<br>bp3-2:TM7PS1-0 =00 | (6) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/1 dividing as the clock source by the TM7PS1 to 0 flag. | | (7) Select IGBT/timer startup factor<br>TM7MD3(0x03F8E)<br>bp1-0:T7IGBT1-0=00 | (7) Set IGBT/timer startup factor to timer 7 count operation. | | (8) Set the timer pulse output generation cycle TM7PR1(0x03F75,0x03F74) =x00C7 | (8) Set 1/2 of the timer pulse output cycle to the timer 7 preset register 1 (TM7PR1). To set 50 kHz by dividing 10 MHz, set as; 200-1=199 (0xC7) At the same time, the same value is loaded to the timer 7 compare register 1 (TM7BC) and the timer 7 binary counter (TM7BC) is initialized to 0x0000. | | (9) Start the timer operation TM7MD1 (0x03F78) bp4:TM7EN =1 | (9) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | TM7BC counts up from 0x0000. If TM7BC reaches the set value of the TM7OC1 register and TM7BC is cleared to 0x0000, the signal of the TM7IO output is inverted and TM7BC counts up from 0x0000 again. # 6.6 16-bit Standard PWM Output (Only duty can be changed consecutively) TMnIO pin outputs the standard PWM output, which is determined by the overflow timing of the binary counter, and the match timing of the timer binary counter and the compare register. # 6.6.1 Operation 16-bit Standard PWM Output (Timer 7, Timer 8) PWM waveform with an arbitrary duty is generated by setting a duty of PWM "H" period to the compare register 1 (TMnOC1). Its cycle is the time of the 16-bit timer full count overflow. Table:6.6.1 shows the PWM output pin. Table: 6.6.1 PWM Output Pin | | Timer 7 | Timer 8 | |-----------------------|--------------------|--------------------| | Pulse out-<br>put pin | TM7IO output (P13) | TM8IO output (P12) | | | TM7O output (P51) | TM8O output (P53) | ■ Count Timing of Standard PWM Output (at Normal) (Timer 7, Timer 8) Figure: 6.6.1 Count Timing of Standard PWM Output (at Normal) ■ Stop Condition of PWM Waveform, Polarity Selection (Timer 8) Select the TM8IO/TM8O output waveform for the time when the PWM operation is stopped by the TM8PWMF of the TM8MD3 register. Select the polarity of PWM output by the TM8PWMO. Before starting the second PWM or later, clear the BC and PWM waveform by writing to the preset register as the PWM output waveform of the first cycle cannot be guaranteed. #### PWM source waveform, - (A)shows "H" until the binary counter reaches the compare register value from 0x0000. - (B)shows "L" after the compare match, then the binary counter counts up till the overflow. - (C)shows "H" again if the binary counter overflow. - Count Timing of Standard PWM Output (when compare register 1 is 0x0000) (Timer 7, Timer 8) Here is the count timing at setting 0x0000 to the compare register 1. Figure: 6.6.2 Count Timing of Standard PWM Output (when compare register 1 is 0x0000) PWM output shows "H", when TMnEN flag is stopped (at "0"). ■ Count Timing of Standard PWM Output (when compare register 1 is 0xFFFF) (Timer 7, Timer 8) Here is the count timing at setting 0xFFFF to the compare register 1. Figure: 6.6.3 Count Timing of Standard PWM Output (when compare register 1 is 0xFFFF) To output the standard PWM output, set the TMnBCR flag of the TM7MD2 or TM8MD2 register to "0" to select the full count overflow as the binary counter clear source and the PWM output set ("H" output) source. The TMnOC1 compare match or the TMnOC2 compare match can be selected as a PWM output reset ("L" output) source with the TnPWMSL flag of the TMnMD2 register. In the initial state of the PWM output, it is changed to "H" output from "L" output at the timing that the PWM operation is selected by the TMnPWM flag of the TMnMD2 register. To guarantee the PWM waveform of the first cycle, after PWM operation is stopped, write to the preset register to clear the binary counter and the PWM waveform when restarting the PWM operation. # 6.6.2 Setup Example ## ■ Standard PWM Output Setup Example The TM7IO output pin outputs the 1/4 duty PWM output waveform at 152.6 Hz with the timer 7 (at the high frequency oscillation, fosc=10 MHz). One cycle of the PWM output waveform is decided by the overflow of the binary counter. "H" period of the PWM output waveform is decided by the set value of the compare register 1. An example setup procedure, with a description of each step is shown below. Figure: 6.6.4 Output Waveform of | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM7MD1 (0x03F78)<br>bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | (2) Set the special function pin to output P1OMD (0x03F1C) bp3:P1OMD3 =1 bp2:NBUZSEL=1 P1DIR (0x03F31) bp3:P1DIR3 =1 | (2) Set the P10MD3 flag of the port 1 output mode register (P10MD) to "1", NBUZSEL flag to "1" to set the P13 pin as a special function pin. Set the P1DIR3 flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. [Chapter 4 I/O Ports] | | (3) Set the PWM output<br>TM7MD2 (0x03F79)<br>bp4:TM7PWM =1 | (3) Set the TM7PWM flag of the timer 7 mode register 2 (TM7MD2) to "1" to select the PWM output. | | (4) Set the standard PWM output<br>TM7MD2 (0x03F79)<br>bp5:TM7BCR =0 | (4) Set the TM7BCR flag of the TM7MD2 register to "0" to select the full count overflow as the binary counter clear source. | | (5) Select the count clock source<br>TM7MD1 (0x03F78)<br>bp1-0:TM7CK1-0 =00<br>bp3-2:TM7PS1-0 =00 | (5) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/1 dividing as the count clock source by the TM7PS1 to 0 flag. | | (6) Select IGBT/timer startup factor<br>TM7MD3(0x03F8E)<br>bp1-0:T7IGBT1-0=00 | (6) Set IGBT/timer startup factor to timer 7 count operation. | | Setup Procedure | Description | |-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (7) Set "H" period of the PWM output<br>TM7PR1(0x03F75,0x03F74) =0x4FFF | (7) Set "H" period of the PWM output to the timer 7 preset register 1 (TM7PR1). To set 1/4 duty of the full count 65536, set as; 65536/4-1=16383 (0x03FFF) At the same time, the same value is loaded to the timer 7 compare register 1 (TM7OC1) and the timer 7 binary counter (TM7BC) is initialized to 0x0000. | | (8) Start the timer operation TM7MD1 (0x03F78) bp4:TM7EN =1 | (8) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | TM7BC counts up from 0x0000. The PWM source waveform outputs "H" until TM7BC reaches the set value of the TM7OC1 register, then after the match it outputs "L". After that, TM7BC continues to count up. Once a overflow occurs, the PWM source waveform outputs "H" again, and TM7BC counts up from 0x0000, again. # 6.7 16-bit High Precision PWM Output (Cycle/Duty can be changed consecutively) The TMnIO pin outputs high precision PWM output, which is determined by the match timing of the timer binary counter and the compare register 1, and match timing of the binary counter and the compare register 2. # 6.7.1 Operation ■ 16-bit High Precision PWM Output Operation (Timer 7, Timer 8) The PWM waveform of any cycle/duty is generated by setting the cycle of PWM to the compare register 1 (TMnOC1) and setting the duty of the "H" period to the compare register 2 (TMnOC2). Count Timing of High Precision PWM Output (at Normal) (Timer 7, Timer 8) Figure: 6.7.1 Count Timing of High Precision PWM Output (at Normal) PWM source waveform, (A) shows "H" until the binary counter reaches the compare register from 0x0000. (B)shows "L" after the TMnOC2 compare match, the binary counter then counts up until the binary counter reaches the TMnOC1 compare register is cleared. (C)shows "H" again, when the binary counter is cleared. ■ Count Timing of High Precision PWM Output (When the compare register 2 is 0x0000) (Timer 7, Timer 8) Here is the count timing as the compare register 2 is set to 0x0000. Figure:6.7.2 Count Timing of High Precision PWM Output (When the compare register 2 is 0x0000) When the TMnEN flag is stopped (at "0"), the PWM output shows "H". ■ Count Timing of High Precision PWM Output (At the compare register 2 = the compere register 1-1) Figure:6.7.3 Count Timing of High Precision PWM Output (At the compare register 2 = the compare register 1-1) To output the high precision PWM output, set the TMnBCR flag of the TMnMD2 register to "1" to select the TM7OC1 compare match as the clear source for the binary counter, and the set ("H" output) source of the PWM output. Also, set the TnPWMLS flag to "1" to select the TMnOC2 compare match as the reset ("L" output) source of the PWM output. In the initial state of the PWM output, it is changed to "H" output from "L" output at the timing that the PWM operation is selected by the TMnPWM flag of the TMnMD register. Set as the set value of TMnOC2 < the set value of TMnOC1. If it is set as the set value of TMnOC2 ≥ the set value of TMnOC1, the PWM output is a "H" fixed output. # 6.7.2 Setup Example # ■ High Precision PWM Output Setup Example (Timer 7, Timer 8) The TM7IO output pin outputs the 1/4 duty PWM output waveform at 400 Hz with the timer 7. Select fosc/2 (at fosc=10 MHz) as the clock source. One cycle of the PWM output waveform is decided by the set value of the compare register 1. "H" period of the PWM output waveform is decided by the set value of the compare register 2. An example setup procedure, with a description of each step is shown below. Figure: 6.7.4 Output Waveform of TM7IO Output Pin | Setup Procedure | Description | |---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter TM7MD1(0x03F78) bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | (2) Set the special function pin to output P1OMD(0x03F1C) bp3:P1OMD3 =1 bp2:NBUZSEL=1 P1DIR (0x03F31) bp3:P1DIR3 =1 | (2) Set the P1OMD3 flag of the port1 output mode register (P1OMD) to "1", the NBUZSEL flag to "1" to set P13 pin as the special function pin. Set the P1DIR3 flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. [Chapter 4 I/O Ports] | | (3) Set the PWM output<br>TM7MD2(0x03F79)<br>bp4:TM7PWM =1 | (3) Set the TM7PWM flag of the timer 7 mode register 2 (TM7MD2) to "1" to select the PWM output. | | (4) Set the high precision PWM output<br>TM7MD2(0x03F79)<br>bp5:TM7BCR =1<br>bp6:T7PWMSL =1 | (4) Set the P1DIR4 flag of the port 1 direction control register (P1DIR) to "1" to select the TM7OC2 compare match as the duty decision source of the PWM output. | | (5) Select the count clock source<br>TM7MD1(0x03F78)<br>bp1-0:TM7CK1-0 =00<br>bp3-2:TM7PS1-0 =00 | (5) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/1 dividing as the count clock source by the TM7PS1 to 0 flag. | | (6) Select IGBT/timer startup factor<br>TM7MD3(0x03F8E)<br>bp1-0:T7IGBT1-0=00 | (6) Set IGBT/timer startup factor to timer 7 count operation. | | Setup Procedure | Description | |--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (7) Set the PWM output cycle<br>TM7PR1(0x03F75,0x03F74) =0x61a7 | (7) Set the PWM output cycle to the timer 7 preset register 1 (TM7PR1). To set 400 Hz by dividing 10 MHz, set as; 25000-1=24999 (0x61a7) | | | At the same time, the same value is loaded to the timer 7 compare register 1 (TM7OC1), the timer 7 binary counter is initialized to 0x0000. | | (8) Set the "H" period of the PWM output TM7PR2(0x03F7D,0x03F7C) =0x1869 | (8) Set "H" period of the IGBT output to the timer 7 preset register 2 (TM7PR2). To set 1/4 duty of 25000 dividing, set as; 25000/4=6250 (0x1869) At the same time, the same value is loaded the timer 7 compare register 2 (TM7OC2). | | (9) Start the timer operation TM7MD1(0x03F78) bp4:TM7EN =1 | (9) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | TM7BC counts up from 0x0000. The PWM source waveform outputs "H" until TM7BC matches the set value of the TM7OC2 register. Once they matches, it outputs "L". After that, TM7BC continues to count up. Once TM7BC matches the TM7OC1 register to be cleared, the PWM output waveform outputs "H" again and TM7BC counts up from 0x0000 again. # 6.8 16-bit Timer Capture # 6.8.1 Operation The value of the binary counter is read out at the timing of the external interrupt input signal which is synchronized to fosc, fs or the external event signal, at the timing of the timer 0 and timer 1 interrupts or at the timing of the writing operation with any value to the capture register. ■ Capture Operation with External Interrupt Signal as the Trigger (Timer 7, Timer 8) Input capture trigger is generated at the external interrupt signal. The capture trigger is selected by the timer 7 mode register 1 (TMnMD1) and the timer mode register 2 (TMnMD2). Selectable capture triggers and the interrupt flag setup are shown below. Table: 6.8.1 Capture Trigger | Capture trigger source | Timer 7 mode register 2 | | Timer 7 mode register 1 | Timer 8 mode register 2 | | Timer 7 mode register 2 | |------------------------|-------------------------|--------------|-------------------------|-------------------------|--------------|-------------------------| | | T7ICT1-0 | T7ICED<br>G0 | T7ICEDG1 | T8ICT1-0 | T8ICED<br>G0 | T8ICEDG1 | | IRQ0 falling edge | 00(IRQ0) | 1 | 0 | 00(IRQ0) | 1 | 0 | | IRQ0 rising edge | 00(IRQ0) | 1 | 1 | 00(IRQ0) | 1 | 1 | | IRQ0 both edges | 00(IRQ0) | 0 | × | 00(IRQ0) | 0 | × | | IRQ1 falling edge | 01(IRQ1) | 1 | 0 | 01(IRQ1) | 1 | 0 | | IRQ1 rising edge | 01(IRQ1) | 1 | 1 | 01(IRQ1) | 1 | 1 | | IRQ1 both edges | 01(IRQ1) | 0 | × | 01(IRQ1) | 0 | × | | IRQ2 falling edge | 10(IRQ2) | 1 | 0 | 10(IRQ2) | 1 | 0 | | IRQ2 rising edge | 10(IRQ2) | 1 | 1 | 10(IRQ2) | 1 | 1 | | IRQ2 both edges | 10(IRQ2) | 0 | × | 10(IRQ2) | 0 | × | If the system clock (fs) is selected as the capture clock and the capture operation is done during the TMnIO input or operation with fosc, an incomplete value at the count up of the binary counter may be written to the input capture register. To prevent this, use fx or synchronous TMnIO input as the count clock. Capture trigger signals of the 16-bit timers 7 and 8 are generated by sampling the rising edge of the capture clock selected by the TMnCKSMP flag of the TMnMD3 register. Therefore, even capture trigger is input, the value of the binary counter is not loaded to the capture register until the rising edge of the next capture clock. If the clock which is slower than CPU operation speed (fs) is set as the timer source clock, set the TMnCKSMP of the TMnMD3 register to fs. Also, the interval of each capture trigger should be set more than 2 cycles of the clock which is set at the TMnCKSMP of the TMnMD3 register. If the capture clock frequency is longer against the system clock, the value of the capture register may be read out before capturing. ■ Capture Count Timing as Both Edges of External Interrupt Signal is selected as Trigger (Timer 7, Timer 8)) Figure: 6.8.1 Capture Count Timing as External Interrupt Signal is selected as Trigger (Timer 7, Timer 8) A capture trigger is generated at the both edges of the external interrupt m input signal. In synchronized with this capture trigger, the value of binary counter is loaded to the input capture register. The value loaded to the capture register is depending on the value of the binary counter at the falling edge of the capture trigger. When the specified edge is selected as the capture trigger source, the capture trigger is generated only at that edge. The other count timing is the same as the count timing of the timer operation. When the binary counter is used as a free counter which counts 0x0000 to 0xFFFF set the compare register 1 to 0xFFFF, or set the TMnBCR flag of the TM7MD2 to "0". Even if an event is generated before the value of the input capture register is read out, the value of the input capture register can be rewritten. In the initial state after releasing the reset, the generation of trigger by the external interrupt signal is disabled. Set the TnICEN flag of the TMnMD2 register to "1" to enable the trigger generation. ■ Capture Operation as Timer 0 and 1 interrupts are selected as Trigger (Timer 7, Timer 8) A capture trigger of the input capture function is generated by the timer 0 and 1 interrupts signals. Select the capture trigger by the timer mode register 2 (TMnMD2) and the timer mode register 4 (TMnMD4). When the timer 0 and 1 interrupts signals are selected as the capture trigger, the edges of the capture trigger are disabled. Figure: 6.8.2 Capture Operation as Timer 0 and 1 interrupts are selected as Trigger (Timer 7, Timer 8) When the T7ICT1-0 flag of the timer mode register 2 is set to x'11', a capture trigger of the input capture function is generated by the timer 0 and 1 interrupts signals. Select the capture trigger by the timer mode register 2 (TMnMD2) and the timer mode register 4 (TMnMD4). When the timer 0 and 1 interrupts signals are selected as the capture trigger, the edges of the capture trigger are disabled. When setting the capture clock as the count clock to execute the event count operation, the timer 0, 1 interrupt signal may not be recognized. To prevent this, select the synchronous TMnIO input as the clock source. # ■ Binary Counter Clearance at the Timing of Capture (Timer 7, Timer 8) When selecting the external interrupt input signal or the timer 0 and 1 interrupts as the capture trigger, the binary counter can be cleared during capture operation by setting the TnCAPCLR flag of the timer mode register 4 (TMnMD4) to "1". The binary counter can be cleared during timer count operation only. Figure: 6.8.3 Binary Counter Clearance at the Timing of Capture (Timer 7, Timer 8) ■ Capture Operation Triggered by Writing Software (Timer 7, Timer 8) Figure: 6.8.4 Capture Count Timing Triggered by Writing Software (Timer 7, Timer 8) The capture trigger is generated at the writing signal to the input capture register. The writing signal is generated at the last cycle of the writing instruction. In synchronized with this capture trigger, the value of the binary counter is loaded to the input capture register. The value is depending on the value of the binary counter at the falling edge of the capture trigger. The other timing is the same as the timer operation. The writing to the input capture to generate the capture trigger should be done with 8-bit access instruction of the TMnICL register or the TMnICH register. At this time, data is not actually written to the TMnIC register. On hardware, there is no flag to disable the capture operation triggered by writing software. Capture operation is enabled regardless of the TnICEN flag of the TMnMD2 register. # 6.8.2 Setup Example # ■ Capture Function Setup Example Figure:6.8.5 Pulse Width Measurement of External Interrupt 0 | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter TM7MD1(0x03F78) bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | (2) Disable the interrupt IRQ0ICR(0x03FE2) bp1:IRQ0IE =0 | (2) Set the IRQIE flag of the IRQ0ICR register to "0" to disable the interrupt. | | (3) Select the timer clear source<br>TM7MD2(0x03F79)<br>bp5:TM7BCR =1 | (3) Set the TM7BCR flag of the timer 7 mode register 2 (TM7MD2) to "1" to select the compare match as the binary counter clear source. | | (4) Select the count clock source<br>TM7MD1(0x03F78)<br>bp1-0:TM7CK1-0 =00<br>bp3-2:TM7PS1-0 =00 | (4) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/1 dividing of fosc as the count clock source by the TM7PS1 to 0 flag. | | (5) Select IGBT/timer startup factor<br>TM7MD3(0x03F8E)<br>bp1-0:T7IGBT1-0=00 | (5) Set IGBT/timer startup factor to timer 7 count operation. | | (6) Set the compare register TM7PR1(0x03F75,0x03F74) =0xFFFF | (6) Set 0xFFFF to the timer 7 preset register 1(TM7PR1). At that time, the same value is loaded to the timer 7 compare register 1 (TM7OC1), the timer 7 binary counter (TM7BC) is initialized to 0x0000. | | (7) Select the capture trigger generation interrupt source TM7MD2(0x03F79) bp1-0:T7ICT1-0 =00 | (7) Select the external interrupt 0 (IRQ0) input as the capture trigger generation source by the T7ICT1 to 0 flag of the TM7MD2 register. | | (8) Select the capture trigger generation edge TM7MD1(0x03F78) bp6:T7ICEDG1 =1 TM7MD2 (0x03F79) bp7:T7ICEDG0 =1 | (8) Set the T7ICEDG1 flag of the TM7MD1 register to "1" to select the rising edge as the capture trigger generation edge. Also, set the T7ICEDG0 flag of the TM7MD2 register to "1" to enable the specify edge as the capture trigger generation source. | | Setup Procedure | Description | |--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (9) Select the capture sampling TM7MD3(0x03F8E) bp7:TM7CKSMP =0 | (9) Select the capture sampling as the count clock. | | (10) Select the interrupt generation valid edge IRQ0ICR(0x03FE2) bp5:REDG0 =1 | (10) Set the REDG0 flag of the external interrupt 0 control register (IRQ0ICR) to "1" to select the rising edge as the interrupt generation valid edge. | | (11) Set the interrupt level IRQ0ICR(0x03FE2) bp7-6:IRQ0LV1-0 =10 | (11) Set the interrupt level by the IRQ0LV1 to 0 flag of the IRQ0ICR register. If the interrupt request flag is already set, clear the request flag. [Chapter 3 3.1.4. Interrupt Flag Setup] | | (12) Enable the interrupt IRQ0ICR(0x03FE2) bp1:IRQ0IE =1 | (12) Set the IRQ0IE flag of the IRQ0ICR register to "1" to enable the interrupt. | | (13) Enable the capture trigger generation<br>TM7MD2(0x03F79)<br>bp2:T7ICEN =1 | (13) Set the T7ICEN flag of the TM7MD2 register to "1" to enable the capture trigger generation. | | (14) Start the timer operation<br>TM7MD1(0x03F78)<br>bp4:TM7EN =1 | (14) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | TM7BC counts up from 0x0000. At the timing of the rising edge of the external interrupt 0 input signal, the value of TM7BC is loaded to the TM7IC register. At that time, the pulse width between rising edge of the external interrupt input signal can be measured by reading the value of the TM7IC register through interrupt service routine, and calculating the difference between the capture values. # 6.9 16-bit High Precision IGBT Output (Cycle/Duty can be changed consecutively) High precision IGBT output starts counting by the external interrupt input signal as the trigger. Startup trigger can be selected by the external interrupt 0, 1 and 2 or starting of the timer 7 count operation. When counting starts, the operation is the same as the high precision PWM output. # 6.9.1 Operation #### ■ IGBT Trigger Selection IGBT trigger can be selected from IRQ0, IRQ1, IRQ2 and the start of the timer 7 count operation. Setup should be done at the T7IGBT0 and T7IGBT1 flag of the TM7MD3 register. When the startup is controlled from external of the microcontroller, one of IRQ0 to IRQ2 should be selected. This trigger detects the input level before activation. Either "H" or "L" level can be selected with the T7IGBTTR flag of the TM7MD3 register. When "1" (the rising edge) is selected, count operation continues while the trigger pin is "H". When "0" (the falling edge) is selected, count operation continues while the trigger pin is "L". To control the startup by the commands, TM7EN count operation should be selected. In that case, timer count operation or IGBT output are controlled by the TM7EN flag of the TM7MD1 register. When "1" (count operation) is selected, count continues counting until "0" (count stop) is set. Make sure to set the TM7IGBT0, 1 of the TM7MD3 register before operating the TM7EN flag of the TM7MD1 register. In that case, setup of T7IGBTTR is neglected. The binary counter is cleared as the counting stops. The value is loaded from the preset register to the compare register in synchronization with the counter clock. 16-bit High Precision IGBT Output (Timer 7) The IGBT waveform of any cycle/duty is generated by setting the cycle of IGBT to the compare register 1 (TM7OC1) and setting the duty of the "H" period to the compare register 2 (TM7OC2). The 16 bit timer that can be used by high precision IGBT output is the timer 7. One shot Pulse Output Setup One shot pulse output can be done by setting the T7ONESHOT flag of the TM7MD4 register to "1". ■ Count Timing of High Precision IGBT Output (At Normal) (Timer 7) Figure: 6.9.1 Count Timing of High Precision IGBT Output (At Normal) - (A) When IGBT trigger is input, IGBT operation becomes valid after 1 count clock. After IGBT output is valid, it is "L" until the next count clock. - (B) When IGBT trigger is valid, it is "H" during the period when the value of the binary counter reaches that of TM7OC2 from X'0000'. ("H" output from X'0001 at the first operation cycle) - (C) After the TM7OC2 compare match, it is "L" and the binary counter counts up until the counter reaches the TM7OC1 compare register to be cleared. - (D) When the binary counter is cleared, it becomes "H" again. - (E) When IGBT trigger becomes invalid, the timer is initialized and IGBT output forcibly becomes "L". - Count Timing of High Precision IGBT Output (When the compare register 2 is X'0000') (Timer 7) The following shows the count timing as the compare register 2 is set to X'0000'. Figure: 6.9.2 Count Timing of High Precision IGBT Output (When the compare register 2 is X'0000') When the TM7EN flag is set to "0" (stop status) and the T7IGBTDT of the TM7MD3 register is set to "0", both TM7IO and TM8IO output "L". Count Timing of High Precision IGBT Output (When compare register 2 = compare register 1) (Timer 7) The following shows the count timing when the value of the compare register 1 is set to the compare register 2. Figure: 6.9.3 Count Timing of High Precision IGBT Output (When compare register 2 = compare register 1) For high precision IGBT output, set the TM7BCR flag of the TM7MD2 register to "1" and select TM7OC1 compare match as the binary counter clear factor and IGBT output set ("H" output) factor. Also, set the T7PWMSL flag of the TM7MD2 register to "1" and select the TM7OC2 compare match as the IGBT output reset ("L" output) factor. In the initial state of the IGBT output (TM7IO), when the IGBT output is selected by the T7IGBTEN of the TM7MD3 register, it is "L" output. After the trigger is input, it changes to "H" at the second cycle. Set as TM7OC2 value ≤ TM7OC1 value. When TM7OC2 value > TM7OC1 value, the IGBT output waveform is fixed to "H". ■ One Shot Pulse Output of High Precision IGBT Output (At Normal) (Timer 7) Figure: 6.9.4 One Shot Pulse Output of High Precision IGBT Output (At Normal) (Timer 7) ■ One Shot Pulse Output of High Precision IGBT Output (When the compare register 2 is X'0000') (Timer 7) Figure:6.9.5 One Shot Pulse Output of High Precision IGBT Output (When the compare register 2 is X'0000') (Timer 7) ■ One Shot Pulse Output of High Precision IGBT Output (When compare register 2 = compare register 1) (Timer 7) Figure:6.9.6 One Shot Pulse Output of High Precision IGBT Output (When compare register 2 = compare register 1) (Timer 7) # 6.9.2 Setup Example # ■ High precision IGBT Output Setup Example (Timer 7) At the interrupt generation edge of the external interrupt 0 input signal, TM7IO output pin outputs the waveform of 1/4 duty IGBT output waveform at 400 Hz using the timer 7. Select fosc/2 (at fosc=20 MHz) as the clock source. Required period for one IGBT output waveform cycle depends on the set value of the compare register 1. "H" period of IGBT output waveform depends on the set value of the compare register 2. An example setup procedure, with a description of each step is shown below. Figure: 6.9.7 Output Waveform of TM7IO Output Pin | Setup Procedure | Description | |--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter<br>TM7MD1(x'3F78)<br>bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | (2) Set the output of special function pins P10MD(x'3F1C') bp4:P10MD3 =1 bp3:NBUZSEL =1 bp4:P10MD2 =1 bp3:BUZSEL =1 P1DIR(x'3F31') bp3:P1DIR3=1 bp2:P1DIR2=1 | (2) Set the P1OMD3 flag of the port 1 output mode register (P1OMD) to "1", the NBUZSEL flag to "1" to set the P13 pin to the special function pin. Set the P1OMD2 flag of the port 1 output mode register to "1", the BUZSDEL flag to "1" to set the P12 pin to the special function pin. Set the P1DIR3 flag of the port 1 direction control register (P1DIR) to "1", the P1DIR2 flag to "1" to set the output mode. Add pull-up/pull-down resistor if necessary. [Chapter 4 I/O port] | | (3) Set IGBT output<br>TM7MD3(x'3F8E')<br>bp2:TM7IGBTEN =1 | (3) Set the T7IGBTEN flag of the timer 7 mode register 3 (TM7MD3) to "1" to select IGBT output. | | (4) Set the high precision IGBT output operation TM7MD2(x'3F79) bp5:TM7BCR =1 bp6:T7PWMSL =1 TM7MD4(x'3F6E') bp3:T7NODED =1 | (4) Set the TM7BCR flag of the TM7MD2 register to "1" to select the TM7OC1 compare match as the clear factor of the binary counter. Set the T7PWMSL flag to "1" to select the TM7OC2 compare match as the duty determination factor of IGBT output. Set the T7NODED flag of the TM7MD4 register to "1" to select the IGBT waveform without dead time. | | Setup Procedure | Description | | |------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | (5) Select IGBT trigger generation interrupt source TM7MD3(x'3F8E) bp1-0:T7IGBT1-0 =01 | (5) Set the external interrupt 0 (IRQ0) input as IGBT trigger generation factor by the T7IGBT1-0 flag of the TM7MD3 register. | | | (6) Select the interrupt generation valid edge IRQ0ICR(x'3FE2) bp5:REDG0 =1 | (6) Set the REDG0 flag of the external interrupt 0 control register (IRQ0ICR) to "1" to select the rising edge as the interrupt generation valid edge. | | | (7) Select IGBT trigger generation level TM7MD3(x'3F8E') bp4:T7IGBTTR=0 | (7) Set the T7IGBTTR flag of the TM7MD3 register to "0" to set the IGBT trigger level to "H". | | | (8) Select IGBT trigger generation edge<br>TM7MD2(x'3F79')<br>bp7:T7ICEDG=1 | (8) Set the T7ICEDG flag of the TM7MD2 register to "1" to select the external interrupt specified edge as the IGBT trigger generation factor. | | | (9) Set the interrupt level IRQ0ICR(x'3FE2') bp7-6:IRQ0LV1-0 =10 | (9) Set the interrupt level by the IRQ1LV1 to 0 flag of the IRQ0ICR register. If any interrupt request flag is already set, clear it. [Chapter 3. 3.1.4 Interrupt Flag Setup] | | | (10) Enable the interrupt IRQ0ICR(x'3FE2') bp1:IRQ0IE =1 | (10) Set the TM7EN flag of the TM7MD1 register to "1" to start the timer 7. | | | (11) Select the count clock source TM7MD1(x'3F78') bp1-0:TM7CK1-0 =00 bp3-2:TM7PS1-0 =01 | (11) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/2 dividing as the count clock source by the TM7PS1 to 0 flag. | | | (12) Set the IGBT output cycle<br>TM7PR1(x'3F75', x'3F74') =x'61a7" | (12) Set the IGBT output cycle to the timer 7 preset register 1 (TM7PR1). To set 400 Hz by dividing MHz, set as; 25000-1=24999 (x61a7') At the same time, the same value is loaded to the timer 7 compare register 1 (TM7OC1), and the timer 7 binary counter (TM7BC) is initialized to x'0000'. | | | (13) Set "H" period of the IGBT output<br>TM7PR2(x'3F7D', x'3F7C') =x'186a' | (13) Set the "H" period of the IGBT waveform to the timer 7 preset register 2 (TM7PR2). To set 1/4 duty of 25000 dividing, set as; 25000/4=6250(x'186') At the same time, the same value is loaded to the timer 7 compare register 2 (TM7OC2). | | | (14) Start the timer operation<br>TM7MD1(x'3F78')<br>bp4: TM7EN= 1 | (14) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | | TM7BC counts up from x'0000. The IGBT output waveform outputs "H" until TM7BC matches the set value of the TM7OC2 register. Once they match, it outputs "L". After that, TM7BC continues to count up. Once TM7BC value matches the TM7OC1 register value to be cleared, the IGBT output waveform outputs "H" and TM7BC counts up from x'0000 again. To output the IGBT output waveform from the large current pin TM7O, set the special function pin to output mode as follows (refer to setup example (2)). Set each of P5OMD1 flag of the port 5 output mode register (P5OMD) to "1" to select P51 pin as the special function pins. Set P5DIR1 flag of the port 5 direction control register to "1" to set output mode. # 6.10 16-bit Standard IGBT Output (Only duty can be changed consecutively) Startup trigger can be selected by the external interrupt 0, 1 and 2 or starting of the timer 7 count operation. When counting starts, the operation is the same as the high precision PWM output. # 6.10.1 Operation ### IGBT Trigger Selection IGBT trigger can be selected from IRQ0, IRQ1, IRQ2 and the start of the timer 7 count operation. Setup should be done at the T7IGBT0 and T7IGBT1 flag of the TM7MD3 register. When the startup is controlled from external of the microcontroller, one of IRQ0 to IRQ2 should be selected. This trigger detects the input level before activation. Either "H" or "L" level can be selected with the T7IGBTTR flag of the TM7MD3 register. When "1" (the rising edge) is selected, count operation continues while the trigger pin is "H". When "0" (the falling edge) is selected, count operation continues while the trigger pin is "L". To control the startup by the commands, TM7EN count operation should be selected. In that case, timer count operation or IGBT output are controlled by the TM7EN flag of the TM7MD1 register. When "1" (count operation) is selected, count continues counting until "0" (count stop) is set. Make sure to set the TM7IGBT0, 1 of the TM7MD3 register before operating the TM7EN flag of the TM7MD1 register. ## ■ 16-bit Standard IGBT Output (Timer 7) The IGBT waveform of any duty is generated by setting the duty of "H" period to the compare register 1 (TM7OC1) and detecting the trigger that is generated by the external interrupt after the external interrupt interface block has passed. The cycle is the full count overflow time of the 16 bit timer. The following shows IGBT output pins, types of the selectable IGBT trigger, and the setting of the interrupt flags. Table:6.10.1 IGBT Output Pin | | Timer 7 | | |-----------------|--------------------|--| | IGBT output pin | TM7IO output (P13) | | | | TM7O output (P51) | | Table:6.10.2 IGBT Trigger | | Timer 7 mode register 3 | | |-----------------------|-------------------------|----------| | | T7IGBT | T7IGBTTR | | IRQ0 falling edge | 01 (IRQ0) | 1 | | IRQ0 rising edge | 01 (IRQ0) | 0 | | IRQ1 falling edge | 10 (IRQ1) | 1 | | IRQ1 rising edge | 10 (IRQ1) | 0 | | IRQ2 falling edge | 11 (IRQ2) | 1 | | IRQ2 rising edge | 11 (IRQ2) | 0 | | TM7EN count operation | 00 | - | # ■ Count Timing of Standard IGBT Output (At Normal) Figure:6.10.1 Count Timing of Standard IGBT Output (At Normal) - (A) When IGBT trigger is input, IGBT operation becomes valid after 1 count clock. After IGBT output is valid, it is "L" until the next count clock. - (B) When IGBT trigger is valid, it is "H" during the period when the value of the binary counter reaches that of TM7OC2 from X'0000'. ("H" output from X'0001 at the first operation cycle) - (C) After the TM7OC2 compare match, it is "L" and the binary counter counts up until the counter reaches the TM7OC1 compare register to be cleared. - (D) When the binary counter is cleared, it becomes "H" again. - (E) When IGBT trigger becomes invalid, the timer is initialized and IGBT output forcibly becomes "L". ■ Count Timing of Standard IGBT Output (When the compare register 1 is X'0000') (Timer 7) The following shows the count timing as the compare register 1 is set to X'0000'. Figure:6.10.2 Count Timing of Standard IGBT Output (When the compare register 1 is X'0000') When TM7EN flag is set to "0" (stop status), IGBT output is "L". ■ Count Timing of Standard IGBT Output (When the compare register 1 is X'FFFF') (Timer 7) The following shows the count timing as the compare register 1 is set to X'FFFF'. Figure:6.10.3 Count Timing of Standard IGBT Output (When the compare register 1 is X'FFFF') For standard IGBT output, set the TM7BCR flag of the TM7MD2 register to "0" and select the full count overflow as the binary counter clear factor and the IGBT output set ("H" output) factor. TM7OC1 compare match or TM7OC2 compare match can be selected as the IGBT output reset ("L" output) factor by the T7PWMSL flag of the TM7MD2 register. # 6.10.2 Setup Example ## ■ Standard IGBT Output Setup Example (Timer 7) At the interrupt generation edge of the external interrupt 0 input signal, TM7IO output pins output the waveform of 1/4 duty IGBT waveform at 305.18 Hz using the timer 7. Frequency for high speed operation (fosc) is 20 MHz. Required period for one IGBT output waveform cycle depends on the overflow time of the binary counter. "H" period of IGBT output waveform depends on the set value of the compare register 1. An example setup procedure, with a description of each step is shown below. Figure:6.10.4 Output Waveform of TM7IO Output Pin and TM8IO Output Pin | Setup Procedure | Description | |---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the counter TM7MD1(x'3F78) bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | (2) Set the output of special function pins P1OMD(x'3F1C') bp4:P1OMD3 =1 bp3:NBUZSEL =1 P1DIR(x'3F31') bp4:P1DIR3=1 | (2) Set the P1OMD3 flag of the port 1 output mode register (P1OMD) to "1", to set the P13 pin to the special function pin. Set the P1DIR3 flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. Add pull-up/pull-down resistor if necessary. [Chapter 4 I/O port] | | (3) Set IGBT output TM7MD3(x'3F8E') bp2:TM7IGBTEN =1 TM7MD2(x'3F79') bp4:PM7PWM =1 | (3) Set the T7IGBTEN flag of the timer 7 mode register 3 (TM7MD3) to "1", the TM7PWM flag of the timer 7 mode register 2 (TM7MD2) to "1" to select IGBT output. | | (4) Set the standard IGBT output operation TM7MD2(x'3F79) bp5:TM7BCR =1 | (4) Set the TM7BCR flag of the TM7MD2 register to "0" to select the full count overflow as the clear factor of the binary counter. | | (5) Select IGBT trigger generation interrupt source TM7MD3(x'3F8E) bp1-0:T7IGBT1-0 =01 | (5) Set the external interrupt 0 (IRQ0) input as IGBT trigger<br>generation factor by the T7IGBT1-0 flag of the<br>TM7MD3 register. | | Setup Procedure | Description | | | | |--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | (6) Select the trigger level TM7MD3(x'3F8E') bp4:T7IGBTTR=1 | (6) Set the T7IGBTTR flag of the TM7MD3 register to "1" to set the IGBT trigger level to "H". | | | | | (7) Select the dead time<br>TM7MD4(x'3F6E')<br>bp3:T7NODED =1 | (7) Set the T7NODED flag of the TM7MD4 register to "1" to select without dead time. | | | | | (8) Select the count clock source<br>TM7MD1(x'3F78')<br>bp1-0:TM7CK1-0 =00<br>bp3-2:TM7PS1-0 =01 | (8) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/1 dividing as the count clock source by the TM7PS1 to 0 flag. | | | | | (9) Start the timer operation TM7MD1(x'3F78') bp4: TM7EN= 1 | (9) Set the TM7EN flag of the TM7MD1 register to "1" to enable the operation of the timer 7. After "H" is input to the P54, IGBT is output from the P13. | | | | # 6.11 Dead Time IGBT Output IGBT output with dead time generates the waveform, inclusive ON or OFF time delay, during the standard IGBT signal inversion. And the formed waveform is output through TM7IO and TM8IO pins. Startup trigger can be selected by the external interrupt 0, 1 and 2 or starting of the timer 7 count operation. ### 6.11.1 Operation #### ■ Dead Time IGBT Output Operation (Timer 7) Dead time IGBT output can be selected at the T7IGBTEN of the timer 7 mode register 3 (TM7MD3). Also, dead time can be set to the dead time preset register 1 and 2 (TM7DEADPR1, 2). Only the timer 7 of 16-bit timer can use dead time IGBT output functions. #### ■ IGBT Trigger Selection IGBT trigger can be selected from IRQ0, IRQ1, IRQ2 and the start of the timer 7 count operation. Setup should be done at the T7IGBT0 and T7IGBT1 flag of the TM7MD3 register. When the startup is controlled from external of the micro controller, one of IRQ0 to IRQ2 should be selected. This trigger detects the input level before activation. Either "H" or "L" level can be selected with the T7IGBTTR flag of the TM7MD3 register. When "1" is selected, count operation continues while the trigger pin is "H". When "0" is selected, count operation continues while the trigger pin is "L". To control the startup by the commands, TM7EN count operation should be selected. In that case, timer count operation or IGBT output are controlled by the TM7EN flag of the TM7MD1 register. When "1" (count operation) is selected, count continues counting until "0" (count stop) is set. Make sure to set the TM7IGBT0, 1 of the TM7MD3 register before operating the TM7EN flag of the TM7MD1 register. In that case, setup of T7IGBTTR is neglected. The binary counter is cleared as the counting stops. The value is loaded from the preset register to the compare register in synchronization with the counter clock. #### ■ Dead Time Count Dead time counter counts the timer clock source. When the dead time insert is set as rising standard, set the period from the falling of TM8IO to the rising of TM7IO to the dead time preset register 1 (TM7DPR1) and the period from the falling of TM7IO to the rising of TM8IO to the dead time preset register 2 (TM7DPR2). Dead time is inserted for the period of the set value +1. Only for the period from the IGBT output is enabled by the IGBT trigger to the first rising of TM7IO (in the case of the IGBT falling standard), the set value of the TM7DPR1 +2 is inserted to the dead time. (1 count clock should be longer than usually.) ■ Count Timing of Dead Time IGBT Output (Timer 7) Figure:6.11.1 Count Timing of Dead Time IGBT Output (Timer 7) Output waveform of the IGBT with dead time (at falling-edge standard) (A)TM7IO="L", TM8IO="L" until the IGBT trigger is input and become valid. - (B)After the trigger is input and after 1 count clock falling edge of the next count clock $\times$ (value of the dead time preset register 1 + 1) output voltage of TM7IO is increased. - (C) After the compare matching (the value of the binary counter matches that of TM7OC2), and after 1 count clock, output voltage of TM7IO is decreased. - (D)After TM7IO output voltage is decreased and after count clock $\times$ (value of the dead time preset register 2 + 1), output voltage of TM8IO is increased. - (E)After the compare matching (the value of the binary counter matches that of TM7OC1) and after 1 count clock, output voltage of TM8IO is decreased. - (F)After TM8IO output voltage is decreased and after count clock $\times$ (value of the dead time preset register 1 + 1), output voltage of TM7IO is increased. - (G)When IGBT trigger becomes invalid, both TM7IO and TM8IO become "L" right away. Set as TM7OC2 value ≤ TM7OC1 value. When TM7OC2 value > TM7OC1 value, the IGBT output waveform is fixed as P13="L", P12="L" at falling edge standard. If IGBT trigger is enabled within 2 cycles of count clock after IGBT trigger is disabled, the following cases may occur: - -the value set in the preset register during IGBT operation may not be loaded to the compare register. - -the value set in the dead time preset register during IGBT operation may not be reflected. If the event input (TM7IO) is selected as the count clock source, the following cases may occur when IGBT trigger is disabled: - -the value set in the preset register during IGBT operation may not be loaded to the compare register. - -the value set in the dead time preset register during IGBT operation may not be reflected. When the event input (TTMnIO) is selected as the count clock source, the value which is entered on the dead time preset register while IGBT operation halt may not be reflected. To prevent this, select the system clock (fs) as the count clock source and enter the value on the dead time preset register. Then, select the event input (TMnIO) as the count clock source and start the IGBT operation. When IRQ0, IRQ1, or IRQ2 is selected as the IGBT trigger, the timing of IGBT operation start may delay up to 1 count clock. ### ■ One Shot Pulse Output Setup One shot pulse can be output by setting the T7ONESHOT flag of the TM7MD4 register to "1". Figure:6.11.2 Count Timing of Dead Time IGBT One Shot Pulse Output (Timer 7) ### 6.11.2 Setup Example #### ■ Dead Time IGBT Output Setup Example (Timer 7) At the interrupt generation edge of the external interrupt 0 input signal, TM7IO and TM8IO output pins output the waveform of 1/4 duty IGBT waveform at 200 Hz with 0.01 ms, 0.02 ms dead time by the falling standard using the timer 7. Select fosc/1 (at fosc=8.0 MHz) as the clock source. Required period for one IGBT output waveform cycle depends on the set value of the compare register 1. "H" period of IGBT output standard waveform depends on the set value of the compare register 2. Dead time period depends on the value of the dead time preset register 1 and 2. An example setup procedure, with a description of each step is shown below. Figure: 6.11.3 Output Waveform of TM7IO Output Pin and TM8IO Output Pin | Setup Procedure | Description | | | | |------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | (1) Stop the counter TM7MD1(x'3F78) bp4:TM7EN =0 | (1) Set the TM7EN flag of the timer 7 mode register 1 (TM7MD1) to "0" to stop the timer 7 counting. | | | | | (2) Set the dead time IGBT output operation TM7MD2(x'3F79') bp5:TM7BCR =1 bp6:T7PWMSL =1 | (2) Set the TM7BCR flag of the TM7MD2 register to "1" to select the TM7OC1 compare register match as the binary counter clear source. Also, set the T7PWMSL flag to "1" to select the TM7OC2 compare match as the duty decision source of the IGBT output. | | | | | (3) Select IGBT/timer startup factor TM7MD3(x'3F8E') bp1-0:TM7IGBT1-0 =01 | (3) Select the external interrupt 0 (IRQ0) input as the IGBT/ timer startup factor by the T7IGBT1 to 0 flag of the TM7MD3 register. | | | | | (4) Select the interrupt generation valid edge TM7MD3(x'3F8E') bp4:T7IGBTTR =0 | (4) Set the T7IGBTTR flag of the TM7MD3 register to "1" to select the rising edge as the interrupt generation valid edge. | | | | | (5) Set the dead time edge<br>TM7MD3(x'3F8E')<br>bp3:T7IGBTDT =0 | (5) Set the T7IGBTDT flag of the timer 7 mode register 3 (TM7MD3) to "0" to select the falling standard as the dead time edge. | | | | | Setup Procedure | Description | | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | (6) Set the interrupt level IRQ0ICR(x'3FE2') bp7-6:IRQ0LV1-0 =10 | (6) Set the interrupt level by the IRQ1LV1 to 0 flag of the IRQ0ICR register. If any interrupt request flag is already set, clear it. | | | | | | (7) Enable the interrupt IRQ0ICR(x'3FE2') bp1:IRQ1IE =1 | (7) Set the IRQ0IE flag of the IRQ0ICR register to "1" to enable the interrupt. | | | | | | (8) Select the count clock source<br>TM7MD1(x'3F78')<br>bp1-0:TM7CK1-0 =00<br>bp3-2:TM7PS1-0 =00 | (8) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/1 dividing as the count clock source by the TM7PS1 to 0 flag. | | | | | | (9) Set the IGBT output cycle TM7PR1(x'3F75', x'3F74') =x'9C3F' bp2:T7ICEN =1 | (9) Set the IGBT output cycle to the timer 7 preset register 1 (TM7PR1). To set 200 Hz by dividing 8.0 MHz, set as; 40000-1=39999 (0x9C3F') At the same time, the same value is loaded to the timer 7 compare register 1 (TM7OC1), and the timer 7 binary counter (TM7BC) is initialized to 0x0000. | | | | | | (10) Set "H" period of the IGBT output<br>TM7PR2(x'3F7D', x'3F7C') =x'2710' | (10) Set the "H" period of the IGBT waveform to the timer 7 preset register 2 (TM7PR2). To set 1/4 duty of 40000 dividing, set as; 40000/4=10000 (0x2710') At the same time, the same value is loaded to the timer 7 compare register 2 (TM7OC2). | | | | | | (11) Set the dead time<br>TM7DPR1(x'3F7E') = x'50"<br>TM7DPR2(x'3F7F') = x'9F' | (11) Set the period from the falling of the TM8IO to the rising of the TM7IO to the timer 7 preset register 1 (TM7DEADPR1) and from the falling of the TM7IO to the rising of the TM8IO to the timer 7 preset register 2 (TM7DEADPR2). To make dead time which is from the TM7IO falling to the TM8IO rising is 0.02 ms and from the TM8IO falling to the TM7IO rising is 0.01 ms, set 0x4F to the timer 7 dead time preset register 1 and 0x9F to the timer 7 dead timer preset register 2. | | | | | | (12) Set the IGBT output TM7MD2 (x'3F79') bp4:TM7PWM =1 TM7MD3 (x'3F8E') bp2:T7IGBTEN =1 TM8MD3 (x'3F8F') bp2:TM8SEL =1 | (12) Set T7IGBTEN flag of the timer 7 mode register 3 (TM7MD3) to "1" to select the dead time IGBT output. Set T78SEL flag of the timer 8 mode register 3 (TM8MD3) to "1" to select the timer 7 IGBT output. | | | | | | (13) Set the special function pin to output P10MD(x'3F1C') bp3: P10MD3=1 bp2: NBUZSEL= 1 bp1: P10MD2=1 bp0: BUZSEL=1 P1DIR (x'3F31') bp3: P1DIR3=1 bp2: P1DIR2=1 | (13) Set the P1OMD3 flag, NBUZSEL flag, P1OMD2 flag and BUZSEL flag of the port 1 output mode register (P1OMD) to "1" to set P13 and P12 as the special function pins. Set the P1DIR3 flag and P1DIR2 flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. [Chapter 4 I/O Ports] Set P13, P12 as the special function pins after setup procedures (1) to (13). | | | | | | Setup Procedure | Description | | | |--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--| | (14) Start the timer operation TM7MD1(x'3F78') bp4: TM7EN= 1 | (14) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. After "H" is input to P54 pin, IGBT is output from P13, P12. | | | TM7BC counts up from X'0000. The IGBT output waveform outputs "H" until TM7BC matches the set value of the TM7OC2 register. Once they match, it outputs "L". After that, TM7BC continues to count up. Once TM7BC value matches the TM7OC1 register value to be cleared, the IGBT output waveform outputs "H" and TM7BC counts up from X'0000 again. TM7IO pin outputs dead time worth of IGBT output waveform. TM8IO pin outputs dead time worth of inverted IGBT output waveform. To output the IGBT output waveform from the large current pin TM7IO, set the special function pin to output mode as follows (refer to setup example (2)). Set each of P5OMD1 flag and P5OMD3 flag of the port 5 output mode register (P5OMD) to "1" to select P51 pin and P53 pin as the special function pins. Set P5DIR1 and P5DIR3 flag of the port 5 direction control register to "1" to set output mode. ## 6.12 16-bit Timer Cascade Connection ### 6.12.1 Operation Cascading timers 7 and 8 forms a 32-bit timer. ■ 16-bit Timer Cascade Connection Operation (Timer 7 + Timer 8) Timer 7 and timer 8 are combined to be a 32-bit timer. Cascading timer is operated at clock source of timer 7 which are lower 16 bits. Table:6.12.1 Timer Function at Cascade Connection | | Timer 7+Timer 8<br>(32-bit) | | | | |--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Interrupt source | TM8IRQ1,TM8IRQ2 | | | | | Timer operation | 0 | | | | | Timer pulse output | O<br>(TM8IO output) | | | | | PWM output | 0 | | | | | Synchronous output | - | | | | | Clock source | fosc<br>fosc/2<br>fosc/4<br>fosc/16<br>fs<br>fs/2<br>fs/4<br>fs/16<br>TM7IO input<br>TM7IO input/2<br>TM7IO input/4<br>TM7IO input/16 | | | | | fosc:Machine clock (High frequency oscillation) fs:System clock [Chapter 2 2.5. Clock Switching] | | | | | <sup>\*</sup>At cascade connection, timer 8 interrupt factor is only counter-clear. At cascade connection, the binary counter and the compare register are operated as a 32-bit register. At operation, set the TM7EN flag of the lower 16-bit timers to "1" to be operated. Also, select the clock source with the lower 16-bit timer. Other setup and count timing are the same as the 16-bit timer at independently operation. When timer 7 and timer 8 are used in the cascade connection, timer 8 is used as the interrupt request flag. Timer pulse output of timer 7 is "L" fixed output. Timer 7 interrupt should be disabled as the interrupt request of timer 7 is generated. The preset registers (TM7PR1 and TM8PR1, TM7PR2 and TM8PR2) cannot be written at once that if the loading timing from the preset register to the compare register occurs at the same time as the writing timing of the preset register, the correct data may not be loaded. ## 6.12.2 Setup Example (Timer Operation) ■ Cascade Connection Timer Setup Example (Timer 7 + Timer 8) Setting example of timer function that the interrupt is constantly generated by cascade connection of timer 7 and timer 8, as 32-bit timer is shown. An interrupt is generated in every 100000 cycles (40 ms) by selecting source clock to fs/2 (fosc=10 MHz, fs=fosc/2). An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | | | | | |------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | (1) Stop the counter TM7MD1 (x'3F78') bp4:TM7EN= 0 TM8MD1 (x'3F88') bp7:TM8EN = 0 | (1) Set the TM7EN flag of the timer 7 mode register (TM7MD1) to "0" and the TM8EN flag of the timer 8 mode register (TM8MD1) to "0" to stop the timer 7 and the timer 8 counting. | | | | | | (2) Select the timer clear source<br>TM7MD2 (x'3F88')<br>bp5:TM7BCR =1 | (2) Set the TM7BCR flag of the TM7MD2 register to "1" to select the compare match as the binary counter clear source. | | | | | | (3) Select the normal lower operation<br>TM7MD2 (x'3F79')<br>bp2:T7ICEN= 0 | (3) Set the T7ICEN flag of the TM7MD2 register to "0" to select the normal timer operation. | | | | | | (4) Set the cascade connection<br>TM8MD3 (x'3F8')<br>bp0:TM8CAS=1 | (4) Set the TM8CAS flag of the TM8MD3 register to "1" to connect the timer 7 and the timer 8 to the cascade. | | | | | | (5) Select the count clock source TM7MD1 (x'3F78') bp1-0:TM7CK1-0=01 bp3-2:TM7PS1-0=01 | (5) Select fs as the clock source by the TM7CK1 to 0 of the TM7MD1 register. Also, select 1/2 of fs as the count clock source by the TM7PS1 to 0 flag. | | | | | | (6) Set the interrupt generation cycle<br>TM7PR1 (x'3F75', x'3F74')=x'869F'<br>TM8PR1 (x'3F85', x'3F84')=x'0001' | (6) Set the interrupt generation cycle to the timer 7 preset register 1 (TM7PR1) and the timer 8 preset register (TM8PR1). (100000 cycles-1). At the same time, the same values as the preset registers are loaded to the timer 7 compare register 1 (TM7OC1) and the timer 8 compare register (TM8OC1), and the binary counters (TM7BC, TM8BC) are initialized to x'0000'. | | | | | | (7) Disable the lower timer interrupt TM7ICR (x'3FED') bp1:TM7IE=0 | (7) Set the TM7IE flag of the timer 7 interrupt control register (TM7ICR) to "0" to disable the interrupt. | | | | | | (8) Set the upper timer interrupt level TM8ICR (x'3FF6') bp7-6:TM8LV1-0=10 | (8) Set the interrupt level by the TM8LS1 to 0 flag of the timer 8 interrupt control register (TM8lCR). If any interrupt request flag is already set, clear it. [Chapter 3 3.1.4. Interrupt Flag Setup] | | | | | | Setup Procedure | Description | | | |-------------------------------------------------------------------------|-------------------------------------------------------------------------------|--|--| | (9) Enable the upper timer interrupt TM8ICR (x'3FF3') bp1:TM8IE=1 | (9) Set the TM8IE flag of the TM8ICR register to "1" to enable the interrupt. | | | | (10) Start the lower timer operation<br>TM7MD1 (x'3F78')<br>bp4:TM7EN=1 | (10) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7. | | | $TM7BCL + TM7BCH + TM8BCL + TM8BCH \ counts \ up \ from \ X'000000000 \ as \ a \ 32-bit \ timer.$ When TM7BCL+TM7BCH+TM8BCL+TM8BCH reaches the set value of TM7OC1L+TM7OC1H+TM8OC1L+TM8OC1H register, the timer 8 interrupt request flag is set at the next count clock and the value of TM7BCL+TM7BCH+TM8BCL+TM8BCH becomes X'00000000 to restart count up. ### 6.12.3 Setup Example (PWM Operation) ### ■ Cascade Connection PWM Output Setup Example (Timer 7 + Timer 8) TM8IO output pin outputs the 1/10 duty PWM output waveform at 1/60 Hz with the cascade connection of timer 7 and timer 8, as a 32-bit timer. Select fosc/1 (fosc=8 MHz, at operation) as the clock source. One cycle of the PWM output waveform is depending on the set value of the compare register 1. "H" period of the PWM output waveform is depending of the set value of the compare register 2. An example setup procedure, with a description of each step is shown below. Figure:6.12.1 Output Waveform of TM8IO Output Pin | Setup Procedure | Description | | | | |-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | (1) Stop the counter TM7MD1 (x'3F78') bp4:TM7EN=0 TM8MD1 (x'3F88') bp7:TM8EN=0 | (1) Set the TM7EN flag of the timer 7 mode register (TM7MD1) to "0", the TM8EN flag of the timer 8 mode register (TM8MD1) to "0" to stop the timer 7 and the timer 8 counting. | | | | | (2) Set the special function pin to output P1OMD (x'3F1C') bp1:P1OMD2=1 bp0:BUZSEL=1 P1DIR (x'3F31') bp2:P1DIR2=1 | (2) Set the P10MD2, BUZSEL flags of the port 1 output mode register (P10MD) to "1" to set the P12 pin as the special function pin. Set the P1DIR2 flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. Add pull-up/pull-down register, if necessary. [Chapter 4. I/O Ports] | | | | | (3) Set the cascade connection<br>TM8MD3 (x'3F8F')<br>bp0:TM8CAS=1 | (3) Set the TM8CAS flag of the TM8MD3 register to "1" to connect the timer 7 and the timer 8 to the cascade. | | | | | (4) Set the PWM output<br>TM7MD2 (x'3F79')<br>bp4:TM7PWM=1 | (4) Set the TM7PWM flag of the timer 7 mode register 2 (TM7MD2) to "1" to select the PWM output. | | | | | (5) Set the high precision PWM output operation TM7MD2 (x'3F79') bp5:TM7BCR=1 bp6:T7PWMSL=1 | (5) Set the TM7BCR flag of the TM7MD2 register to "1" to select the TM7OC1 compare match as the binary counter clear source. Also, set the T7PWMSL flag to "1" to select the TM7OC2 compare match as the duty of the PWM output. | | | | | (6) Select the count clock source<br>TM7MD1 (x'3F78')<br>bp1-0:TM7CK1-0=00<br>bp3-2:TM7PS1-0=00 | (6) Select fosc as the clock source by the TM7CK1 to 0 flag of the TM7MD1 register. Also, select 1/1 dividing as the count clock source by the TM7PS1 to 0 flag. | | | | | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (7) Set the PWM output cycle<br>TM7PR1 (x'3F75',x'3F74') = x'37FF'<br>TM8PR1 (x'3F85',x'3F84') = x'1C9C' | (7) Set the PWM output cycle to the timer 7 preset register 1 (TM7PR1) and the timer 8 preset register 1 (TM8PR1). To set 1/60 Hz by dividing 8 MHz, set as; 480.000.000-1=479.999.999 (x'1C9C37FF') At the same time, the same values are loaded to the timer 7 compare register 1 (TM7OC1) and the timer 8 compare register 1 (TM8OC1), and the timer 7 binary counter (TM7BC) and the timer 8 binary counter (TM7BC) are initialized to x'0000. | | (8) Set "H" period of the PWM output<br>TM7PR2 (x'3F7D',x'3F7C') = x'6C00'<br>TM8PR2 (x'3F8D',x'3F8C') = x'02DC' | (8) Set "H" period of the PWM output to the timer 7 preset register 2 (TM7PR2) and the timer 8 preset register 2 (TM8PR2). To set 1/10 duty of 480.000.000 dividing, set as; 480.000.000/10=48.000.000 (x'02DC6C00) At the same time, the same values are loaded to the timer 7 compare register 2 (TM7OC2) and the timer 8 compare register 2 (TM8OC2). | | (9) Start the timer operation TM7MD1 (x'3F78') bp4:TM7EN=1 | (9) Set the TM7EN flag of the TM7MD1 register to "1" to operate the timer 7 and the timer 8. | TM7BCL + TM7BCH + TM8BCL + TM8BCH counts up from X'00000000 as a 32-bit timer. The TM8IO outputs "H" until TM7BCL + TM7BCH + TM8BCL + TM8BCH reaches the set value of the TM7OC2L + TM7OC2H + TM8OC2L + TM8OC2H register. Once they mach, it outputs "L". After that, TM7BCL + TM7BCH + TM8BCL + TM8BCH continues to count up, once TM7OC1L + TM7OC1H + TM8OC1L + TM8OC1H reaches the TM7BCL + TM7BCH + TM8BCL + TM8BCH register to be cleared, the TM8IO outputs "H" again and TM7BCL + TM7BCH + TM8BCL + TM8BCH counts up from X'00000000 again. In the initial state of the PWM output, "L" output is changed to "H" output as the PWM output is selected by the TM7PWM flag of the TM7MD2 register. Set value should be set as; $TM7OC2L + TM7OC2H + TM8OC2L + TM8OC2H \le$ TM7OC1L + TM7OC1H + TM8OC1L + TM8OC1H. If it is set as; TM7OC2L + TM7OC2H + TM8OC2L + TM8OC2H ≥ TM7OC1L + TM7OC1H + TM8OC1L + TM8OC1H, the PWM output is a "H" fixed output. ## 7.1 Overview This LSI has a time base timer and a 8-bit free-running timer (timer 6). Time base timer is a 15-bit timer counter. ## 7.1.1 Functions Table:7.1.1 shows the clock source and the interrupt generation cycle that timer 6 and time base timer 7 can use. Table: 7.1.1 Clock Source and Generation Cycle | | Time base timer | Timer 6<br>(8-bit free-running) | |----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8-bit timer operation | × | О | | Interrupt | TBIRQ | TM6IRQ | | Clock source | fosc<br>fx | fosc<br>fx<br>fs<br>fosc $\times$ 1/2 <sup>7</sup> *1<br>fosc $\times$ 1/2 <sup>13</sup> *1<br>fx $\times$ 1/2 <sup>7</sup> *2<br>fx $\times$ 1/2 <sup>13</sup> *2 | | Interrupt generation cycle | fosc $\times$ 1/2 <sup>7</sup><br>fosc $\times$ 1/2 <sup>8</sup><br>fosc $\times$ 1/2 <sup>9</sup><br>fosc $\times$ 1/2 <sup>10</sup><br>fosc $\times$ 1/2 <sup>13</sup><br>fosc $\times$ 1/2 <sup>15</sup><br>fx $\times$ 1/2 <sup>8</sup><br>fx $\times$ 1/2 <sup>9</sup><br>fx $\times$ 1/2 <sup>10</sup><br>fx $\times$ 1/2 <sup>13</sup><br>fx $\times$ 1/2 <sup>15</sup> | The interrupt generation cycle is decided by the arbitrary value written to TM6OC. | fosc: Machine clock (High speed oscillation) fx: Machine clock (Low speed oscillation) fs: System clock [Chapter 2. 2.5 Clock Switching] <sup>\*1</sup> Can be used when a clock source of time base timer is selected to 'fosc'. <sup>\*2</sup> Can be used when a clock source of time base timer is selected to 'fx'. When 'fs' is used as a clock source, it counts at "rising" of the count clock and in other uses, it counts "falling" of the count clock. Count clock source should be changed when the timer interrupt is disabled. ## 7.1.2 Block Diagram ■ Timer 6, Time Base Timer Block Diagram Figure: 7.1.1 Block Diagram (Timer 6, Time Base Timer) # 7.2 Control Registers Timer 6 consists of binary counter (TM6BC), compare register (TM6OC), and is controlled by mode register (TM6MD). Time base timer is controlled by mode register (TM6MD) and time base timer clear register (TBCLR). Both timers are operated by the enable signal of the TM6BEN. ## 7.2.1 Control Registers Table:7.2.1 shows the registers that control timer 6, time base timer. Table:7.2.1 Control Registers | | Register | Address | R/W | Function | Page | |-----------------|--------------------------------------|---------|-----------------------|----------------------------------------|--------| | Timer 6 | TM6BC | 0x03F60 | R | Timer 6 binary counter | VII-6 | | | TM6OC | 0x03F61 | R/W | Timer 6 compare register | VII-6 | | | TM6MD | 0x03F62 | R/W | Timer 6 mode register | VII-8 | | | TM6BEN | 0x03F64 | R/W | Timer 6 enable register | VII-7 | | | TM6ICR | 0x03FEB | R/W | Timer 6 interrupt control register | III-28 | | Time base timer | se timer TM6MD 0x03F62 R/W Timer 6 n | | Timer 6 mode register | VII-8 | | | | TBCLR | 0x03F63 | W | Time base timer clear control register | VII-6 | | | TBICR | 0x03FEC | R/W | Time base interrupt control register | III-29 | ### 7.2.2 Programmable Timer Registers Timer 6 is a 8-bit programmable counter. Programmable counter consists of compare register (TM6OC) and binary counter (TM6BC). Binary counter is a 8-bit up-counter. When the TM6CLRS flag of the timer 6 mode register (TM6MD) is "0" and the interrupt cycle data is written to the compare register (TM6OC), the timer 6 binary counter (TM6BC) is cleared to 0x00. ■ Timer 6 Binary Counter (TM6BC:0x03F60) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | TM6BC7 | TM6BC6 | TM6BC5 | TM6BC4 | TM6BC3 | TM6BC2 | TM6BC1 | TM6BC0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | ■ Timer 6 Compare Register (TM6OC:0x03F61) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | TM6OC7 | TM6OC6 | TM6OC5 | TM6OC4 | TM6OC3 | TM6OC2 | TM6OC1 | TM6OC0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W Time base timer can be reset its operation by the software. Time base timer can be cleared by writing an arbitrary value to the time base timer clear control register (TBCLR). ■ Time Base Timer Clear Control Register (TBCLR:0x03F63) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | TBCLR7 | TBCLR6 | TBCLR5 | TBCLR4 | TBCLR3 | TBCLR2 | TBCLR1 | TBCLR0 | | At reset | - | - | - | - | - | - | - | - | | Access | W | W | W | W | W | W | W | W | ## 7.2.3 Timer 6 Enable Registers This register controls the starting operation of the timer 6 and the time base timer. ■ Timer 6 Enable Registers (TM6BEN:0x03F64) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|-----|-----|-----|-----|------|-------| | Flag | - | - | - | - | - | - | TBEN | TM6EN | | At reset | - | - | - | - | - | - | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|-------|------------------------------------------------------| | 7-2 | - | - | | 1 | TBEN | Time base timer operation control 0:Stop 1:Operation | | 0 | TM6EN | Timer 6 operation control 0:Stop 1:Operation | Timer 6 does not start operating unless the TM6EN flag of the TM6BEN register is set to "1". Time base timer does not start operating unless the TBEN flag of the TM6BEN register is set to "1". ## 7.2.4 Timer Mode Registers This is readable / writable register that controls timer 6 and time base timer. ■ Timer 6 Mode Register (TM6MD:0x03F62) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------------|--------|--------|--------|--------|--------|--------|--------| | Flag | TM6CLR<br>S | TM6IR2 | TM6IR1 | TM6IR0 | TM6CK3 | TM6CK2 | TM6CK1 | TM6CK0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TM6CLRS | Timer 6 binary counter clear selection flag 0:Enable the initialization of TM6BC as TM6OC is written. 1:Disable the initialization of TM6BC as TM6OC is written. * TM6IRQ is disable as TM6CLRS = 0, TM6IRQ is enable as TM6CLRS = 1. | | 6-4 | TM6IR2<br>TM6IR1<br>TM6IR0 | Time base timer interrupt cycle selection 000:Time base selection clock $\times$ 1/2 <sup>7</sup> 001:Time base selection clock $\times$ 1/2 <sup>8</sup> 010:Time base selection clock $\times$ 1/2 <sup>9</sup> 011:Time base selection clock $\times$ 1/2 <sup>10</sup> 10-:Time base selection clock $\times$ 1/2 <sup>13</sup> 11-:Time base selection clock $\times$ 1/2 <sup>15</sup> | | 3-1 | TM6CK3<br>TM6CK2<br>TM6CK1 | Timer 6 clock source selection 000:fosc 001:fs 010:fx 011:Synchronous fx 100:Time base selection clock $\times$ 1/2 <sup>13</sup> 101:Synchronous time base selection clock $\times$ 1/2 <sup>13</sup> 110:Time base selection clock $\times$ 1/2 <sup>7</sup> 111:Synchronous time base selection clock $\times$ 1/2 <sup>7</sup> | | 0 | TM6CK0 | Time base timer clock source selection 0:fosc 1:fx | # 7.3 8-bit Free-running Timer ## 7.3.1 Operation #### 8-bit Free-running Timer (Timer 6) The generation cycle of the timer interrupt should be set in advance, by the set value of the compare register (TM6OC) and the clock source selection. When the binary counter (TM6BC) reaches the set value of the compare register, an interrupt request is generated at the next count clock and the binary counter is cleared to restart count up from 0x00. Table: 7.3.1 shows selectable clock source. Table:7.3.1 Clock Source at Timer Operation (Timer 6) | One count time | One count time | | | | | |----------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--| | At fosc=10 MHz | At fosc=8.39 MHz | At fosc=2 MHz | | | | | 100 ns | 119.1 ns | 500 ns | | | | | 30.5 μs | • | | | | | | 200 ns | 238.3 ns | 1000 ns | | | | | 12.8 μs | 15.2 μs | 64 μs | | | | | 819.2 μs | 976.4 μs | 4096 μs | | | | | 3.9 ms | | , | | | | | 250 ms | 250 ms | | | | | | | At fosc=10 MHz 100 ns 30.5 μs 200 ns 12.8 μs 819.2 μs 3.9 ms | At fosc=10 MHz At fosc=8.39 MHz 100 ns 119.1 ns 30.5 μs 200 ns 238.3 ns 12.8 μs 15.2 μs 819.2 μs 976.4 μs 3.9 ms | | | | fosc = 20 MHz, 8.39 MHz, 2 MHz fx = 32.768 KHz fs = fosc/2 #### ■ 8-bit Free-running Timer as a 1 Minute-timer, a 1 Second-timer Table:7.3.2 shows the clock source selection and the TM6OC register setup, when a 8-bit free-running timer is used as a 1 minute-timer, a 1 second-timer. Table: 7.3.2 1 Minute-timer, 1 Second-timer (Timer 6) Setup | Interrupt Generation<br>Cycle | Clock source | TM6OC Register | |-------------------------------|------------------------|----------------| | 1 min | fx × 1/2 <sup>13</sup> | 0xEF | | 1 s | fx × 1/2 <sup>13</sup> | 0x03 | | fx = 32.768 kHz | | | When the 1 minute-timer (1 m.) is set on Table: 7.3.2, the bp2 waveform frequency (cycle) of the TM6BC register is 1 Hz (1 s.). So, that can be used for adjusting the seconds. Figure:7.3.1 Waveform of TM6BC Register bp2 (Timer 6) For proper count, count clock should be switched after the timer stops its operation. #### ■ Count Timing of Timer Operation (Timer 6) Binary counter counts up with the selected clock source as a count clock. Figure: 7.3.2 Count Timing of Timer Operation (Timer 6) - 1. When any data is written to the compare register as the TM6CLRS flag is "0", the binary counter is cleared to 0x00. - 2. Even if any data is written to the compare register as the TM6CLRS flag is "1", the binary counter is not changed. - 3. When the binary counter reaches the value of the compare register as the TM6CLRS flag is "1", an interrupt request flag is set at the next count clock. - 4. When an interrupt request flag is set, the binary counter is cleared to 0x00 and restarts the counting. - 5. Even if the binary counter reaches the value of the compare register as the TM6CLRS flag is "0", no interrupt request flag is set. When the binary counter reaches the value in the compare register, the interrupt request flag is set and the binary counter is cleared at the next count clock. So set the compare register as: Compare register setting = (count till the interrupt request -1) If the fx input is selected as a clock source and the value of timer 6 binary counter is read out at operation, an incorrect value could be read out. To prevent this, select a synchronous fs as the count clock source. When fx is used to the clock source, the binary counter should be cleared before starting the timer operation. Also, when 0x00 is set to the compare register, the synchronous fx should be used. If the smaller value than the binary counter is set to the compare register at counting operation, the binary counter continues counting till overflow. When fx and time base selection clock (at time base clock source is selected as fx) are selected as clock sources, the binary counter may not be cleared. To prevent this, select a synchronous fx and synchronous time base selection clock. When a timer interrupt request flag is generated, up to 3 system clock is required for the next flag generation. Even if the binary counter reaches the value in the compare register, a timer interrupt request flag is not generated. ### 7.3.2 Setup Example ### ■ Timer Operation Setup (Timer 6) Timer 6 generates interrupts constantly for timer function. Interrupts are generated in every 250 dividing (25 $\mu$ s) by selecting fs (fs = 10 MHz at operation) as clock source. An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Enable the binary counter<br>TM6MD(0x03F62)<br>bp7 :TM6CLRS =0 | (1) Set the TM6CLRS flag of the timer 6 mode register (TM6MD) to "0". At the time, the initialization of the timer 6 binary counter (TM6BC) is enabled. | | (2) Disable the interrupt TM6ICR(0x03FEB) bp1:TM6IE =0 | (2) Set the TM6IE flag of the TM6ICR register to "0" to disable the interrupt. | | (3) Select the clock source<br>TM6MD(0x03F62)<br>bp3-1 :TM6CK3-1 =001 | (3) Clock source can be selected by the TM6CK3 to 1 flag of the TM6MD register. Actually, fx is selected. | | (4) Set the interrupt generation cycle TM6OC(0x03F61) =0xF9 | (4) Set the interrupt generation cycle to the timer 6 compare register (TM6OC). At that time, TM6BC is initialized to 0x00. | | (5) Enable the interrupt request<br>TM6MD(0x03F62)<br>bp7 :TM6CLRS =1 | (5) Set the TM6CLRS flag of the TM6MD register to "1" to enable the interrupt request generation. | | (6) Set the interrupt level TM6ICR(0x03FEB) bp7-6:TM6LV1-0=01 | (6) Set the interrupt level by the TM6LV1 to 0 flag of the timer 6 interrupt control register (TM6ICR). If the interrupt request flag may be already set, clear them. [Chapter 3. 3.1.4 Interrupt Flag Setup] | | (7) Enable the interrupt TM6ICR(0x03FEB) bp1 :TM6IE =1 | (7) Set the TM6IE flag of the TM6ICR register to "1" to enable the interrupt. | | (8) Start the TM6 operation<br>TM6BEN(0x03F64)<br>bp0 :TM6EN =1 | (8) Set the TM6EN flag of the TM6BEN register to "1" to start the timer 6. | As TM6OC is set, TM6BC is initialized to 0x00 to count up. When TM6BC matches TM6OC, the timer 6 interrupt request flag is set at the next count clock and TM6BC is cleared to 0x00 to restart counting. If the TM6CLRS flag of the TM6MD register is set to "0", TM6BC can be initialized at every rewriting of TM6OC register, but in that state the timer 6 interrupt is disabled. If the timer 6 interrupt should be used, set the TM6CLRS flag to "1" after rewriting the TM6OC register. On the timer 6 clock source selection, if the time base timer output or the time base timer synchronous output is selected, the clock setup of time base timer is necessary. # 7.4 Time Base Timer ## 7.4.1 Operation ### ■ Time Base Timer (Time Base Timer) Interrupt is constantly generated by a selected clock source and a interrupt generation cycle. Table:7.4.1 shows the interrupt cycle is combination with the clock source; Table: 7.4.1 Selection of Time Base Timer Interrupt Generation Cycle | Selected clock source | Interrupt generation cycle | | |------------------------------|----------------------------|----------| | fosc | $fosc \times 1/2^7$ | 12.8 μs | | | fosc × 1/2 <sup>8</sup> | 25.6 μs | | | fosc × 1/2 <sup>9</sup> | 51.2 μs | | | fosc × 1/2 <sup>10</sup> | 102.4 μs | | | fosc × 1/2 <sup>13</sup> | 819.2 μs | | | fosc × 1/2 <sup>15</sup> | 3.27 ms | | fx | $fx \times 1/2^7$ | 3.9 ms | | | $fx \times 1/2^8$ | 7.8 ms | | | $fx \times 1/2^9$ | 15.6 ms | | | $fx \times 1/2^{10}$ | 31.2 ms | | | $fx \times 1/2^{13}$ | 250 ms | | | $fx \times 1/2^{15}$ | 1 s | | fosc = 10 MHz fx = 32.768 kH | Z | | ■ Count Timing Timer Operation (Time Base Timer) The counter counts up with the selected clock source as a counter clock. Figure:7.4.1 Count Timing of Timer Operation (Time Base Timer) • When the selected interrupt cycle is passed, the interrupt request flag of the time base interrupt control register (TBICR) is set. An interrupt may be generated at switching of the clock source. Enable the interrupt after switching the clock source. The initialization can be done by writing an arbitrary value to the time base timer clear control register (TBCLR). When fx is selected as a clock source, the time base timer may not be initialized. For prevention, write twice to the time base timer clear control register (TBCLR). ## 7.4.2 Setup Example ### ■ Timer Operation Setup (Time Base Timer) An interrupt can be generated constantly with time base timer in the selected interrupt cycle. The interrupt generation cycle is $fosc \times 1/2^{13}$ (1 ms:fosc = 8.192 MHz) to generate interrupts. An example setup procedure, with a description of each step is shown below | Setup Procedure | Description | |-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select the clock source<br>TM6MD(0x03F62)<br>bp0 :TM6CK0 =0 | (1) Select fosc as a clock source by the TM6CK0 flag of the timer 6 mode register (TM6MD). | | (2) Disable the interrupt TBICR(0x03FEC) bp1 :TBIE =0 | (2) Set the TBIE flag of the TBICR register to "0" to disable the interrupt. | | (3) Select the interrupt generation cycle TM6MD(0x03F62) bp6-4 :TM6IR2-0 =100 | (3) Select the selected clock × 1/2 <sup>13</sup> as an interrupt generation cycle by the TM6IR2 to 0 flag of the TM6MD register. | | (4) Initialize the time base timer TBCLR(0x03F63) =0x00 | (4) Write value to the time base timer clear control register (TBCLR) to initialize time base timer. | | (5) Set the interrupt level TBICR(0x0EFC) bp7-6 :TBLV1-0 =01 | (5) Set the interrupt level by the TBLV1 to 0 flag of the time base interrupt control register (TBICR). If any interrupt request flag may be already set, clear them. [Chapter 3. 3.1.4 Interrupt Flag Setup] | | (6) Enable the interrupt TBICR(0x03FEC) bp1 :TBIE =1 | (6) Set the TBIE flag of the TBICR register to "1" to enable the interrupt. | | (7) Start the time base timer operation TM6BEN(0x03F64) bp1 :TBEN =1 | (7) Set the TBEN flag of the TM6BEN register to "1" to start the time base timer. | • When the selected interrupt generation cycle is passed, the interrupt request flag of the time base interrupt control register (TBICR) is set to "1". ### Chapter 7 Time Base Timer / Free-running Timer ## 8.1 Overview Remote control carrier output functions can generate the carrier wave for the remote control and output. ## 8.1.1 Functions Table:8.1.1 shows the remote control carrier output functions. Table:8.1.1 The remote control carrier output functions. | Remote control carrier output base timer selection | Timer 0<br>Timer 3 | |----------------------------------------------------|---------------------------------------------------| | Duty selection | 1/2<br>1/3<br>Timer output | | Remote control carrier output enable factor | RMOEN | | Remote control carrier output enable | "L" level output<br>Remote control carrier output | | P14 special function selection | Timer 0<br>Remote control carrier output | This function is not available in the STOP/HALT mode. ## 8.1.2 Block Diagram ■ Remote Control Carrier Output Block Diagram Figure:8.1.1 Remote Control Carrier Output Block Diagram # 8.2 Control Registers ## 8.2.1 Control Registers Table:8.2.1 shows the registers that control the remote control carrier output. Table:8.2.1 Control Registers | Registers | Address | R/W | Function | Page | |-----------|---------|-----|------------------------------------------------|--------| | RMCTR | 0x03F6C | R/W | Remote control carrier output control register | VIII-5 | | TM0MD | 0x03F54 | R/W | Timer 0 mode register | V-14 | | TM0OC | 0x03F52 | R/W | Timer 0 compare register | V-12 | | CK0MD | 0x03F56 | R/W | Timer 0 prescaler selection register | V-9 | | P1OMD | 0x03F1C | R/W | Port 1 output mode register | IV-10 | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | # 8.2.2 Remote Control Carrier Output Control Register ## ■ Remote Control Carrier Output Control Register (RMCTR:0x03F6C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|----------|-------|-------|--------|--------|--------| | Flag | - | - | Reserved | TM0RM | RMOEN | RMDTY1 | RMDTY0 | RMBTMS | | At reset | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|------------------|---------------------------------------------------------------------------------------------------| | 7-6 | - | - | | 5 | Reserved | Set always to "0". | | 4 | TMORM | P14 special functions output selection 0:TM0IO 1:RMOUT | | 3 | RMOEN | Remote control carrier output enable 0:"L" level output 1:remote control carrier output | | 2-1 | RMDTY1<br>RMDTY0 | Remote control carrier duty selection 00:1/2 duty 01:1/3 duty 1-:Timer output | | 0 | RMBTMS | Remote control carrier base timer selection 0:Timer 0 output selection 1:Timer 3 output selection | # 8.3 Operations # 8.3.1 Operations Remote control carrier output functions can generate the carrier pulse for the remote control. Operation of the remote control carrier output Remote control carrier can be created by using the output signals of timer 0 and timer 3. Duty ratio can be selected from 1/2, 1/3, Timer output. Remote control carrier output signal is output from the RMOUT pin (P14). Figure:8.3.1 Remote Control Carrier Output Signal Duty Ratio ■ Count Timing of Remote Control Carrier Output Functions Figure:8.3.2 Count Timing of Remote Control Carrier Output Functions 1. Even if the RMOEN flag is switched OFF at the carrier output "H", the carrier wave is held by the synchronous circuit. When RMOEN flag is changed, the base cycle and the duty selection timer should not be changed at the same time, as the carrier pulse may not be output correctly. Set the timer output over 1 cycle of the system clock. The remote control carrier output may be executed incorrectly when the timer output is set under 1 cycle. ### 8.3.2 Setup Examples ■ Setup Example of the Remote Control Carrier Output Functions (Timer 0, Timer 3) The setup examples that 1/3 duty carrier pulse signal is output as 36.7 kHz for "H" period from the RMOUT pin with the timer 0 are shown below. The clock source of the timer 0 is selected as fs/2 (at fs = 8 MHz). An example setup procedure, with a description of each step is shown below. Figure:8.3.3 Output Wave of RMOUT Output Pin | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Disable the remote control carrier output<br>RMCTR(0x03F6C)<br>bp3 :RMOEN =0 | (1) Set the RMOEN flag of the remote control carrier output control register (RMCTR) to "0" to disable the remote control carrier output. | | (2) Select the base cycle setup timer<br>RMCTR(0x03F6C)<br>bp0 :RMBTMS =0 | (2) Set the RMBTMS flag of the RMCTR register to "0" to select the timer 0 as the setup timer of the base cycle. | | (3) Select the carrier output duty RMCTR(0x03F6C) bp2-1 :RMDTY1-0 =01 | (3) Set the RMDTY1, 0 flag of the RMCTR register to "0, 1" to select the duty to 1/3. | | (4) Confirm the counter stop<br>TM0MD(0x03F54)<br>bp3 :TM0EN =0 | (4) Set the TM0EN flag of the timer 0 mode register (TM0MD) to "0" to stop counting of the timer 0. | | (5) Set the remote control carrier output of the special function pin P10MD(0x03F1C) bp4 :P10MD4 =1 P1DIR(0x03F31) bp4 :P1DIR4 =1 RMCTR(0x03F6C) bp4 :TM0RM =1 | (5) Set the P1OMD4 flag of the port 1 output mode register (P1OMD) to "1" to set P14 pin to the particular function pin. Set the P1DIR4 flag of the port 1 direction control register (P1DIR) to "1" to set the output mode. Set the TM0RM flag of the RMCTR register to "1" to select the remote control carrier output. | | (6) Select the timer general operation TM0MD(0x03F54) bp4 :TM0PWM =0 bp5 :TM0MOD =0 | (6) Set the TM0PWM flag and the TM0MOD flag of the TM0MD register to "0" to select the timer general operation. | | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (7) Select the count clock source<br>TM0MD(0x03F54)<br>bp2-0 :TM0CK2-0 =X01 | (7) Select the prescaler output to the clock source by theTM0CK2 to 0 of the TM0MD register. | | (8) Select and enable the prescaler output CK0MD(0x03F56) bp2-1 :TM0PSC1-0 =X0 bp0 :TM0BAS =1 | (8) Select the fs/2 to the prescaler output by the TM0PSC1 to 0 flag, TM0BAS flag of the timer 0 prescaler selection register. | | (9) Set the base cycle of the remote control carrier TM0OC(0x03F52) =0x36 | (9) Set the base cycle of the remote control carrier by<br>writing 0x36 to the timer 0 compare register (TM0OC).<br>To divide fs=8 MHz to get 1/2 dividing of 36.7 kHz<br>(73.4 kHz), the setup value should be<br>(fs/2 MHz/73.4 kHz) - 1 = 54 (0x36). | | (10) Start the timer operation<br>TM0MD(0x03F54)<br>bp3 :TM0EN =1 | (10) Set the TM0EN flag of the TM0MD register to "1" to start the timer 0. | | (11) Enable the remote control carrier output RMCTR(0x03F6C) bp3 :RMOEN =1 | (11) Set the RMOEN flag of the RMCTR register to "1" to enable the remote control carrier output. | TM0BC starts the count up from 0x00. As the base cycle pulse that is set at the TM0OC is output from the timer 0, 1/3 of the remote control carrier pulse signal is output. If the RMOEN flag of the RMCTR register is set to "0", the output signal of the remote control carrier pulse is stopped. Chapter 8 Remote Control Carrier Functions # 9.1 Overview This LSI has a watchdog timer that is used to detect software processing errors. It is controlled by the watchdog timer control register (WDCTR). When an overflow of watchdog timer is generated, a watchdog interrupt (WDIRQ) is generated. If the watchdog interrupt is generated twice in a row, it is regarded to be an indication that the software cannot execute in the intended sequence; thus, a system reset is initiated by the hardware. ### 9.1.1 Functions ### Table: 9.1.1 shows watchdog timer functions. ### Table:9.1.1 Watchdog Timer Functions | Watchdog time-out period setup selection | 2 <sup>16</sup> of system clock<br>2 <sup>18</sup> of system clock<br>2 <sup>20</sup> of system clock | | | |------------------------------------------|-------------------------------------------------------------------------------------------------------|--|--| | Watchdog timer enable | Stop<br>Operation | | | ## 9.1.2 Block Diagram ### ■ Watchdog Timer Block Diagram Figure: 9.1.1 Block Diagram (Watchdog Timer) The watchdog timer is also used as a timer to count the oscillation stabilization wait time. This is used as a watchdog timer except at recovering from STOP mode and at reset releasing. The watchdog timer is initialized at reset or at STOP mode, and counts system clock (fs) as a clock source from the initial value (0x0000). The oscillation stabilization wait time is set by the oscillation stabilization control register (DLYCTR). # 9.2 Control Register The watchdog timer is formed by the control register (WDCTR). ## 9.2.1 Control Registers Table:9.2.1 shows the registers that control the watchdog timer. Table:9.2.1 Watchdog Timer Control Register Functions | Register | Address | R/W | Function | Page | |----------|---------|-----|---------------------------------|------| | WDCTR | 0x03F02 | R/W | Watchdog timer control register | IX-4 | # 9.2.2 Watchdog Timer Control Register The watchdog timer is controlled by the watchdog timer control register (WDCTR). ■ Watchdog Timer Control Register (WDCTR:0x03F02) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|-----|----------|----------|----------|-------|-------|------| | Flag | - | - | Reserved | Reserved | Reserved | WDTS1 | WDTS0 | WDEN | | At reset | - | - | 0 | 0 | 0 | 1 | 1 | 0 | | Access | R/W | bp | Flag | Description | |-----|----------------|--------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | - | - | | 5-3 | Reserved | Set always to "0". | | 2-1 | WDTS1<br>WDTS0 | Watchdog time-out period setup 00:2 <sup>16</sup> of system clock 01:2 <sup>18</sup> of system clock 1X:2 <sup>20</sup> of system clock | | 0 | WDEN | Watchdog timer enable 0:Watchdog timer is stopped 1:Watchdog timer is operated | # 9.3 Operation ### 9.3.1 Operation The watchdog timer counts system clock (fs) as a clock source. If the watchdog timer is overflowed, the watchdog interrupt (WDIRQ) is generated as non maskable interrupt (NMI). At reset, the watchdog timer is stopped, but once the operation is enabled, it cannot be stopped except at reset. The watchdog timer control register (WDCTR) sets when the watchdog timer is released or how long the time-out period should be. When the watchdog interrupt (WDIRQ) is generated, it is regarded to be an indication that the software cannot execute in the intended sequence; thus, a system reset is initiated by the hardware. Once the watchdog timer starts operation, it cannot be stopped ### ■ Usage of Watchdog Timer When the watchdog timer is used, constant clear in program is needed to prevent an overflow of the watchdog timer. As a result of the software failure, the software cannot execute in the intended sequence, thus the watchdog timer overflows to detect errors. Programming of the watchdog timer is generally done in the last step of program debugging. #### How to Detect Incorrect Code Execution The watchdog timer is executed to be cleared in the certain cycle on the correct code execution. In MN101C78A, the watchdog timer detects errors when, 1. the watchdog timer overflows. When the watchdog timer detects any error, the watchdog interrupt (WDIRQ) is generated as a non maskable interrupt (NMI). How to clear Watchdog Timer The watchdog timer can be cleared by writing to the watchdog timer control register (WDCTR). The watchdog timer can be cleared regardless of the writing data to the register. The bit-set (BSET) that does not change the value is recommended. #### ■ Watchdog Time-out Period The watchdog time-out period is decided by the bp2, 1 (WDTS1-0) of the watchdog timer control register (WDCTR) and the system clock (fs). If the watchdog timer is not cleared by the set value, it is regarded as an error and the watchdog interrupt (WDIRQ) of the non maskable interrupt (NMI) is generated. The system clock is decided by the CPU mode control register (CPUM). #### [Chapter 2 2.5 Clock Switching] The watchdog time-out period is generally decided by the execution time for main routine of the program. The period should be set longer than the execution time of main routine divided by natural number $(1, 2, \cdots)$ . Set the command of the watchdog timer clear to the main routine as the value makes the same cycle. ### ■ Watchdog Timer and CPU Mode The relation between the watchdog timer and CPU mode features are as follows; - 1. In NORMAL, IDLE, SLOW mode, the system clock is counted. - 2. The counting is continued regardless of swithching in NORMAL, IDLE, SLOW mode. - 3. In HALT mode, the watchdog timer is stopped. - 4. In STOP mode, the watchdog timer is cleared automatically. - 5. In STOP mode, the watchdog interrupt cannot be generated. - 6. After recovering from STOP mode, if the detection of the incorrect code execution is valid, the counting is executed for the duration of the oscillation stabilization wait time. If the detection is invalid, the counting is stopped in the condition that the counting of the oscillation stabilization wait time is proceeded. - 7. After releasing reset, the watchdog timer is cleared automatically and stop counting. In the system that uses STOP mode, whether the STOP mode is done or not is generally divided on the program execution. However, in this case, the counting value of the watchdog timer differs. ## 9.3.2 Setup Example The watchdog timer detects errors. In the following example, the time-out period is set to $2^{18} \times$ system clock. An example setup procedure, with a description of each step is shown below. ■ Initial Setup Program (Watchdog Timer Initial Setup Example) | Setup Procedure | Description | |--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the time-out period<br>WDCTR(0x03F02)<br>bp2-1:WDTS1-0 =01 | (1) Set the WDTS1-0 flag of the watchdog timer control register (WDCTR) to "01" to select the time-out period to 2 <sup>18</sup> × system clock. | | (2) Start the watchdog timer operation WDCTR(0x03F02) bp0:WDEN =1 | (2) Set the WDEN flag of the WDCTR register to start the watchdog timer operation. | ■ Main Routine Program (Watchdog Timer Constant Clear Setup Example) | Setup Procedure | Description | |-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the watchdog timer for the constant clear Writing to WDCTR(0x03F02) | (1) Clear the watchdog timer by the cycle from $2^{18} \times \text{system}$ clock. | | (c.f.)BSET (WDCTR) WDEN<br>(bp0:WDEN=1) | The watchdog timer clear should be inserted in the main routine, with the same cycle, and to be the set cycle. The recommended instruction is the bit-set (BSET), does not change value, for clear. | ### ■ Interrupt Service Routine Setup | Setup Procedure | Description | |---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the watchdog interrupt service routine NMICR(0x03FE1) TBNZ (NMICR),WDIR,WDPR0 | (1) If the watchdog timer overflows, the non maskable interrupt is generated. Confirm that the WDIR flag of the non maskable interrupt control register (NMICR) is "1" on the interrupt service routine to manage the suitable execution. | The operation just before the watchdog interrupt may be executed wrongly. Therefore, if the watchdog interrupt is generated, initialize the system. Chapter 9 Watchdog Timer # 10.1 Overview This LSI has a buzzer. It can output the square wave that multiply by $1/2^9$ to $1/2^{14}$ of the high frequency oscillation clock, or by $1/2^3$ to $1/2^4$ of the low frequency oscillation clock. ## 10.1.1 Functions Table:10.1.1 shows the buzzer functions. Table:10.1.1 Buzzer Functions | P12, P13 output selection | Port output<br>Buzzer output | |------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | Buzzer output frequency selection | fosc/2 <sup>14</sup> fosc/2 <sup>13</sup> fosc/2 <sup>12</sup> fosc/2 <sup>11</sup> fosc/2 <sup>10</sup> fosc/2 <sup>9</sup> fx/2 <sup>4</sup> | | Oscillation stabilization wait cycle selection | fs/2 <sup>14</sup><br>fs/2 <sup>10</sup><br>fs/2 <sup>6</sup> *1<br>fs/2 <sup>2</sup> *1 | <sup>\*1:</sup>Do not use at high-speed operation (NORMAL mode). Use at slow-speed operation (SLOW mode). When BUZOE flag is set to "0", buzzer output becomes "Low". # 10.1.2 Block Diagram ### ■ Buzzer Block Diagram Figure:10.1.1 Buzzer Block Diagram # 10.2 Control Register Buzzer is formed by the control register (DLYCTR). # 10.2.1 Registers Table:10.2.1 shows the buzzer control register. Table:10.2.1 Buzzer Control Register | Register | Address | R/W | Functions | Page | |----------|---------|-----|------------------------------------------------------|-------| | DLYCTR | 0x03F03 | R/W | Oscillation Stabilization Wait Time Control Register | X-5 | | P1OMD | 0x03F1C | R/W | Port 1output mode register | IV-10 | # 10.2.2 Oscillation Stabilization Wait Time Control Register (DLYCTR) ■ Oscillation Stabilization Wait Time Control Register (DLYCTR:0x03F03) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-------|-------|-------|-------|-------|-------|---|---| | Flag | BUZOE | BUZS2 | BUZS1 | BUZS0 | DLYS1 | DLYS0 | - | - | | at reset | 0 | 0 | 0 | 0 | 0 | 0 | - | - | | Access | R/W | R/W | R/W | R/W | R/W | R/W | - | - | | bp | Flag | Description | |-----|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | BUZOE | P12, P13 output selection 0:Port output 1:Buzzer output | | 6-4 | BUZS2<br>BUZS1<br>BUZS0 | Buzzer output frequency selection 000:fosc/2 <sup>14</sup> 001:fosc/2 <sup>13</sup> 010:fosc/2 <sup>12</sup> 011:fosc/2 <sup>11</sup> 100:fosc/2 <sup>10</sup> 101:fosc/2 <sup>9</sup> 110:fx/2 <sup>4</sup> 111:fx/2 <sup>3</sup> | | 3-2 | DLYS1<br>DLYS0 | Oscillation stabilization wait period selection 00:fs/2 <sup>14</sup> 01:fs/2 <sup>10</sup> 10:fs/2 <sup>6</sup> *1 11:fs/2 <sup>2</sup> *1 | | 1-0 | - | - | <sup>\*1:</sup>Do not use at high-speed operation (NORMAL mode). Use at slow-speed operation (SLOW mode). # 10.3 Operation ## 10.3.1 Operation #### ■ Buzzer Buzzer outputs the square wave, having frequency $1/2^9$ to $1/2^{14}$ of the high oscillation clock (fosc), or $1/2^3$ to $1/2^4$ of the low oscillation clock (fx). The BUZS 2, 1, 0 flag of the oscillation stabilization wait control register (DLYCTR) set the frequency of the buzzer output. The BUZOE flag of the oscillation stabilization wait control register (DLYCTR) sets buzzer output ON / OFF. ### ■ Buzzer Output Frequency The frequency of buzzer output is decided by the frequency of the high oscillation clock (fosc) or the low oscillation clock (fx) and the bit 6, 5, 4 (BUZS2, BUZS1, BUZS0) of the oscillation stabilization wait control register (DLYCTR). Table:10.3.1 Buzzer Output Frequency | fosc | fx | BUZS2 | BUZS1 | BUZSO | Buzzer output frequency | |----------|--------|-------|-------|-------|-------------------------| | 10 MHz | - | 0 | 0 | 0 | 2.44 kHz | | 10 MHz | - | 0 | 0 | 1 | 4.88 kHz | | 10 MHz | - | 0 | 1 | 0 | 9.76 kHz | | 8.39 MHz | - | 0 | 1 | 0 | 2.05 kHz | | 8.39 MHz | - | 0 | 1 | 1 | 4.1 kHz | | 2 MHz | - | 1 | 0 | 0 | 1.95 kHz | | 2 MHz | - | 1 | 0 | 1 | 3.91 kHz | | - | 32 kHz | 1 | 1 | 0 | 2 kHz | | - | 32 kHz | 1 | 1 | 1 | 4 kHz | ## 10.3.2 Setup Example ### ■ Setup Example Buzzer outputs the square wave of 2 kHz from P12 pin. It is used 8.39 MHz as the high oscillation clock (fosc). An example of setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the buzzer frequency<br>DLYCTR (0x03F03)<br>bp6-4 :BUZS2-0 =010 | (1) Set BUZS2 to BUZS0 flag of the oscillation stabilization wait control register (DLYCTR) to "010" to select fosc/ 2 <sup>12</sup> to the buzzer frequency. When the high oscillation clock fosc is 8.39 MHz, the buzzer output frequency is 2.05 kHz. | | (2) Set P12 pin P10MD (0x03F1C) bp0 :BUZSEL =1 P1DIR (0x03F31) bp2 :P1DIR2 =1 | (2) Set BUZSEL flag of port 1 output mode register (P10MD) to "1" to set P12 to special function pin. Set P1DIR2 flag of port 1 direction control register (P1DIR) to "1" to set output mode, then low level is output from P12. | | (3) Buzzer output ON DLYCTR (0x03F03) bp7 :BUZOE =1 | (3) Set the BUZSE flag of the oscillation stabilization wait control register (DLYCTR) to "1" to output the square wave of the buzzer output frequency set by P12 pin. | | (4) Buzzer output OFF DLYCTR (0x03F03) bp7 :BUZOE =0 | (4) Set the BUZOE flag of the oscillation stabilization wait control register to (DLYCTR) "0" to clear, and P12 pin outputs low level. | Setup of the buzzer output ON should be done after setup of the buzzer frequency. When the low oscillation clock (fx) dividing is selected as the buzzer output frequency and the buzzer output is switched ON from OFF, the buzzer dividing counter is not cleared unless more than 1 clock of the low oscillation clock is secured. # 11.1 Overview This LSI contains a serial interface 0 that can be used for both communication types of clock synchronous and UART (duplex). Also the used pins can be switched to A (port A: PA0/SBO0A/TXD0A/AN0, PA1/SBI0A/RXD0A/AN1, PA2/SBT0A/AN2) or to B (Port 7: P75/SBO0B/TXD0B/KEY5/SEG2, P76/SBI0B/RXD0B/KEY6/SDA4A/SEG1, P77/SBT0B/KEY7/SCL4B/SEG0). On this text, if there are not much difference between port A and port B on the operation, port A and B are omitted. ### 11.1.1 Functions Table:11.1.1 shows functions of serial interface 0. Table:11.1.1 Serial Interface 0 functions | Communication style | Clock synchronous | UART (duplex) | |------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------| | Interrupt | SCOTIRQ | SC0TIRQ(on transmission completion) SC0RIRQ(on reception completion) | | Pins | SBO0,SBI0,SBT0 | TXD0,RXD0 | | 3 channels type | 0 | - | | 2 channels type | O(SBO0,SBT0) | 0 | | 1 channel type | - | TXD0 | | Specification of transfer bit count/ Frame selection | 1 to 8 bits | 7 bit +1STOP 7 bit +2STOP 8 bit +1STOP 8 bit +2STOP | | Selection of parity bit | - | 0 | | Parity bit control | - | 0 parity 1 parity odd parity even parity | | Selection of start condition | 0 | Only "enable start condition" is available | | Specification of the first transfer bit | 0 | О | | Specification of input edge/ output edge | 0 | - | | SBO0 output control after final data is transferred | H/L/final data hold | - | | Function in STANDBY mode | Only slave reception is available | - | | Internal clock | Not divided<br>Divided by 8<br>Divided by 16 | Divided by 8<br>Divided by 16 | | Clock source | fosc/2 | fosc/2 | | |-----------------------------------|----------------|----------------|--| | | fosc/4 | fosc/4 | | | | fosc/16 | fosc/16 | | | | fosc/64 | fosc/64 | | | | fs/2 | fs/2 | | | | fs/4 | fs/4 | | | | External clock | Timer 1 output | | | | Timer 1 output | Timer 2 output | | | | Timer 2 output | | | | Maximum transfer rate | 5.0 MHz | 300 kbps | | | fosc:Machine clock (High speed of | scillation) | 1 | | fs:System clock # 11.1.2 Block Diagram ### ■ Serial interface 0 Block Diagram Figure:11.1.1 Serial interface 0 Block Diagram # 11.2 Control Registers # 11.2.1 Registers Table:11.2.1 shows registers to control serial interface 0. Table:11.2.1 Serial interface 0 Control Registers | Register | Address | R/W | Function | Page | |----------|---------|-----|-------------------------------------------------------|--------| | SC0MD0 | 0x03F91 | R/W | Serial interface 0 mode register 0 | XI-7 | | SC0MD1 | 0x03F92 | R/W | Serial interface 0 mode register 1 | XI-8 | | SC0MD2 | 0x03F93 | R/W | Serial interface 0 mode register 2 | XI-9 | | SC0MD3 | 0x03F94 | R/W | Serial interface 0 mode register 3 | XI-10 | | SC0STR | 0x03F95 | R | Serial interface 0 status register | XI-11 | | RXBUF0 | 0x03F96 | R | Serial interface 0 reception data buffer | XI-6 | | TXBUF0 | 0x03F97 | R/W | Serial interface 0 transmission data buffer | XI-6 | | SCSEL | 0x03F90 | R/W | Serial interface I/O pins switching control register | XI-6 | | PAODC | 0x03F2D | R/W | Port A Nch open-drain control register | IV-77 | | PADIR | 0x03F3A | R/W | Port A direction control register | IV-75 | | PAPLU | 0x03F4A | R/W | Port A pull-up/pull-down control register | IV-76 | | SC0RICR | 0x03FEF | R/W | Serial 0 UART reception interrupt control register | III-32 | | SC0TICR | 0x03FF0 | R/W | Serial 0 UART transmission interrupt control register | III-33 | R/W:Readable/ Writable R:Readable only ## 11.2.2 Data Buffer Registers Serial interface 0 has one each of 8-bit data buffer register for transmission and for reception. ■ Serial interface 0 Reception Data Buffer (RXBUF0:0x03F96) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | RXBUF07 | RXBUF06 | RXBUF05 | RXBUF04 | RXBUF03 | RXBUF02 | RXBUF01 | RXBUF00 | | Reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ■ Serial interface 0 Transmission Data Buffer (TXBUF0:0x03F97) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TXBUF07 | TXBUF06 | TXBUF05 | TXBUF04 | TXBUF03 | TXBUF02 | TXBUF01 | TXBUF00 | | Reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W # 11.2.3 Mode Registers ## ■ Serial interface 0 Mode Register 0 (SC0MD0:0x03F91) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---|---|--------|--------|---------|---------|---------| | Flag | SC0CE1 | - | - | SC0DIR | SC0STE | SC0LNG2 | SC0LNG1 | SC0LNG0 | | Reset | 0 | - | - | 0 | 0 | 1 | 1 | 1 | | Access | R/W | - | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |-----|-------------------------------|-----------------------------------------------------------------------------------------------| | 7 | SC0CE1 | Transmission data output edge 0:falling 1:rising Reception data input edge 0:rising 1:falling | | 6-5 | - | - | | 4 | SC0DIR | First bit to be transferred 0:MSB first 1:LSB first | | 3 | SC0STE | Start condition selection 0:Disabled 1:Enabled | | 2-0 | SC0LNG2<br>SC0LNG1<br>SC0LNG0 | Transfer bit 000:1bit 001:2bit 010:3bit 011:4bit 100:5bit 101:6bit 111:8bit | ## ■ Serial interface 0 Mode Register 1(SC0MD1:0x03F92) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---------|---------|-------------|--------|--------|--------|--------| | Flag | SCOIOM | SC0SBTS | SC0SBIS | SC0SBO<br>S | SC0CKM | SC0MST | SC0DIV | SC0CMD | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | R/W | R/W | R/W | - | R/W | R/W | R/W | | bp | Flag | Description | |----|---------|-----------------------------------------------------------------------------------------| | 7 | SCOIOM | Serial data input selection 0:Data input from SBI0 (RXD0) 1:Data input from SBO0 (TXD0) | | 6 | SC0SBTS | SBT0 pin function selection 0:Port 1:Transfer clock I/O | | 5 | SC0SBIS | Serial input control selection 0:Input "1" 1:Input serial | | 4 | SC0SBOS | SBO0(TXD0) pin function 0:Port 1:Output serial data | | 3 | SC0CKM | Transfer clock dividing selection 0:Not divided 1:Divided | | 2 | SCOMST | Clock master/ slave selection 0:Clock slave 1:Clock master | | 1 | SCODIV | Transfer clock dividing selection 0:Devided by 8 1:Devided by 16 | | 0 | SC0CMD | Synchronous serial/ duplex UART selection 0:Synchronous serial 1:Duplex UART | ## ■ Serial interface 0 Mode Register 2 (SC0MD2:0x03F93) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|---|---------|---------| | Flag | SC0FM1 | SC0FM0 | SC0PM1 | SC0PM0 | SC0NPE | - | SC0BRKF | SC0BRKE | | Reset | 0 | 0 | 0 | 0 | 0 | - | 0 | 0 | | Access | R/W | R/W | R/W | R/W | R/W | - | R | R/W | | bp | Flag | | Description | | | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--| | 7-6 | SC0FM1<br>SC0FM0 | Frame mode specification 00:7 data bit + 1 stop bit 01:7 data bit + 2 stop bit 10:8 data bit + 1 stop bit 11:8 data bit + 2 stop bit | | | | | 5-4 | SC0PM1<br>SC0PM0 | Added bit specification Transmission 00:Add "0" 01:Add "1" 10:Add odd parity 11:Add even parity | Reception Check for 0 Check for 1 Check for odd parity Check for even parity | | | | 3 | SC0NPE | Parity enable 0:Enable parity bit 1:Disable parity bit | | | | | 2 | - | - | | | | | 1 | SC0BRKF | Break status receive monitor 0:Data reception 1:Break reception | | | | | 0 | SC0BRKE | Break status transmit control 0:Data transmission 1:Break transmission | | | | ## ■ Serial interface 0 Mode Register 3 (SC0MD3:0x03F94) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---|---|-------------|---------|---------|---------| | Flag | SC0FDC1 | SC0FDC0 | - | - | SC0PSC<br>E | SC0PSC2 | SC0PSC1 | SC0PSC0 | | Reset | 0 | 0 | - | - | 0 | 0 | 0 | 0 | | Access | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | bp | Flag | Description | |-----|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC0FDC1<br>SC0FDC0 | Output selection after SBO0 final data is transferred 00:Fix to "1" (High) output 01:Hold final data 10:Fix to "0" (Low) output 11:Reserved | | 5-4 | - | - | | 3 | SC0PSCE | Prescaler count control 0:Disable the count 1:Enable the count | | 2-0 | SC0PSC2<br>SC0PSC1<br>SC0PSC0 | Selection clock<br>000:fosc/2<br>001:fosc/4<br>010:fosc/16<br>011:fosc/64<br>100:fs/2<br>101:fs/4<br>110:Timer 1 output<br>111:Timer 2 output | ## ■ Serial interface 0 Status Register (SC0STR:0x03F95) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------------|---------|---------|---------|--------|--------|--------|--------| | Flag | SC0TBS<br>Y | SC0RBSY | SC0TEMP | SC0REMP | SC0FEF | SC0PEK | SC0ORE | SC0ERE | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | | bp | Flag | Description | |----|---------|-----------------------------------------------------------------| | 7 | SCOTBSY | Serial bus status 0:Other use 1:Serial transmission in progress | | 6 | SCORBSY | Serial bus status 0:Other use 1:Serial reception in progress | | 5 | SCOTEMP | Transmission buffer empty flag 0:Empty 1:Full | | 4 | SCOREMP | Reception buffer empty flag 0:Empty 1:Full | | 3 | SC0FEF | Framing error detection 0:No error 1:Error | | 2 | SC0PEK | Parity error detection 0:No error 1:Error | | 1 | SC0ORE | Overrun error detection 0:No error 1:Error | | 0 | SC0ERE | Error monitor flag 0:No error 1:Error | ## ■ Serial interface I/O pin switching control Register (SCSEL:0x03F90) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------------|--------------|--------------|--------------|-------|---|-------|-------| | Flag | TEMPSC<br>12 | TEMPSC<br>11 | TEMPSC0<br>2 | TEMPSC0<br>1 | SC4SL | - | SC1SL | SC0SL | | Reset | 0 | 0 | 0 | 0 | 0 | - | 0 | 0 | | Access | R/W | R/W | R/W | R/W | R/W | - | R/W | R/W | | bp | Flag | Description | |-----|--------------------|---------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TMPSC12<br>TMPSC11 | Serial 1 used timer 2 output dividing switching X0:Timer 2 output 01:Timer 2 output divided by 2 11:Timer 2 output divided by 8 | | 5-4 | TMPSC02<br>TMPSC01 | Serial 0 used timer 2 output dividing switching X0:Timer 2 output 01:Timer 2 output divided by 2 11:Timer 2 output divided by 8 | | 3 | SC4SL | Serial 4 I/O pin switching 0:A (P10, P11) 1:B (P76, P77) | | 2 | - | - | | 1 | SC1SL | Serial 1 I/O pin switching 0:A (P15 to P17) 1:B (PA4 to PA6) | | 0 | SC0SL | Serial 0 I/O pin switching 0:A (PA0 to PA2) 1:B (P75 to P77) | # 11.3 Operation Serial interface 0 can be used for both clock synchronous and duplex UART. ### 11.3.1 Clock Synchronous Serial Interface #### Activation Factor for Communication Table:11.3.1 shows activation factors for communication. At master communication, the transfer clock is generated by setting data to the transmission data buffer TXBUF0, or by receiving a start condition. Except during communication, the input signal from SBT0 pin is masked to prevent operating errors by noise. This mask can be released automatically by setting a data to TXBUF0 (access to the TXBUF0 register), or enabling a start condition to the data input pin. Therefore, at slave communication, set data to TXBUF0, or input an external clock after a start condition is input. However, the external clock should be input after 3.5 transfer clock interval past from the data set to TXBUF0. This period is for loading the data from TXBUF0 to the internal shift register. | Clock | Communication type | Start condition | Activation factor of communication | | | |--------|------------------------|-----------------|----------------------------------------------------|--|--| | Master | Transmission | Enabled | Set transmission data (*1) | | | | | | Disabled | Set transmission data(*2) | | | | | Reception | Enabled | Input start condition(*3) | | | | | | | or | | | | | | | Set dummy data(*2) | | | | | | Disabled | Set dummy data (*2) | | | | | Transmission/Reception | Enabled | -(*4) | | | | | | Disabled | Set transmission data(*2) | | | | Slave | Transmission | Enabled | Input clock after transmission data is set (*5) | | | | | | Disabled | Input clock after transmission data is set (*6) | | | | | Reception | Enabled | Input clock after start condition is input (*7) or | | | | | | | Input clock after dummy data is set (*6) | | | | | | Disabled | Input clock after dummy data is set (*6) | | | | | Transmission/Reception | Enabled | -(*4) | | | | | | Disabled | Input clock after transmission data is set (*6) | | | - (\*1) After the start condition output, the transfer clock is output after 1 transfer clock interval. - (\*2) After setting transmission data/dummy data, the transfer clock should be output after 3.5 transfer clock interval at the maximum. The system configuration is required so that the transmission data/dummy data are written after the master receives the information of slave data load completion. - (\*3) After the start condition input, the transfer clock is output after 2.5 transfer clock interval at the maximum. When receiving data continuously, the system configuration is required to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. - (\*4) When the start condition is set to "enable", transmission and reception should not be excuted at the same time. - (\*5) After setting the transmission data, output the start condition and wait until the master excutes the clock input. At the clock input, 1 or more transfer clock interval is required after the start condition output. - (\*6) At the clock input, 3.5 or more transfer clock interval is required after setting transmission data/dummy data. The system configuration is required to notify the master of the data load completion. - (\*7) At the clock input, 0.5 or more transfer clock interval is required after the start condition input. When receiving data continuously, the system configuration is required to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. #### ■ Transfer Bit Setup The transfer bit count can be set from 1 to 8 bits. Set the transfer bit count by the SC0LNG 2 to 0 flag of the SC0MD0 register (at reset:111). The SC0LNG2 to 0 flag holds the former set value until it is set again. Except during communication, SBT0 pin is masked to prevent errors by noise. At slave communication, set data to TXBUF0 or input a clock to SBT0 pin after a start condition is input. To communicate properly, more than 2.5 transfer clock interval after the data set to TXBUF0 is required to input the external clock. ### ■ Start Condition Setup The SC0STE flag of the SC0MD0 register sets the start condition whether it is enabled or disabled. The start condition is recognized when SC0CE1 flag of SC0MD0 is set to "0" and a clock line (SBT0 pin) is "H", data line (SBI0 pin with 3 lines or SBO0 pin with 2 lines) is changed from "H" to "L". Also, it is recognized when SC0CE1 flag is set to "1" and a clock line (SBT0 pin) is "L", data line (SBI0 pin with 3 lines or SBO0 pin with 2 lines) is changed from "H" to "L". Both the SCOSBOS flag and the SCOSBIS flag of the SCOMD1 register should be set to "0" before the start condition setup is changed. When transmission and reception are executed at the same time, set the start condition to "disable" to prevent abnormal operation. ### ■ First Transfer Bit Setup The SCODIR flag of the SCOMDO register can set the transfer bit. MSB first or LSB first can be selected. #### Transmission Data Buffer The transmission data buffer TXBUF0 is the spare buffer which stores data to be loaded to internal shift register. Set the data to be transferred to transmission data buffer TXBUF0, and the data is automatically loaded to internal shift register. The data loading takes more than 3 transfer clocks cycles. Data setting to TXBUF0 again during data loading may not be operated properly. You can determine whether or not data loading is in progress by monitoring transmission buffer empty flag SC0TEMP of the SC0STR. SC0TEMP flag is set to "1"when data is set to TXBUF0 and cleared to "0" when data loading ends. Figure:11.3.1 Transmission Data Buffer #### Reception Date Buffer The reception data buffer RXBUF0 is the spare buffer that pushed the received data in the internal shift register. After the communication complete interrupt SC0TIRQ is generated, all data stored in the internal shift register is stored to the received data buffer RXBUF0 automatically. RXBUF0 can store data up to 1 byte. RXBUF0 is rewritten every time communication is completed. Data of RXBUF0 should be read out before the next reception is completed. The received data buffer empty flag SC0REMP is set to "1" at the same time SC0TIRQ is generated. SC0REMP is cleared to "0" after RXBUF0 is read out. When the start condition is set to "enable" in the clock synchronous communication, transmission and reception should not be executed at the same time to prevent abnormal operation. If the start condition is input to restart during communication, the transmission data is not valid. Set the transmission data to TXBUF0 again to operate the transmission again. RXBUF0 is rewritten every time when communication is completed. At continuous communication, data of RXBUF0 should be read out by the time the next reception completes. #### Transmission Bit Count and First Transfer Bit At transmission, when the transfer bit count is 1 bit to 7 bits, the data storing method to the transmission data buffer TXBUF0 is different depending on the first transfer bit selection. At MSB first, use the upper bits of TXBUF0 for storing. When the transfer bit count is 6 bits, as shown on Figure:11.3.2, if data "A" to "F" are stored to bp2 to bp7 of TXBUF0, the transfer is operated from "F" to "A". At LSB first, use the lower bits of TXBUF0 for storing. When the transfer bit count is 6 bits, as shown on Figure:11.3.3, if data "A" to "F" are stored to bp0 to bp5 of TXBUF0, the transfer is operated from "A" to "F". Figure:11.3.2 Transmission Bit Count and First Transfer Bit (starting with MSB) Figure:11.3.3 Transmission Bit Count and First Transfer Bit (starting with LSB) ### ■ Reception Bit Count and First Transfer Bit At reception, when the transfer bit count is 1 bit to 7 bits, the data storing method to the reception data buffer RXBUF0 is different depending on the first transfer bit. At MSB first, data is stored to the lower bits of RXBUF0. When the transfer bit count is 6 bits, as shown on figure Figure:11.3.5, if data "A" to "F" are stored to bp0 to bp5 of RXBUF0, the transfer is operated from "F" to "A". At LSB first, data is stored to the upper bits of RXBUF0. When the transfer bit count is 6 bits, as shown on Figure:11.3.4, if data "A" to "F" are stored to bp2 to bp7 of RXBUF0, the transfer is operated from "A" to "F". Figure:11.3.4 Reception Bit Count and First transfer Bit (starting with MSB bit) Figure:11.3.5 Reception Bit Count and First transfer Bit (starting with LSB bit) #### ■ Continuous Transmission This serial interface has a function for continuous communication. If data is set to the transmission data buffer TXBUF0 during communication, the transmission buffer empty flag SC0TEMP is automatically set to communicate continuously. Data setup to TXBUF0 should be done after the data is loaded to the internal shift register before the communication complete interrupt SC0TIRQ is generated. At master communication, suspension of communication between the SC0TIRQ generation and the next transfer clock output is 4 transfer clocks. ## ■ Input Edge/ Output Edge Setup The SC0CE1 flag of the SC0MD0 register sets the output edge of the transmission data and the input edge of the reception data. Data at transmission is output at the falling edge of clock as the SC0CE1 flag = "0", and at the rising edge of clock as the SC0CE1 = "1". Data at reception is input at the rising edge of clock as the SC0CE1 = "0", and at the falling edge of clock as the SC0CE1 flag = "1". Table:11.3.2 Transmission Data Output Edge and Reception Data Input Edge | Transmission data output edge | Reception data input edge | |-------------------------------|-------------------------------| | | | | <u> </u> | | | | | | _ | Transmission data output edge | ### Clock Setup Clock source is selected from the dedicated prescaler and timers 1, 2 output (2 channels) with the SC0PSC2 to 0 of the SC0MD3 register. The dedicated prescaler is started by selecting "count enable" with the SC0PSCE flag of the SC0MD3 register. The SC0MST flag of the SC0MD1 register can select the internal clock (clock master), or the external clock (clock slave). Even if the external clock is selected, set the internal clock that has the same clock cycle or lower to the external clock by the SC0MD3 register as the interrupt flag SC0TIRQ is generated by the internal clock. The following is the internal clock source that can be set by the SC0MD3 register. Also, the SC0CKM flag of the SC0MD1 register can divide the internal clock. SC0DIV flag can select the dividing ratio between "divided by 8" and "divided by 16". Table:11.3.3 Synchronous Serial Interface Internal Clock Source | | Serial Interface 0 | |------------------|--------------------| | Clock source | fosc/2 | | (internal clock) | fosc/4 | | | fosc/16 | | | fosc/64 | | | fs/2 | | | fs/4 | | | Timer 1 output | | | Timer 2 output | | | Timer 2 output/2 | | | Timer 2 output/8 | Set always the SC0SBIS flag and SC0SBOS flag of the SC0MD1 register to "0" before switching the clock setup. When the slave reception is executed with the start condition "enable" at the continuous communication, the system configuration is required to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. #### Pin Switching Used pin can be switched to A (SBO0A, SBI0A, SBT0A) or B (SBO0B, SBI0B, SBT0B) by the SCOSL flag of the SCSEL register. #### ■ Data Input Pin Setup 3 channels type (clock pin: SBT0 pin, data output pin: SB00 pin, data input pin: SB10 pin) or 2 channels type (clock pin: SBT0 pin, data I/O pin: SB00 pin) can be selected as a communication mode. SB10 pin can be used only for serial data input. SB00 pin can be selected as serial data input or output. Whether the serial data is input from SB10 pin or SB00 pin, it can be selected by the SC0IOM flag of the SC0MD1 register. When "data input from SB00 pin" is selected to set the 2 channels type, transmission/ reception can be switched by the SB00 pin direction control. For SB00A pin, it can be done by the PADIR2 flag of the PADIR register, for SB00B pin, by the P7DIR5 flag of the P7DIR. At this time, SB10 pin can be used as a general port, too. The transfer speed should be up to 5.0 MHz. If the transfer clock is over 5.0 MHz, the transmission data may not be sent correctly. At reception, if SC0IOM of the SC0MD1 register is set to "1" and "serial data input from SB00" is selected, SBI0 pin can be used as a general port. ### Reception Buffer Empty Flag After reception is completed (SC0TIRQ is generated), data is automatically stored to RXBUF0 from the internal shift register. If data is stored to the shift register RXBUF0 when the SC0SBIS of the SC0MD1 register is set to "serial input", the reception buffer empty flag SC0REMP of the SC0STR register is set to "1". This indicates that the reception data is going to be read out. SC0REMP is cleared to "0" by reading out the data of RXBUF0. ### ■ Transmission Buffer Empty Flag During the communication (after the data is loaded to the internal shift register and before the communication complete interrupt SC0TIRQ is generated) if any data is set to TXBUF0 again, the transmission buffer empty flag SC0REMP of the SC0STR register is set to "1". This indicates that the next transmission data is going to be loaded. Data is loaded to the internal shift register from TXBUF0 by generation of SC0TIRQ, and the next transfer is started as SC0TEMP is cleared to "0". # Overrun Error and Error Monitor Flag After reception complete, if the next data has already been received before reading out of the data of the received data buffer RXBUF0, overrun error is generated and the SC0ORE flag of the SC0STR register is set to "1". At the same time, the error monitor flag SC0ERE is set to indicate a reception error. The SC0ERE flag is cleared after the data of RXBUF0 is read out and the next communication complete interrupt SC0TIRQ is generated. SC0ERE is cleared as SC0ORE flag is cleared. These error flags have no effect on communication operation. ### ■ Reception BUSY Flag When the SC0SBIS flag of the SC0MD1 register is set to "serial data input" and the data is set to TXBUF0, or the start condition is recognized, the BUSY flag SC0RBSY of the SC0STR register is set to "1". The flag is cleared to "0" after the communication complete interrupt SC0TIRQ is generated. During continuous communication, the SC0RBSY flag is always set. If the transmission buffer empty flag SC0TEMP is cleared to "0" as the communication complete interrupt SC0TIRQ is generated, SC0RBSY is cleared to "0". If the SC0SBIS flag is set to "0" during communication, the SC0RBSY flag is cleared to "0". ### ■ Transmission BUSY Flag When the SC0SBOS flag of the SC0MD1 register is set to "serial data output" and the data is set to TXBUF0, or the start condition is recognized, the SC0TBUSY flag of the SC0STR register is set if the SC0SBOS flag of the SC0MD1 register is "1". The flag is cleared to "0" after the communication complete interrupt SC0TIRQ is generated. During continuous communication, the SC0TBSY flag is always set. If the transmission buffer empty flag SC0TEMP is cleared to "0" as the communication complete interrupt SC0TIRQ is generated, SC0TBSY is cleared to "0". If the SC0SBOS flag is set to "0" during communication, the SC0TBSY flag is cleared to "0". #### Forced Reset This serial interface contains forced reset for abnormal operation. For forced reset, the SC0SBOS flag and the SC0SBIOS flag of the SC0MD1 register should be set to "0" (SBO0 pin: port, input data:"1" input). At forced reset, the status register (the SC0BRKF flag of the SC0MD2 register, all flags of the SC0STR register) are initialized as they are set at reset, but the control register holds the set value. #### Last Bit of Transmission Data Table:11.3.4 shows the data output holding period of the last bit at transmission, and the minimum data input period of the last bit at reception. At slave, the internal clock should be set up to keep the data hold time at transmission. Table:11.3.4 Last Bit Data Length of Transfer Data | | The last bit data holding period at transmission | The last data input period at reception | |-----------|--------------------------------------------------------------------------------------------|-----------------------------------------| | At master | 1 bit data length | 1 bit data length (Minimum) | | At slave | [1 bit data length of external clock $\times$ 1/2] + [internal clock cycle $\times$ (1-2)] | | When start condition is disabled (at SC0STE flag = 0), the SBO0 output after the data output holding period of the final bit can be set by the setting value of the SC0FDC1 to 0 flag of the SC0MD3 register, as shown on Table:11.3.5 After releasing the reset, despite the setting value of the SC0FDC1 to 0 flag, output before the serial transfer is "H". When start condition is enabled (at SC0STE flag = 1), despite the setting value of the SC0FDC1 to 0, "H" is output. Table:11.3.5 SBO0 Output after the Data Output Holding Period of the Last Bit (without start condition) | SC0FDC1 flag | SC0FDC0 flag | SBO0 output after the data output holding period of the last bit | |--------------|--------------|------------------------------------------------------------------| | 0 | 0 | Fixed to "1"(High) output | | 1 | 0 | Last data holding | | 0 | 1 | Fixed to "0"(Low) output | | 1 | 1 | Reserved | # ■ Other Control Flag Setup Table:11.3.6 shows the flags that do not required to be set or monitored as the flags are not used at clock synchronous communication. Table:11.3.6 Other Control Flag | Register | Flag | Detail | |----------|-------------|-----------------------------------| | SC0MD2 | SCOBRKE | Break status transmission control | | | SCOBRKF | Break status reception monitor | | | SC0NPE | Parity enable | | | SC0PM1 to 0 | Added bit specification | | | SC0FM1 to 0 | Frame mode specification | | SC0STR | SC0PEK | Parity error detection | | | SC0FEF | Frame error detection | # ■ Transmission Timing Figure:11.3.6 Transmission Timing (at falling edge, start condition is enabled) Figure:11.3.7 Transmission Timing (at falling edge, start condition is disabled) Figure:11.3.8 Transmission Timing (at rising edge, start condition is enabled) Figure:11.3.9 Transmission Timing (at rising edge, start condition is disabled) # Reception Timing Figure:11.3.10 Reception Timing (at rising edge, start condition is enabled) Figure:11.3.11 Reception Timing (at rising edge, start condition is disabled) Figure:11.3.12 Reception Timing (at falling edge, start condition is enabled) Figure:11.3.13 Reception Timing (at falling edge, start condition is disabled) # ■ Transmission/ Reception Timing As data is received at the opposite edge of the transmission clock, set the polarity of reception data input edge to opposite polarity of the transmission data output edge. When transmission and reception are executed at the same time, set the start condition to "disable" to prevent abnormal operation. Figure:11.3.14 Transmission/ Reception Timing (Reception:at rising edge, Transmission:at falling edge) Figure:11.3.15 Transmission/ Reception Timing (Reception:at falling edge, Transmission:at rising edge) ### ■ Communication Function at Standby Mode This serial interface is capable of slave reception in STANDBY mode. CPU operation status can be recovered from standby to normal by the communication complete interrupt SC0TIRQ that is generated after the slave reception. (In STANDBY mode, continuous reception is disabled after data of transfer bit count set by SC0LNG2-0 flags of the SC0MD0 register is received.) The received data should be read out from the received data buffer RXBUF0 after recovering to NORMAL mode. In STANDBY mode, reception with start condition is not available, thus, disable start condition. And set dummy data to transmission data buffer TXBUF0 before transition to STANDBY mode. Figure:11.3.16 Reception Timing at Standby Mode (Reception:at rising edge, start condition is disabled) # ■ Pins Setup (with 3 channels, at transmission) Table:11.3.7 shows the setup for synchronous serial interface pin with 3 channels (SBO0 pin, SBI0 pin, SBT0 pin) at transmission. Table:11.3.7 Setup for Synchronous Serial Interface Pin (with 3 channels, at transmission) | Setup item | Data output pin Data input pin | | Clock I/O pin | | |---------------------------------------|----------------------------------|---------------------|--------------------------------|--------------------------------| | · · · · · · · · · · · · · · · · · · · | SBI0A pin | SBT0 pin/ SBT0B pin | | | | | SBO0B pin | SBI0B pin | Clock master | Clock slave | | | | | SC0SCMD1(SC0MST) | | | Port pin | PA0/P75 | PA1/P76 | PA2/P77 | | | Port pin setup | Select pin (A, B) | | | | | | SCSEL (SC0SL) | | | | | Serial data input | SBI0 | | - | | | selection SC0MD1(SC0IOM) | | | | | | Function | Serial data output | "1" input | Transfer clock I/O | Transfer clock I/O | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | SC0MD1(SC0SBTS) | | | Style | Push-pull/ Nch open-<br>drain | - | Push-pull/ N-ch open-<br>drain | Push-pull/ N-ch open-<br>drain | | | PAODC(PAODC0)/<br>P7ODC(P7ODC5) | | PAODC(PAODC2)/P70 | ODC(P7ODC7) | | I/O | Output mode | - | Output mode | Input mode | | | PADIR(PADIR0)/<br>P7DIR(P7DIR5) | | PADIR(PADIR2)/P7DIF | R(P7DIR7) | | Pull-up setup | Added/ Not added | - | Added/ Not added | Added/ Not added | | | PAPLU(PAPLU0)/<br>P7PLU(P7APLU5) | | PAPLU(PAPLU2)/P7P | LU(P7PLU7) | # ■ Pins Setup (with 3 channels, at reception) Table:11.3.8 shows the setup for synchronous serial interface pin with 3 channels (SBO0 pin, SBI0 pin, SBT0 pin) at reception. Table:11.3.8 Setup for Synchronous Serial Interface Pin (with 3 channels, at reception) | Setup item | Data output pin | Data input pin | Clock I/O pin | | |-------------------|-------------------|--------------------------------|--------------------------------|--------------------------------| | | • | SBT0A pin/ SBT0B pin | | | | | SBO0B pin | SBI0B pin | Clock master | Clock slave | | | | | SC0SCMD1(SC0MST) | | | Port pin | PA0/P75 | PA1/P76 | PA2/P77 | | | Port pin setup | Select pin (A, B) | | | | | | SCSEL (SC0SL) | | | | | Serial data input | SBI0 | | - | | | selection | SC0MD1(SC0IOM) | | ] | | | Function | Port | Serial input | Transfer clock I/O | Transfer clock I/O | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | SC0MD1(SC0SBTS) | | | Style | - | - | Push-pull/ N-ch open-<br>drain | Push-pull/ N-ch open-<br>drain | | | | | PAODC(PAODC2)/P70 | DDC(P7ODC7) | | I/O | - | Input mode | Output mode | Input mode | | | | PADIR(PADIR1)<br>P7DIR(P7DIR6) | PADIR(PADIR2)/P7DIF | R(P7DIR7) | | Pull-up setup | - | - | Added/ Not added | Added/ Not added | | | | | PAPLU(PAPLU2)/P7PI | U(P7PLU7) | # ■ Pins Setup (with 3 channels, at transmission / reception) Table:11.3.9 shows the setup for synchronous serial interface pin with 3 channels (SBO0 pin, SBI0 pin, SBT0 pin) at transmission / reception. Table:11.3.9 Setup for Synchronous Serial Interface Pin (with 3 channels, at transmission / reception) | Setup item | Data output pin Data input pin 0 | | Clock I/O pin | | |-------------------|----------------------------------|--------------------------------|--------------------------------|--------------------------------| | | - | SBT0A pin/SBT0B pin | | | | | SBO0B pin | SBI0B pin | Clock master | Clock slave | | | | | SC0SCMD1(SC0MST) | | | Port pin | PA0/P75 | PA1/P76 | PA2/P77 | | | Port pin setup | Select pin (A, B) | | | | | | SCSEL (SC0SL) | | | | | Serial data input | SBI0 | | - | | | selection | SC0MD1(SC0IOM) | | <u>-</u> | | | Function | Serial data output | Serial input | Transfer clock I/O | Transfer clock I/O | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | SC0MD1(SC0SBTS) | | | | Push-pull/ N-ch<br>open-drain | - | Push-pull/ N-ch open-<br>drain | Push-pull/ N-ch open-<br>drain | | | PAODC(PAODC0)<br>P7ODC(P7ODC5) | | PAODC(PAODC2)<br>P7ODC(P7ODC7) | | | I/O | Output mode | Input mode | Output mode | Input mode | | | PADIR(PADIR0)<br>P7DIR(P7DIR5) | PADIR(PADIR1)<br>P7DIR(P7DIR6) | PADIR(PADIR2)<br>P7DIR(P7DIR7) | | | Pull-up setup | Added/ Not added | - | Added/ Not added | Added/ Not added | | | PAPLU(PAPLU0)<br>P7PLU(P7PLU5) | | PAPLU(PAPLU2)<br>P7PLU(P7PLU7) | | # ■ Pins Setup (with 2 channels, at transmission) Table:11.3.10 shows the setup for synchronous serial interface pin with 2 channels (SBO0 pin, SBT0 pin) at transmission. SBI0 pin can be used as a port. Table:11.3.10 Setup for Synchronous Serial Interface Pin (with 2 channels, at transmission) | Setup item | em Data output pin Serial unused pin | | Clock I/O pin | | |-------------------|--------------------------------------|-----------------|--------------------------------|--------------------------------| | SBO | SBO0A pin S | ODIOD :-:- | SBT0A pin/ SBT0B pin | | | | SBO0B pin | | Clock master | Clock slave | | | | | SC0SCMD1(SC0MST) | | | Port pin | PA0/P75 | PA1/P76 | PA2/P77 | | | Port pin setup | Select pin (A, B) | | • | | | | SCSEL (SC0SL) | | | | | Serial data input | SBO0 | | - | | | selection | SC0MD1(SC0IOM) | | 1 | | | Function | Serial data input | "1" input | Transfer clock I/O | Transfer clock I/O | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | SC0MD1(SC0SBIS) | | | Style | Push-pull/ N-ch open-<br>drain | - | Push-pull/ N-ch open-<br>drain | Push-pull/ N-ch open-<br>drain | | | PAODC(PAODC0)<br>P7ODC(P7ODC5) | | PAODC(PAODC2)<br>P7ODC(P7ODC7) | | | I/O | Output mode | - | Output mode | Input mode | | | PADIR(PADIR0)<br>P7DIR(PADIR5) | | PADIR(PADIR2)<br>P7DIR(P7DIR7) | | | Pull-up setup | Added/ Not added | - | Added/ Not added | Added/ Not added | | | PAPLU(PAPLU0)<br>P7PLU(P7PLU5) | | PAPLU(PAPLU2)<br>P7PLU(P7PLU7) | | # ■ Pins Setup (with 2 channels, at reception) Table:11.3.11 shows the setup for synchronous serial interface pin with 2 channels (SBO0 pin, SBT0 pin) at reception. SBI0 pin can be used as a port. Table:11.3.11 Setup for Synchronous Serial Interface Pin (with 2 channels, at reception) | Setup item | etup item Data output pin Serial unused pin ( | | Clock I/O pin | | |-------------------|-----------------------------------------------|----------------------|--------------------------------|----------------------------| | | SBO0A pin SBI0A pin | SBT0A pin/ SBT0B pin | | | | | SBO0B pin | SBI0B pin | Clock master | Clock slave | | | | | SC0SCMD1(SC0MS | Γ) | | Port pin | PA0/P75 | PA1/P76 | PA2/P77 | | | Port pin setup | Select pin (A, B) | | | | | | SCSEL (SC0SL) | | | | | Serial data input | SBO0 | | - | | | selection | SC0MD1(SC0IOM) | | | | | Function | Port | Serial input | Transfer clock I/O | Transfer clock I/O | | | SC0MD1(SC0SBO<br>S) | SC0MD1(SC0SBIS) | SC0MD1(SC0SBIS) | • | | Style | - | - | Push-pull/ N-ch open-drain | Push-pull/ N-ch open-drain | | | | | PAODC(PAODC2)<br>P7ODC(P7ODC7) | | | I/O | Input mode | - | Output mode | Input mode | | | PADIR(PADIR0)<br>P7DIR(P7DIR5) | 1 | PADIR(PADIR2)<br>P7DIR(P7DIR7) | • | | Pull-up setup | - | - | Added/ Not added | Added/ Not added | | | | | PAPLU(PAPLU2)<br>P7PLU(P7PLU7) | • | # 11.3.2 Setup Example # ■ Transmission / Reception Setup Example The setup example for clock synchronous serial communication with serial 0 is shown. Table:11.3.12 shows the conditions at transmission / reception. Table:11.3.12 Setup Examples for Synchronous Serial Interface Transmission / Reception | Setup item | Set to | |-------------------------------------------|--------------------------| | Serial data input pin | Select SBI0 (3 channels) | | Transfer bit count | 8 bit | | Start condition | None | | First transfer bit | MSB | | Input edge | Falling edge | | Output edge | Rising edge | | Clock | Clock master | | Clock source | fs/2 | | Clock source dividing | Not divided | | Pin | A (port A) | | SBT0/SBO0 pin style | Nch open-drain | | SBT0 pin pull-up resistor | Added | | SBO0 pin pull-up resistor | Added | | serial 0 communication complete interrupt | Enable | | SBO0 output after last data output | "1"(H) fix | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------| | (1) Select the prescaler operation<br>SC0MD3(0x03F94)<br>bp3 :SC0PSCE =1 | (1) Set the SC0PSCE flag of the SC0MD3 register to "1" to select "prescaler operation". | | (2) Select the clock source<br>SC0MD3(0x03F94)<br>bp2-0 :SC0PSC2-0 =100 | (2) Set the SC0PSC2 to 0 flag of the SC0MD3 register to "100" to select the fs/2 as the clock source. | | (3) SBO0A output control after the last data is output SC0MD3(0x03F94) bp7,6 :SC0FDC1-0 =00 | (3) Set the SC0FDC1 to 0 flag of the SC0MD3 register to "00" to select "1" (High) fix of the SB00 last data output. | | Setup Procedure | Description | |-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (4) Select the pin<br>SCSEL(0x03F90)<br>bp :SC0SL =0 | (4) Set the SC0SL flag of the SCSEL register to "0" to select A (port A) as I/O pin. | | (5) Control the pin style PAODC(0x03F2D) bp2:PAODC2=1 bp0:PAODC0=1 PAPLU(0x03F4A) bp2:PAPLU2=1 bp0:PAPLU0=1 | (5) Set the PAODC2,PAODC0 flag of the PAODC register to "1,1" and select Nch open-drain to SBO0/SBT0 pin. Set the PAPLU2,PAPLU0 flag of the PAPLU register to "1,1" to enable the pull-up resistor. | | (6) Control the pin direction PADIR(0x03F3A) bp2:PADIR2 =1 bp1:PADIR1 =0 bp0:PADIR0 =1 | (6) Set the PADIR2, PADIR0 flag of the Port A pin direction control register (PADIR) to "1,1" and the PADIR1 flag to "0" to set PA2, PA0 to the output mode, PA1 to the input mode. | | (7) Set the SC0MD0 register Select the transfer bit count SC0MD0(0x03F91) bp2-0 :SC0LNG2-0 =111 | (7) Set the SC0LNG2 to 0 flag of the serial 0 mode register 0 (SC0MD0) to "111" to set the transfer bit count as "8 bits". | | Select the start condition SC0MD0(0x03F91) bp3 :SC0STE =0 | Set the SC0STE flag of the SC0MD0 register to "0" to disable the start condition. | | Select the first bit to be transferred SC0MD0(0x03F91) bp4 :SC0DIR =0 | Set the SC0DIR flag of the SC0MD0 register to "0" to set MSB as a transfer first bit. | | Select the transfer edge<br>SC0MD0(0x03F91)<br>bp7 :SC0CE1 =1 | Set the SC0CE1 flag of the SC0MD0 register to "1" to set the reception data input edge "falling" and the transmission data output edge "rising". | | (8) Set the SC0MD1 register Select the communication style SC0MD1(0x03F92) | (8) Set the SC0CMD flag of the SC0MD1 register to "0" to select the synchronous serial. | | bp0 :SC0CMD =0 Select the transfer clock | Set the SC0MST flag of the SC0MD1 register to "1" to select the clock master (internal clock). Set the SC0CKM flag to "0" to select "not divided" for | | SC0MD1(0x03F92)<br>bp2 :SC0MST =1 | the clock source. | | bp3 :SC0CKM =0 Select the transfer clock SC0MD1(0x03F92) bp4 :SC0SBOS =1 | Set the SC0SBOS, SC0SBIS, SC0SBTS flag of the SC0MD1 register to "1" to set the SB00 pin to the serial data output, the SBI0 pin to the serial input, SBT0 pin to the transfer clock input/output. Set the SC0IOM flag "0" to set the serial data input from the SBI0 pin. | | bp5 :SC0SBIS =1<br>bp6 :SC0SBTS =1<br>bp7 :SC0IOM =0 | | | (9) Set the interrupt level<br>SC0TICR(0x03FF0)<br>bp7-6 :SC0LV1-0 =10 | (9) Set the interrupt level by the SC0TLV1 to 0 flag of the serial 0 UART transmission interrupt control register (SC0TICR). | | Setup Procedure | Description | |-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (10) Enable the interrupt SC0TICR(0x03FF0) bp1 :SC0TIE =1 bp0 :SC0TIR =0 | (10) Set the SC0TIE flag of the SC0TICR register to "1" to enable the interrupt. If any interrupt request flag (SC0TIR of the SC0TICR register) is already set, clear SC0TIR before the interrupt is enabled. | | (11) Start the serial transmission<br>Transmission data → TXBUF0(0x03F97)<br>Received data → input SBI0 pin | (11) Set the transmission data to the serial transmission data buffer TXBUF0. The transmission or reception is started by the internal clock generation. When the transmission is finished, the serial 0 UART transmission interrupt SC0TIRQ is generated. [Chapter 3. 3-1-4 Setup] | Note: Procedures (1) to (3), (5), (6), (7) to (8) can be set at the same time. # ■ Reception Setup Example The setup example for clock synchronous serial communication with serial 0 is shown. Table:11.3.12 shows the conditions at Reception. Table:11.3.13 Setup Examples for Synchronous Serial Interface Reception | Setup item | Set to | |-------------------------------------------|--------------------------| | Serial data input pin | Select SBI0 (3 channels) | | Transfer bit count | 8 bit | | Start condition | None | | First transfer bit | MSB | | Input edge | Falling edge | | Output edge | Rising edge | | Clock | Clock Slave | | Clock source | fs/2 | | Clock source dividing | Not divided | | Pin | A (port A) | | SBT0/SBO0 pin style | Nch open-drain | | SBT0 pin pull-up resistor | Added | | SBO0 pin pull-up resistor | Added | | serial 0 communication complete interrupt | Enable | | SBO0 output after last data output | "1"(H) fix | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select the prescaler operation<br>SC0MD3(0x03F94)<br>bp3 :SC0PSCE =1 | (1) Set the SC0PSCE flag of the SC0MD3 register to "1" to select "prescaler operation". | | (2) Select the clock source<br>SC0MD3(0x03F94)<br>bp2-0 :SC0PSC2-0 =100 | (2) Set the SC0PSC2 to 0 flag of the SC0MD3 register to "100" to select the fs/2 as the clock source. | | (3) SBO0A output control after the last data is output SC0MD3(0x03F94) bp7,6 :SC0FDC1-0 =00 | (3) Set the SC0FDC1 to 0 flag of the SC0MD3 register to "00" to select "1" (High) fix of the SBO0 last data output. | | (4) Select the pin<br>SCSEL(0x03F90)<br>bp0 :SC0SL =0 | (4) Set the SC1SL flag of the SCSEL register to "0" to select A (port A) as I/O pin. | | (5) Control the pin style PAODC(0x03F2D) bp2:PAODC2=1 bp0:PAODC0=1 PAPLU(0x03F4A) bp2:PAPLU2=1 bp0:PAPLU0=1 | (5) Set the PAODC7,PAODC5 flag of the PAODC register to "1,1" to select Nch open-drain to SBT0 pin. Set the PAPLU2, PAPLU5 flag of the PAPLU register to "1,1" to enable the pull-up resistor. | | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (6) Control the pin direction PADIR(0x03F3A) bp2:PADIR2 =1 bp1:PADIR1 =0 bp0:PADIR0 =1 | (6) Set the PADIR2, PADIR0 flag of the Port A pin direction control register (PADIR) to "1,1" and the PADIR1 flag to "0" to set PA2, PA0 to the output mode, PA1 to the input mode. | | (7) Set the SC0MD0 register Select the transfer bit count SC0MD0(0x03F91) bp2-0 :SC0LNG2-0 =111 Select the start condition SC0MD0(0x03F91) bp3 :SC0STE =0 Select the first bit to be transferred SC0MD0(0x03F91) bp4 :SC0DIR =0 Select the transfer edge SC0MD0(0x03F91) bp7 :SC0CE1 =1 | <ul> <li>(7) Set the SC0LNG2 to 0 flag of the serial 0 mode register 0 (SC0MD0) to "111" to set the transfer bit count as 8 bits.</li> <li>Set the SC0STE flag of the SC0MD0 register to "0" to disable the start condition.</li> <li>Set the SC0DIR flag of the SC0MD0 register to "0" to set MSB as a transfer first bit.</li> <li>Set the SC0CE1 flag of the SC0MD0 register to "1" to set the reception data input edge "falling" and the transmission data output edge "rising".</li> </ul> | | (8) Set the SC0MD1 register Select the communication style SC0MD1(0x03F92) bp0 :SC0CMD =0 Select the transfer clock SC0MD1(0x03F92) bp2 :SC0MST =0 bp3 :SC0CKM =0 Select the transfer clock SC0MD1(0x03F92) bp4 :SC0SBOS =1 bp5 :SC0SBIS =1 bp6 :SC0SBTS =1 bp7 :SC0IOM =0 | <ul> <li>(8) Set the SC0CMD flag of the SC0MD1 register to "0" to select the synchronous serial.</li> <li>Set the SC0MST flag of the SC0MD1 register to "0" to select the clock slave (external clock).</li> <li>Set the SC0CKM flag to "0" to select "not divided " for the clock source.</li> <li>Set the SC0SBOS, SC0SBIS, SC0SBTS flag of the SC0MD1 register to "1" to set the SB00 pin to the serial data output, the SBI0 pin to the serial input, SBT0 pin to the transfer clock input/output. Set the SC0IOM flag "0" to set the serial data input from the SBI0 pin.</li> </ul> | | (9) Set the interrupt level<br>SC0TICR(0x03FF0)<br>bp7-6 :SC0LV1-0 =10 | (9) Set the interrupt level by the SC0TLV1 to 0 flag of the serial 0 UART transmission interrupt control register (SC0TICR). | | (10) Enable the interrupt SC0TICR(0x03FF0) bp1 :SC0TIE =1 bp0 :SC0TIR =0 | (10) Set the SC0TIE flag of the SC0TICR register to "1" to enable the interrupt. If any interrupt request flag (SC0TIR of the SC0TICR register) is already set, clear SC0TIR before the interrupt is enabled. | | (11) Start the serial Reception dummy data → TXBUF0(0x03F97) Received data → input SBI0 pin | (11) Set the dummy data to the serial transmission data buffer TXBUF0. After the dummy data is set, when clock input is done after more than 3.5 transfer clock, reception is started. When reception is finished, the serial 0 UART transmission interrupt SC0TIRQ is generated. [Chapter 3. 3-1-4 Setup] | Note: Each procedure (1) to (3), (7), (8), (9) to (10) can be set at the same time. At the reception with the start condition input, set the SC0STE flag to "1" to select start condition enable at the step (7) in the setup procedure. At the step (11), execute the start condition input instead of setting dummy data. After start condition input, more than 0.5 transfer clock is required for the clock input. For communication with 2 channels, serial data is input/output from the SBO0 pin. Input/output is switched by the port direction control register PADIR. At reception, set always SC0SBIS of the SC0MD1 register to "1" to select "serial input". The SBI0 pin can be used as a general port. This serial interface contains a force reset function. If the communication should be stopped by force, set SC0SBOS and SC0SBIS of the SC0MD1 register to "0". Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:11.2.1 except TXBUF0) are set. Transfer rate of transfer clock set by the SC0MD3 register should not exceed 5.0 MHz. # ■ Transmission / Reception Setup Example (Standby Mode Reception) The setup example for clock synchronous serial communication with serial 0 is shown. Table:11.3.14 shows the condition at standby mode reception. Table:11.3.14 Setup Examples for Synchronous Serial Interface Transmission / Reception (Standby Mode Reception) | Setup item | Set to | |-------------------------------------------|--------------------------| | Serial data input pin | Select SBI0 (3 channels) | | Transfer bit count | 8 bit | | Start condition | None | | First transfer bit | MSB | | Input edge | Falling edge | | Clock | Clock slave | | Operation mode | Stop mode | | Clock source | fs/2 | | Clock source dividing | Not divided | | Pin | A (port A) | | SBT0/SBO0 pin style | Push-pull | | SBT0 pin pull-up resistor | Not added | | SBO0 pin pull-up resistor | Not added | | serial 0 communication complete interrupt | Enable | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select the prescaler operation<br>SC0MD3(0x03F94)<br>bp3 :SC0PSCE =1 | (1) Set the SC0PSCE flag of the SC0MD3 register to "1" to select "prescaler operation". | | (2) Select the clock source<br>SC0MD3(0x03F94)<br>bp2-0 :SC0PSC2-0 =100 | (2) Set the SC0PSC2 to 0 flag of the SC0MD3 register to "100" to select fs/2 as the clock source. | | (3) Select the pin<br>SCSEL(0x03F90)<br>bp0 :SC0SL =0 | (3) Set the SC0SL flag of the SCSEL register to "0" to select A (port A) as I/O pin | | (4) Control the pin style PAODC(0x03F2D) bp2:PAOD2=0 bp0:PAODC0=0 PAPLU(0x03F4A) bp2:PAPLU2=0 bp0:PAPLU0=0 | (4) Set the PAODC2,PAODC0 flag of the PAODC register to "0,0" to select Push-pull to SBO0/SBT0 pin. Set the PAPLU2,PAPLU0 flag of the PAPLU register to "0,0" to disenable the pull-up resistor. | | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (5) Control the pin direction PADIR(0x03F3A) bp2:PADIR2 =0 bp1:PADIR1 =0 bp0:PADIR0 =1 | (5) Set the PADIR2, PADIR1 flag of the Port A pin direction control register (PADIR) to "0,0" and the PADIR0 flag to "1" to set PA2, PA1 to disable the start condition. | | (6) Select the transfer bit count SC0MD0(0x03F91) bp2-0 :SC0LNG2-0 =111 | (6) Set the SC0LNG2-0 flag of the serial 0 mode register (SC0MD0) to "111" to set the transfer bit count as 8 bits. | | (7) Select the start condition<br>SC0MD0(0x03F91)<br>bp3 :SC0STE =0 | (7) Set the SC0STE flag of the serial 0 mode register (SC0MD0) to "1" to disable the start condition. | | (8) Select the first bit to be transferred SC0MD0(0x03F91) bp4 :SC0DIR =0 | (8) Set the SC0DIR flag of the SC0MD0 register to "0" to set MSB as a transfer first bit. | | (9) Select the transfer edge<br>SC0MD0(0x03F91)<br>bp7 :SC0CE1 =1 | (9) Set the SC0CE1 flag of the SC0MD0 register to "1" to set the reception data input edge as falling. | | (10) Select the communication type<br>SC0MD1(0x03F92)<br>bp0 :SC0CMD =0 | (10) Set the SC0CMD flag of the SC0MD1 register to "0" to select the synchronous serial. | | (11) Select the transfer clock<br>SC0MD1(0x03F92)<br>bp2 :SC0MST =0<br>bp3 :SC0CKM =0 | (11) Set the SC0MST flag of the SC0MD1 register to "0" to select the clock slave (external slave). Set the SC0CKM flag to "0" to select "not divided" for the clock source. | | (12) Control the pin function<br>SC0MD1(0x03F92)<br>bp4 :SC0SBOS =0<br>bp5 :SC0SBIS =1<br>bp6 :SC0SBTS =1<br>bp7 :SC0IOM =0 | (12) Set the SC0SBOS flag of the SC0MD1 register to "0", the SC0SBTS flag of the SC0SBIS register to "1" to set the SBI0 pin to the serial data input as the SBO0 pin general port, the SBT0 pin to the transfer clock input/output. Set the SC0IOM flag "0" to set the serial data input from the SBI0 pin. | | (13) Set the interrupt level<br>SC0TICR(0x03FF0)<br>bp7-6 :SC0LV1-0 =10 | (13) Set the interrupt level by the SC0LV1 to 0 flag of the serial 0 UART transmission interrupt control register (SC0TICR). (Set level 2) | | (14) Enable the interrupt SC0TICR(0x03FF0) bp1 :SC0TIE =1 bp0 :SC0TIR =0 | (14) Set the SC0TIE flag of the SC0TICR register to "1" to enable the interrupt. If any interrupt request flag (SC0TIR of the SC0TICR register) is already set, clear SC0TIR before the interrupt is enabled. | | (15) Set the startup factor of the serial<br>communication<br>Dummy data → TXBUF0(0x03F97) | (15) Set the dummy data to the serial transmission data buffer TXBUF0. | | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (16) Transfer to STOP mode<br>CPUM(0x03F00)<br>bp3:STOP =1 | (16) Set the STOP flag of the CPUM register to "1" to transfer to the stop mode. | | (17) Start the serial communication Transmission clock → input SBT0 pin Received data → input SBI0 pin | (17) Input the transfer clock to the SBT0 pin and transfer data to the SBI0 pin. | | (18) Recover from the standby mode | (18) The serial 0 UART transmission interrupt SC0TIRQ is generated at the same time of the 8 <sup>th</sup> bits data reception, then, CPU is recovered from the stop mode to the normal mode after the oscillation stabilization wait. | Note: Procedures (1), (2), (6) to (9), (10) to (12), (13) to (14) can be set at the same time. Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:11.2.1 except TXBUF0) are set. # 11.3.3 UART Serial Interface Serial 0 can be used for duplex UART communication. Table:11.3.15 shows UART serial interface functions. Table:11.3.15 URAT Serial Interface Functions | Communication style | UART (duplex)j | |----------------------------------|--------------------------------------------------------------------------| | Interrupt | SC0TIRQ (transmission), SC0RIRQ (reception) | | Pins | TXD0 (output / input)<br>RXD0 (input) | | First transfer bit specification | MSB / LSB | | Parity bit selection | 0 | | Parity bit control | 0 parity<br>1 parity<br>odd parity<br>even parity | | Frame selection | 7 bits + 1 STOP<br>7 bits + 2 STOP<br>8 bits + 1 STOP<br>8 bits + 2 STOP | | Continuous operation | 0 | | Maximum transfer rate | 300 kbps<br>(standard 300 bps to 38.4 kbps)<br>(with baud rate timer) | #### Activation Factor for Communication At transmission, when data is set to the transmission data buffer TXBUF0, start condition is generated to start transfer. At reception, when start condition is received, communication is started. At reception, if the data length of "L" for start bit is longer than 0.5 bit, it can be recognized as start condition. #### Transmission Data transfer is automatically started by setting data to the transmission data buffer TXBUF0. When the transmission is completed, the serial 0 transmission interrupt SC0TIRQ is generated. #### ■ Reception Once the start condition is recognized, reception is started after the transfer bit counter that counts transfer bit is cleared. When the reception is completed, the serial 0 reception interrupt SC0RIRQ is generated. #### ■ Duplex communication On duplex communication, the transmission and reception can be operated separately at the same time. The frame mode and parity bit of the used data on transmission / reception should have the same polarity. ### ■ Transfer Bit Count Setup The transfer bit count is automatically set after the frame mode is specified by the SC0FM1 to 0 flag of the SC0MD2 register. If the SC0CMD flag of the SC0MD1 register is set to "1", and UART communication is selected, the setup by the synchronous serial transfer bit count selection flag SC0LNG2 to 0 is no longer valid. ## ■ Data Input Pin Setup 2 channels type, data output pin (TXD0 pin), data input pin (RXD0 pin, or 1 channel type, data I/O pin (TXD0 pin) can be selected as a communication mode. The RXD0 pin can be used only for serial data input. The TXD0 pin can be used for serial data input or output. Whether the serial data is input from RXD0 or TXD0, it can be selected by the SC0IOM flag of the SC0MD1 register. When "data input from TXD0 pin" is selected to set the 1 channel communication, transmission / reception can be switched by the TXD0 pin direction control. For TXD0A pin, it can be done by the PADIR2 flag of the PADIR register. For TXD0B, by the P7DIR5 flag of the P7DIR register. At the same time, the RXD0 pin can be used as a general port. ### ■ Reception Buffer Empty Flag When SCORIRQ is generated, data is stored automatically to RXBUF0 from the internal shift register. When data is stored to RXBUF0 from the shift register, the reception buffer empty flag SCOREMP of the SCOSTR register is set to "1". That indicates that the received data is going to be read out. SCOREMP is cleared to "0" by reading out the data of RXBUF0. ### ■ Reception BUSY Flag When the start condition is recognized, the SC0RBSY flag of the SC0STR register is set to "1". When the reception complete interrupt SC0TIRQ is generated, the flag is cleared to "0". If the SC0SBIS flag is set to "0" during reception, the SC0RBSY flag is reset to "0". #### ■ Transmission BUSY Flag When data is set to TXBUF0, the SC0TBSY flag of the SC0STR register is set to "1". When the transmission complete interrupt SC0TIRQ is generated, the flag is cleared to "0". During continuous communication, the SC0TBSY flag is always set. If the transmission buffer empty flag SC0TEMP is set to "0" as the transmission complete interrupt SC0TIRQ is generated, the SC0TBSY is cleared to "0". If the SC0SBOS flag is set to "0", the SC0TBSY flag is reset to "0". # ■ Frame Mode and Parity Check Setup Figure 11-3-17 shows the data format at UART communication. Figure:11.3.17 UART Serial Interface Transmission / Reception Data Format The transmission / reception data consists of start bit, character bit, parity bit and stop bit. Table:11.3.16 shows its types to be set. Table:11.3.16 UART Serial Interface Transmission / Reception Data | Start bit | 1 bit | |---------------|-----------------------------------------| | Character bit | 7,8 bit | | Parity bit | fixed to 0, fixed to 1, odd, even, none | | Stop bit | 1,2 bits | The SC0FM1 to 0 flag of the SC0MD2 register sets the frame mode. Table:11.3.17 shows the UART serial interface frame mode settings. If the SC0CMD flag of the SC0MD1 register is set to "1", and UART communication is selected, the transfer bit count on the SC0LNG2 to 0 flag of the SC0MD0 register is no longer valid. Table:11.3.17 UART Serial Interface Frame Mode | SC0MD2 r | egister | Frame mode | |----------|---------|----------------------------------------| | SC0FM1 | SC0FM0 | | | 0 | 0 | Character bit 7 bits + Stop bit 1 bit | | 0 | 1 | Character bit 7 bits + Stop bit 2 bits | | 1 | 0 | Character bit 8 bits + Stop bit 1 bit | | 1 | 1 | Character bit 8 bits + Stop bit 2 bits | Parity bit is to detect wrong bits with transmission / reception data. Table:11.3.18 shows types of parity bit. The SCONPE, SCOPM1 to 0 flag of the SCOMD2 register set parity bit. Table:11.3.18 Parity Bit of UART Serial Interface | SC0MD2 | | | Parity bit | Setup | |--------|--------|--------|-------------|------------------------------------------------------------------------------| | SC0NPE | SC0PM1 | SC0PM0 | | | | 0 | 0 | 0 | Fixed to 0 | Set parity bit to "0" | | 0 | 0 | 1 | Fixed to 1 | Set parity bit to "1" | | 0 | 1 | 0 | Odd parity | Control that the total of "1" of parity bit and character bit should be odd | | 0 | 1 | 1 | Even parity | Control that the total of "1" of parity bit and character bit should be even | | 1 | - | - | None | Do not add parity bit | # ■ Break Status Transmission Control Setup The SC0BRKE flag of the SC0MD2 register generates the brake status. If SC0BRKE is set to "1" to select the brake transmission, all bits from start bits to stop bits transfer "0". #### ■ Reception Error At reception, there are 3 types of error; overrun error, parity error and framing error. Reception error can be determined by the SCOORE, SCOPEK, SCOFEF flag of the SCOSTR register. Even one of those errors is detected, the SCOERE flag of the SCOSTR register is set to "1". Among reception error flags, the SCOPEK flag and the SCOFEF flag are renewed when the reception complete interrupt SCORIRQ is generated. The SCOORE flag is cleared at the same time of next communication complete interrupt SCORIRQ generation after the data of the RXBUFO is read out. The decision of the received error flag should be operated before the next communication is finished. Those error flag has no effect on communication operation. Table:11.3.19 shows the list of reception error source. Table:11.3.19 Reception Error Source of UART Serial Interface | Flag | Error | | | |--------|---------------|-----------------------------------------------------------|----------------------------------------------------------| | SC0ORE | Overrun error | Next data is received before reading the reception buffer | | | SC0PEK | Parity error | at fixed to 0 | when parity bit is "1" | | | | at fixed to 1 | When parity bit is "0" | | | | Odd parity | The total of "1" of parity bit and character bit is even | | | | Even parity | The total of "1" of parity bit and character bit is odd | | SC0FEF | Framing error | Stop bit is not detected | | #### ■ Judgement of Break Status Reception Reception at break status can be judge. If all received data from start bit and stop bit is "0", the SC0BRKF flag of the SC0MD2 register is set and determines the break status. The SC0BRKF flag is set when the reception complete interrupt SC0RIRQ is generated. #### Continuous Communication This serial interface has continuous communication function. When data is set to the transmission data buffer TXBUF0 during communication, the transmission buffer empty flag SC0TEMP is automatically set to communicate continuously. This does not generate any blank in communication. Set data to TXBUF between previous data setup and generation of the communication complete interrupt SC0TIRQ. #### Clock Setup Transfer clock is not necessary for UART communication itself, but necessary for setup of data transmission / reception timing in the serial interface. Select the timer to be used as a baud rate timer by the SC0MD3 register. ## ■ Reception Bit Count and First Transfer Bit At reception, when the transfer bit count is 7 bits, the data storing method to the received data buffer RXBUF0 is different depending on the first transfer bit selection. At MSB first, data is stored to the upper bits of RXBUF0. When the transfer bit count is 7 bits, as shown on Figure:11.3.18, data "G" to "A" are stored to bp7 to bp1 of RXBUF0 in this order. At LSB first, data are stored to the lower bits of RXBUF0. When the transfer bit count is 7 bits, as shown on Figure:11.3.19, data "A" to "G" are stored to bp0 to bp6 of RXBUF0 in this order. Figure:11.3.18 Reception Bit Count and First Transfer Bit (starting with MSB) Figure:11.3.19 Transfer Bit Count and First Transfer Bit (starting with LSB) The following items are the same as clock synchronous serial. ■ First Transfer Bit Setup Refer to:XI-15 ■ Transmission Data Buffer Refer to:XI-15 Received Data Buffer Refer to:XI15 ■ Transfer Bit Count and First Transfer Bit Refer to:XI-17 ■ Transmission Buffer Empty Flag Refer to:XI-20 ■ Emergency Reset Refer to:XI-21 # ■ Transmission Timing Figure:11.3.20 Transmission Timing (parity bit is enabled) Figure:11.3.21 Transmission Timing (parity bit is disabled) # Reception Timing Figure:11.3.22 Reception Timing (parity bit is enabled) Figure:11.3.23 Reception Timing (parity bit is disabled) #### ■ Transfer Speed Setup Baud rate timer (timer 1, timer 2) can set any transfer rate. Table:11.3.20 shows the setup example of the transfer speed. Table:11.3.20 UART Serial Interface Transfer Speed | Setup | Register | Page | |-------------------------------------------|----------|-------| | Serial 0 clock source (timer 1 , timer 2) | SC0MD3 | XI-10 | | Clock source dividing | SC0MD1 | XI-10 | | Timer 1 clock source | TM1MD | V-15 | | Timer 1 compare register | TM1OC | V-12 | | Timer 2 clock source | TM2MD | V-16 | | Timer 2 compare register | TM2OC | V-12 | Timer compare register is set as follows; baud rate = 1 / (overflow cycle $\times$ 2 $\times$ internal clock dividing) overflow cycle = (set value of compare register + 1) $\times$ timer clock cycle therefore, set value of compare register = timer clock frequency / (baud rate $\times$ 2 $\times$ internal clock dividing) - 1 For example, if baud rate should be 300 bps at timer clock source fs/4 (fosc = 8 MHz, fs = fosc/2) when the internal clock dividing is set to 8, set value should be as follows: Set value of compare register = (8 $\times$ 10<sup>6</sup> / 2 / 4) / (300 $\times$ 2 $\times$ 8) - 1 = 207 = 0xCF Timer clock source and the set value of timer compare register at the standard rate are shown in the following page. Transfer rate should not exceed 300 kbps. Table:11.3.21 Setup Value of Serial Interface Transfer Speed 1 : When Setting UART Inter Clock to "Divided by 8" (decimal) | | | Transfer s | peed (bit/s) | | | | | | | | | |---------------|--------------|--------------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------|-----------|----------------------| | foos | Clock source | 300 | | 960 | | 1200 | | 2400 | | 4800 | | | fosc<br>(MHz) | (Timer) | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate<br>d value | | 2.00 | fosc | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fosc/4 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fosc/16 | 25 | 300 | - | - | - | - | - | - | - | - | | | fosc/32 | 12 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fs/4 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | 4.00 | fosc | - | - | - | - | 207 | 1202 | 103 | 2404 | 51 | 4808 | | | fosc/4 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fosc/16 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/32 | 25 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | 12 | 300 | - | - | - | - | - | - | - | - | | | fs/2 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fs/4 | 104 | 297 | - | - | 25 | 1202 | 12 | 2404 | - | - | | 4.19 | fosc | - | - | - | - | 217 | 1201 | 108 | 2403 | 54 | 4761 | | | fosc/4 | 217 | 300 | 67 | 963 | - | - | - | - | - | - | | | fosc/16 | - | - | 16 | 963 | - | - | 6 | 2338 | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 217 | 300 | 67 | 963 | - | - | - | - | - | - | | | fs/4 | 108 | 300 | 33 | 963 | - | - | 13 | 2338 | - | - | | 8.00 | fosc | - | - | - | - | - | - | 207 | 2404 | 103 | 4808 | | | fosc/4 | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fosc/16 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fosc/32 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/64 | 25 | 300 | - | - | - | - | - | - | - | - | | | fs/2 | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fs/4 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | 8.38 | fosc | - | - | - | - | - | - | 217 | 2403 | 108 | 4805 | | | fosc/4 | - | - | 135 | 963 | 108 | 1201 | - | - | - | - | | | fosc/16 | 108 | 300 | 33 | 963 | - | - | 13 | 2338 | - | _ | | | fosc/32 | - | - | 16 | 963 | - | - | 6 | 2338 | - | - | | | fosc/64 | - | - | - | | _ | _ | - | - | _ | _ | | | fs/2 | 1- | - | 135 | 963 | 108 | 1201 | - | - | - | - | | | fs/4 | 217 | 300 | 67 | 963 | - | - | - | - | _ | - | | 10.00 | fosc | 1 | - | - | - | _ | _ | - | - | 129 | 4808 | | 10.00 | fosc/4 | + | - | 162 | 959 | 129 | 1202 | 64 | 2404 | - | - | | | fosc/16 | 129 | 300 | 102 | - | - | - | - | | _ | <del> </del> | | | fosc/32 | 64 | 300 | | [ | | | | | | <u> </u> | | | fosc/64 | U-4 | - | | [ | | | | [ | | <u> </u> | | | fs/2 | 1 | [ | 162 | 959 | 129 | 1202 | 64 | 2404 | | <u> </u> | | | | <del>-</del> | <u> </u> | 162 | 303 | | | 04 | 2404 | - | Γ | | | fs/4 | - | - | I- | - | 64 | 1202 | - | - | 1- | I- | Table:11.3.22 Setup Value of Serial Interface Transfer Speed 2 : When Setting UART Inter Clock to "Divided by 8" (decimal) | | | Transfer s | peed (bit/s) | ı | | | | | | | | |---------------|-------------------------|------------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------| | , | Ola ale access | 300 | | 960 | | 1200 | | 2400 | | 4800 | | | fosc<br>(MHz) | Clock source<br>(Timer) | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | | 2.00 | fosc | 12 | 9615 | - | - | - | - | 3 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.00 | fosc | 25 | 9615 | 12 | 19231 | - | - | 7 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.19 | fosc | 26 | 9699 | - | - | - | - | - | - | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 8.00 | fosc | 51 | 9615 | 25 | 19231 | - | - | 15 | 31250 | 12 | 38462 | | | fosc/4 | 12 | 9615 | - | - | - | - | 3 | 31250 | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 12 | 9615 | - | - | - | - | 3 | 31250 | - | - | | | fs/4 | - | - | - | - | - | - | 1 | 31250 | - | - | | 8.38 | fosc | 54 | 9523 | 26 | 19398 | - | - | - | - | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 10.00 | fosc | 64 | 9615 | - | - | - | - | - | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | 31250 | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | | - | - | - | - | - | - | - | 31250 | - | - | | | | 1_ | _ | - | - | - | - | - | - | _ | - | | | fs/2<br>fs/4 | - | - | - | - | - | - | - | 31250 | -<br>- | | Table:11.3.23 Setup Value of Serial Interface Transfer Speed 1 : When Setting UART Inter Clock to "Divided by 16" (decimal) | | | Transfer s | peed (bit/s) | | | | | | | | | |---------------|-------------------------|------------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------| | , | 01 1 | 300 | | 960 | | 1200 | | 2400 | | 4800 | | | fosc<br>(MHz) | Clock source<br>(Timer) | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | | 2.00 | fosc | - | - | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fosc/4 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/16 | 12 | 300 | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | İ | fs/4 | 25 | 300 | - | - | - | - | - | - | - | - | | 4.00 | fosc | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fosc/4 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fosc/16 | 25 | 300 | - | - | - | - | - | - | - | - | | İ | fosc/32 | 12 | 300 | - | - | - | - | - | - | - | - | | İ | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fs/4 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | 4.19 | fosc | - | - | 135 | 963 | 108 | 1201 | 54 | 2381 | - | - | | | fosc/4 | 108 | 300 | 33 | 963 | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 108 | 300 | 33 | 963 | - | - | - | - | - | - | | | fs/4 | 54 | 298 | 16 | 963 | - | - | - | - | - | - | | 8.00 | fosc | - | - | - | - | 207 | 1202 | 103 | 2404 | 51 | 4808 | | | fosc/4 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fosc/16 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/32 | 25 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | 12 | 300 | - | - | - | - | - | - | - | - | | | fs/2 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fs/4 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | 8.38 | fosc | - | - | - | - | 217 | 1201 | 108 | 2403 | 54 | 4761 | | | fosc/4 | 217 | 300 | 67 | 963 | 54 | 1190 | - | - | - | - | | | fosc/16 | 54 | 298 | 16 | 963 | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 217 | 300 | 67 | 963 | 54 | 1190 | - | - | - | - | | | fs/4 | 108 | 300 | 33 | 963 | - | - | - | - | - | - | | 10.00 | fosc | - | - | - | - | - | - | 129 | 2404 | 64 | 4808 | | | fosc/4 | - | - | 80 | 965 | 64 | 1202 | - | - | - | - | | | fosc/16 | 64 | 300 | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | 80 | 965 | 64 | 1202 | - | - | - | - | | | fs/4 | 129 | 300 | - | - | - | - | - | - | - | - | Table:11.3.24 Setup Value of Serial Interface Transfer Speed 2 : When Setting UART Inter Clock to "Divided by 16" (decimal) | | | Transfer s | peed (bit/s) | l | | | | | | | | |---------------|-------------------------|------------|-------------------|-----------|-------------------|--------------------------------------------------|-------------------|-----------|-------------------|-----------|-------------------| | , | | 300 | | 960 1 | | 1200 | | 2400 | | 4800 | | | fosc<br>(MHz) | Clock source<br>(Timer) | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | | 2.00 | fosc | - | - | - | - | - | - | 1 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.00 | fosc | 12 | 9615 | - | - | - | - | 3 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.19 | fosc | - | - | - | - | - | - | - | - | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 8.00 | fosc | 25 | 9615 | 12 | 19231 | - | - | 7 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 8.38 | fosc | - | - | - | - | - | _ | - | - | - | - | | | fosc/4 | - | - | - | - | _ | - | - | - | - | - | | | fosc/16 | - | - | - | - | _ | _ | - | - | _ | - | | | fosc/32 | - | - | - | - | - | _ | - | - | _ | - | | | fosc/64 | - | _ | - | - | - | _ | _ | _ | _ | _ | | | fs/2 | - | _ | l_ | _ | _ | _ | _ | _ | _ | _ | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 10.00 | fosc | - | - | - | - | - | _ | 9 | 31250 | _ | - | | . 5.00 | fosc/4 | - | - | - | - | - | _ | - | - | _ | - | | | fosc/16 | - | - | - | - | - | _ | - | - | - | - | | | fosc/32 | 1_ | <u> </u> | _ | <u> </u> | <del> </del> | | L | - | | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | _ | - | - | - | - | | | fs/4 | 1 | <u> </u> | ļ- | <u> </u> | | | <u> </u> | ļ- | | ļ- | | | 15/4 | | - | - | - | - | - | - | - | - | - | #### ■ Pin Setup (with 1,2 channels, at transmission) Table:11.3.25 shows the pins setup for UART serial interface transmission. The pins setup is common to the TXD0 pin, RXD0 pin, regardless of whether the pins are independent / connected. Table:11.3.25 UART Serial Interface Pin Setup (with 1,2 channels, at transmission) | Setup item | Data output pin | Data input pin | |-----------------------------|-----------------------------|-----------------| | | TXD0 pin | RXD0 pin | | Port pin | PA0/P75 | PA1/P76 | | Port pin setup | Select pin (A, B) | | | | SCSEL (SC0SL) | | | Serial data input selection | RXD0 | | | | SC0MD1(SC0IOM) | | | Function | Serial data output | "1" output | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | | Style | Push-pull/ N-ch open-drain | - | | | PAODC(PAODC0)/P7ODC(P7ODC5) | | | I/O | Output mode | - | | | PADIR(PADIR0)/P7DIR(P7DIR5) | | | Pull-up setup | Added / not added | - | | | PAPLU(PAPLU0)/P7PLU(P7PLU5) | | ### ■ Pin Setup (with 2 channels, at reception) Table:11.3.26 shows the pins setup for UART serial interface reception with 2 channels (TXD0 pin, RXD0pin). Table:11.3.26 UART Serial Interface Pin Setup (with 2 channels, at reception) | Setup item | Data output pin | Data input pin | | | | |-----------------------------|-------------------|---------------------------------|--|--|--| | | TXD0 pin | RXD0 pin | | | | | Port pin | PA0/P75 | PA1/P76 | | | | | Port pin setup | Select pin (A, B) | | | | | | | SCSEL (SCOSL) | | | | | | Serial data input selection | RXD0 | | | | | | | SC0MD1(SC0IOM) | | | | | | Function | Port | Serial data input | | | | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | | | | | Style | - | - | | | | | I/O | - | Input mode | | | | | | - | PADIR(PADIR1)/<br>P7DIR(P7DIR6) | | | | | Pull-up setup | - | - | | | | #### ■ Pin Setup (with 1 channel, at reception) Table:11.3.27 shows the pin setup for UART serial interface reception with 1 channel (TXD0 pin). The RXD0 pin can be used as a port as it is not used. Table:11.3.27 UART Serial Interface Pin Setup (with 1 channel, at reception) | Setup item | Data output pin | Data input pin | | | |-----------------------------|-----------------------------|-------------------|--|--| | | TXD0 pin | RXD0 pin | | | | Port pin | PA0/P75 | PA1/P76 | | | | Port pin setup | Select pin (A, B) | | | | | | SCSEL (SC0SL) | | | | | Serial data input selection | TXD0 | | | | | | SC0MD1(SC0IOM) | | | | | Function | Port | Serial data input | | | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | | | | Style | - | - | | | | I/O | Input mode | - | | | | | PADIR(PADIR0)/P7DIR(P7DIR5) | - | | | | Pull-up setup | - | - | | | #### ■ Pin Setup (with 2 channels, at transmission / reception) $Table: 11.3.28 \ shows \ the \ pin \ setup \ for \ UART \ serial \ interface \ transmission \ / \ reception \ with \ 2 \ channels \ (TXD0 \ pin, RXD0 \ pin).$ Table:11.3.28 UART Serial Interface Pin Setup (with 2 channels, at transmission / reception) | Setup item | Data output pin | Data input pin | | | | |-----------------------------|-----------------------------|---------------------------------|--|--|--| | | TXD0 pin | RXD0 pin | | | | | Port pin | PA0/P75 | PA1/P76 | | | | | Port pin setup | Select pin (A, B) | | | | | | | SCSEL (SC0SL) | | | | | | Serial data input selection | RXD0 | | | | | | | SC0MD1(SC0IOM) | | | | | | Function | Serial data output | Serial data input | | | | | | SC0MD1(SC0SBOS) | SC0MD1(SC0SBIS) | | | | | Style | Push-pull/ N-ch open-drain | - | | | | | | PAODC(PAODC0)/P7ODC(P7ODC5) | | | | | | I/O | Output mode | Input mode | | | | | | PADIR(PADIR0)/P7DIR(P7DIR5) | PADIR(PADIR1)/<br>P7DIR(P7DIR6) | | | | | Pull-up setup | Added / not added | - | | | | | | PAPLU(PAPLU0)/P7PLU(P7PLU5) | | | | | ## 11.3.4 Setup Example ### ■ Transmission / Reception Setup The setup example for UART transmission / reception with serial 0 is shown. Table: 11.3.29 shows the condition at transmission / reception. Table:11.3.29 UART Interface Transmission Reception Setup | Setup item | SEt to | |------------------------------------------|-------------------------------| | TXD0/RXD0 pin | Independent (with 2 channels) | | Frame mode specification | 8 bits + 2 stop bits | | First transfer bit | MSB | | Clock source | Timer 1 | | Clock source dividing | Divided by 8 | | Pin | A (port A) | | TXD0/RXD0 pin type | N-ch open-drain | | Pull-up resistor of TXD0 pin | Added | | Parity bit add/check | "0" added/check | | Serial 0 transmission complete interrupt | Enable | | Serial 0 reception complete interrupt | Enable | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the baud rate timer | (1) Set the baud rate timer by the TM1MD register, the TM1OC register. Set the TM1EN flag to "1" to start timer 1. [Chapter 5 5.8 Serial Transfer Clock Output Operation] | | (2) Select the clock source<br>SC0MD3(0x03F94)<br>bp2-0 :SC0PSC2-0 =110 | (2) Set the bp2 to 0 flag of the SC0MD3 register to "110" to select Timer 1 output as a clock source. | | (3) Select the pin<br>SCSEL(0x03F90)<br>bp0 :SC0SL =0 | (3) Set the SC0SL flag of the SCSEL register to "0" to select A (port A) as I/O pin. | | (4) Control the pin style PAODC(0x03F2D) bp0:PAODC0=1 PAPLU(0x03F4A) bp0:PAPLU0=1 | (4) Set the PAODC0 flag of the PAODC register to "1" to select Nch open-drain. Set the PAPLU0 flag of the PAPLU register to "1" to enable the pull-up resistor. | | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (5) Control the pin direction PADIR(0x03F3A) bp0 :PADIR0 =1 bp1 :PADIR1 =0 | (5) Set the PADIR0 flag of the Port A pin direction control register (PADIR) to "1" and the PADIR1 flag to "0" to set PA0 to the output mode, PA1 to the input mode. | | (6) Set the SC0MD0 register Select the start condition SC0MD0(0x03F91) bp3 :SC0STE =1 | (6) Set the SC0STE flag of the SC0MD0 register to "1" to enable start condition. | | Select the first bit to be transferred SC0MD0(0x03F91) bp4 :SC0DIR =0 | Set the SC0DIR flag of the SC0MD0 register to "0" to select MSB as first transfer bit. | | (7) Set the SC0MD2 register Control the output data SC0MD2(0x03F93) bp0 :SC0BRKE =0 | (7) Set the SC0BRKE flag of the SC0MD2 register to "0" to select the serial data transmission. | | Select the added parity bit<br>SC0MD2(0x03F93)<br>bp3:SC0NPE =0<br>bp5-4:SC0PM1-0=00 | Set the SC0PM1 to 0 flag of the SC0MD2 register to "00" to select 0 parity, and set the SC0NPE flag to "0" to enable add parity bit. | | Specify the flame mode<br>SC0MD2(0x03F93)<br>bp7-6 :SC0FM1-0 =11 | Set the SC0FM1 to 0 flag of the SC0MD2 register to "11" to select 8 bits + 2 stop bits for the flame mode. | | (8) Set the SC0MD1 register Select the communication type SC0MD1(0x03F92) bp0 :SC0CMD =1 | (8) Set the SC0CMD flag of the SC0MD1 register to "1" to select duplex UART. | | Select the clock frequency<br>SC0MD1(0x03F92)<br>bp3:SC0CKM =1<br>bp2:SC0MST =1<br>bp1:SC0DIV =0 | Set the SC0CKM flag of the SC0MD1 register to "1" to select "divided" at source clock. Set the SC0DIV flag to "0" to select divided by 8 as the source clock. The SC0MST flag should always be set to "1" to select clock master. | | Control the pin function<br>SC0MD1(0x03F92)<br>bp4 :SC0SBOS =1<br>bp5 :SC0SBIS =1<br>bp7 :SC0IOM =0 | Set the SC0SBOS, SC0SBIS flag of the SC0MD1 register to "1" to set the RXD0 pin to serial data output and the RXD0 pin to serial data input. | | (9) Enable the interrupt SC0RICR(0x03FEF) bp1 :SC0RIE =1 SC0TICR(0x03FF0) bp1 :SC0TIE =1 | (9) Set the SCORIE flag of the SCORICR register to "1", and SCOTIE flag of the SCOTICR register to "1" to enable the interrupt request. If the interrupt request is already set, clear it. | | Setup Procedure | Description | |---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <ul> <li>(10) Start the serial transmission The transmission → TXBUF0(0x03F97) The reception data → input to RXD0 </li> </ul> | (10) When the transmission data is set to the serial transmission data buffer (TXBUF0), the transmission is started. When the transmission is finished, the serial 0 transmission interrupt (SC0TIRQ) is generated. Also, after the received data is stored to the RXBUF0, the serial 0 reception interrupt (SC0RIRQ) is generated. | Note: Procedures (6), (7), (8) can be set at the same time. When the TXD0 / RXD0 pin are connected for communication with 1 channel, serial data is input/output from the TXD0 pin. Input/output can be switched by the port direction control register PADIR. At reception, set SC0SBIOS of the SC0MD1 register to "1" to select serial data input. The RXD0 pin can be used as a general port. This serial interface contains emergency reset function. If communication should be stopped by force, set SC0SBOS and SC0SBIS of the SC0MD1 register to "0". Each flag should be set as the setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:11.2.1 TXBUF0, RXBUF0) are set. Timer 1 and timer 2 can be used as a baud rate timer. Refer to Chapter 5 5.8 Serial Transfer Clock Output Operation. ## 12.1 Overview This LSI contains a serial interface 1 that can be used for both communication types of clock synchronous and UART (duplex). Also the used pins can be switched to A (port 1: P15/TM0OB/SBO1A/TXD1A/SEG1, P16/TM2IO/SBI1A/RXD1A/SEG9, P17/TM2OB/SBT1A/SEG8) or to B (Port A:PA5/AN5/SBO1B/TXD1B, PA6/AN6/SBT1B, PA4/AN4/SBI1B/RXD1B/VPP). On this text, if there are not much difference between port A and port B on the operation, port A and B are omitted. Operation with the used pin B is available for 48 pin package product only. For 44 pin package, select A as the used pin. #### 12.1.1 Functions Table:12.1.1 shows functions of serial interface 1. Table:12.1.1 Serial Interface 1 functions | Communication style | Clock synchronous | UART (duplex) | |------------------------------------------------------|-------------------|----------------------------------------------------------------------| | Interrupt | SC1TIRQ | SC1TIRQ(on transmission completion) SC1RIRQ(on reception completion) | | Used pins | SBO1,SBI1,SBT1 | TXD1,RXD1 | | 3 channels type | 0 | - | | 2 channels type | O(SBO1,SBT1) | 0 | | 1 channel type | - | TXD1 | | Specification of transfer bit count/ Frame selection | 1 to 8 bits | 7 bit +1STOP 7 bit +2STOP 8 bit +1STOP 8 bit +2STOP | | Selection of parity bit | - | 0 | | Parity bit control | - | 0 parity<br>1 parity<br>odd parity<br>even parity | | Selection of start condition | 0 | Only "enable start condition" is available | | Specification of the first transfer bit | 0 | 0 | | Specification of input edge/ output edge | 0 | - | | SBO1 output control after final data is transferred | H/L/final data hold | - | |--------------------------------------------------------------|-----------------------------------|----------------| | Function in STANDBY mode | Only slave reception is available | - | | Internal clock dividing value | Not divided | Divided by 8 | | | Divided by 8<br>Divided by 16 | Divided by 16 | | Clock source | fosc/2 | fosc/2 | | | fosc/4 | fosc/4 | | | fosc/16 | fosc/16 | | | fosc/64 | fosc/64 | | | fs/2 | fs/2 | | | fs/4 | fs/4 | | | External clock | Timer 1 output | | | Timer 1 output | Timer 2 output | | | Timer 2 output | | | Maximum transfer rate | 5.0 MHz | 300 kbps | | fosc:Machine clock (High speed oscillatio<br>fs:System clock | n) | | ## 12.1.2 Block Diagram #### ■ Serial interface 1 Block Diagram Figure:12.1.1 Serial interface 1 Block Diagram # 12.2 Control Registers ## 12.2.1 Registers Table:12.2.1 shows registers to control serial interface 1. Table:12.2.1 Serial interface 1 Control Registers | Register | Address | R/W | Function | Page | |----------|---------|-----|-------------------------------------------------------|---------| | SC1MD0 | 0x03F99 | R/W | Serial interface 1 mode register 0 | XII-7 | | SC1MD1 | 0x03F9A | R/W | Serial interface 1 mode register 1 | XII-8 | | SC1MD2 | 0x03F9B | R/W | Serial interface 1 mode register 2 | XII-9 | | SC1MD3 | 0x03F9C | R/W | Serial interface 1 mode register 3 | XII-10 | | SC1STR | 0x03F9D | R | Serial interface 1 status register | XII-11 | | RXBUF1 | 0x03F9E | R | Serial interface 1 received data buffer | XII-6 | | TXBUF1 | 0x03F9F | R/W | Serial interface 1 transmission data buffer | XII-6 | | SCSEL | 0x03F90 | R/W | Serial interface I/O pins switching control register | XI- 12 | | P1ODC | 0x03F1B | R/W | Port 1 Nch open drain control register | IV- 11 | | P1DIR | 0x03F31 | R/W | Port 1 direction control register | IV-8 | | P1PLUD | 0x03F41 | R/W | Port 1 pull-up/pull-down control register | IV- 9 | | SC1RICR | 0x03FF1 | R/W | Serial 1 UART reception interrupt control register | III- 34 | | SC1TICR | 0x03FF2 | R/W | Serial 1 UART transmission interrupt control register | III- 35 | R/W:Readable/ Writable R:Readable only ## 12.2.2 Data Buffer Registers Serial interface 1 has one each of 8-bit data buffer register for transmission, and for reception. ■ Serial interface 1 Reception Data Buffer (RXBUF1:0x03F9E) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | RXBUF17 | RXBUF16 | RXBUF15 | RXBUF14 | RXBUF13 | RXBUF12 | RXBUF11 | RXBUF10 | | Reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ■ Serial interface 1 Transmission Data Buffer (TXBUF1:0x03F9F) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TXBUF17 | TXBUF16 | TXBUF15 | TXBUF14 | TXBUF13 | TXBUF12 | TXBUF11 | TXBUF10 | | Reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ## 12.2.3 Mode Registers ## ■ Serial interface 1 Mode Register 0 (SC1MD0:0x03F99) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---|---|--------|--------|---------|---------|---------| | Flag | SC1CE1 | - | - | SC1DIR | SC1STE | SC1LNG2 | SC1LNG1 | SC1LNG0 | | Reset | 0 | - | - | 0 | 0 | 1 | 1 | 1 | | Access | R/W | - | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | |-----|-------------------------------|-----------------------------------------------------------------------------------------------| | 7 | SC1CE1 | Transmission data output edge 0:falling 1:rising Reception data input edge 0:rising 1:falling | | 6-5 | - | - | | 4 | SC1DIR | First bit to be transferred 0:MSB first 1:LSB first | | 3 | SC1STE | Start condition selection 0:Disabled 1:Enabled | | 2-0 | SC1LNG2<br>SC1LNG1<br>SC1LNG0 | Transfer bit 000:1bit 001:2bit 010:3bit 011:4bit 100:5bit 101:6bit 111:8bit | ## ■ Serial interface 1 Mode Register 1(SC1MD1:0x03F9A) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---------|---------|-------------|--------|--------|--------|--------| | Flag | SC1IOM | SC1SBTS | SC1SBIS | SC1SBO<br>S | SC1CKM | SC1MST | SC1DIV | SC1CMD | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | R/W | R/W | R/W | - | R/W | R/W | R/W | | bp | Flag | Description | |----|---------|-----------------------------------------------------------------------------------------| | 7 | SC1IOM | Serial data input selection 0:Data input from SBI1 (RXD1) 1:Data input from SBO1 (TXD1) | | 6 | SC1SBTS | SBT1 pin function selection 0:Port 1:Transfer clock I/O | | 5 | SC1SBIS | Serial input control selection 0:Input "1" 1:Input serial | | 4 | SC1SBOS | SBO1(TXD1) pin function 0:Port 1:Output serial data | | 3 | SC1CKM | Transfer clock dividing selection 0:Not divided 1:Divided by 8 | | 2 | SC1MST | Clock master/ slave selection 0:Clock slave 1:Clock master | | 1 | SC1DIV | Transfer clock dividing selection 0:Devided by 8 1:Devided by 16 | | 0 | SC1CMD | Synchronous serial/ duplex UART selection 0:Synchronous serial 1:Duplex UART | ## ■ Serial interface 1 Mode Register 2 (SC1MD2:0x03F9B) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|---|---------|---------| | Flag | SC1FM1 | SC1FM0 | SC1PM1 | SC1PM0 | SC1NPE | - | SC1BRKF | SC1BRKE | | Reset | 0 | 0 | 0 | 0 | 0 | - | 0 | 0 | | Access | R/W | R/W | R/W | R/W | R/W | - | R | R/W | | bp | Flag | | Description | | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--| | 7-6 | SC1FM1<br>SC1FM0 | Frame mode specification 00:7 data bit + 1 stop bit 01:7 data bit + 2 stop bit 10:8 data bit + 1 stop bit 11:8 data bit + 2 stop bit | | | | 5-4 | SC1PM1<br>SC1PM0 | Added bit specification Transmission 00:Add "0" 01:Add "1" 10:Add odd parity 11:Add even parity | Reception Check for 0 Check for 1 Check for odd parity Check for even parity | | | 3 | SC1NPE | Parity enable 0:Enable parity bit 1:Disable parity bit | | | | 2 | - | - | | | | 1 | SC1BRKF | Break status receive monitor<br>0:Data reception<br>1:Break reception | | | | 0 | SC1BRKE | Break status transmit control 0:Data transmission 1:Break transmission | | | ## ■ Serial interface 1 Mode Register 3 (SC1MD3:0x03F9C) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---|---|-------------|---------|---------|---------| | Flag | SC1FDC1 | SC1FDC0 | - | - | SC1PSC<br>E | SC1PSC2 | SC1PSC1 | SC1PSC0 | | Reset | 0 | 0 | - | - | 0 | 0 | 0 | 0 | | Access | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | bp | Flag | Description | |-----|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC1FDC1<br>SC1FDC0 | Output selection after SBO1 final data transmission 00:Fix to "1" (High) output 01:Hold final data 10:Fix to "0" (Low) output 11:Reserved | | 5-4 | - | - | | 3 | SC1PSCE | Prescaler count control 0:Disable the count 1:Enable the count | | 2-0 | SC1PSC2<br>SC1PSC1<br>SC1PSC0 | Selection clock 000:fosc/2 001:fosc/4 010:fosc/16 011:fosc/64 100:fs/2 101:fs/4 110:Timer 1 output 111:Timer 2 output | ## ■ Serial interface 1 Status Register (SC1STR:0x03F9D) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------------|---------|---------|---------|--------|--------|--------|--------| | Flag | SC1TBS<br>Y | SC1RBSY | SC1TEMP | SC1REMP | SC1FEF | SC1PEK | SC1ORE | SC1ERE | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | | bp | Flag | Description | |----|---------|-----------------------------------------------------------------| | 7 | SC1TBSY | Serial bus status 0:Other use 1:Serial transmission in progress | | 6 | SC1RBSY | Serial bus status 0:Other use 1:Serial reception in progress | | 5 | SC1TEMP | Transmission buffer empty flag 0:Empty 1:Full | | 4 | SC1REMP | Reception buffer empty flag 0:Empty 1:Full | | 3 | SC1FEF | Framing error detection 0:No error 1:Error | | 2 | SC1PEK | Parity error detection 0:No error 1:Error | | 1 | SC1ORE | Overrun error detection 0:No error 1:Error | | 0 | SC1ERE | Error monitor flag 0:No error 1:Error | ## ■ Serial interface I/O pin switching control Register (SCSEL:0x03F90) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------------|--------------|---------|---------|-------|---|--------|--------| | Flag | TEMPSC<br>12 | TEMPSC<br>11 | TEMPSC2 | TEMPSC1 | SC4SL | - | SC1ORE | SC1ERE | | Reset | 0 | 0 | 0 | 0 | 0 | - | 0 | 0 | | Access | R/W | R/W | R/W | R/W | R/W | - | R/W | R/W | | bp | Flag | Description | |-----|--------------------|---------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TMPSC12<br>TMPSC11 | Serial 1 used timer 2 output dividing switching X0:Timer 2 output 01:Timer 2 output divided by 2 11:Timer 2 output divided by 8 | | 5-4 | TMPSC02<br>TMPSC01 | Serial 0 used timer 2 output dividing switching X0:Timer 2 output 01:Timer 2 output divided by 2 11:Timer 2 output divided by 8 | | 3 | SC4SL | Serial 4 I/O pin switching 0:A (P10, P11) 1:B (P76, P77) | | 2 | - | - | | 1 | SC1SL | Serial 1 I/O pin switching 0:A (P15 to P17) 1:B (PA4 to PA6) | | 0 | SC0SL | Serial 0 I/O pin switching 0:A (PA0 to PA2) 1:B (P75 to P77) | # 12.3 Operation Serial interface 1 can be used for both clock synchronous and duplex UART. ### 12.3.1 Clock Synchronous Serial Interface #### Activation Factor for Communication Table:12.3.1 shows activation factors for communication. At master communication, the transfer clock is generated by setting data to the transmission data buffer TXBUF1, or by receiving a start condition. Except during communication, the input signal from SBT1 pin is masked to prevent operating errors by noise. This mask can be released automatically by setting a data to TXBUF1 (access to the TXBUF1 register), or enabling a start condition to the data input pin. Therefore, at slave communication, set data to TXBUF1, or input an external clock after a start condition is input. However, the external clock should be input after 3.5 transfer clock interval past from the data set to TXBUF1. This period is for loading the data from TXBUF1 to the internal shift register. | Clock | Communication type | Start condition | Activation source of communication | |--------|------------------------|-----------------|----------------------------------------------------| | Master | Transmission | Enabled | Set transmission data (*1) | | | | Disabled | Set transmission data(*2) | | | Reception | Enabled | Input start condition(*3) | | | | | or | | | | | Set dummy data(*2) | | | | Disabled | Set dummy data (*2) | | | Transmission/Reception | Enabled | -(*4) | | | | Disabled | Set transmission data(*2) | | Slave | Transmission | Enabled | Input clock after transmission data is set (*5) | | | | Disabled | Input clock after transmission data is set (*6) | | | Reception | Enabled | Input clock after start condition is input (*7) or | | | | | Input clock after dummy data is set (*6) | | | | Disabled | Input clock after dummy data is set (*6) | | | Transmission/Reception | Enabled | -(*4) | | | | Disabled | Input clock after transmission data is set (*6) | - (\*1) After the start condition output, the transfer clock is output after 1 transfer clock interval. - (\*2) After setting transmission data/dummy data, the transfer clock should be output after 3.5 transfer clock interval at the maximum. The system configuration is required so that the transmission data/dummy data are written after the master receives the information of slave data load completion. - (\*3) After the start condition input, output the transfer clock after 2.5 transfer clock interval at the maximum. When receiving data continuously, the system configuration is required to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. - (\*4) When the start condition is set to "enable", transmission and reception should not be excuted at the same time. - (\*5) After setting the transmission data, output the start condition and wait until the master excutes the clock input. At the clock input, 1 or more transfer clock interval is required after the start condition output. - (\*6) At the clock input, 3.5 or more transfer clock interval is required after setting transmission data/ dummy data. The system configuration is required to notify the master of the data load completion. - (\*7) At the clock input, 0.5 or more transfer clock interval is required after the start condition input. When receiving data continuously, the system configuration is required to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. #### ■ Transfer Bit Setup The transfer bit count is selected from 1 to 8 bits. Set the transfer bit count by the SC1LNG 2 to 0 flag of the SC1MD0 register (at reset:111). The SC1LNG2 to 0 flag holds the former set value until it is set again. Except during communication, SBT1 pin is masked to prevent errors by noise. At slave communication, set data to TXBUF1 or input a clock to SBT1 pin after a start condition is input. To communicate properly, more than 2.5 transfer clock interval after the data set to TXBUF1 is required to input the external clock. #### ■ Start Condition Setup The SC1STE flag of the SC1MD0 register sets whether a start condition is enabled or disabled. The start condition is recognized when SC1CE1 flag of SC1MD0 is set to "0" and a clock line (SBT1 pin) is "H", data line (SBI1 pin with 3 lines or SBO1 pin with 2 lines) is changed from "H" to "L". Also, it is recognized when SC1CE1 flag is set to "1" and a clock line (SBT1 pin) is "L", data line (SBI1 pin with 3 lines or SBO1 pin with 2 lines) is changed from "H" to "L". Both the SC1SBOS flag and the SC1SBIS flag of the SC1MD1 register should be set to "0", before the start condition setup is changed. When transmission and reception are executed at the same time, set the start condition to "disable" to prevent abnormal operation. #### ■ First Transfer Bit Setup The SC1DIR flag of the SC1MD0 register can set the transfer bit. MSB first or LSB first can be selected. #### Transmission Data Buffer The transfer data buffer TXBUF1 is the spare buffer which stores data to be loaded to internal shift register. Set the data to be transferred to transfer data buffer TXBUF1, and the data is automatically loaded to internal shift register. The data loading takes more than 3 transfer clocks cycles. Data setting to TXBUF1 again during data loading may not be operated properly. You can determine whether or not data loading is in progress by monitoring transfer buffer empty flag SC1TEMP of the SC1STR. SC1TEMP flag is set to "1"when data is set to TXBUF1 and cleared to "0" when data loading ends. Figure:12.3.1 Transmission Data Buffer #### Reception Date Buffer The reception data buffer RXBUF1 is the spare buffer that pushed the received data in the internal shift register. After the communication complete interrupt SC1TIRQ is generated, all data stored in the internal shift register is stored to the received data buffer RXBUF1 automatically. RXBUF1 can store data up to 1 byte. RXBUF1 is rewritten every time communication is completed. Data of RXBUF1 should be read out before the next reception is completed. The received data buffer empty flag SC1REMP is set to "1" at the same time SC1TIRQ is generated. SC1REMP is cleared to "0" after RXBUF1 is read out. To communicate properly, the external clock should be input after 3.5 transfer clock interval past from the data set to TXBUF1. When the start condition is set to "enable" in the clock synchronous communication, transmission and reception should not be executed at the same time to prevent abnormal operation. If the start condition is input to restart during communication, the transmission data is not valid. Set the transmission data to TXBUF1 again to operate the transmission again. RXBUF1 is rewritten every time communication is completed. At continuous communication, data of RXBUF1 should be read out before the next reception is completed. #### ■ Transfer Bit Count and First Transfer Bit At transmission, when the transfer bit count is 1 bit to 7bits, the data storing method to the transmission data buffer TXBUF1 is different depending on the first transfer bit selection. At MSB first, use the upper bits of TXBUF1 for storing. When the transfer bit count is 6 bits, as shown on Figure:12.3.2, if data "A" to "F" are stored to bp2 to bp7 of TXBUF1, the transmission is operated from "F" to "A". At LSB first, use the lower bits of TXBUF1 for storing. When the transfer bit count is 6 bits, as shown on Figure:12.3.3, if data "A" to "F" are stored to bp0 to bp5 of TXBUF1, the transmission is operated from "A" to "F". Figure:12.3.2 Transmission Bit Count and First Transfer Bit (starting with MSB) Figure:12.3.3 Transmission Bit Count and First Transfer Bit (starting with LSB) #### ■ Reception Bit Count and First Transfer Bit At reception, when the transfer bit count is 1 bit to 7 bits, the data storing method to the received data buffer RXBUF1 is different depending on the first transfer bit. At MSB first, data is stored to the lower bits of RXBUF1. When the transfer bit count is 6 bits, as shown on figure Figure:12.3.5, if data "A" to "F" are stored to bp0 to bp5 of RXBUF1, the transmission is operated from "F" to "A". At LSB first, data is stored to the upper bits of RXBUF1. When there the transfer bit count is 6 bits, as shown on Figure:12.3.4, if data "A" to "F" are stored to bp2 to bp7 of RXBUF1, the transmission is operated from "A" to "F". Figure:12.3.4 Reception Bit Count and First Transfer Bit (starting with MSB bit) Figure:12.3.5 Reception Bit Count and First Transfer Bit (starting with LSB bit) #### ■ Continuous Transmission This serial interface has a function for continuous communication. If data is set to the transmission data buffer TXBUF1 during communication, the transmission buffer empty flag SC1TEMP is automatically set to communicate continuously. Data set to TXBUF1 should be done after the data is loaded to the internal shift register before the communication complete interrupt SC1TIRQ is generated. At master communication, suspension of communication between the SC1TIRQ generation and the next transfer clock output is 4 transfer clocks. #### ■ Input Edge/ Output Edge Setup The SC1CE1 flag of the SC1MD0 register set the output edge of the transmission data and the input edge of the received data. Data at transmission is output at the falling edge of clock as the SC1CE1 flag = "0", and at the rising edge of clock as the SC1CE1 = "1". Data at reception is input at the rising edge of clock as the SC1CE1 = "0", and at the falling edge of clock as the SC1CE1 flag = "1". Table:12.3.2 Transmission Data Output Edge and Reception Data Input Edge | SC1CE1 | Transmission data output edge | Reception data input edge | |--------|-------------------------------|---------------------------| | 0 | | | | 1 | | | #### ■ Clock Setup Clock source is selected from the dedicated prescaler and timers 1, 2 output (2 channels) with the SC1PSC2 to 0 of the SC1MD3 register. The dedicated prescaler is started by selecting "count enable" with the SC1PSCE flag of the SC1MD3 register. The SC1MST flag of the SC1MD1 register can select the internal clock (clock master), or the external clock (clock slave). Even if the external clock is selected, set the internal clock that has the same clock cycle or lower to the external clock, by the SC1MD3 register as the interrupt flag SC1TIRQ is generated by the internal clock. The following is the internal clock source that can be set by the SC1MD3 register. Also, the SC1CKM flag of the SC1MD1 register can divide the internal clock. SC1DIV flag can select the dividing ratio between "divided by 8" and "divided by 16". Table:12.3.3 Synchronous Serial Interface Clock Source | | serial 1 | |------------------|------------------| | Clock source | fosc/2 | | (internal clock) | fosc/4 | | | fosc/16 | | | fosc/64 | | | fs/2 | | | fs/4 | | | Timer 1 output | | | Timer 2 output | | | Timer 2 output/2 | | | Timer 2 output/8 | Set always the SC1SBIS flag and SC1SBOS flag of the SC1MD1 register to "0" before switching the clock setup. When the slave reception is executed with the start condition "enable" at the continuous communication, the system configuration is required to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. #### ■ Used Pin Switching Used pin can be switched to A (SBO1A, SBI1A, SBT1A) or B (SBO1B, SBI1B, SBT1B) by the SC1SL flag of the SCSEL register. #### ■ Data Input Pin Setup 3 channels type (clock pin: SBT1 pin, data output pin: SBO1 pin, data input pin: SBI1 pin) or 2 channels type (clock pin: SBT1 pin, data I/O pin: SBO1 pin) can be selected as a communication mode. SBI1 pin can be used only for serial data input. SBO1 pin can be selected as serial data input or output. Whether the serial data is input from SBI1 pin or SBO1 pin, it can be selected by the SC1IOM flag of the SC1MD1 register. When "data input from SBO1 pin" is selected to set the 2 channels type, transmission/ reception can be switched by the SBO1 pin direction control. For SBO1A pin, it can be done by the P1DIR5 flag of the P1DIR register, for SBO1B pin, by the PADIR5 flag of the PADIR register. At this time, SBI1 pin can be used as a general port, too. The transfer speed should be up to 5.0 MHz. If the transfer clock is over 5.0 MHz, the transmission data may not be sent correctly. At reception, if SC1IOM of the SC1MD1 register is set to "1" and "serial data input from SBO1" is selected, SBI1 pin can be used as a general port. #### ■ Reception Buffer Empty Flag After reception is completed (SC1TIRQ is generated), data is automatically stored to RXBUF1 from the internal shift register. If data is stored to the shift register RXBUF1 when the SC1SBIS of the SC1MD1 register is set to "serial input", the reception buffer empty flag SC1REMP of the SC1STR register is set to "1". This indicates that the reception data is going to be read out. SC1REMP is cleared to "0" by reading out the data of RXBUF1. #### ■ Transmission Buffer Empty Flag During the communication (after setting data to TXBUF1 and before the communication complete interrupt SC1TIRQ is generated) if any data is set to TXBUF1 again, the transmission buffer empty flag SC1REMP of the SC1STR register is set to "1". This indicates that the next transmission data is going to be loaded. Data is loaded to the inside shift register from TXBUF1 by generation of SC1TIRQ, and the next transfer is started as SC1TEMP is cleared to "0". #### Overrun Error and Error Monitor Flag After reception complete, if the next data has been already received before reading out of the data of the received data buffer RXBUF1, overrun error is generated and the SC1ORE flag of the SC1STR register is set to "1". At the same time, the error monitor flag SC1ERE is set to indicate a reception error. The SC1ERE flag is cleared after the data of the RXBUF1 is read out and the next communication complete interrupt SC1TIRQ is generated. SC1ERE is cleared as SC1ORE flag is cleared. These error flags have no effect on communication operation. #### ■ Reception BUSY Flag When the SC1SBIS flag of the SC1MD1 register is set to "serial data input" and the data is set to TXBUF1, or the start condition is recognized, the BUSY flag SC1RBSY of the SC1STR register is set to "1". The flag is cleared to "0" after the communication complete interrupt SC1TIRQ is generated. During continuous communication, the SC1RBSY flag is always set. If the transmission buffer empty flag SC1TEMP is cleared to "0" as the communication complete interrupt SC1TIRQ is generated, SC1RBSY is cleared to "0". If the SC1SBIS flag is set to "0" during communication, the SC1RBSY flag is cleared to "0". #### ■ Transmission BUSY Flag When the SC1SBOS flag of the SC0MD1 register is set to "serial data output" and the data is set to TXBUF1, or the start condition is recognized, the SC1TBUSY flag of the SC1STR register is set if the SC1SBOS flag of the SC1MD1 register is "1". The flag is cleared to "0" after the communication complete interrupt SC1TIRQ is generated. During continuous communication, the SC1TBSY flag is always set. If the transmission buffer empty flag SC1TEMP is cleared to "0" as the communication complete interrupt SC1TIRQ is generated, SC1TBSY is cleared to "0". If the SC1SBOS flag is set to "0" during communication, the SC1TBSY flag is cleared to "0". #### Forced Reset This serial interface contains forced reset for abnormal operation. For forced reset, the SC1SBOS flag and the SC1SBIOS flag of the SC1MD1 register should be set to "0" (SBO1 pin: port, input data:"1" input). At forced reset, the status register (the SC1BRKF flag of the SC1MD2 register, all flags of the SC1STR register) are initialized as they are set at reset, but the control register holds the set value. #### ■ Last Bit of Transmission Data Table:12.3.4 shows the data output holding period of the last bit at transmission, and the minimum data input period of the last bit at reception. At slave, the internal clock should be set up to keep the data hold time at transmission. Table:12.3.4 Last Bit Data Length of Transfer Data | | The last bit data holding period at transmission | The last data input period at reception | |-----------|--------------------------------------------------------------------------------------------|-----------------------------------------| | At master | 1 bit data length | 1 bit data length (Minimum) | | At slave | [1 bit data length of external clock $\times$ 1/2] + [internal clock cycle $\times$ (1-2)] | | When start condition is disabled (at SC1STE flag = 0), the SBO1 output after the data output holding period of the final bit can be set by the setting value of the SC1FDC1 to 0 flag of the SC1MD3 register as shown on Table:12.3.5. After releasing the reset, despite the setting value of the SC1FDC1 to 0 flag, output before the serial transfer is "H". When start condition is enabled (at SC1STE flag = 1), despite the setting value of the SC1FDC1 to 0, "H" is output. Table:12.3.5 SBO1 Output after the Data Output Holding Period of the Last Bit (without start condition) | SC1FDC1 flag | SC1FDC0 flag | SBO1 output after the data output holding period of the last bit | |--------------|--------------|------------------------------------------------------------------| | 0 | 0 | Fixed to "1"(High) output | | 1 | 0 | Last data holding | | 0 | 1 | Fixed to "0"(Low) output | | 1 | 1 | Reserved | ### ■ Other Control Flag Setup Table:12.3.6 shows flags that do not required to be set or monitored as the flags are not used at clock synchronous communication. Table:12.3.6 Other Control Flag | Register | Flag | Detail | |----------|-------------|-----------------------------------| | SC1MD2 | SC1BRKE | Break status transmission control | | | SC1BRKF | Break status reception monitor | | | SC1NPE | Parity enable | | | SC1PM1 to 0 | Added bit specification | | | SC1FM1 to 0 | Frame mode specification | | SC1STR | SC1PEK | Parity error detection | | | SC1FEF | Frame error detection | #### ■ Transmission Timing Figure:12.3.6 Transmission Timing (at falling edge, start condition is enabled) Figure:12.3.7 Transmission Timing (at falling edge, start condition is disabled) Figure:12.3.8 Transmission Timing (at rising edge, start condition is enabled) Figure:12.3.9 Transmission Timing (at rising edge, start condition is disabled) #### Reception Timing Figure:12.3.10 Reception Timing (at rising edge, start condition is enabled) Figure:12.3.11 Reception Timing (at rising edge, start condition is disabled) Figure:12.3.12 Reception Timing (at falling edge, start condition is enabled) Figure:12.3.13 Reception Timing (at falling edge, start condition is disabled) ### ■ Transmission/ Reception Timing As data is received at the opposite edge of the transmission clock, set the polarity of reception data input edge to opposite polarity of the transmission data output edge. When transmission and reception are executed at the same time, set the start condition to "disable" to prevent abnormal operation. Figure:12.3.14 Transmission/ Reception Timing (Reception: at rising edge, Transmission: at falling edge) Figure:12.3.15 Transmission/ Reception Timing (Reception: at falling edge, Transmission: at rising edge) #### Communication Function at Standby Mode This serial interface is capable of slave reception in STANDBY mode. CPU operation status can be recovered from standby to normal by the communication complete interrupt SC1TIRQ that is generated after the slave reception. (In STANDBY mode, continuous reception is disabled after data of transfer bit count set by SC1LNG2-0 flags of the SC1MD0 register is received.) The received data should be read out from the received data buffer RXBUF1 after recovering NORMAL mode. In STANDBY mode, reception with start condition is not available, thus, disable start condition. And set dummy data to transmission data buffer TXBUF1 before transition to STANDBY mode. Figure:12.3.16 Reception Timing at Standby Mode (Reception: at rising edge, start condition is disabled) # ■ Pins Setup (with 3 channels, at transmission) Table:12.3.7 shows the setup for synchronous serial interface pin with 3 channels (SBO1 pin, SBI1 pin, SBT1 pin) at transmission. Table:12.3.7 Setup for Synchronous Serial Interface Pin (with 3 channels, at transmission) | Setup item | Data output pin | Data input pin | Clock I/O pin | | |-------------------|-----------------------------------|---------------------|-------------------------------|-------------------------------| | | SBO1A pin/SBO1B | SBI1A pin/SBI1B pin | SBT1 pin/SBT1B pin | | | | pin | | Clock master | Clock slave | | | | | SC1SCMD1(SC1MST) | | | Port pin | P15 | P16 | P17/PA6 | | | Port pin setup | Select used pin (A, B) | | | | | | SCSEL (SC1SL) | | | | | Serial data input | SBI1 | | - | | | selection | SC1MD1(SC1IOM) | C1MD1(SC1IOM) | | | | Function | Serial data output | "1" input | Transfer clock I/O | Transfer clock I/O | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | SC1MD1(SC1SBTS) | | | Style | Push-pull/ Nch open-<br>drain | - | Push-pull/ Nch open-<br>drain | Push-pull/ Nch open-<br>drain | | | P1ODC(P1ODC5)/<br>PAODC(PAODC5) | | P1ODC(P1ODC7)/PAC | DDC(PAODC6) | | I/O | Output mode | - | Output mode | Input mode | | | P1DIR(P1DIR5)/<br>PADIR(PADIR5) | | P1DIR(P1DIR7)/PADIR | (PADIR6) | | Pull-up setup | Added/ Not added | - | Added/ Not added | Added/ Not added | | | P1PLUD(P1PLUD5)/<br>PAPLU(PAPLU5) | | P1PLUD(P1PLUD7) | | # ■ Pins Setup (with 3 channels, at reception) Table:12.3.8 shows the setup for synchronous serial interface pin with 3 channels (SBO1 pin, SBI1 pin, SBT1 pin) at reception. Table:12.3.8 Setup for Synchronous Serial Interface Pin (with 3 channels, at reception) | Setup item | Data output pin | Data input pin | Clock I/O pin | | |-------------------|------------------------|----------------------------------|--------------------------------|-------------------------------| | SBO1A pin/ SBO1B | | SBI1A pin/ SBI1B pin | SBT1A pin/ SBT1B pin | | | | pin | | Clock master | Clock slave | | | | | SC1SCMD1(SC1MST) | | | Port pin | P15/ PA5 | P16/ PA4 | P17/ PA6 | | | Port pin setup | Select used pin (A, B) | | | | | | SCSEL (SC1SL) | | | | | Serial data input | SBI1 | | - | | | selection | SC1MD1(SC1IOM) | | | | | Function | Port | Serial input | Transfer clock I/O | Transfer clock I/O | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | SC1MD1(SC1SBTS) | | | Style | - | - | Push-pull/ Nch open-<br>drain | Push-pull/ Nch open-<br>drain | | | | | P1ODC(P1ODC7) /PAODC(PAODC6) | | | I/O | - | Input mode | Output mode | Input mode | | | | P1DIR(P1DIR6) /<br>PADIR(PADIR4) | P1DIR(P1DIR7)/ PADII | R(PADIR6) | | Pull-up setup | - | - | Added/ Not added | Added/ Not added | | | | | P1PLUD(P1PLUD7)/ PAPLU(PAPLU6) | | # ■ Pins Setup (with 3 channels, at transmission / reception) $Table: 12.3.9 \ shows \ the \ setup \ for \ synchronous \ serial \ interface \ pin \ with \ 3 \ channels \ (SBO1 \ pin, \ SBI1 \ pin, \ SBI1 \ pin) \ at \ transmission \ / \ reception.$ Table:12.3.9 Setup for Synchronous Serial Interface Pin (with 3 channels, at transmission / reception) | Setup item | Data output pin | Data input pin | Clock I/O pin | | |-------------------|-----------------------------------|---------------------------------|-------------------------------|-------------------------------| | | SBO1A pin/ SBO1B | SBI1A pin/ SBI1B pin | SBT1A pin/ SBT1B pin | | | | pin | | Clock master | Clock slave | | | | | SC1SCMD1(SC1MST) | | | Port pin | P15/PA5 | P16/PA4 | P17/PA6 | | | Port pin setup | Select used pin (A, B) | 1 | | | | | SCSEL (SC1SL) | | | | | Serial data input | SBI1 | | - | | | selection | SC1MD1(SC1IOM) | | | | | Function | Serial data output | Serial input | Transfer clock I/O | Transfer clock I/O | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | SC1MD1(SC1SBTS) | | | Style | Push-pull/ Nch open-<br>drain | - | Push-pull/ Nch open-<br>drain | Push-pull/ Nch open-<br>drain | | | P1ODC(P1ODC5)/<br>PAODC(PAODC5) | | P1ODC(P1ODC7)/ PAG | ODC(PAODC6) | | I/O | Output mode | Input mode | Output mode | Input mode | | | P1DIR(P1DIR5)/<br>PADIR(PADIR5) | P1DIR(P1DIR6)/<br>PADIR(PADIR4) | P1DIR(P1DIR7)/ PADII | R(PADIR6) | | Pull-up setup | Added/ Not added | - | Added/ Not added | Added/ Not added | | | P1PLUD(P1PLUD5)/<br>PAPLU(PAPLU5) | | P1PLUD(P1PLUD7)/ P | APLU(PAPLU6) | # ■ Pins Setup (with 2 channels, at transmission) Table:12.3.10 shows the setup for synchronous serial interface pin with 2 channels (SBO1 pin, SBT1 pin) at transmission. SBI1 pin can be used as a port. Table:12.3.10 Setup for Synchronous Serial Interface Pin (with 2 channels, at transmission) | Setup item | Data output pin | Serial unused pin | Clock I/O pin | | |-------------------|-----------------------------------|----------------------|-------------------------------|-------------------------------| | | SBO1A pin/ SBO1B | SBI1A pin/ SBI1B pin | SBT1A pin/ SBT1B pin | | | | pin | | Clock master | Clock slave | | | | | SC1SCMD1(SC1MST) | • | | Port pin | P15/PA5 | P16/PA4 | P17/PA6 | | | Port pin setup | Select used pin (A, B) | • | 1 | | | | SCSEL (SC1SL) | | | | | Serial data input | SBO1 | | - | | | selection | SC1MD1(SC1IOM) | | | | | Function | Serial data input | "1" input | Transfer clock I/O | Transfer clock I/O | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | SC1MD1(SC1SBIS) | | | Style | Push-pull/ Nch open-<br>drain | - | Push-pull/ Nch open-<br>drain | Push-pull/ Nch open-<br>drain | | | P1ODC(P1ODC5)/<br>PAODC(PAODC5) | | P1ODC(P1ODC7)/ PAG | DDC(PAODC6) | | I/O | Output mode | - | Output mode | Input mode | | | P1DIR(P1DIR5)/<br>PADIR(P1DIR5) | | P1DIR(P1DIR7)/ PADIR(PADIR6) | | | Pull-up setup | Added/ Not added | - | Added/ Not added | Added/ Not added | | | P1PLUD(P1PLUD5)/<br>PAPLU(PAPLU5) | | P1PLUD(P1PLUD7)/ P. | APLU((PAPLU6) | # ■ Pins Setup (with 2 channels, at reception) Table:12.3.11 shows the setup for synchronous serial interface pin with 2 channels (SBO1 pin, SBT1 pin) at reception. SBI1 pin can be used as a port. Table:12.3.11 Setup for Synchronous Serial Interface Pin (with 2 channels, at reception) | Setup item | Data output pin | Serial unused pin | Clock I/O pin | | |-------------------|--------------------------------------------|-------------------|-------------------------------|-------------------------------| | | SBO1A pin/ SBO1B SBI1 pin/ SBI1B pin S | | SBT1A pin/ SBT1B pin | | | | pin | | Clock master | Clock slave | | | | | SC1SCMD1(SC1MS7 | ) | | Port pin | P15/PA5 | P16/PA4 | P17/PA6 | | | Port pin setup | Select used pin (A, E | 3) | | | | | SCSEL (SC1SL) | | | | | Serial data input | SBO1 | | - | | | selection | SC1MD1(SC1IOM) | | | | | Function | Port | Serial input | Transfer clock I/O | Transfer clock I/O | | | SC1MD1(SC1SBO<br>S) | SC1MD1(SC1SBIS) | SC1MD1(SC1SBIS) | | | Style | - | - | Push-pull/ Nch open-<br>drain | Push-pull/ Nch open-<br>drain | | | | | P1ODC(P1ODC7)/ PA | AODC(PAODC6) | | I/O | Input mode | - | Output mode | Input mode | | | P1DIR(P1DIR5)/<br>PADIR(PADIR5) | | P1DIR(P1DIR7)/ PAD | IR(PADIR6) | | Pull-up setup | - | - | Added/ Not added | Added/ Not added | | | | | P1PLUD(P1PLUD7)/ | PAPLU(PAPLU6) | # 12.3.2 Setup Example # ■ Transmission / Reception Setup Example The setup example for clock synchronous serial communication with serial 1 is shown. Table:12.3.12 shows the conditions at transmission / reception. Table:12.3.12 Setup Examples for Synchronous Serial Interface Transmission / Reception | Setup item | Set to | |-------------------------------------------|--------------------------| | Serial data input pin | Select SBI1 (3 channels) | | Transfer bit count | 8 bit | | Start condition | None | | First transfer bit | MSB | | Input edge | Falling edge | | Output edge | Rising edge | | Clock | Clock master | | Clock source | fs/2 | | Clock source dividing | Not divided | | Used pin | A (port 1) | | SBT1/SBO1 pin style | Nch open-drain | | SBT1 pin pull-up resistor | Added | | SBO1 pin pull-up resistor | Added | | serial 1 communication complete interrupt | Enable | | SBO1 output after last data output | "1"(H) fix | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------| | (1) Select the prescaler operation<br>SC1MD3(0x03F9C)<br>bp3 :SC1PSCE =1 | (1) Set the SC1PSCE flag of the SC1MD3 register to "1" to select "prescaler operation". | | (2) Select the clock source<br>SC1MD3(0x03F9C)<br>bp2-0 :SC1PSC2-0 =100 | (2) Set the SC1PSC2 to 0 flag of the SC1MD3 register to "100" to select the fs/2 to clock source. | | (3) SBO1A output control after the last data output SC1MD3(0x03F9C) bp7,6 :SC1FDC1-0 =00 | (3) Set the SC1FDC1 to 0 flag of the SC1MD3 register to "00" to select "1" (High) fix of the SBO1 last data output. | | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (4) Select the used pin<br>SCSEL(0x03F90)<br>bp1 :SC1SL =0 | (4) Set the SC1SL flag of the SCSEL register to "0" to select A (port A) as I/O pin. | | (5) Control the pin style P1ODC(0x03F1B) bp7:P1ODC7=1 bp5:P1ODC5=1 P1PLUD(0x03F41) bp7:P1PLUD7=1 bp5:P1PLUD5=1 | (5) Set the P1ODC7,P1ODC5 flag of the P1ODC register to "1,1" and select Nch open-drain to SBO1/SBT1 pin. Set the P1PLUD7,P1PLUD5 flag of the P1PLUD register to "1,1" to enable the pull-up resistor. | | (6) Control the pin direction P1DIR(0x03F31) bp7 :P1DIR7 =1 bp6 :P1DIR6 =0 bp5 :P1DIR5 =1 | (6) Set the P1DIR7, P1DIR5 flag of the Port 1 pin direction control register (P1DIR) to "1,1" and the P1DIR6 flag to "0" to set P17, P15 to the output mode, P16 to the input mode. | | (7) Set the SC1MD0 register Select the transfer bit count SC1MD0(0x03F99) bp2-0 :SC1LNG2-0 =111 | (7) Set the SC1LNG2 to 0 flag of the serial 1 mode register 0 (SC1MD0) to "111" to set the transfer bit count as "8 bits". | | Select the start condition<br>SC1MD0(0x03F99)<br>bp3 :SC1STE =0 | Set the SC1STE flag of the SC1MD0 register to "0" to disable the start condition. | | Select the first bit to be transferred SC1MD0(0x03F99) bp4 :SC1DIR =0 | Set the SC1DIR flag of the SC1MD0 register to "0" to set MSB as a transfer first bit. | | Select the transfer edge<br>SC1MD0(0x03F99)<br>bp7 :SC1CE1 =1 | Set the SC1CE1 flag of the SC1MD0 register to "1" to set the reception data input edge "falling" and the transmission data output edge "rising". | | (8) Set the SC1MD1 register Select the communication style SC1MD1(0x03F9A) | (8) Set the SC1CMD flag of the SC1MD1 register to "0" to select the synchronous serial. | | bp0 :SC1CMD =0 Select the transfer clock | Set the SC1MST flag of the SC1MD1 register to "1" to select the clock master (internal clock). Set the SC1CKM flag to "0" to select "not divided" for | | SC1MD1(0x03F9A)<br>bp2:SC1MST =1 | the clock source. | | bp3 :SC1CKM =0 | Set the SC1SBOS, SC1SBIS, SC1SBTS flag of the SC1MD1 register to "1" to set the SBO1 pin to the | | Select the transfer clock<br>SC1MD1(0x03F9A) | serial data output, the SBI1 pin to the serial input, SBT1 pin to the transfer clock input/output. Set the SC1IOM | | bp4 :SC1SBOS =1<br>bp5 :SC1SBIS =1 | flag "0" to set the serial data input from the SBI1 pin. | | bp6 :SC1SBTS =1<br>bp7 :SC1IOM =0 | | | (9) Set the interrupt level<br>SC1TICR(0x03FF2)<br>bp7-6 :SC1TLV1-0 =10 | (9) Set the interrupt level by the SC1TLV1 to 0 flag of the serial 1 transmission interrupt control register (SC1TICR). | | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (10) Enable the interrupt SC1TICR(0x03FF2) bp1 :SC1TIE =1 bp0 :SC0TIR =0 | (10) Set the SC1TIE flag of the SC1TICR register to "1" to enable the interrupt. If any interrupt request flag (SC1TIR of the SC1TICR register) is already set, clear SC1TIR before the interrupt is enabled. | | (11) Start the serial transmission Transmission data → TXBUF1(0x03F9F) Reception data → input SBI1 pin | (11) Set the transmission data to the serial transmission data buffer TXBUF1. The transmission or reception is started by the internal clock generation. When the transmission is finished, the serial 1 UART transmission interrupt SC1TIRQ is generated. [Chapter 3. 3-1-4 Setup] | Note: Procedures (1) to (3),(5),(6),(7) to (8) can be set at the same time. # ■ Reception Setup Example The setup example for clock synchronous serial communication with serial 1 is shown. Table: 12.3.12 shows the conditions at Reception. Table:12.3.13 Setup Examples for Synchronous Serial Interface Reception | Setup item | Set to | |-------------------------------------------|--------------------------| | Serial data input pin | Select SBI1 (3 channels) | | Transfer bit count | 8 bit | | Start condition | None | | First transfer bit | MSB | | Input edge | Falling edge | | Output edge | Rising edge | | Clock | Clock Slave | | Clock source | fs/2 | | Clock source dividing | Not divided | | Used pin | A (port 1) | | SBT1/SBO1 pin style | Nch open-drain | | SBT1 pin pull-up resistor | Added | | SBO1 pin pull-up resistor | Added | | Serial 1 communication complete interrupt | Enable | | SBO1 output after last data output | "1"(H) fix | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select the prescaler operation<br>SC1MD3(0x03F9C)<br>bp3:SC1PSCE =1 | (1) Set the SC1PSCE flag of the SC1MD3 register to "1" to select "prescaler operation". | | (2) Select the clock source<br>SC1MD3(0x03F9C)<br>bp2-0 :SC1PSC2-0 =100 | (2) Set the SC1PSC2 to 0 flag of the SC1MD3 register to "100" to select the fs/2 to clock source. | | (3) SBO1A output control after the last data output SC1MD3(0x03F9C) bp7,6 :SC1FDC1-0 =00 | (3) Set the SC1FDC1 to 0 flag of the SC1MD3 register to "00" to select "1" (High) fix of the SBO1 last data output. | | (4) Select used pin<br>SCSEL(0x03F90)<br>bp1 :SC1SL =0 | (4) Set the SC1SL flag of the SC1SEL register to "0" to select A (port 1) as I/O pin. | | (5) Control the pin style P1ODC(0x03F1B) bp7:P1ODC7=1 bp5:P1ODC5=1 P1PLUD(0x03F4A) bp7:P1ODC7=1 bp5:P1ODC5=1 | (5) Set the P1ODC7,P1ODC5 flag of the P1ODC register to "1,1" to select Nch open-drain to SBT0 pin. Set the P1PLUD7,P1PLUD5 flag of the P1PLUD register to "1,1" to enable the pull-up resistor. | | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (6) Control the pin direction P1DIR(0x03F31) bp7 :P1DIR7 =1 bp6 :P1DIR6 =0 bp5 :P1DIR5 =1 | (6) Set the P1DIR7, P1DIR5 flag of the Port 1 pin direction control register (P1DIR) to "1,1" and the P1DIR6 flag to "0" to set P17, P15 to the output mode, P16 to the input mode. | | (7) Set the SC1MD0 register Select the transfer bit count SC1MD0(0x03F99) bp2-0 :SC1LNG2-0 =111 Select the start condition SC1MD0(0x03F99) bp3 :SC1STE =0 Select the first bit to be transferred SC1MD0(0x03F99) bp4 :SC1DIR =0 Select the transfer edge SC1MD0(0x03F99) bp7 :SC1CE1 =1 | <ul> <li>(7) Set the SC1LNG2 to 0 flag of the serial 1 mode register 0 (SC1MD0) to "111" to set the transfer bit count as "8 bits".</li> <li>Set the SC1STE flag of the SC1MD0 register to "0" to disable the start condition.</li> <li>Set the SC1DIR flag of the SC1MD0 register to "0" to set MSB as a transfer first bit.</li> <li>Set the SC1CE1 flag of the SC1MD0 register to "1" to set the reception data input edge "falling" and the transmission data output edge "rising".</li> </ul> | | (8) Set the SC1MD1 register Select the communication style SC1MD1(0x03F9A) bp0 :SC1CMD =0 Select the transfer clock SC1MD1(0x03F9A) bp2 :SC1MST =1 bp3 :SC1CKM =0 Select the transfer clock SC1MD1(0x03F9A) bp4 :SC1SBOS =1 bp5 :SC1SBIS =1 bp6 :SC1SBTS =1 bp7 :SC1IOM =0 | <ul> <li>(8) Set the SC1CMD flag of the SC1MD1 register to "0" to select the synchronous serial.</li> <li>Set the SC1MST flag of the SC1MD1 register to "0" to select the clock slave (external clock).</li> <li>Set the SC1CKM flag to "0" to select "not divided " for the clock source.</li> <li>Set the SC1SBOS, SC1SBIS, SC1SBTS flag of the SC1MD1 register to "1" to set the SBO1 pin to the serial data output, the SBI1 pin to the serial input, SBT1 pin to the transfer clock input/output. Set the SC1IOM flag "0" to set the serial data input from the SBI1 pin.</li> </ul> | | (9) Set the interrupt level<br>SC1TICR(0x03FF2)<br>bp7-6 :SC1TLV1-0 =10 | (9) Set the interrupt level by the SC1TLV1 to 0 flag of the serial 1 transmission interrupt control register (SC1TICR). | | (10) Enable the interrupt SC1TICR(0x03FF2) bp1 :SC1TIE =1 bp2 :SC0TIR =0 | (10) Set the SC1TIE flag of the SC1TICR register to "1" to enable the interrupt. If any interrupt request flag (SC1TIR of the SC1TICR register) is already set, clear SC1TIR before the interrupt is enabled. | | (11) Start the serial Reception<br>dummy data → TXBUF1(0x03F9F)<br>Received data → input SBI1 pin | (11) Set the transmission data to the serial dummy data buffer TXBUF1. After the dummy data is set, when clock input is done after more than 3.5 transfer clock, reception is started. When reception is finished, the serial 1 UART transmission interrupt SC1TIRQ is generated. [Chapter 3. 3-1-4 Setup] | Note: Each procedure (1) to (3),(7),(8),(9) to (10) can be set at the same time. \* At the reception with the start condition input, set the SCOSTE flag to "1" and the start condition to "enable" in step (7). In step (11), execute the start condition input instead of dummy data setting. After the start condition input, 0.5 or more transfer clock is needed before the clock input. At the reception with the start condition input, set the SC0STE flag to "1" to select start condition enable at the step (7) in the setup procedure. At the step (11), execute the start condition input instead of setting dummy data. After start condition input, more than 0.5 transfer clock is required for the clock input. For transmission with 3 channels, set the SC1SBIS of SC1MD1 register to "1" to set the serial input to "1" input. SBI1 pin can be used as a general port. For reception with 3 channels, set the SC1SBOS of SC1MD1 register to "0" to select "port". SBO1 pin can be used as a general port. For communication with 2 channels, serial data is input/output from the SBO1 pin. Input/output is switched by the port direction control register P1DIR. At reception, set always SC1SBIS of the SC1MD1 register to "1" to select "serial input". The SBI1 pin can be used as a general port. This serial interface contains a force reset function. If the communication should be stopped by force, set SC1SBOS and SC1SBIS of the SC1MD1 register to "0". Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:12.2.1 except TXBUF1) are set. Transfer rate of transfer clock set by the SC1MD3 register should not exceed 5.0 MHz. # ■ Transmission / Reception Setup Example (Standby Mode Reception) The setup example for clock synchronous serial communication with serial 1 is shown. Table:12.3.14 shows the condition at standby mode reception. Table:12.3.14 Setup Examples for Synchronous Serial Interface Transmission / Reception (Standby Mode Reception) | Setup item | Set to | | | | |-------------------------------------------|--------------------------|--|--|--| | Serial data input pin | Select SBI1 (3 channels) | | | | | Transfer bit count | 8 bit | | | | | Start condition | None | | | | | First transfer bit | MSB | | | | | Input edge | Falling edge | | | | | Clock | Clock slave | | | | | Operation mode | Stop mode | | | | | Clock source | fs/2 | | | | | Clock source dividing | Not divided | | | | | Used pin | A (port 1) | | | | | SBT1/SBO1 pin style | Push-pull | | | | | SBT1 pin pull-up resistor | Not added | | | | | SBO1 pin pull-up resistor | Not added | | | | | serial 1 communication complete interrupt | Enable | | | | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select the prescaler operation<br>SC1MD3(0x03F9C)<br>bp3 :SC1PSCE =1 | (1) Set the SC1PSCE flag of the SC1MD3 register to "1" to select "prescaler operation". | | (2) Select the clock source<br>SC1MD3(0x03F9C)<br>bp2-0 :SC1PSC2-0 =100 | (2) Set the SC1PSC2 to 0 flag of the SC1MD3 register to "100" to select fs/2 as the clock source. | | (3) Select the used pin<br>SCSEL(0x03F90)<br>bp1 :SC1SL =0 | (3) Set the SC1SL flag of the SCSEL register to "0" to select A (port 1) as I/O pin. | | (4) Control the pin style P1ODC(0x03F1B) bp7:P1ODC7=0 bp5:P1ODC5=0 P1PLUD(0x03F41) bp7:P1PLUD7=0 bp5:P1PLUD5=0 | (4) Set the P1ODC7,P1ODC5 flag of the P1ODC register to "1" to select Push-pull to SBT1 pin. Set the P1PLUD7,P1PLUD5 flag of the P1PLUD register to "1" to enable the pull-up resistor. | | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (5) Control the pin direction P1DIR(0x03F31) bp7 :P1DIR7 =0 bp6 :P1DIR6 =0 bp5 :P1DIR5 =1 | (5) Set the P1DIR7, P1DIR6 flag of the Port 1 pin direction control register (P1DIR) to "1" and the P1DIR5 flag to "1" to set P17, P16 to the input mode, P15 to the output mode. | | (6) Select the transfer bit count SC1MD0(0x03F99) bp2-0 :SC1LNG2-0 =111 | (6) Set the SC1LNG2 to 0 flag of the serial 1 mode register (SC1MD0) to "111" to set the transfer bit count as "8 bits". | | (7) Select the start condition<br>SC1MD0(0x03F99)<br>bp3 :SC1STE =0 | (7) Set the SC1STE flag of the serial 1 mode register (SC1MD0) to "1" to disable the start condition. | | (8) Select the first bit to be transferred SC1MD0(0x03F99) bp4 :SC1DIR =0 | (8) Set the SC1DIR flag of the SC1MD0 register to "0" to set MSB as a transfer first bit. | | (9) Select the transfer edge<br>SC1MD0(0x03F99)<br>bp7 :SC1CE1 =1 | (9) Set the SC1CE1 flag of the SC1MD0 register to "1" to set the reception data input edge "falling". | | (10) Select the communication type<br>SC1MD1(0x03F9A)<br>bp0 :SC1CMD =0 | (10) Set the SC1CMD flag of the SC1MD1 register to "0" to select the synchronous serial. | | (11) Select the transfer clock<br>SC1MD1(0x03F9A)<br>bp2:SC1MST =0<br>bp3:SC1CKM =0 | (11) Set the SC1MST flag of the SC1MD1 register to "0" to select the clock slave (external slave). Set the SC1CKM flag to "0" to select "not divided" for the clock source. | | (12) Control the pin function<br>SC1MD1(0x03F9A)<br>bp4 :SC1SBOS =0<br>bp5 :SC1SBIS =1<br>bp6 :SC1SBTS =1<br>bp7 :SC1IOM =0 | (12) Set the SC1SBOS flag of the SC1MD1 register to "0", the SC1SBIS flag, SC1SBTS flag to "1" to set the SBO1 pin to a general port, the SBI1 pin to the serial data input, the SBT1 pin to the transfer clock input/output. Set the SC1IOM flag "0" to set the serial data input from the SBI1 pin. | | (13) Set the interrupt level<br>SC1TICR(0x03FF2)<br>bp7-6 :SC1LV1-0 =10 | (13) Set the interrupt level by the SC1LV1 to 0 flag of the serial 1 UART transmission interrupt control register (SC1TICR). (Set level 2) | | (14) Enable the interrupt SC1TICR(0x03FF2) bp1 :SC1TIE =1 bp0 :SC1TIR =0 | (14) Set the SC1TIE flag of the SC1TICR register to "1" to enable the interrupt. If any interrupt request flag (SC1TIR of the SC1TICR register) is already set, clear SC1TIR before the interrupt is enabled. | | (15) Set the startup factor of the serial<br>communication<br>Dummy data → TXBUF1(0x03F9F) | (15) Set the dummy data to the serial transmission data buffer TXBUF1. | | Setup Procedure | Description | | | | | |----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | (16) Transfer to STOP mode<br>CPUM(0x03F00)<br>bp3:STOP =1 | (16) Set the STOP flag of the CPUM register to "1" to transfer to the stop mode. | | | | | | (17) Start the serial communication Dummy data → TXBUF1(0x03F9F) Reception data → input SBI1 pin | (17) Input the transfer clock to the SBT1 pin and transfer data to the SBI1 pin. | | | | | | (18) Recover from the standby mode | (18) The serial 1 UART transmission interrupt SC1TIRQ is generated at the same time of the 8 <sup>th</sup> bits data reception. After the oscillation stabilization wait, CPU is recovered from the stop mode to the normal mode. | | | | | Note: Procedure (1),(2) (6) to (9), (10) to (12), (13) to (14) can be set at the same time. Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:12.2.1 except TXBUF1) are set. # 12.3.3 UART Serial Interface Serial 1 can be used for duplex UART communication. Table:12.3.15 shows UART serial interface functions. Table:12.3.15 URAT Serial Interface Functions | Communication style | UART (duplex)j | |----------------------------------|--------------------------------------------------------------------------| | Interrupt | SC1TIRQ (transmission), SC1RIRQ (reception) | | Used pins | TXD1 (output / input)<br>RXD1 (input) | | First transfer bit specification | MSB / LSB | | Parity bit selection | 0 | | Parity bit control | 0 parity<br>1 parity<br>odd parity<br>even parity | | Frame selection | 7 bits + 1 STOP<br>7 bits + 2 STOP<br>8 bits + 1 STOP<br>8 bits + 2 STOP | | Continuous operation | 0 | | Maximum transfer rate | 300 kbps<br>(standard 300 bps to 38.4 kbps)<br>(with baud rate timer) | #### Activation Factor for Communication At transmission, when data is set to the transmission data buffer TXBUF1, start condition is generated to start transfer. At reception, when a start condition is received, communication is started. At reception, if the data length of "L" for start bit is longer than 0.5 bit, that can be recognized as start condition. #### ■ Transmission Data transfer is automatically started by setting data to the transmission data buffer TXBUF1. When the transmission is completed, the serial 1 transmission interrupt SC1TIRQ is generated. #### ■ Reception Once the start condition is received, reception is started after the transfer bit counter that counts transfer bit is cleared. When the reception is completed, the serial 1 reception interrupt SC1RIRQ is generated. #### ■ Duplex communication On duplex communication, the transmission and reception can be operated separately at the same time. The frame mode and parity bit of the used data on transmission / reception should have the same polarity. #### Transfer Bit Count Setup The transfer bit count is automatically set after the frame mode is specified by the SC1FM1 to 0 flag of the SC1MD2 register. If the SC1CMD flag of the SC1MD1 register is set to "1", and UART communication is selected, the setup by the synchronous serial transfer bit count selection flag SC1LNG2 to 0 is no longer valid. #### ■ Data Input Pin Setup 2 channels type, data output pin (TXD1 pin), data input pin (RXD1 pin, or 1 channel type, data I/O pin (TXD1 pin) can be selected as a communication mode. The RXD1 pin can be used only for serial data input. The TXD1 pin can be used for serial data input or output. Whether the serial data is input from RXD1 or TXD1, it can be selected by the SC1IOM flag of the SC1MD1 register. When "data input from TXD1 pin" is selected to set the 1 channel communication, transmission / reception can be switched by the TXD0 pin direction control. For TXD0A pin, it can be done by the PADIR2 flag of the PADIR register. For TXD0B, by the P7DIR5 flag of the P7DIR register. At the same time, the RXD1 pin can be used as a general port. #### ■ Reception Buffer Empty Flag When SC1RIRQ is generated, data is stored automatically to RXBUF1 from the internal shift register. When data is stored to RXBUF1 from the shift register, the reception buffer empty flag SC1REMP of the SC1STR register is set to "1". That indicates that the received data is going to be read out. SC1REMP is cleared to "0" by reading out the data of RXBUF1. #### ■ Reception BUSY Flag When the start condition is recognized, the SC1RBSY flag of the SC1STR register is set to "1". When the reception complete interrupt SC1TIRQ is generated, the flag is cleared to "0". If the SC1SBIS flag is set to "0" during reception, the SC1RBSY flag is reset to "0". #### ■ Transmission BUSY Flag When data is set to TXBUF1, the SC1TBSY flag of the SC1STR register is set to "1". When the transmission complete interrupt SC1TIRQ is generated, the flag is cleared to "0". During continuous communication, the SC1TBSY flag is always set. If the transmission buffer empty flag SC1TEMP is set to "0" as the transmission complete interrupt SC1TIRQ is generated, the SC1TBSY is cleared to "0". If the SC1SBOS flag is set to "0", the SC1TBSY flag is reset to "0". # ■ Frame Mode and Parity Check Setup Figure 11-3-17 shows the data format at UART communication. Figure:12.3.17 UART Serial Interface Transmission / Reception Data Format The transmission / reception data consists of start bit, character bit, parity bit and stop bit. Table:12.3.16 shows its types to be set. Table:12.3.16 UART Serial Interface Transmission / Reception Data | Start bit | 1 bit | |---------------|-----------------------------------------| | Character bit | 7,8 bit | | Parity bit | fixed to 0, fixed to 1, odd, even, none | | Stop bit | 1,2 bits | The SC1FM1 to 0 flag of the SC1MD2 register sets the frame mode. Table:12.3.17 shows the UART serial interface frame mode settings. If the SC1CMD flag of the SC1MD1 register is set to "1", and UART communication is selected, the transfer bit count on the SC1LNG2 to 0 flag of the SC1MD0 register is no longer valid. Table:12.3.17 UART Serial Interface Frame Mode | SC1MD2 register | | Frame mode | |-----------------|---|----------------------------------------| | SC1FM1 SC1FM0 | | | | 0 | 0 | Character bit 7 bits + Stop bit 1 bit | | 0 | 1 | Character bit 7 bits + Stop bit 2 bits | | 1 | 0 | Character bit 8 bits + Stop bit 1 bit | | 1 | 1 | Character bit 8 bits + Stop bit 2 bits | Parity bit is to detect wrong bits with transmission / reception data. Table:12.3.18 shows types of parity bit. The SC1NPE, SC1PM1 to 0 flag of the SC1MD2 register set parity bit. Table:12.3.18 Parity Bit of UART Serial Interface | SC1MD2 | | Parity bit | Setup | | | | |--------|--------|------------|-------------|------------------------------------------------------------------------------|--|--| | SC1NPE | SC1PM1 | SC1PM0 | | | | | | 0 | 0 | 0 | Fixed to 0 | Set parity bit to "0" | | | | 0 | 0 | 1 | Fixed to 1 | Set parity bit to "1" | | | | 0 | 1 | 0 | Odd parity | Control that the total of "1" of parity bit and character bit should be odd | | | | 0 | 1 | 1 | Even parity | Control that the total of "1" of parity bit and character bit should be even | | | | 1 | - | - | None | Do not add parity bit | | | # ■ Break Status Transmission Control Setup The SC1BRKE flag of the SC1MD2 register generates the brake status. If SC1BRKE is set to "1" to select the brake transmission, all bits from start bits to stop bits transfer "0". #### ■ Reception Error At reception, there are 3 types of error; overrun error, parity error and framing error. Reception error can be determined by the SC1ORE, SC1PEK, SC1FEF flag of the SC1STR register. Even one of those errors is detected, the SC1ERE flag of the SC1STR register is set to "1". Among reception error flags, the SC1PEK and the SC1FEF flags are renewed when the reception complete interrupt SC1RIRQ is generated. The SC1ORE flag is cleared at the same time of next communication complete interrupt SC1RIRQ generation after the data of the RXBUF1 is read out. The decision of the received error flag should be operated before the next communication is finished. Those error flag has no effect on communication operation. Table:12.3.19 shows the list of reception error source. Table:12.3.19 Reception Error Source of UART Serial Interface | Flag | Error | | | | | | | |--------|---------------|--------------------------------------|----------------------------------------------------------|--|--|--|--| | SC1ORE | Overrun error | Next data is receive | ed before reading the receive buffer | | | | | | SC1PEK | Parity error | at fixed to 0 when parity bit is "1" | | | | | | | | | at fixed to 1 | When parity bit is "0" | | | | | | | | Odd parity | The total of "1" of parity bit and character bit is even | | | | | | | | Even parity | The total of "1" of parity bit and character bit is odd | | | | | | SC1FEF | Framing error | Stop bit is not detected | | | | | | #### Judgement of Break Status Reception Reception at break status can be judge. If all received data from start bit and stop bit is "0", the SC1BRKF flag of the SC1MD2 register is set and determines the break status. The SC1BRKF flag is set when the reception complete interrupt SC1RIRQ is generated. #### Continuous Communication This serial interface has continuous communication function. When data is set to the transmission data buffer TXBUF1 during communication, the transmission buffer empty flag SC1TEMP is automatically set to communicate continuously. This does not generate any blank in communication. Set data to TXBUF between previous data setup and generation of the communication complete interrupt SC1TIRQ. #### Clock Setup Transfer clock is not necessary for UART communication itself, but necessary for setup of data transmission / reception timing in the serial interface. Select the timer to be used as a baud rate timer by the SC1MD3 register. ### ■ Reception Bit Count and First Transfer Bit At reception, when the transfer bit count is 7 bits, the data storing method to the received data buffer RXBUF1 is different depending on the first transfer bit selection. At MSB first, data is stored to the upper bits of RXBUF1. When the transfer bit count is 7 bits, as shown on Figure:12.3.18, data "G" to "A" are stored to bp7 to bp1 of RXBUF1 in this order. At LSB first, data is stored to the lower bits of RXBUF1. When the transfer bit count is 7 bits, as shown on Figure:12.3.19, data "A" to "G" are stored to bp0 to bp6 of RXBUF1 in this order. Figure:12.3.18 Reception Bit Count and First Transfer Bit (starting with MSB) Figure:12.3.19 Reception Bit Count and First Transfer Bit (starting with LSB) The following items are the same as clock synchronous serial. ■ First Transfer Bit Setup Refer to:XII-14 ■ Transmission Data Buffer Refer to:XII-15 ■ Reception Data Buffer Refer to:XII15 ■ Transmission Bit Count and First Transfer Bit Refer to:XII-16 ■ Transmission Buffer Empty Flag Refer to:XII-19 ■ Emergency Reset Refer to:XII-20 # ■ Transmission Timing Figure:12.3.20 Transmission Timing (parity bit is enabled) Figure:12.3.21 Transmission Timing (parity bit is disabled) # ■ Reception Timing Figure:12.3.22 Reception Timing (parity bit is enabled) Figure:12.3.23 Reception Timing (parity bit is disabled) ### ■ Transfer Speed Setup Baud rate timer (timer 1, timer 2) can set any transfer rate. Table:12.3.20 shows the setup example of the transfer speed. Table:12.3.20 UART Serial Interface Transfer Speed | Setup | Register | Page | |-------------------------------------------|----------|--------| | Serial 1 clock source (timer 1 , timer 2) | SC1MD3 | XII-10 | | Clock source dividing | SC1MD1 | XII- 8 | | Timer 1 clock source | TM1MD | V- 15 | | Timer 1 compare register | TM1OC | V- 12 | | Timer 2 clock source | TM2MD | V- 16 | | Timer 2 compare register | TM20C | V- 12 | Timer compare register is set as follows; baud rate = 1 / (overflow cycle $\times$ 2 $\times$ internal clock dividing) overflow cycle = (set value of compare register + 1) $\times$ timer clock cycle therefore, set value of compare register = timer clock frequency / (baud rate $\times$ 2 $\times$ internal clock dividing) - 1 For example, if baud rate should be 300 bps at timer clock source fs/4 (fosc = 8 MHz, fs = fosc/2) when the internal clock dividing is set to 8, set value should be as follows: Set value of compare register = (8 $\times$ 10<sup>6</sup> / 2 / 4) / (300 $\times$ 2 $\times$ 8) - 1 = 207 = 0xCF Timer clock source and the set value of timer compare register at the standard rate are shown in the following page. Transfer rate should not exceed 300 kbps. Table:12.3.21 Setup Value of Serial Interface Transfer Speed 1 : When Setting UART Inter Clock to "Divided by 8" (decimal) | | | Transfer speed (bit/s) | | | | | | | | | | |---------------|-------------------------|------------------------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------| | , | Clock source<br>(Timer) | 300 | | 960 | | 1200 | 1200 | | | 4800 | | | fosc<br>(MHz) | | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | | 2.00 | fosc | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fosc/4 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fosc/16 | 25 | 300 | - | - | - | - | - | - | - | - | | | fosc/32 | 12 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | Ì | fs/2 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fs/4 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | 4.00 | fosc | - | - | - | - | 207 | 1202 | 103 | 2404 | 51 | 4808 | | Ì | fosc/4 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fosc/16 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/32 | 25 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | 12 | 300 | - | - | - | - | - | - | - | - | | | fs/2 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fs/4 | 104 | 297 | - | - | 25 | 1202 | 12 | 2404 | - | - | | 4.19 | fosc | - | - | - | - | 217 | 1201 | 108 | 2403 | 54 | 4761 | | | fosc/4 | 217 | 300 | 67 | 963 | - | - | - | - | - | - | | | fosc/16 | - | - | 16 | 963 | - | - | 6 | 2338 | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 217 | 300 | 67 | 963 | - | - | - | - | - | - | | | fs/4 | 108 | 300 | 33 | 963 | - | - | 13 | 2338 | - | - | | 8.00 | fosc | - | - | - | - | - | - | 207 | 2404 | 103 | 4808 | | | fosc/4 | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fosc/16 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fosc/32 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/64 | 25 | 300 | - | - | - | - | - | - | - | - | | | fs/2 | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fs/4 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | 8.38 | fosc | - | - | - | - | - | - | 217 | 2403 | 108 | 4805 | | | fosc/4 | - | - | 135 | 963 | 108 | 1201 | - | - | - | - | | | fosc/16 | 108 | 300 | 33 | 963 | - | - | 13 | 2338 | - | - | | | fosc/32 | - | - | 16 | 963 | - | - | 6 | 2338 | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | 135 | 963 | 108 | 1201 | - | - | - | - | | | fs/4 | 217 | 300 | 67 | 963 | - | - | - | - | - | - | | 10.00 | fosc | - | - | - | - | - | - | - | - | 129 | 4808 | | | fosc/4 | - | - | 162 | 959 | 129 | 1202 | 64 | 2404 | - | - | | | fosc/16 | 129 | 300 | - | - | - | - | - | - | - | - | | | fosc/32 | 64 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | 162 | 959 | 129 | 1202 | 64 | 2404 | - | - | | | fs/4 | - | - | - | - | 64 | 1202 | - | - | - | - | Table:12.3.22 Setup Value of Serial Interface Transfer Speed 2 : When Setting UART Inter Clock to "Divided by 8" (decimal) | | | Transfer s | Transfer speed (bit/s) | | | | | | | | | |---------------|-------------------------|------------|------------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------| | , | Clock source<br>(Timer) | 300 | | 960 1 | | 1200 | 1200 | | | 4800 | | | fosc<br>(MHz) | | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | | 2.00 | fosc | 12 | 9615 | - | - | - | - | 3 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.00 | fosc | 25 | 9615 | 12 | 19231 | - | - | 7 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.19 | fosc | 26 | 9699 | - | - | - | - | - | - | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | _ | - | - | - | _ | _ | _ | _ | | | fs/2 | - | - | _ | _ | - | - | _ | _ | _ | _ | | | fs/4 | - | - | - | - | - | - | - | _ | _ | _ | | 8.00 | fosc | 51 | 9615 | 25 | 19231 | - | - | 15 | 31250 | 12 | 38462 | | 0.00 | fosc/4 | 12 | 9615 | - | - | - | - | 3 | 31250 | - | - | | | fosc/16 | 1- | - | _ | _ | _ | _ | - | - | _ | _ | | | fosc/32 | - | - | _ | _ | _ | _ | _ | - | _ | _ | | | fosc/64 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | fs/2 | 12 | 9615 | | | | | 3 | 31250 | | | | | fs/4 | 12 | - | | _ | | _ | 1 | 31250 | _ | _ | | 8.38 | fosc | 54 | 9523 | 26 | 19398 | - | - | ! | 31230 | - | - | | 0.30 | fosc/4 | 54 | 9023 | 20 | 19390 | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | 40.00 | fs/4 | - | - | - | - | - | - | - | - | - | - | | 10.00 | fosc | 64 | 9615 | - | - | - | - | - | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | 31250 | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | 31250 | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | Table:12.3.23 Setup Value of Serial Interface Transfer Speed 1 : When Setting UART Inter Clock to "Divided by 16" (decimal) | | | Transfer speed (bit/s) | | | | | | | | | | |---------------|-------------------------|------------------------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------| | , | 01 1 | 300 | | 960 | | 1200 | | 2400 | | 4800 | | | fosc<br>(MHz) | Clock source<br>(Timer) | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | | 2.00 | fosc | - | - | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fosc/4 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/16 | 12 | 300 | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fs/4 | 25 | 300 | - | - | - | - | - | - | - | - | | 4.00 | fosc | - | - | 129 | 962 | 103 | 1202 | 51 | 2404 | 25 | 4808 | | | fosc/4 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fosc/16 | 25 | 300 | - | - | - | - | - | - | - | - | | | fosc/32 | 12 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | | fs/4 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | 4.19 | fosc | - | - | 135 | 963 | 108 | 1201 | 54 | 2381 | - | - | | | fosc/4 | 108 | 300 | 33 | 963 | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 108 | 300 | 33 | 963 | - | - | - | - | - | - | | | fs/4 | 54 | 298 | 16 | 963 | - | - | - | - | - | - | | 8.00 | fosc | - | - | - | - | 207 | 1202 | 103 | 2404 | 51 | 4808 | | | fosc/4 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fosc/16 | 51 | 300 | - | - | 12 | 1202 | - | - | - | - | | | fosc/32 | 25 | 300 | - | - | - | - | - | - | - | - | | | fosc/64 | 12 | 300 | - | - | - | - | - | - | - | - | | | fs/2 | 207 | 300 | 64 | 962 | 51 | 1202 | 25 | 2404 | 12 | 4808 | | | fs/4 | 103 | 300 | - | - | 25 | 1202 | 12 | 2404 | - | - | | 8.38 | fosc | - | - | - | - | 217 | 1201 | 108 | 2403 | 54 | 4761 | | | fosc/4 | 217 | 300 | 67 | 963 | 54 | 1190 | - | - | - | - | | | fosc/16 | 54 | 298 | 16 | 963 | - | - | _ | _ | - | - | | | fosc/32 | - | - | - | - | _ | _ | _ | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | 217 | 300 | 67 | 963 | 54 | 1190 | _ | _ | - | - | | | fs/4 | 108 | 300 | 33 | 963 | - | - | _ | _ | - | - | | 10.00 | fosc | - | - | - | - | - | _ | 129 | 2404 | 64 | 4808 | | . 5.00 | fosc/4 | + | _ | 80 | 965 | 64 | 1202 | - | - 10 / | - | - | | | fosc/16 | 64 | 300 | - | - | - | - | _ | _ | - | - | | | fosc/32 | - | - | - | _ | _ | _ | _ | _ | - | - | | | fosc/64 | -<br> - | - | - | | - | | | _ | -<br> - | - | | | fs/2 | - | - | 80 | 965 | 64 | 1202 | | | 1_ | [ | | | fs/4 | 129 | 300 | - | - | _ | 1202 | | | - | _ | | | 15/4 | 123 | 300 | | | | | <u> </u> | <u> </u> | <u> </u> | <u> </u> | Table:12.3.24 Setup Value of Serial Interface Transfer Speed 2 : When Setting UART Inter Clock to "Divided by 16" (decimal) | | | Transfer speed (bit/s) | | | | | | | | | | |---------------|-------------------------|------------------------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------|-----------|-------------------| | 4 | 01 1 | 300 | | 960 | | 1200 | | 2400 | | 4800 | | | fosc<br>(MHz) | Clock source<br>(Timer) | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | Set value | Calculate d value | | 2.00 | fosc | - | - | - | - | - | - | 1 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.00 | fosc | 12 | 9615 | - | - | - | - | 3 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 4.19 | fosc | - | - | - | - | - | - | - | - | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 8.00 | fosc | 25 | 9615 | 12 | 19231 | - | - | 7 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | 1 | 31250 | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 8.38 | fosc | - | - | - | - | - | - | - | - | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | - | - | - | - | - | - | - | - | | 10.00 | fosc | - | - | - | - | - | - | 9 | 31250 | - | - | | | fosc/4 | - | - | - | - | - | - | - | - | - | - | | | fosc/16 | - | - | - | - | - | - | - | - | - | - | | | fosc/32 | - | - | - | - | - | - | - | - | - | - | | | fosc/64 | - | - | - | - | - | - | - | - | - | - | | | fs/2 | - | - | - | - | - | - | - | - | - | - | | | fs/4 | - | - | _ | - | - | - | - | <u> </u> | <u> </u> | - | # ■ Pin Setup (with 1,2 channels, at transmission) Table:12.3.25 shows the pins setup at UART serial interface transmission. The pins setup is common to the TXD1 pin, RXD1 pin, regardless of whether the pins are independent / connected. Table:12.3.25 UART Serial Interface Pin Setup (with 1,2 channels, at transmission) | Setup item | Data output pin | Data input pin | | | | |-----------------------------|-------------------------------|-----------------|--|--|--| | | TXD1 pin | RXD1 pin | | | | | Port pin | P15/PA5 | P16/PA4 | | | | | Port pin setup | Select used pin (A, B) | | | | | | | SCSEL (SC1SL) | | | | | | Serial data input selection | RXD1 | | | | | | | SC1MD1(SC1IOM) | | | | | | Function | Serial data output | "1" output | | | | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | | | | | Style | Push-pull/ Nch open-drain | - | | | | | | P1ODC(P1ODC5)/PAODC(PAODC5) | | | | | | I/O | Output mode | - | | | | | | P1DIR(P1DIR5)/PADIR(PADIR5) | | | | | | Pull-up setup | Added / not added | - | | | | | | P1PLUD(P1PLUD5)/PAPLU(PAPLU5) | | | | | # ■ Pin Setup (with 2 channels, at reception) Table:12.3.26 shows the pins setup at UART serial interface reception with 2 channels (TXD1 pin, RXD1pin). Table:12.3.26 UART Serial Interface Pin Setup (with 2 channels, at reception) | Setup item | Data output pin | Data input pin | | | | |-----------------------------|------------------------|---------------------------------|--|--|--| | | TXD1 pin | RXD1 pin | | | | | Port pin | P15/PA5 | P16/PA4 | | | | | Port pin setup | Select used pin (A, B) | | | | | | | SCSEL (SC1SL) | | | | | | Serial data input selection | RXD1 | | | | | | | SC1MD1(SC1IOM) | | | | | | Function | Port | Serial data input | | | | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | | | | | Style | - | - | | | | | I/O | - | Input mode | | | | | | - | P1DIR(P1DIR6)/<br>PADIR(PADIR7) | | | | | Pull-up setup | - | - | | | | # ■ Pin Setup (with 1 channel, at reception) Table:12.3.27 shows the pin setup at UART serial interface reception with 1 channel (TXD1 pin). The RXD1 pin in not used, so can be used as a port. Table:12.3.27 UART Serial Interface Pin Setup (with 1 channel, at reception) | Setup item | Data output pin | Data input pin | | | | |-----------------------------|-----------------------------|-------------------|--|--|--| | | TXD1 pin | RXD1 pin | | | | | Port pin | P15/PA5 | P16/PA4 | | | | | Port pin setup | Select used pin (A, B) | | | | | | | SCSEL (SC1SL) | | | | | | Serial data input selection | TXD1 | | | | | | | SC1MD1(SC1IOM) | | | | | | Function | Port | Serial data input | | | | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | | | | | Style | - | - | | | | | I/O | Input mode | - | | | | | | P1DIR(P1DIR5)/PADIR(PADIR5) | - | | | | | Pull-up setup | - | - | | | | # ■ Pin Setup (with 2 channels, at transmission / reception) Table:12.3.28 shows the pin setup at UART serial interface transmission / reception with 2 channels (TXD1 pin, RXD1 pin). Table:12.3.28 UART Serial Interface Pin Setup (with 2 channels, at transmission / reception) | Setup item | Data output pin | Data input pin | | | | |-----------------------------|-------------------------------|---------------------------------|--|--|--| | | TXD1 pin | RXD1 pin | | | | | Port pin | P15/PA5 | P16/PA4 | | | | | Port pin setup | Select used pin (A, B) | | | | | | | SCSEL (SC1SL) | | | | | | Serial data input selection | RXD1 | | | | | | | SC1MD1(SC1IOM) | | | | | | Function | Serial data output | Serial data input | | | | | | SC1MD1(SC1SBOS) | SC1MD1(SC1SBIS) | | | | | Style | Push-pull/ Nch open-drain | - | | | | | | P1ODC(P1ODC5)/PAODC(PAODC5) | | | | | | I/O | Output mode | Input mode | | | | | | P1DIR(P1DIR5)/PADIR(PADIR5) | P1DIR(P1DIR6)/<br>PADIR(PADIR7) | | | | | Pull-up setup | Added / not added | - | | | | | | P1PLUD(P1PLUD5)/PAPLU(PAPLU5) | | | | | # 12.3.4 Setup Example # ■ Transmission / Reception Setup The setup example at UART transmission / reception with serial 1 is shown. Table: 12.3.29 shows the condition at transmission / reception. Table:12.3.29 UART Interface Transmission Reception Setup | Setup item | SEt to | |------------------------------------------|-------------------------------| | TXD1/RXD1 pin | Independent (with 2 channels) | | Frame mode specification | 8 bits + 2 stop bits | | First transfer bit | MSB | | Clock source | Timer 1 | | Clock source dividing | Divided by 8 | | Used pin | A (port 1) | | TXD1/RXD1 pin type | Nch open-drain | | Pull-up resistor of TXD1 pin | Added | | Parity bit add/check | "0" added/check | | Serial 1 transmission complete interrupt | Enable | | Serial 1 reception complete interrupt | Enable | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the baud rate timer | (1) Set the baud rate timer by the TM1MD register, the TM1OC register. Set the TM1EN flag to "1" to start timer 1. [Chapter 5 5.8 Serial Transfer Clock Output Operation] | | (2) Select the clock source<br>SC1MD3(0x03F9C)<br>bp2-0 :SC1PSC2-0 =110 | (2) Set the bp2 to 0 flag of the SC1MD3 register to "110" to select Timer 1 output as a clock source. | | (3) Select the used pin<br>SCSEL(0x03F90)<br>bp1 :SC1SL =0 | (3) Set the SC1SL flag of the SCSEL register to "0" to select A (port 1) as I/O pin. | | (4) Control the pin style P1ODC(0x03F1B) bp5:P1ODC5=1 P1PLUD(0x03F41) bp5:P1PLU5=1 | (4) Set the P1ODC5 flag of the P1ODC register to "1" to select Nch open-drain to TXD1 pin. Set the P1PLUD5 flag of the P1PLUD register to "1" to enable the pull-up resistor. | | Setup Procedure | Description | |--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (5) Control the pin direction P1DIR(0x03F31) bp5 :P1DIR5 =1 bp6 :P1DIR6 =0 | (5) Set the P1DIR5 flag of the Port 1 pin direction control register (P1DIR) to "1" and the P1DIR6 flag to "0" to set P15 to the output mode, P16 to the input mode. | | (6) Set the SC1MD0 register Select the start condition SC1MD0(0x03F99) bp3 :SC1STE =1 | (6) Set the SC1STE flag of the SC1MD0 register to "1" to enable start condition. | | Select the first bit to be transferred SC1MD0(0x03F99) bp4 :SC1DIR =0 | Set the SC1DIR flag of the SC1MD0 register to "0" to select MSB as first transfer bit. | | (7) Set the SC1MD2 register Control the output data SC1MD2(0x03F9B) bp0 :SC1BRKE =0 | (7) Set the SC1BRKE flag of the SC1MD2 register to "0" to select the serial data transmission. | | Select the added parity bit<br>SC1MD2(0x03F9B)<br>bp3 :SC1NPE =0<br>bp5-4 :SC1PM1-0 =00 | Set the SC1PM1 to 0 flag of the SC1MD2 register to "00" to select 0 parity, and set the SC1NPE flag to "0" to enable add parity bit. | | Specify the flame mode<br>SC1MD2(0x03F9B)<br>bp7-6 :SC1FM1-0 =11 | Set the SC1FM1 to 0 flag of the SC1MD2 register to "11" to select 8 bits + 2 stop bits at the flame mode. | | (8) Set the SC1MD1 register Select the communication type SC1MD1(0x03F9A) bp0 :SC1CMD =1 | (8) Set the SC1CMD flag of the SC1MD1 register to "1" to select duplex UART. | | Select the clock frequency<br>SC1MD1(0x03F9A)<br>bp3:SC1CKM =1<br>bp2:SC1MST =1<br>bp1:SC1DIV =0 | Set the SC1CKM flag of the SC1MD1 register to "1" to select "divided" at source clock. Set the SC1DIV flag to "0" to select "divided by 8" as source clock. The SC1MST flag should always be set to "1" to select clock master. | | Control the pin function SC1MD1(0x03F9A) bp4 :SC1SBOS =1 bp5 :SC1SBIS =1 bp7 :SC1IOM =0 | Set the SC1SBOS, SC1SBIS flag of the SC1MD1 register to "1" to set the RXD1 pin to serial data output and the RXD1 pin to serial data input. | | (9) Enable the interrupt SC1RICR(0x03FF1) bp1 :SC1RIE =1 SC1TICR(0x03FF2) bp1 :SC1TIE =1 | (9) Set the SC1RIE flag of the SC1RICR register to "1", and SC1TIE flag of the SC1TICR register to "1" to enable the interrupt request. If the interrupt request is already set, clear it. | | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (10) Start the serial transmission<br>The transmission → TXBUF1(0x03F9F)<br>The reception data → input to RXD1 | (10) When the transmission data is set to the serial transmission data buffer (TXBUF1), the transmission is started. When the transmission is finished, the serial 1 transmission interrupt (SC1TIRQ) is generated. Also, after the received data is stored to the RXBUF1, the serial 1 reception interrupt (SC1RIRQ) is generated. | Note:(6), (7), (8) can be set at the same time. When the TXD1 / RXD1 pin are connected for communication with 1 channel, serial data is input/output from the TXD1 pin. Input/output can be switched by the port direction control register P1DIR. At reception, set SC1SBIOS of the SC1MD1 register to "1" to select serial data input. The RXD1 pin can be used as a general port. This serial interface contains emergency reset function. If communication need to be stopped by force, set SC1SBOS and SC1SBIS of the SC1MD1 register to "0". Each flag should be set as the setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:12.2.1 TXBUF1, RXBUF1) are set. Timer 1 and timer 2 can be used as a baud rate timer. Refer to Chapter 5 5.8 Serial Transfer Clock Output Operation. Chapter 12 Serial interface 1 # 13.1 Overview This LSI contains a serial interface 3 that is capable of both clock synchronous / IIC (single master) serial communication. ## 13.1.1 Functions Table:13.1.1 shows the serial interface 3 functions. Table:13.1.1 Serial Interface 3 Functions | Communication style | Clock synchronous | IIC (single master) | | |-----------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------|--| | Interrupt | SC3IRQ | SC3IRQ | | | Pins | SBO3,SBI3,SBT3 | SDA3,SCL3 | | | 3 channels type | O | - | | | 2 channels type | O (SBO3,SBT3) | 0 | | | Transfer bit count | 1 to 8 bit | 1 to 8 bit | | | Start condition | O | 0 | | | First transfer bit | O | 0 | | | Input edge / Output edge | О | - | | | SBO3 output control after final data is transferred | H/L/ last data hold | - | | | Function in STANDBY mode | Slave reception only | - | | | ACK bit | - | 0 | | | ACK bit level | - | 0 | | | Clock sources | fosc/2 fosc/4 fosc/8 fosc/32 fs/2 fs/4 external clock timer 2 output timer 3 output | fosc/2 fosc/4 fosc/8 fosc/32 fs/2 fs/4 timer 2 output timer 3 output | | | Maximum transfer rate | 5.0 MHz | NORMAL mode: 100 kHz<br>High speed mode: 400 kHz | | fosc: machine clock (for high speed oscillation) fs: system clock In IIC communication, transfer clock is obtained by dividing the clock source by 8. ## 13.1.2 Block Diagram #### ■ Serial Interface 3 Block Diagram Figure:13.1.1 Serial Interface 3 Block Diagram # 13.2 Control Registers ## 13.2.1 Registers List Table:13.2.1 shows the registers that control serial interface 3. Table:13.2.1 Serial Interface 3 Control Registers List | Register | Address | R/W | Function | Page | |----------|---------|-----|----------------------------------------------------------|---------| | SC3MD0 | 0x03FA0 | R/W | Serial interface 3 mode register 0 | XIII-6 | | SC3MD1 | 0x03FA1 | R/W | Serial interface 3 mode register 1 | XIII-7 | | SC3MD3 | 0x03FA2 | R/W | Serial interface 3 mode register 3 | XIII-8 | | SC3STR | 0x03FA3 | R | Serial interface 3 status register | XIII-9 | | SC3TRB | 0x03FA4 | R | Serial interface 3 transmission/reception shift register | XIII-5 | | TXBUF3 | 0x03FA5 | R/W | Serial interface 3 transmission data buffer | XIII-5 | | SC3CTR | 0x03FA6 | R/W | Serial interface 3 control register | XIII-10 | | P3ODC | 0x03F3B | R/W | Port 3 N-ch open drain control register | IV-30 | | P3DIR | 0x03F33 | R/W | Port 3 direction control register | IV-27 | | P3PLU | 0x03F43 | R/W | Port 3 pull-up control register | IV-28 | | SC3ICR | 0x03FF3 | R/W | Serial interface 3 interrupt control register | III-36 | R /W : Readable / Writable R : Readable ## 13.2.2 Data Buffer Register Serial interface 3 has a 8-bit serial data buffer register for transmission. ■ Serial Interface 3 Transmission Data Buffer (TXBUF3: 0x03FA5) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | TXBUF37 | TXBUF36 | TXBUF35 | TXBUF34 | TXBUF33 | TXBUF32 | TXBUF31 | TXBUF30 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ## 13.2.3 Data Register Serial interface 3 has a 8-bit serial data register. ■ Serial Interface 3 Transmission / Reception Shift Register (SC3TRB: 0x03FA4) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | SC3TRB7 | SC3TRB6 | SC3TRB5 | SC3TRB4 | SC3TRB3 | SC3TRB2 | SC3TRB1 | SC3TRB0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R/W ## 13.2.4 Serial interface 3 Mode Register ## ■ Serial Interface 3 Mode Register 0 (SC3MD0: 0x03FA0) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|---|--------|--------|---------|---------|---------| | Flag | SC3BSY | SC3CE1 | - | SC3DIR | SC3STE | SC3LNG2 | SC3LNG1 | SC3LNG0 | | At reset | 0 | 0 | - | 0 | 0 | 1 | 1 | 1 | | Access | R | R/W | - | R/W | R/W | R/W | R/W | R/W | | bp | Flag | Description | | | | | | |-----|-------------------------------|------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7 | SC3BSY | Serial bus status in clock synchronous communication 0: Other use 1: Serial transnission is in progress | | | | | | | 6 | SC3CE1 | Transmission data output edge Reception data input edge 0: Falling Rising 1: Rising Falling | | | | | | | 5 | - | - | | | | | | | 4 | SC3DIR | First bit to be transferred 0: MSB first 1: LSB first | | | | | | | 3 | SC3STE | Start condition 0: Disable start condition 1: Enable start condition | | | | | | | 2-0 | SC3LNG2<br>SC3LNG1<br>SC3LNG0 | Transfer bit count 000: 1 bit 001: 2 bit 010: 3 bit 011: 4 bit 100: 5 bit 101: 6 bit 110: 7 bit 111: 8 bit | | | | | | ## ■ Serial interface 3 Mode Register 1 (SC3MD1: 0x03FA1) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|---------|---------|---------|---|--------|---|---| | Flag | SC3IOM | SC3SBTS | SC3SBIS | SC3SBOS | - | SC3MST | - | - | | At reset | 0 | 0 | 0 | 0 | - | 0 | - | - | | Access | R/W | R/W | R/W | R/W | - | R/W | - | - | | bp | Flag | Description | |-----|---------|------------------------------------------------------------------------------------| | 7 | SC3IOM | Serial data input selection 0: Data input from SBI3 1: Data input from SBO3 (SDA3) | | 6 | SC3SBTS | SBT3 pin function 0: Port 1: Transfer clock input / output | | 5 | SC3SBIS | Serial input control 0: "1" input 1: Serial data input | | 4 | SC3SBOS | SBO3(SDA3) pin function 0: Port 1: Serial data output | | 3 | - | - | | 2 | SC3MST | Clock master / slave selection 0: Slave 1: Master | | 1-0 | - | - | ## ■ Serial interface 3 Mode Register 3 (SC3MD3: 0x03FA2) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---|---|---------|---------|---------|---------| | Flag | SC3FDC1 | SC3FDC0 | - | - | SC3PSCE | SC3PSC2 | SC3PSC1 | SC3PSC0 | | At reset | 0 | 0 | - | - | 0 | 0 | 0 | 0 | | Access | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | bp | Flag | Description | |-----|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | SC3FDC1<br>SC3FDC0 | SBO3 output selection after transfer of last data 00: Fixed to "1"(High) output 01: Hold last data 10: Fixed to "0"(Low) output 11: Reserved | | 5-4 | - | - | | 3 | SC3PSCE | Prescaler count control 0: Disable the count 1: Enable the count | | 2-0 | SC3PSC2<br>SC3PSC1<br>SC3PSC0 | Clock selection 000: fosc/2 001: fosc/4 010: fosc/8 011: fosc/32 100: fs/2 101: fs/4 110: timer 2 output 111: timer 3 output | ## ■ Serial interface 3 Status Register (SC3STR: 0x03FA3) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---------|---|---|---|---|---| | Flag | - | - | SC3TEMP | - | - | - | - | - | | At reset | - | - | 0 | - | - | - | - | - | | Access | - | - | R | - | - | - | - | - | | bp | Flag | Description | |-----|---------|---------------------------------------------| | 7-6 | - | - | | 5 | SC3TEMP | Transfer buffer empty flag 0: Empty 1: Full | | 4-0 | - | - | ## ■ Serial interface 3 Control Register (SC3CTR: 0x03FA6) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|----------|---------|---------|--------|----------|----------| | Flag | IIC3BSY | IIC3STC | IIC3STPC | IIC3TMD | IIC3REX | SC3CMD | IIC3ACKS | IIC3ACK0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R/W | bp | Flag | Description | |----|----------|-------------------------------------------------------------------------------------------| | 7 | IIC3BSY | Serial bus status in IIC communication 0: Other use 1: Serial transnission is in progress | | 6 | IIC3STC | Start condition 0: Disable start condition 1: Enable start condition *1 | | 5 | IIC3STPC | Stop condition detection flag in IIC communication *2 0: undetected 1: detected | | 4 | IIC3TMD | Communication mode 0: NORMAL mode 1: High-speed mode | | 3 | IIC3REX | Transmission / reception mode selection 0: Transmission 1: Reception | | 2 | SC3CMD | Synchronous / IIC selection 0: Synchronous 1: IIC | | 1 | IIC3ACKS | ACK bit enable 0: Disable 1: Enable | | 0 | IIC3ACK0 | ACK bit level selection *3 0: L level 1: H level | \*1:"1"is not writable. \*2:"0"is not writable. Also, this is not writable at the forced reset (when the SC3SBOS flag and SC3SBIS flag of SC3MD1register are "0"). \*3:The written value is readable only after IIC communication is generated. # 13.3 Operation Serial interface 3 is used as both clock synchronous /single master IIC serial interface. ## 13.3.1 Clock Synchronous Serial Interface #### Activation Factor for Communication Table:13.3.1 shows the activation source for communication. At master, a transfer clock is generated by setting data to the transfer data buffer TXBUF3, or by enabling start condition. Signals input from SBT3 pin inside serial interface are masked to prevent operating errors by noise, except during communication. This mask is automatically released by setting data to TXBUF3 (access to the TXBUF3 register), or enabling start condition to the data input pin. Therefore, at slave communication, set data to TXBUF3 or input start condition before input external clock. However, the external clock should be input after more than 3.5 transfer clock interval after the data set to TXBUF3. This wait time is needed to load the data from TXBUF3 to the internal shift register. Table:13.3.1 Synchronous Serial Interface Activation Factor and Cautions | Clock | Communication type | Start condition | Activation source of communication | | | |--------|--------------------|-----------------|---------------------------------------------------------------------------------------------|--|--| | Master | Transmission | Enabled | Set transmission data (*1) | | | | | | Disabled | Set transmission data(*2) | | | | | Reception | Enabled | Input start condition(*3) or Set dummy data(*2) | | | | | | Disabled | Set dummy data (*2) | | | | | Transmission/ | Enabled | -(*4) | | | | | Reception | Disabled | Set transmission data(*2) | | | | Slave | Transmission | Enabled | Input clock after transmission data is set (*5) | | | | | | Disabled | Input clock after transmission data is set (*6) | | | | | Reception | Enabled | Input clock after start condition is input (*7) or Input clock after dummy data is set (*6) | | | | | | Disabled | Input clock after dummy data is set (*6) | | | | | Transmission/ | Enabled | -(*4) | | | | | Reception | Disabled | Input clock after transmission data is set (*6) | | | - (\*1) After the start condition output, output the transfer clock 1 transfer clock later. - (\*2) After setting transmission data/dummy data, the transfer clock should be output after 3.5 transfer clock at the maximum. The system configuration is needed so that the transmission data/dummy data are written after the master receives the information of slave data load completion. - (\*3) After the start condition input, output the transfer clock after 2.5 transfer clock at the maximum. When receiving data continuously, the system configuration is needed to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. - (\*4) When the start condition is set to "enable", transmission and reception should not be excuted at the same time. - (\*5) After setting the transmission data, output the start condition and wait until the master excutes the clock input. At the clock input, 1 or more transfer clock should be needed after the start condition output. - (\*6) At the clock input, 3.5 or more transfer clock should be needed after setting transmission data/dummy data. The system configuration is needed to notify the master of the data load completion. - (\*7) At the clock input, 0.5 or more transfer clock should be needed after the start condition input. When receiving data continuously, the system configuration is needed to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. #### ■ Transfer Bit Count Setup The transfer bit count can be selected from 1 bit to 8 bits. Set the SC3LNG 2 to 0 flag of the SC3MD0 register (at reset: 111). The SC3LNG 2 to 0 flag holds the previous value until other value is set. The SBT3 pin is masked inside serial interface to prevent operating errors by noise, except during communication. At slave, set data to SC3TRB or input start condition before input clock to the TXBUF3 pin. Wait more than 3.5 transfer clocks before input the external clock after the data set to TXBUF3. Otherwise, normal operation is not guaranteed. #### Start Condition Setup Enable or disable of start condition can be selected with the SC3STE flag of the SC3MD0 register. Start condition is detected when the SC3CE1 flag of the SC3MD0 register is set to "0" and data line SBI3 pin (3 channels) or SBO3 pin (2 channels) changes from "H" to "L" while the clock line (SBT3 pin) is "H". It is also detected when the SC3CE1 flag of the SC3MD0 register is set to "1" and data line SBI3 pin (3 channels) or SBO3 pin (2 channels) changes from "H" to "L" while the clock line (SBT3 pin) is "L". Set the SC3SB0S flag of the SC3MD1 register to "0" before change the start condition edge. When transmission and reception are executed at the same time, set the start condition to "disable" in order to prevent abnormal operation. #### First Transfer Bit Setup The SC3DIR flag of the SC3MD0 register sets the first bit to be transferred. LSB or MSB can be selected. #### Transmission Data Buffer The transfer data buffer TXBUF3 is the spare buffer which stores data to be loaded to internal shift register. Set the data to be transferred to transfer data buffer TXBUF3, and the data is automatically loaded to internal shift register. The data loading takes more than 3 transfer clocks cycles. Data setting to TXBUF3 again during data loading may not be operated properly. You can determine whether or not data loading is in progress by monitoring transfer buffer empty flag SC3TEMP of the SC3STR. SC3TEMP flag is set to "1"when data is set to TXBUF3 and cleared to "0" when data loading ends. Figure:13.3.1 Transmission Data Buffer #### ■ Reception Data Buffer Use transmission / reception shift register SC3TRB as reception data buffer. The received data is stored to SC3TRB shifting by 1 bit. When the start condition is set to "enable" in the clock synchronous communication, transmission and reception should not be executed at the same time in order to prevent abnormal operation. If start condition is input for activation during communication again, the transmission data becomes invalid. To transmit the data, set it to TXBUF3 again. SC3TRB is overwritten in every communication. In sequence reception, read out the data in SC3TRB before the next reception is started. #### Transmission Bit Count and First Transfer Bit When the transfer bit count is 1 to 7 bits, data storage to the transmission /reception shift register TXBUF3 depends on the first transfer bit. When MSB is the first bit to be transferred, the lower bits of TXBUF3 are used for storage. In Figure:13.3.2, if data "A" to "F" are stored to bp2 to bp7 of SC3TRB as the transfer bit count is 6 bits, data is transferred from "F" to "A". When LSB is the first bit to be transferred, use the lower bits of TXBUF3 for storage. In Figure:13.3.3, if data "A" to "F" are stored to bp0 to bp5 of TXBUF3, as the transfer bit count is 6 bits, data is transferred from "A" to "F". Figure: 13.3.2 Transfer Bit Count and First Transfer Bit (MSB First) Figure:13.3.3 Transfer Bit Count and First Transfer Bit (LSB First) #### Receive Bit Count and First Transfer Bit When the transfer bit count is 1 to 7 bits, data storage to the transmit/receive shift register SC3TRB depends on the first transfer bit. When MSB is the first bit to be transferred, the lower bits of SC3TRB are used for storage. In Figure:13.3.4, as the transfer bit count is 6 bits, data "A" to "F" are stored to bp5 to bp0 of SC3TRB, and they are transferred from "F" to "A". When LSB is the first bit to be transferred, use the upper bits of SC3TRB for storage. In Figure:13.3.5, data "A" to "F" are stored to bp2 to bp7 of SC3TRB, as the transfer bit count is 6 bits, and they are transferred from "A" to "F". Figure:13.3.4 Receive Bit Count and First Transfer Bit (MSB First) Figure:13.3.5 Receive Bit Count and First Transfer Bit (LSB First) #### ■ Continuous Transmission Serial interface 3 is capable of continuous transmission. If data is set to transmission data buffer TXBUF3 during transmission, transmission buffer empty flag SC3TEMP is set and the set data is automatically transmit. Set data to TXBUF3 in the period that after data is loaded to internal shift register and before communication end interrupt SC3IRQ is generated. In master communication, communication blank from SC3IRQ generation to next transfer clock output is 4 transfer clock. #### ■ Input edge / output edge Setup The SC3CE1 flag of the SC3MD0 register sets the output edge of the transmission data and the input edge of the received data. Data at transmission is output at the falling edge of clock as the SC3CE1 flag = "0", and at the rising edge of clock as the SC3CE1 = "1". Data at reception is input at the rising edge of clock as the SC3CE1 = "0", and at the falling edge of clock as the SC3CE1 flag = "1" Table:13.3.2 Input Edge / Output Edge of Transmission and Reception Data | SC3CE1 | Transmission data output edge | Received data input edge | |--------|-------------------------------|--------------------------| | 0 | | | | 1 | | | #### Clock Setup Clock source is selected from the dedicated prescaler and timers 2, 3 output (2 channels) with the SC3PSC3 to 0 of the SC3MD3 register. The dedicated prescaler is started by selecting "count enable" with the SC3PSCE of the SC3MD3 register. The SC3MST flag of the SC3MD1 register selects the internal clock (clock master), or the external clock (clock slave). Even if the external clock is selected, set the internal clock with same frequency to the external clock with the SC3MD3 register, as the interrupt flag SC3IRQ is generated by the internal clock. Table:13.3.3 shows the internal clock source which can be set with the SC3MD3 register. Table:13.3.3 Synchronous Serial Interface Inside Clock Source | | Serial 3 | |------------------|----------------| | Clock source | fosc/2 | | (Internal clock) | fosc/4 | | | fosc/8 | | | fosc/32 | | | fs/2 | | | fs/4 | | | timer 2 output | | | timer 3 output | Set "0" to the SC3SBIS and SC3SBOS flags of the SC3MD register before change the clock setup. When the slave reception is executed with the start condition "enable" at the continuous communication, the system configuration is needed to notify the master of the readout completion. Without the notification, the data before readout may be overwritten. #### ■ Data Input Pin Setup There are 2 communication modes to be selected: 3 channels (clock pin (SBT3 pin), data output pin (SBO3 pin), data input pin (SBI3 pin)), 2 channels (clock pin (SBT3 pin), data I/O pin (SBO3 pin)). The SBI3 pin can be used only for serial data input. The SBO3 pin can be used for serial data input and output. The SC3IOM flag of the SC3MD1 register selects either serial data is input from the SBI3 pin, or the SBO3 pin. When "data input from the SBO3 pin" is selected for communication with 2 channels, the P3DIR3 flag of the P3DIR register is used to switch the transmission / reception of the SBO3 pin. The SBI3 pin, not used at that time, can be used as a general port. Maximum transfer speed should be under 5.0 MHz. If transfer clock exceeds 5.0 MHz, data may not be transferred properly. In reception, you can use SBI3 pin as general port by setting SC3IOM of the SC3MD1 register to "1" to select "serial data input from SBO3 pin". #### ■ Transmission Buffer Empty Flag If any data is set to TXBUF3 during communication (after setting data to TXBUF3 before generating the communication complete interrupt SC3IRQ), the transmission buffer empty flag SC3TEMP of the SC3STR register is set to "1". That indicates that the next transmission data is going to be loaded. Data is loaded to inside shift register from TXBUF3 by generation of SC3TIRQ, and the next transfer is started as SC3TEMP is cleared to "0". #### BUSY flag If data is set to the transmission/reception shift register TXBUF3, or start condition is enabled, the busy flag SC3BSY is set. That is cleared to "0" by the generation of the communication end interrupt SC3IRQ. The SC3BSY flag setup is maintained during continuous communication. If transmission buffer empty flag SC3TEMP is "0" when communication end interrupt SC3IRQ is generated, SC3BSY is cleared to "0". #### ■ Forced Reset You can shut down the communication by setting both of the SC3SBOS flag and the SC3SBIS flag of the SC3MD1 register to "0" (the SBO3 pin function: port, input data: input "1") and SC3BSY flag of the SC3MD0 register. When a forced reset is done, the SC3BSY flag of the SC3MD0 register is cleared, but other control registers hold their set values. #### ■ Last Bit of Transmission Data Table:13.3.4 shows last bit data output holding time at transmission, and the minimum data input time of the last bit at reception. At slave, internal clock setup is necessary to reserve data holding time at data transmission. Table:13.3.4 Last Bit Data Length of Transmission Data | | at transmission Last bit data holding period | at reception Last bit data input period | |-----------|---------------------------------------------------------------------------------------------------|-----------------------------------------| | At master | 1 bit data length | 1 bit data length (min) | | At slave | [1 bit data length of external clock $\times$ 1/2]+ [internal clock cycle $\times$ (1/2 to 3/2) ] | | When start condition is disabled (SC3STE flag=0), SBO3 output after last bit data output hold time can be set with SC3FDC1-0 of the SC3MD3 register as shown in Table:13.3.5. After reset release, output before serial transfer is "H" regardless of the set value of SC3FDC1-0 flags. When start condition is enabled (SC3STE flag =1), "H" is output regardless of the set value of SC3FDC1-0 flags. Table:13.3.5 SBO3 Output after Last Bit Data Output Hold Time (without start condition) | SC3FDC1 flag SC3FDC0 flag | | SBO3 output after last bit data output hold time | |---------------------------|---|--------------------------------------------------| | 0 | 0 | Fixed to "1"(High) output | | 1 | 0 | Fixed to "0"(Low) output | | 0 | 1 | Hold last data | | 1 | 1 | Reserved | ## ■ Transmission Timing Figure:13.3.6 Transmission Timing (Falling edge, Start condition is enabled) Figure:13.3.7 Transmission Timing (Falling edge, Start condition is disabled) Figure:13.3.8 Transmission Timing (Rising edge, Start condition is enabled) Figure:13.3.9 Transmission Timing (Rising edge, Start condition is disabled) ## Reception Timing Figure:13.3.10 Reception Timing (Rising edge, Start condition is enabled) Figure:13.3.11 Reception Timing (Rising edge, Start condition is disabled) Figure:13.3.12 Reception Timing (Falling edge, Start condition is enabled) Figure:13.3.13 Reception Timing (Falling edge, Start condition is disabled) #### Transmission / Reception As data is received at the opposite edge of the transmission clock, set the polarity of reception data input edge to opposite polarity of the transmission data output edge. When transmission and reception are executed at the same time, set the start condition to "disable" to prevent abnormal operation. Figure:13.3.14 Transmission / Reception Timing (Reception : Rising edge, Transmission : Falling edge) Figure:13.3.15 Transmission / Reception Timing (Reception : Falling edge, Transmission : Rising edge) #### Communication in STANDBY mode This serial interface is capable of slave reception in STANDBY mode. CPU operation status can be recovered from standby to normal by the communication complete interrupt SC3TIRQ that is generated after the slave reception. (In STANDBY mode, continuous reception is disabled after data of transfer bit count set by SC3LNG2-0 flags of the SC3MD0 register is received.) The received data should be read out from the transmission/reception shift register SC3TRB after recovering to NORMAL mode. In STANDBY mode, reception with start condition is not available, thus, disable start condition. And set dummy data to transmission data buffer TXBUF3 before transition to STANDBY mode. Figure:13.3.16 Reception Timing (Rising edge, Start condition is disabled) ## ■ Pins Setup (3 channels, at transmission) Table:13.3.6 shows the pins setup at synchronous serial interface transmission with 3 channels (SBO3 pin, SBI3 pin, SBT3 pin). Table:13.3.6 Synchronous Serial Interface Pins Setup (3 channels, at transmission) | Item | Data output pin | Data input pin | Clock I/O pin | | | |-------------------|---------------------------------|----------------|-------------------------------|-------------------------------|--| | | SBO3 pin | SBI3 pin | SBT3 pin | | | | | | | Clock master | Clock slave | | | Port Pin | P33 | P31 | P32 | | | | Serial data input | SBI3 | | - | | | | selection | SC3MD1(SC3IOM) | | | | | | Function | Serial data output | "1" input | Serial clock I/O | Serial clock I/O | | | | SC3MD1(SC3SBOS) SC3MD1(SC3SBIS) | | SC3MD1(SC3SBTS) | | | | Туре | Push-pull/N-ch open-<br>drain | - | Push-pull/N-ch open-<br>drain | Push-pull/N-ch open-<br>drain | | | | P3ODC(P3ODC3) | | P3ODC(P3ODC2) | | | | I/O | Output mode | - | Output mode | Input mode | | | | P3DIR(P3DIR3) | | P3DIR(P3DIR2) | | | | Pull-up | added / not added | - | added / not added | added / not added | | | | P3PLU(P3PLU3) | 1 | P3PLU(P3PLU2) | | | #### ■ Pins Setup (3 channels, at reception) Table:13.3.7 shows the pins setup at synchronous serial interface reception with 3 channels (SBO3 pin, SBI3 pin, SBT3 pin). Table:13.3.7 Synchronous Serial Interface Pins Setup (3 channels, at reception) | Item | Data output pin | Data input pin | Clock I/O pin | | | |-------------------|---------------------------------|-------------------|-------------------------------|-------------------------------|--| | | SBO3 pin | SBI3 pin | SBT3 pin | | | | | | | Clock master | Clock slave | | | Port Pin | P33 | P31 | P32 | | | | Serial data input | SBI3 | | - | | | | selection | SC3MD1(SC3IOM) | | | | | | Function | Port | Serial data input | Serial clock I/O | Serial clock I/O | | | | SC3MD1(SC3SBOS) SC3MD1(SC3SBIS) | | SC3MD1(SC3SBTS) | | | | Туре | - | - | Push-pull/N-ch open-<br>drain | Push-pull/N-ch open-<br>drain | | | | | | | | | | | | | P3ODC(P3ODC2) | | | | I/O | - | Input mode | Output mode | Input mode | | | | | P3DIR(P3DIR1) | P3DIR(P3DIR2) | | | | Pull-up | - | - | added / not added | added / not added | | | | | | P3PLU(P3PLU2) | | | ## ■ Pins Setup (3 channels, at reception / transmission) Table:13.3.8 shows the setup for synchronous serial interface pin with 3 channels (SBO3 pin, SBI3 pin, SBT3 pin) at transmission / reception. Table:13.3.8 Synchronous Serial Interface Pins Setup (3 channels, at transmission / reception) | Item | Data output pin | Data input pin | Clock I/O pin | | | |-------------------|---------------------------------|---------------------------|-------------------------------|-------------------------------|--| | | SBO3 pin | SBI3 pin | SBT3 pin | | | | | | | Clock master | Clock slave | | | Port Pin | P33 | P31 | P32 | | | | Serial data input | SBI3 | | - | | | | selection | SC3MD1(SC3IOM) | | | | | | Function | Serial data output | Serial data input | Serial clock I/O | Serial clock I/O | | | | SC3MD1(SC3SBOS) SC3MD1(SC3SBIS) | | SC3MD1(SC3SBTS) | | | | Туре | Push-pull/N-ch open-<br>drain | - | Push-pull/N-ch open-<br>drain | Push-pull/N-ch open-<br>drain | | | | P3ODC(P3ODC3) | <sup>2</sup> 3ODC(P3ODC3) | | P3ODC(P3ODC2) | | | I/O | Output mode | Input mode | Output mode | Input mode | | | | P3DIR(P3DIR3) P3DIR(P3DIR1) | | P3DIR(P3DIR2) | | | | Pull-up | added / not added | - | added / not added | added / not added | | | | P3PLU(P3PLU3) | | P3PLU(P3PLU2) | | | ## ■ Pins Setup (2 channels, at transmission) Table:13.3.9 shows the pins setup at synchronous serial interface transmission with 2 channels (SBO3pin, SBT3 pin). The SBI3 pin is not used, so that it can be used as a general port. Table:13.3.9 Synchronous Serial Interface Pins Setup (2 channels, at transmission) | Item | Data I/O pin | Serial unused pin | Clock I/O pin | | | |-------------------|---------------------------------|-------------------|-------------------------------|-------------------------------|--| | | SBO3 pin | SBI3 pin | SBT3 pin | | | | | | | Clock master | Clock slave | | | Port Pin | P33 | P31 | P32 | | | | Serial data input | SB03 | | - | | | | selection | SC3MD1(SC3IOM) | | | | | | Function | Serial data output | "1" input | Serial clock I/O | Serial clock I/O | | | | SC3MD1(SC3SBOS) SC3MD1(SC3SBIS) | | SC3MD1(SC3SBIS) | | | | Туре | Push-pull/N-ch open-<br>drain | - | Push-pull/N-ch open-<br>drain | Push-pull/N-ch open-<br>drain | | | | P3ODC(P3ODC3) | | P3ODC(P3ODC2) | | | | I/O | Output mode | - | Output mode | Input mode | | | | P3DIR(P3DIR3) | | P3DIR(P3DIR2) | | | | Pull-up | added / not added | - | added / not added | added / not added | | | | P3PLU(P3PLU3) | | P3PLU(P3PLU2) | | | ## ■ Pins Setup (2 channels, at reception) Table:13.3.10 shows the pins setup at synchronous serial interface reception with 2 channels (SBO3 pin, SBT3 pin). The SBI3 pin is not used, so that it can be used as a general port. Table:13.3.10 Synchronous Serial Interface Pins Setup (2 channels, at reception) | Item | Data I/O pin | Serial unused pin | Clock I/O pin | | |-------------------|-----------------|-------------------|-------------------------------|-------------------------------| | | SBO3 pin | SBI3 pin | SBT3 pin | | | | | | Clock master | Clock slave | | Port Pin | P33 | P31 | P32 | , | | Serial data input | SB03 | | - | | | selection | SC3MD1(SC3IOM) | | | | | Function | Port | Serial input | Serial clock I/O | Serial clock I/O | | | SC3MD1(SC3SBOS) | SC3MD1(SC3SBIS) | SC3MD1(SC3SBIS) | | | Туре | - | - | Push-pull/N-ch open-<br>drain | Push-pull/N-ch open-<br>drain | | | | | P3ODC(P3ODC2) | | | I/O | Input mode | - | Output mode | Input mode | | | P3DIR(P3DIR3) | | P3DIR(P3DIR2) | | | Pull-up | - | - | added / not added | added / not added | | | | | P3PLU(P3PLU2) | | ## 13.3.2 Setup Example ## ■ Transmission / Reception Setup Example The setup example for clock synchronous serial communication with serial 3 is shown. Table:13.3.11 shows the conditions at transmission/reception. Table:13.3.11 Conditions for Synchronous Serial Interface at transmission / reception | Item | set to | |------------------------------------------------|-------------------| | Serial data input pin | SBI3 (3 channels) | | Transfer bit count | 8 bits | | Start condition | Disabled | | First transfer bit | MSB | | Input edge | Falling | | Output edge | Rising | | Clock | Clock master | | Clock source | fs/2 | | SBT3/SB03 pin type | N-ch open-drain | | SBT3 pull-up resistor | Added | | SB03 pull-up resistor | Added | | Serial interface 3 communication end interrupt | Enabled | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select prescaler operation. SC3MD3 (0x03FA2) bp3 :SC3PSCE =1 | (1) Set the SC3PSCE flag of the SC3MD3 register to "1" to select prescaler operation. | | (2) Select the clock source.<br>SC3MD3 (0x03FA2)<br>bp2-0 :SC3PSC2-0 =100 | (2) Set the SC3PSC2-0 flag of the SC3MD3 register to "100" to select fs/2 for clock source. | | (3) Control of pin type. P3ODC (0x03F3B) bp2:P3ODC2 = 1 bp3:P3ODC3 = 1 P3PLU (0x03F43) bp2:P3PLU2 = 1 bp3:P3PLU3 = 1 | (3) Set the P3ODC2, P3ODC3 flags of the P3ODC register to "1, 1" to select N-ch open drain for the SBO3/SBT3 pin type. Set the P3ODC2, P3ODC3 flags of the P3PLU register to "1, 1" to add pull-up resistor. | | Setup Procedure | Description | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (4) Control of pin direction. P3DIR (0x03F33) bp2:P3DIR2 =1 bp1:P3DIR1 =0 bp3:P3DIR3 =1 | (4) Set the P3DIR2, P3DIR3 flags of the Port 3 pin control direction register (P3DIR) to "1, 1" to set P32, P33 to output mode, to set P31 to input mode. | | (5) Set the SC3MD0 register. Select the transfer bit count. SC3MD0 (0x03FA0) bp2-0 :SC3LNG2-0 =111 Select the start condition. SC3MD0 (0x03FA0) | <ul><li>(5) Set the SC3LNG2-0 flag of the serial 3 mode register (SC3MD0) to "111" to set the transfer bit count as 8 bits.</li><li>Set the SC3STE flag of the SC3MD0 register to "0" to disable start condition.</li></ul> | | bp3 :SC3STE =0 Select the first bit to be transferred. SC3MD0 (0x03FA0) bp4 :SC3DIR =0 | Set the SC3DIR flag of the SC3MD0 register to "0" to set MSB as the first transfer bit. | | Select the transfer edge.<br>SC3MD0 (0x03FA0)<br>bp6 :SC3CE1 =1 | Set the SC3CE1 flag of the SC3MD0 register to "1" to set the transmission data output edge to "rising", and the received data input edge to "falling". | | (6) Set the SC3CTR register.<br>SC3CTR (0x03FA6)<br>bp2 :SC3CMD =0 | (6) Set the SC3CMD flag of the SC3CTR register to "0" to select serial data tansmission. | | (7) Set the SC3MD1 register. Select the transfer clock. SC3MD1 (0x03FA1) bp2 :SC3MST =1 Control of pin function. SC3MD1 (0x03FA1) bp4 :SC3SBOS =1 bp5 :SC3SBIS =1 bp6 :SC3SBTS =1 bp7 :SC3IOM =0 | (7) Set the SC3MST flag of the SC3MD1 register to "1" to select clock master (internal clock). Set the SC3SBOS, SC3SBIS, SC3SBTS flags of the SC3MD1 register to "1" to set the SBO3 pin to serial data output, the SBI3 pin to serial data input, and the SBT3 pin to serial clock I/O. Set the SC3IOM flag to "0" to set "serial data input from the SBI3 pin". | | (8) Set the interrupt level. SC3ICR (0x03FF3) bp7-6 :SC3LV1-0 =10 | (8) Set the interrupt level by the SC3LV1-0 flag of the serial 3 interrupt control register (SC3ICR). | | (9) Enable the interrupt. SC3ICR (0x03FF3) bp1 :SC3IE =1 bp0 :SC3IR =0 | (9) Set the SC3IE flag of the SC3ICR register to "1" to enable the interrupt. If the interrupt request flag (SC3IR of the SC3ICR register) is already set, clear SC3IR before enabling interrupt. | | (10) Start serial transmission.<br>Transmission data → TXBUF3 (0x03FA5)<br>Reception data → Input to SBI3 pin | (10) Set the transmission data to the serial transmission data buffer TXBUF3. The internal clock is generated to start transmission/reception. After communication, the serial 3 interrupt SC3IRQ is generated. [Chapter 3. 3-1-4 Setup] | Note: Procedures (1) to (2),(5), (6) and (7) can be set at the same time. Note: Procedures (8) and (9) can be set at the same time. For communication with 3 channels, set the SC3BIS of the SC3MD1 register to "0" to set the serial input to "1". The SBI3 pin can be used as a general port. For reception only, set the SC3SBOS of the SC3MD1 register to "0" to select port. The SBO3 pin can be used as a general port. For communication with 2 channels, set the SBO3 pin to serial data I/O. The port direction control register P3DIR switches the I/O. For reception, set the SC3SBIS of the SC3MD1 register to "1" to select serial input. The SBO3 pin can be used as a general port. This serial interface contains a force reset function. If the communication should be stopped by force, set SC3SBOS and SC3SBIS of the SC3MD1 register to "0". Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:13.2.1 except TXBUF3) are set. Transfer rate of transfer clock set by the SC3MD3 register should not exceed 5.0 MHz. ## ■ Reception Setup Example The setup example for clock synchronous serial communication with serial 3 is shown. Table:13.3.12 shows the conditions at reception. Table:13.3.12 Conditions for Synchronous Serial Interface at reception | Item | set to | |-----------------------------------------------------|-------------------| | Serial data input pin | SBI3 (3 channels) | | Transfer bit count | 8 bits | | Start condition | Disabled | | First transfer bit | MSB | | Input edge | Falling | | Output edge | Rising | | Clock | Clock slave | | Clock source | fs/2 | | SBT3/SB03 pin type | N-ch open-drain | | SBT3 pin pull-up resistor | Added | | SB03 pin pull-up resistor | Added | | Serial interface 3 communication complete interrupt | Enabled | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select prescaler operation.<br>SC3MD3 (0x03FA2)<br>bp3 :SC3PSCE =1 | (1) Set the SC3PSCE flag of the SC3MD3 register to "1" to select prescaler operation. | | (2) Select the clock source.<br>SC3MD3 (0x03FA2)<br>bp2-0 :SC3PSC2-0 =100 | (2) Set the SC3PSC2-0 flag of the SC3MD3 register to "100" to select fs/2 as the clock source. | | (3) Control the pin type. P3ODC (0x03F3B) bp2 :P3ODC2 =1 P3PLU (0x03F43) bp2 :P3PLU2 =1 | (3) Set the P3ODC2 flags of the P3ODC register to "1" to select N-ch open drain for the SBT3 pin type. Set the P3PLU2 flags of the P3PLU register to "1" to add pull-up resistor. | | (4) Control of pin direction. P3DIR (0x03F33) bp2:P3DIR2 =1 bp1:P3DIR1 =0 | (4) Set the P3DIR2 flags of the Port 3 pin control direction register (P3DIR) to "1" and set P3DIR1 to "0" to set P32 to output mode, to set P31 to input mode. | | Setup Procedure | Description | |---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (5) Set the SC3MD0 register. Select the transfer bit count. SC3MD0 (0x03FA0) bp2-0 :SC3LNG2-0 =111 | (5) Set the SC3LNG2-0 flag of the serial 3 mode register (SC3MD0) to "111" to set the transfer bit count as 8 bits. | | Select the start condition. SC3MD0 (0x03FA0) bp3 :SC3STE =0 | Set the SC3STE flag of the SC3MD0 register to "0" to disable start condition. | | Select the first transfer bit.<br>SC3MD0 (0x03FA0)<br>bp4 :SC3DIR =0 | Set the SC3DIR flag of the SC3MD0 register to "0" to set MSB as the first transfer bit. | | Select the transfer edge. SC3MD0 (0x03FA0) bp6 :SC3CE1 =1 | Set the SC3CE1 flag of the SC3MD0 register to "1" to set the transmission data output edge to "rising", and the reception data input edge to "falling". | | (6) Set the SC3CTR register.<br>SC3CTR (0x03FA6)<br>bp2 :SC3CMD =0 | (6) Set the SC3CMD flag of the SC3CTR register to "0" to select serial data tansmission. | | (7) Set the SC3MD1 register. Select the transfer clock. SC3MD1 (0x03FA1) | (7) Set the SC3MST flag of the SC3MD1 register to "0" to select clock slave (external clock). | | bp2:SC3MST =0 Control the pin function. SC3MD1 (0x03FA1) bp4:SC3SBOS =0 bp5:SC3SBIS =1 bp6:SC3SBTS =1 bp7:SC3IOM =0 | Set the SC3SBIS, SC3SBTS flags of the SC3MD1 register to "1" to set the SBI3 pin to serial data input, the SBT3 pin to serial clock I/O. Set the SC3BOS flag to "0" to set the SBO3 pin to the port. Set the SC3IOM flag to "0" to set "serial data input from the SBI3 pin". | | (8) Set the interrupt level.<br>SC3ICR (0x03FF3)<br>bp7-6 :SC3LV1-0 =10 | (8) Set the interrupt level by the SC3LV1-0 flag of the serial 3 interrupt control register (SC3ICR). | | (9) Enable the interrupt. SC3ICR (0x03FF3) bp1 :SC3IE =1 bp0 :SC3IR =0 | (9) Set the SC3IE flag of the SC3ICR register to "1" to enable the interrupt . If the interrupt request flag (SC3IR of the SC3ICR register) is already set, clear SC3IR before enabling interrupt. | | (10) Start serial reception. dummy data → TXBUF3 (0x03FA5) Reception data → Input to SBI3 pin | (10) Set the dummy data to the serial transmission data buffer TXBUF3. Wait 3.5 or more transfer clock after the dummy data setting, and execute the clock input. Then the reception starts. After the reception completes, the serial 3 interrupt SC3IRQ is generated. [Chapter 3. 3-1-4 Setup] | Note: Procedures (1) to (2),(5), (6) and (7) can be set at the same time. Note: Procedures (8) and (9) can be set at the same time. <sup>\*</sup> At the reception with the start condition input, set the SC3STE flag to "1" and the start condition to "enable" in step (5). In step (10), execute the start condition input instead of dummy data setting. After the start condition input, 0.5 or more transfer clock is required before the clock input. For communication with 3 channels, set the SC3BIS of the SC3MD1 register to "0" to set the serial input to "1". The SBI3 pin can be used as a general port. For reception only, set the SC3SBOS of the SC3MD1 register to "0" to select port. The SBO3 pin can be used as a general port. For communication with 2 channels, set the SBO3 pin to serial data I/O. The port direction control register P3DIR switches the I/O. For reception, set the SC3SBIS of the SC3MD1 register to "1" to select serial input. The SBO3 pin can be used as a general port. This serial interface contains a force reset function. If the communication should be stopped by force, set SC3SBOS and SC3SBIS of the SC3MD1 register to "0". Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table:13.2.1 except TXBUF3) are set. Transfer rate of transfer clock set by the SC3MD3 register should not exceed 5.0 MHz. ## ■ Transmission / Reception Setup Example (reception in STANDBY mode) The setup example for clock synchronous serial communication with serial 3 is shown. Table:13.3.13 shows the conditions at reception in STANDBY mode. Table:13.3.13 Conditions for Synchronous Serial Interface at transmission / reception (reception in STANDBY mode) | Item | set to | |-----------------------------------------------------|-------------------| | Serial data input pin | SBI3 (3 channels) | | Transfer bit count | 8 bit | | Start condition | Disabled | | First transfer bit | MSB | | Input edge | Falling | | Clock | Clock slave | | Operation mode | STOP mode | | Clock source | fs/2 | | SBT3/SB03 pin type | Push-pull | | SBT3 pin pull-up resistor | Not added | | SBI3 pin pull-up resistor | Not added | | Serial interface 3 communication complete interrupt | Enabled | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select prescaler operation.<br>SC3MD3 (0x03FA2)<br>bp3 :SC3PSCE =1 | (1) Set the SC3PSCE flag of the SC3MD3 register to "1" to select prescaler operation. | | (2) Select the clock source.<br>SC3MD3 (0x03FA2)<br>bp2-0 :SC3PSC2-0 =100 | (2) Set the SC3PSC2-0 flag of the SC3MD3 register to "100" to select fs/2 as the clock source. | | (3) Control the pin type. P3ODC (0x03F3B) bp2 :P3ODC2 =0 P3PLU(0x03F43) bp2 :P3PLU2 =0 | (3) Set the P3ODC2, P3ODC3 flags of the P3ODC register to "0, 0" to select push-pull for the SBO3/SBT3 pin type. Set the P3PLU2, P3PLU3 flags of the P3PLU register to "0, 0" not to add pull-up resistor. | | (4) Control the pin direction. P3DIR (0x03F33) bp2:P3DIR2 =1 bp1:P3DIR1 =0 bp3:P3DIR3 =0 | (4) Set the P3DIR2, P3DIR3 flags of the Port 3 pin control direction register (P3DIR) to "1, 0" to set P32 to output mode, P33, P31 to input mode. | | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (5) Select the transfer bit count.<br>SC3MD0 (0x03FA0)<br>bp2-0 :SC3LNG2-0 =111 | (5) Set the SC3LNG2-0 flags of the serial 3 mode register (SC3MD0) to "111" to set the transfer bit count as 8 bits | | (6) Select the start condition.<br>SC3MD0 (0x03FA0)<br>bp3 :SC3STE =0 | (6) Set the SC3STE flag of the SC3MD0 register to "0" to disable start condition. | | (7) Select the first transfer bit.<br>SC3MD0 (0x03FA0)<br>bp4 :SC3DIR =0 | (7) Set the SC3DIR flag of the SC3MD0 register to "0" to set MSB as the first transfer bit. | | (8) Select the transfer edge.<br>SC3MD0 (0x03FA0)<br>bp6 :SC3CE1 =1 | (8) Set the SC3CE1 flag of the SC3MD0 register to "1" to set the reception data input edge to "falling". | | (9) Select the communication type. SC3CTR (0x03FA6) bp0 :SC3CMD =0 | (9) Set the SC3CMD flag of the SC3CTR register to "0" to select synchronous serial interface. | | (10) Select the transfer clock.<br>SC3MD1 (0x03FA1)<br>bp2 :SC3MST =0 | (10) Set the SC3MST flag of the SC3MD1 register to "0" to select clock slave (external clock). | | (11) Control the pin function. SC3MD1(0x03FA1) bp4:SC3SBOS =0 bp5:SC3SBIS =1 bp6:SC3SBTS =1 bp7:SC3IOM =0 | (11) Set the SC3SBOS flags of the SC3MD1 register to "0", SC3SBIS, SC3SBTS flags to "1" to set the SBO3 pin to general port, the SBI3 pin to serial data input, and the SBT3 pin to serial clock I/O. Set the SC3IOM flag to "0" to set "serial data input from the SBI3 pin". | | (12) Set the interrupt level<br>SC3ICR (0x03FF3)<br>bp7-6 :SC3LV1-0 =10 | (12) Set the interrupt level (to level 2) by the SC3LV1-0 flags of the serial 3 interrupt control register (SC3ICR). | | (13) Enable the interrupt. SC3ICR (0x03FF3) bp1 :SC3IE =1 bp0 :SC3IR =0 | (13) Set the SC3IE flag of the SC3ICR register to "1" to enable the interrupt. If the interrupt request flag (SC3IR of the SC3ICR register) is already set, clear SC3IR before the interrupt is enabled. [ Chapter 3 3.1.4. Interrupt Flag Setup ] | | <ul><li>(14) Set the activation factor for serial communication.</li><li>Dummy data → TXBUF3 (0x03FA5)</li></ul> | (14) Set dummy data to the serial transmission data buffer TXBUF3. | | (15) Transition to STOP mode.<br>CPUM (0x03F00)<br>bp3:STOP =1 | (15) Set the STOP flag of the CPUM register to "1" for transition to STOP mode. | | (16) Start serial reception.<br>Transfer clock → Input to SBT3 pin<br>Reception data → Input to SBI3 pin | (16) Set the transfer clock to SBT3 pin and transfer data to SBI3 pin. | | Setup Procedure | Description | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (17) Return from STANDBY mode | (17) Serial 3 interrupt SC3IRQ is generated at the same time of reception of the 8 <sup>th</sup> bits data, and then CPU returns from STOP mode to NORMAL mode after oscillation stabilization wait time. | Note: Procedures (5) to (8),(10) to (11), (12) to (13) can be set at the same time. Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table: 13.2.1, except TXBUF3) are set. ## 13.3.3 Single Master IIC Serial Interface Serial interface 3 is capable of IIC serial communication in single master. Communication of this IIC interface is based on the IIC-BUS data transfer format of Phillips. Table:13.3.14 shows the functions of IIC serial interface. Table:13.3.14 IIC Serial Interface Functions | Communication type | Single master IIC | | |-----------------------------------------------------|----------------------------------------------------------------------|--| | Interrupt | SC3IRQ | | | Pins | SDA3,SCL3 | | | Transfer bit count specification | 1 to 8 bit | | | First transfer bit specification | 0 | | | ACK bit selection | 0 | | | ACK bit level selection | 0 | | | Clock source | fosc/2 fosc/4 fosc/8 fosc/32 fs/2 fs/4 timer 2 output timer 3 output | | | The transfer rate is the clock source divided by 8. | | | #### Activation factor for Communication Set data (at transmission) or dummy data (at reception) to the transmission/reception shift register TXBUF3. Start condition and transfer clock are generated to start communication, regardless of transmission/reception. This serial interface can not be used for slave communication. #### ■ Start Condition Setup In IIC communication, enable start condition by the SC3STE flag of the SC3MD0 register at the first communication after reset release. From the second communication, the SC3STE flag of the SC3MD0 register can select if start condition is enabled or not. If start condition is detected during data communication in which the start condition is enabled, the SC3STC flag of the SC3CTR register is set to "1", and the communication end interrupt SC3IRQ is generated to end the transmission. This means that the communication is not executed properly and needs to be re-executed. Clear the SC3STC flag by program. When data line (SDA3 pin) is changed from "H" to "L" while clock line (the SCL3 pin) is "H", start condition is generated. #### ■ Generation of Stop Condition Stop condition is generated as the SDA3 line is changed from "L" to "H", while the SCL3 line is "H". Stop condition can be generated by setting the IIC3STPC flag of the SC3CTR register to "0" by program. When the stop condition is generated, IIC3STPC flag is cleared automatically. Figure:13.3.17 Start Condition and Stop Condition #### ■ Input Edge/Output Edge Setup In IIC communication, data is always received at the falling edge of the clock. Even if the SC3CE1 flag is set to "0", the received data is stored in the falling edge of the clock. #### ■ Data I/O Pin Setup The SDA3 pin (used as SBO3 pin, too) is used to input/output data. Set the SC3IOM flag of the SC3MD1 register to "1" to input serial data from the SBO3 pin. As the SBI3 pin is not used at that time, it can be used as a general port. But always set the SC3SBIS flag of the above register to "1" to set "input serial data". To detect start condition, set the SC3SBIS flag of the SC3MD1 register to "input serial data", regardless of transmission/reception. #### ■ Reception of Confirming (ACK) Bit after Data Transmission The IIC3ACKS flag of the SC3CTR register selects if ACK bit is enabled or not. If ACK bit is enabled, ACK bit is received from the slave station after data (1 to 8 bits) is transferred. At reception of ACK bit, the SDA3 line is automatically released. To receive ACK bit, 1 clock is output to store ACK bit to the IIC3ACK0 of the SC3CTR register. The transmission/reception shift register SC3TRB is not operated by the ACK bit reception clock. When the received ACK bit level is "L", the reception is normal at slave and the next data can be received. If the level is "H", the reception maybe completed at slave, so set the IIC3STPC flag of the SC3CTR register to "0" to end communication. Figure:13.3.18 ACK Bit Reception Timing after Transmission of 8-Bit Data #### ■ Transmission of Confirming (ACK Bit) of Data Reception Selection of enable/disable of ACK bit is the same as the transmission. When ACK bit is enabled, ACK bit and clock are output after data (1 to 8 bits) is received. When the reception is continued, ACK bit outputs "L". And when the reception is finished, it outputs "H". The IIC3ACK0 of the SC3CTR register sets the output ACK bit level. Figure:13.3.19 ACK Bit Transmission Timing after Reception of 8-Bit Data #### Transfer Format There are two transfer format used on IIC bus are: the addressing format that transmits/receives data after 1 byte data (address data) that consists of slave address (7 bits) and R/W bit (1 bit) is transferred after start condition, and the free data format that transmits data right after the start condition. The serial interface of this LSI supports 2 communication formats for only master transmission and master reception in IIC communication. Sequence of communication is shown below. The shaded part shows the data transferred from slave. Figure:13.3.20 Communication Sequence on Each Transfer Format [Figure:13.3.21 Master Transmission Timing, Figure:13.3.22 Master Reception Timing] #### ■ Clock Setup The transfer clock for IIC communication is obtained by dividing clock source by 8 inside this serial. The clock source is selected from the dedicated prescaler, timer 2 or 3 output by the SC3MD3 register. The clock source should be set in such a way that the transfer rate is under 100 kHz in NORMAL mode, 400 kHz in high speed mode with the SC3MD3 register. The dedicated prescaler starts as this register selects "prescaler Count Enable". Set the SC3MST flag of the SC3MD1 register to "1" to select the internal clock (clock master). This IIC interface can not be used with external clock (clock slave). Table:13.3.15 IIC Serial Interface Clock Sources | | Single master IIC | |----------------------------------|-------------------| | Clcok source<br>(internal clock) | fosc/2 | | | fosc/4 | | | fosc/8 | | | fosc/32 | | | fs/2 | | | fs/4 | | | timer 2 output | | | timer 3 output | The transfer rate in IIC communication is obtained by dividing clock source by 8. The clock source should be set in such a way that the transfer rate is under 100 kHz in NORMAL mode, 400 kHz in high speed mode with the SC3MD3 register. Set the SC3MST flag of the SC3MD1 register to "1" to select internal clock (clock master). Set the SC3SBIS and SC3SBOS flags of the SC3MD1 register to "0" before change the clock setup. #### ■ Transmission/Reception Mode Setup and Operation The IIC3REX flag of the SC3CTR register selects the status of the transmission or the reception. The first data is always added start condition for communication regardless of the setting value of the SC3STE. The start condition is output from this serial (master). The start condition is not added over the second communication, select the start condition "none" at the first setting. And the start condition is added over the second communication, select the start condition "enable" at the first setting. At addressing format, slave address and R/W bit are set to the first data after start condition for transmission. At master reception, switch to the reception mode at the interrupt transaction after the transmission of the first 1 byte data is finished, after the ACK signal from slave is confirmed. If the communication should be continued to other device without stop, transmit slave address and R/W bit again after start condition is generated again. At reception, the SDA line is automatically released to wait for reception. After the storage of data is finished, confirmation of the reception (ACK bit) is output. [ Figure:13.3.21 Master Transmission Timing, Figure:13.3.22 Master Reception Timing] #### ■ IIC BUSY Flag Operation When data is set to the transmission buffer TXBUF3, IIC3BSY flag of the SC3CTR register is set to "1". When ACK transmission/reception (with ACK enabled communication) or the final bit communication (with ACK disabled communication) completes, the IIC3BSY flag is cleared to "0". Also, when the stop condition generation flag (IIC3STPC) is set to "1", IIC3BSY is set to "1" and cleared to "0" when stop condition is completed. If start condition is detected during communication, the communication end interrupt SC3IRQ is generated and the IIC3BSY flag is automatically cleared. The following items are the same as clock synchronous serial. ■ First Transfer Bit Setup Refer to: XIII-13 Transmission Data Buffer Refer to: XIII-13 Reception Data Buffer Refer to: XIII-13 ■ Transfer Bit Count and First Transfer Bit Refer to: XIII-15 ■ Continuous Communication Refer to: XIII-15 Forced Reset Refer to: XIII-17 In communication, set Nch-open drain for pin type, as the hardware switches if bus is used/released. In reception, set the SDA3 pin (the SBO3 pin) direction to "output". #### Master Transmission Timing Figure:13.3.21 Master Transmission Timing - (1) Output start condition. - (2) Bus released period, ACK bit is received. - (3) Interrupt Set data to TXBUF3 - (4) Receive ACK bit. - (5) Interrupt Communication ends: clear the IIC3BSY flag. (6) Generates stop condition. #### ■ Master Reception Timing Figure:13.3.22 Master Reception Timing - (1) Output start condition. - (2) Bus released period, ACK bit is received. - (3) Interrupt Set to reception mode : IIC3REX = $0 \rightarrow 1$ Set data to TXBUF3 - (4) Receive ACK bit. - (5) Interrupt Communication ends: clear the IIC3BSY flag. (6) Generates stop condition. #### ■ Pin Setup (2 channels, at transmission) Table:13.3.16 shows the pins setup in IIC serial interface transmission with 2 channels (SDA3 pin, SCL3 pin). Table:13.3.16 Pin Setup (2 channels, at transmission) | Item | Data I/O pin | Clock output pin | |----------------|--------------------------|---------------------| | | SDA3 pin | SCL3 pin | | Pin | P33 | P32 | | SDA3/SCL3 pins | SBI3/SBO3 pin connection | - | | | SC3MD1(SC3IOM) | | | Function | Serial data output | Serial clock output | | | SC3MD1(SC3SBOS) | SC3MD1(SC3SBTS) | | | Serial data input | - | | | SC3MD1(SC3SBIS) | | | Туре | N-ch open-drain | N-ch open-drain | | | P3ODC(P3ODC3) | P3ODC(P3ODC2) | | I/O | Output mode | Output mode | | | P3DIR(P3DIR3) | P3DIR(P3DIR2) | | Pull-up | Added | Added | | | P3PLU(P3PLU3) | P3PLU(P3PLU2) | #### ■ Pin Setup (2 channels, at reception) Table:13.3.17 shows the pins setup in IIC serial interface reception with 2 channels (SDA3 pin, SCL3 pin). Table:13.3.17 Pin Setup (2 channels, at reception) | Item | Data I/O pin | Clock output pin | | |----------------|--------------------------|---------------------|--| | | SDA3 pin | SCL3 pin | | | Pin | P33 | P32 | | | SDA3/SCL3 pins | SBI3/SBO3 pin connection | - | | | | SC3MD1(SC3IOM) | | | | Function | Port | Serial clock output | | | | SC3MD1(SC3SBOS) | SC3MD1(SC3SBTS) | | | | Serial data input | - | | | | SC3MD1(SC3SBIS) | | | | Туре | N-ch open-drain | N-ch open-drain | | | | P3ODC(P3ODC3) | P3ODC(P3ODC2) | | | I/O | Output mode | Output mode | | | | P3DIR(P3DIR3) | P3DIR(P3DIR2) | | | Pull-up | Added | Added | | | | P3PLU(P3PLU3) | P3PLU(P3PLU2) | | ## 13.3.4 Setup Example #### ■ Master Transmission Setup Example The setup example for the transmission of several bytes data to the all the devices on IIC bus with IIC serial Interface 3 is shown. Table:13.3.18 shows the conditions at communication. Table:13.3.18 Conditions Single Master IIC Communication Setup | Item | Set to | |-----------------------------|---------------------------------------------| | SBI3/SBO3 pins | Connection (2 channels) | | Transfer bit count | 8 bits | | Start condition | Enable (disable after second communication) | | First transfer bit | MSB | | ACK bit | Enable | | IIC communication mode | NORMAL mode | | Clock source | fosc/32 | | SCL3/SDA3 pin type | N-ch open-drain | | SCL3 pin pull-up resistance | Added | | SDA3 pin pull-up resistance | Added | An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | | |------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--| | (1) Select prescaler operation.<br>SC3MD3 (0x03FA2)<br>bp3: SC3PSCE =1 | (1) Set the SC3PSCE flag of the SC3MD3 register to "1" to select prescaler operation. | | | (2) Select the clock source.<br>SC3MD3 (0x03FA2)<br>bp2-0: SC3PSC2-0 =011 | (2) SC3PSC2-0 flags of the SC3MD3 register to "011" to select fs/32 as the clock source. | | | (3) Control the pin type. P3ODC (0x03F3B) bp2: P3ODC2 =1 bp3: P3ODC3 =1 | (3) Set the P3ODC2,P3ODC3 flag of the P3ODC register to "1, 1" to select N-ch open drain for the SDA3/SCL3 pin type. | | | (4) Control the pin direction. P3DIR (0x03F33) bp2: P3ODC2 =1 bp3: P3ODC3 =1 | (4) Set the P3DIR2, P3DIR3 flag of P3 pin control direction register (P3DIR) to "1, 1" to set P32, P33 to output mode. | | | Setup Procedure | Description | | |---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | (5) Set ACK bit.<br>SC3CTR (0x03FA6)<br>bp0 :SC3ACKO =x<br>bp1 :IIC3ACKS =1 | (5) Set the IIC3ACKS flag of the serial 3 control register (SC3CTR) to "1" to select "enable ACK bit". ACK bit is received at transmission that setup of the ACK bit level with the IIC3ACKS flag is not necessary. | | | (6) Select the communication mode.<br>SC3CTR (0x03FA6)<br>bp4 :IIC3TMD =0 | (6) Set the IIC3TMD flag of the serial 3 control register (SC3CTR) to "0" to select NORMAL mode. | | | (7) Select the communication type. SC3CTR (0x03FA6) bp2 :SC3CMD =1 | (7) Set the SC3CMD flag of the serial 3 control register (SC3CTR) to "1" to select IIC. | | | (8) <transmission setup=""> Select the transmission/reception SC3CTR(0x03FA6) bp3 :IIC3REX =0</transmission> | (8) Set the IIC3REX flag of the serial 3 control register (SC3CTR) to "0" to select the transmission mode. | | | (9) Initialize the monitor flag.<br>SC3CTR (0x03FA6)<br>bp6 :IIC3STC =0 | (9) Set the IIC3STC flag of the serial 3 control register (SC3CTR) to "0, 0" to initialize the start condition detection flag. | | | (10) Set the SC3MD0 register. Select the transfer bit count. SC3MD0 (0x03FA0) bp2-0 :SC3LNG2-0 =111 Select the start condition. | (10) Set the SC3LNG2-0 flag of the serial 3 mode register (SC3MD0) to "111" to set the transfer bit count as 8 bits. Set the SC3STE flag of the SC3MD0 register to "0" to | | | SC3MD0 (0x03FA0) bp3 :SC3STE =1 Select the first transfer bit. SC3MD0 (0x03FA0) bp4 :SC3DIR =0 | disenable start condition(Start condition is not added after the second communication.). Set the SC3DIR flag of the SC3MD0 register to "0" "to set MSB as the first transfer bit. | | | Select the IIC communication edge.<br>SC3MD0(0x03FA0)<br>bp6 :SC3CE1 =1 | In IIC communication, set always the SC3CE1 flag of the SC3MD0 register to "1". | | | (11) Set the SC3MD1 register. Select the transfer clock. SC3MD1 (0x03FA1) bp2 :SC3MST =1 | (11) Set the SC3MST flag of the SC3MD1 register to "1" to select clock master (internal clock). In IIC communication, do not select external clock. | | | Control the pin function. SC3MD1 (0x03FA1) bp4 :SC3SBOS =1 bp5 :SC3SBIS =1 bp6 :SC3SBTS =1 bp7 :SC3IOM =1 | Set the SC3SBOS, SC3SBIS, SC3SBTS flags of the SC3MD1 register to "1" to set the SDA3 pin (the SBO3 pin) to serial data output, the SBI3 pin to serial data input, and the SCL3 pin (the SBT3 pin) to serial clock I/O. Set the SC3IOM flag to "1" to set "serial data input from the SDA3 pin (the SBO3 pin)". | | | (12) Set the interrupt level. SC3ICR (0x03FF3) bp7-6 :SC3LV1-0 =10 | (12) Set the interrupt level by the SC3LV1-0 flag of the serial 3 interrupt control register (SC3ICR). | | | Setup Procedure | Description | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | (13) Enable the interrupt. SC3ICR (0x03FF3) bp1 :SC3IE =1 | (13) Set the SC3IE flag of the SC3ICR register to "1" to enable the interrupt. If the interrupt request flag (SC3II of the SC3ICR register) is already set, clear SC3IR before the interrupt is enabled. [ Chapter 3 3.1.4 Interrupt Flag Setup ] | | | <ul> <li>(14) <start transmission.=""> Start serial transmission. Confirm that SCL3 (P32) is "H". Transmission data → TXBUF3 (0x03FA5)</start></li> </ul> | (14) Set the transmission data to the transmission data<br>buffer TXBUF3. Then the transfer clock is generated to<br>start transmission. If the ACK bit is received after data<br>transmission, the communication complete interrupt<br>SC3IRQ is generated. | | | (15) <transmission ends.=""> <setup data="" next="" the="" transmission=""> Judge the monitor flag. SC3CTR (0x03FA6) bp6 :IIC3STC</setup></transmission> | (15) Confirm the IIC3STC flag of the serial 3 control register (SC3CTR). When the previous transmission is completed properly, IIC3STC = "0". If IIC3STC = "1", the communication should be re-executed. | | | (16) Judge the ACK bit level.<br>SC3CTR (0x03FA6)<br>bp0 :SC3ACK0 | (16) Confirm the level of the ACK bit, received by the SC3ACK0 flag of the serial 3 control register (SC3CTR). When SC3ACK0 = 0, the transmission can be continued. When SC3ACK0 = 1, the reception at slave may not be operated properly, so finish the communication. | | | (17) Set the SC3MD0 register. Select the transfer bit count. SC3MD0 (0x03FA0) bp2-0 :SC3LNG2-0 | (17) To change the transfer count bit, set the transfer count bit by the SC3LNG2-0 flag of the serial 3 mode register (SC3MD0). | | | (18) <start data="" next="" transmission.=""> Serial transmission starts. [ <math>\rightarrow</math> (15)]</start> | (18) Set the transmission data to TXBUF3 to start the transmission. [ $\rightarrow$ (15)] | | | (19) <transmission ends.=""></transmission> | (19) Set the IIC3STPC flag of the serial 3 control register (SC3CTR) to "1". Stop condition is automatically generated to finish the communication. | | Note: Procedures (1), (2) can be set at the same time. Note: Procedures (5) to (9) can be set at the same time. Note: Procedures (10), (11)can be set at the same time. Note: Procedures (12), (13)can be set at the same time. Each flag should be set as this setup procedure in order. Activation of communication should be operated after all control registers (refer to Table: 13.2.1, except TXBUF3) are set. # 14.1 Overview This LSI contains a serial interface 4, which is compatible with IIC serial interface (slave) communication. ## 14.1.1 Functions Table:14.1.1 shows the serial interface 4 functions. Table:14.1.1 Serial Interface 4 Functions | Communication style | IIC (slave) | |-----------------------|---------------------------| | Interrupt | SC4IRQ | | Pins | SDA,SCL | | Addressing | 7 bits/10 bits | | General call | О | | Maximum transfer rate | 400 kHz (High speed mode) | Serial interface 4 is only available in NORMAL mode. It is not available in other modes (SLOW, HALT0, HALT1, STOP1). ## 14.1.2 Block Diagram #### ■ Serial Interface 4 Block Diagram Figure:14.1.1 Serial Interface 4 Block Diagram ## 14.1.3 Control Registers $Table: 14.1.2 \ shows \ the \ registers \ that \ control \ serial \ interface \ 4.$ Table:14.1.2 Serial Interface 4 Control Registers List | Register | Address | R/W | Function | Page | |----------|----------|-----|-----------------------------------------------------|--------| | SC4AD0 | 0x03FA7' | R/W | Serial interface 4 addressing register 0 | XIV-6 | | SC4AD1 | 0x03FA8' | R/W | Serial interface 4 addressing register 1 | XIV-6 | | SC4TXB | 0x03FAA' | R/W | Serial interface 4 transmission data buffer | XIV-5 | | SC4RXB | 0x03FA9' | R | Serial interface 4 reception data buffer | XIV-5 | | SC4STR | 0x03FAB | R | Serial interface 4 status register | XIV-7 | | SCSEL | 0x03F90' | R/W | Serial interface I/O pin switching control register | XIV-8 | | P1ODC | 0x03F1B' | R/W | Port 1 N-ch open drain control register | IV-11 | | P7ODC | 0x03F1D' | R/W | Port 7 N-ch open drain control register | IV-54 | | P1DIR | 0x03F31' | R/W | Port 1 direction control register | IV-8 | | P1PLUD | 0x03F41' | R/W | Port 1 pull-up resistor control register | IV-9 | | P1OUT | 0x03F11' | R/W | Port 1 output control register | IV-7 | | P7DIR | 0x03F37' | R/W | Port 7 direction control register | IV-52 | | P7PLUD | 0x03F47' | R/W | Port 7 pull-up resistor control register | IV-53 | | P7OUT | 0x03F17' | R/W | Port 7 output control register | IV-51 | | SC4ICR | 0x03FF5' | R/W | Serial interface 4 interrupt control register | III-38 | R/W: Readable / Writable ## 14.1.4 Data Buffer Register Serial interface 4 has one each of 8-bit serial data buffer register for transmission and for reception. ■ Serial Interface 4 Reception Data Buffer (SC4RXB: 0x03FA9) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | I2CRXB7 | I2CRXB6 | I2CRXB5 | I2CRXB4 | I2CRXB3 | I2CRXB2 | I2CRXB1 | I2CRXB0 | | At reset | Х | Х | Х | Х | Х | Х | Х | Х | | Access | R | R | R | R | R | R | R | R | | bp | Flag | Description | |-----|--------------------------------------------------------------------------------------|------------------------------------------| | 7-0 | I2CRXB7<br>I2CRXB6<br>I2CRXB5<br>I2CRXB4<br>I2CRXB3<br>I2CRXB2<br>I2CRXB1<br>I2CRXB1 | Serial interface 4 reception data buffer | ■ Serial Interface 4 Transmission Data Buffer (SC4TXB: 0x03FAA) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | I2CTXB7 | I2CTXB6 | I2CTXB5 | I2CTXB4 | I2CTXB3 | I2CTXB2 | I2CTXB1 | I2CTXB0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|--------------------------------------------------------------------------------------|---------------------------------------------| | 7-0 | I2CTXB7<br>I2CTXB6<br>I2CTXB5<br>I2CTXB4<br>I2CTXB3<br>I2CTXB2<br>I2CTXB1<br>I2CTXB0 | Serial interface 4 transmission data buffer | #### 14.1.5 Mode Register #### ■ Serial Interface 4 Addressing Register (SC4AD0: 0x03FA7) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | I2CAD7 | I2CAD6 | I2CAD5 | I2CAD4 | I2CAD3 | I2CAD2 | I2CAD1 | I2CAD0 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |------|------------------------------------------------------------------------------|----------------------------------------| | 7-20 | I2CAD7<br>I2CAD6<br>I2CAD5<br>I2CAD4<br>I2CAD3<br>I2CAD2<br>I2CAD1<br>I2CAD0 | Serial interface 4 addressing register | ## ■ Serial Interface 4 Addressing Register 1 (SC4AD1: 0x03FA8) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|--------|--------|-----|-----|--------|--------|--------|--------| | Flag | SELI2C | I2CMON | - | - | I2CGEM | I2CADM | I2CAD9 | I2CAD8 | | At reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|------------------|--------------------------------------------------------------------------------------------| | 7 | SELI2C | Reset control 0:Reset 1:Operational status | | 6 | I2CMON | Monitor mode selection 0:Communication mode 1:Monitor mode | | 5-4 | - | - | | 3 | I2CGEM | Communication mode selection 0:Normal communication mode 1:General call communication mode | | 2 | I2CADM | Address mode selection 0:7 bits address mode 1:10 bits address mode | | 1-0 | I2CAD9<br>I2CAD8 | Address setup | ## ■ Serial Interface 4 Status Register 1 (SC4STR: 0x03FAB) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|-----|--------|------|-------|--------|--------|--------------|---| | Flag | WRS | I2CINT | STRT | RSTRT | I2CBSY | SLVBSY | ACKVALI<br>D | - | | At reset | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R | R | R | R | R | R | R | R | | bp | Flag | Description | |----|----------|--------------------------------------------------------------------------------| | 7 | WRS | Data transfer direction determination flag<br>0:Slave→Master<br>1:Master→Slave | | 6 | I2CINT | Interrupt detection flag 0:Undetected 1:Detected | | 5 | STRT | Start condition detection 0:Undetected 1:Detected | | 4 | RSTRT | Re-start condition detection 0:Undetected 1:Detected | | 3 | I2CBSY | Bus busy flag 0:Bus free status 1:Bus busy status | | 2 | SLVBSY | Slave busy flag 0:Other than during data transfer 1:During data transfer | | 1 | ACKVALID | ACK detection flag 0:Undetected 1:Detected | | 0 | - | - | ## ■ Serial Interface Input/Output Pin Switching Control Register (SCSEL: 0x03F90) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---------|---------|---------|-------|-----|-------|-------| | Flag | TMPSC12 | TMPSC11 | TMPSC02 | TMPSC01 | SC4SL | - | SC!SL | SC0SL | | At reset | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | bp | Flag | Description | |-----|--------------------|--------------------------------------------------------------------------------------------------------------------| | 7-6 | TMPSC12<br>TMPSC11 | Serial interface 1 used timer2 output dividing switching X0:Timer 2 output 01:Timer 2 output/2 11:Timer 2 output/8 | | 5-4 | TMPSC02<br>TMPSC01 | Serial interface0 used timer2 output dividing switching X0:Timer 2 output 01:Timer 2 output/2 11:Timer 2 output/8 | | 3 | SC4SL | Serial interface 4 I/O pin switching 0:P10, P11 1:P76, P77 | | 2 | - | - | | 1 | SC!SL | Serial interface 1 I/O pin switching 0:P15 to P17 1:PA4 to PA6 | | 0 | SC0SL | Serial interface 0 I/O pin switching<br>0:PA0 to PA2<br>1:P75 to P77 | # 14.2 Operation #### Activation and Termination Factors Set the SELI2C flag of the SC4AD1 register to "1" to activate this serial interface. For the termination, set the flag to "0". The ports used for communication can be used as general ports while the serial interface is not in operative state. When the SELI2C register is set to "0", SC4AD0 register, SC4TXB register and SC4RXB register is automatically cleared. #### ■ Slave Address Setup This serial interface can select either 7 bits or 10 bits slave address. To select 7 bits slave address, set the I2CADM flag of the SC4AD1 register to "0" to select 7 bits address mode, and set the slave address to upper 7 bits of the I2CAD0 register (I2CAD7 to I2CAD1). To select 10 bits slave address, set the I2CADM flag of the SC4AD1 register to "1" to select 10 bits address mode, and set the upper 2 bits of the slave address to lower 2 bits of the I2CAD1 register (I2CAD9, I2CAD8) and set the lower 8 bits of the slave address to I2CAD0 register. When 10 bits address mode is selected, this serial interface circuit is capable of data reception only. #### General Call Communication This serial interface is compatible with general call communication mode. Set the I2CGEM flag of the SC4AD1 register to "1" to select general call communication mode. In this mode, slave address set in the SC4AD0 and SC4AD1 registers are invalid. #### ■ Data Transmission/Reception This serial interface enables automatic address determination after detection of start condition on IIC bus. Serial interface 4 interrupt (SC4IRQ) is generated only when address transmitted from master matches the set slave address. Data transmission/reception are controlled with the WRS flag of the SC4STR register, and slave transmission is selected when the WRS flag is set to "0", slave reception is selected when the WRS flag is set to "1". In slave transmission, setting the transmission data to SC4TXB register opens the bus line and data transmission is started by the clock transmitted from master. In slave reception, setting the dummy data to SC4RXB register opens the bus line and data reception is started by the clock transmitted from master. #### ■ Start/Re-Start Condition Detection When data (SDA) pin changes from "H" to "L" while clock (SCL) pin is "H", start condition is detected and the STRT flag of the SC4STR register is set to "1". The STRT flag is cleared to "0" after communication data is set when the interrupt routine right after the slave address reception sets the communication data. If start condition is detected again during data transfer, the RSTRT flag is set. This flag is cleared to "0" after communication data is set when the interrupt routine right after the slave address reception sets the communication data. If address transmitted from master does not match the slave address, these flags are automatically cleared at the timing when address miscompare is detected. #### Busy Flag This serial interface contains 2 busy flags (SLVBSY, I2CBSY). The SLVBSY flag is set to "1" when address transmitted from master matches the slave address. The I2CBSY flag is set to "1" during communication on IIC bus. In 10 bits address mode, if the upper 2 bits address which is first to be transmitted from master matches the I2CAD9-8 of the SC4AD1 register, the SLVBSY flag is set to "1" but SC4IRQ is not generated. If the lower 8 bits address which is next to be transmitted from master matches the I2CAD7-0 of the SC4AD0 register, the SLVBSY flag is remained "1" and SC4IRQ is generated. If these address mismatch, the SLVBSY flag is cleared to "0" and SC4IRQ is not generated. #### Bus Line Monitor General call communication can be monitored with the bus line OFF (serial interface 4 is not activated). For monitoring, while the SELI2C flag is set to "1", set the I2CGEM flag of the SC4AD1 register to "1" and set the I2CMON flag to "1". Though serial 4 interrupt (SC4IRQ) is generated at this time, it does not output signal to the data and clock that it has no effect on the communication. #### ■ Pin Setup Table:14.2.1 shows pin setup (SDA, SCL pins) for IIC serial interface 4 data transmission. N-ch open drain setup is always necessary for using this serial interface. Use the pull-up resistor control register (PnPLU) of each port for pull-up resistor setup. Input/output of the transfer data is automatically switched. Table:14.2.1 Pin Setup | Item | Data I/O pin | Clock output pin | |-----------------------------------|------------------|------------------| | | SDA pin | SCL pin | | Port Pin | P10 | P11 | | | P76 | P77 | | Function | Serial data I/O | Serial clock I/O | | N-ch open-drain setup register | P1ODC<br>P7ODC | | | Pull-up resistor control register | P1PLUD<br>P7PLUD | | This serial interface does not features the function that resets the serial interface circuit by identifying reception data or by changing the slave address. Including general call communication mode, reception data identification should be done by software. ## 14.2.1 Setup Example of the Slave IIC Serial Interface #### ■ Setup Example of the Data Transmission The setup example for slave transmission with serial 4 is shown. Table:14.2.2 shows the conditions at transmission. Table:14.2.2 Conditions for Slave IIC Communication | Item | set to | |-------------------|---------| | Data pin (SDA) | P10 | | Clock pin (SCI) | P11 | | Addressing mode | 7 bits | | Slave address | 0110011 | | Transmission data | x'55' | | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Control the pin type. P1ODC (x'3F1B') bp1-0 :P1ODC1-0 =11 P1PLUD (x'3F41') bp1-0 :P1PLUD1-0 =11 | (1) Set the P1ODC0, P1ODC1 flags of the P1ODC register to "1" to select N-ch open-drain for P10 and P11. Set the P1PLUD0, P1PLUD1 flag of the P1PLUD register to "1" to add pull-up resistor. | | (2) Control the pin direction. P1DIR (x'3F31') bp1-0 :P1DIR1-0 =11 | (2) Set the P1DIR0, P1DIR1 flags of the port 1pin direction control register (P1DIR) to "1" to set P10 and P11 to output mode. | | (3) Select communication pin.<br>SCSEL (X'3F90)<br>bp3 :SC4SL =0 | (3) Set the SC4SL flag of the SCSEL register to "0" to select P10 and P11 for communication pins. | | (4) Select communication mode, address mode.<br>SC4AD1 (x'3FA8)<br>bp3 :I2CGEM =0<br>bp2 :I2CADM =0 | (4) Set the I2CGEM flag to "0" to select normal communication mode, and set I2CADM flag to "0" to select 7 bits address mode. | | (5) Activate serial interface 4.<br>SC4AD1 (x'3FA8)<br>bp7 :SELI2C =1 | (5) Set the SELI2C flag of the SC4AD1 register to "1" to activate the serial interface. | | (6) Set the slave address.<br>SC4AD0 (x'3FA7)<br>bp7-0 :I2CAD7-1 =0110011 | (6) Set the slave address to the upper 7 bits of the SC4AD1 register (I2CAD7-1). | | (7) Start IIC communication. | (7) Master on the IIC bus starts communication. | | Setup Procedure | Description | |-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (8) Confirm data transmission/reception.<br>SC4STR (x'3FAB')<br>bp7 :WRS =0 | (8) When the address transmitted from the master matches the slave address set in the SC4AD1 register, serial interface 4 interrupt (SC4IRQ) is generated. In the interrupt routine, when the WRS flag of the SC4MD0 register is "0", this communication is recognized as slave transmission. | | (9) Set transmission data.<br>SC4TXB (x'3FAA')<br>bp7-0 :SI2CTXB7-0 =x'55' | (9) Set the transmission data to the SC4TXB register. | # 15.1 Overview This LSI contains an A/D converter with 10 bits resolutions. It contains a built-in sample hold circuit. The channels 0 to 6 (AN0 to AN6) of analog input can be switched by software. When A/D converter is stopped, the power consumption can be reduced by turning the built-in ladder resistance OFF. A/D conversion is activated by a register setup. #### 15.1.1 Functions Table:15.1.1 shows the A/D converter functions. Table:15.1.1 A/D Converter Functions | A/D Input Pins | 7 pins | |------------------------|----------------------------------------| | Pins | AN6 to AN0 | | Interrupt | ADIRQ | | Resolution | 10 bits | | Conversion Time (Min.) | 24.5 μs(T <sub>AD</sub> = as 800 ns) | | Input range | V <sub>SS</sub> to V <sub>REF+</sub> | | Power Consumption | Built-in Ladder Resistance<br>(ON/OFF) | The conversion time shown in the above table does not include between the instant when A/D conversion start flag is enabled and the instant when the actual analog signal is sampled. The actual time is the conversion time plus 1 $T_{AD}$ . ## 15.1.2 Block Diagram #### ■ A/D Converter Block Diagram Figure:15.1.1 A/D Converter Block Diagram # 15.2 Control Registers A/D converter consists of the register (ANCTRn) and the data storage buffer (ANBUFn). ## 15.2.1 Registers Table:15.2.1 shows the registers used to control A/D converter. Table:15.2.1 A/D Converter Control Registers | Register | Address | R/W | Function | Page | |----------|---------|-----|------------------------------------------|--------| | ANCTR0 | 0x03FCB | R/W | A/D converter control register 0 | XV-5 | | ANCTR1 | 0x03FCC | R/W | A/D converter control register 1 | XV-6 | | ANCTR2 | 0x03FCD | R/W | A/D converter control register 2 | XV-6 | | ANBUF0 | 0x03FCE | R | A/D converter data storage buffer 0 | XV-7 | | ANBUF1 | 0x03FCF | R | A/D converter data storage buffer 1 | XV-7 | | ADICR | 0x03FF4 | R/W | A/D converter interrupt control register | III-37 | | IRQ2ICR | 0x03FE4 | R/W | External interrupt 2 control register | III-22 | | EDGDT | 0x03F1E | R/W | Both edges interrupt control register | III-49 | | PAIMD | 0x03F4E | R/W | Port A input mode register | IV-76 | | PAPLUD | 0x03F4A | R/W | Port A Pull-up resistor control register | IV-76 | R/W: Readable/Writable R: Readable only ## 15.2.2 Control Registers ## ■ A/D Converter Control Register0 (ANCTR0:0x03FCB) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|--------|---|---|---| | Flag | ANSH1 | ANSH0 | ANCK1 | ANCK0 | ANLADE | - | - | - | | Reset | 0 | 0 | 0 | 0 | 0 | - | - | - | | Access | R/W | R/W | R/W | R/W | R/W | - | - | - | | bp | Flag | Description | | | | |-----|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|--|--| | 7-6 | ANSH1 ANSH0 Sample hold time 00:T <sub>AD</sub> x 2 01:T <sub>AD</sub> x 6 10:T <sub>AD</sub> x 18 11:T <sub>AD</sub> x 18 | | | | | | 5-4 | ANCK1<br>ANCK0 | A/D conversion clock (ftad=1/T <sub>AD</sub> ) 00:fs/2 01:fs/4 10:fs/8 11:fx x 2 * as T <sub>AD</sub> >800 ns | | | | | 3 | ANLADE | A/D ladder resistance control 0:A/D ladder resistance OFF 1:A/D ladder resistance ON | | | | | 2-0 | - | - | | | | ## ■ A/D Converter Control Register1 (ANCTR1:0x03FCC) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|---|---|---|--------|--------|--------| | Flag | - | - | - | - | - | ANSHS2 | ANSHS1 | ANSHS0 | | Reset | - | - | - | - | - | 0 | 0 | 0 | | Access | - | - | - | - | - | R/W | R/W | R/W | | bp | Flag | Description | |-----|----------------------------|-------------------------------------------------------------------------------------------| | 7-3 | - | - | | 2-0 | ANSHS2<br>ANSHS1<br>ANSHS0 | Analog input channel 000:AN0 001:AN1 010:AN2 011:AN3 100:AN4 101:AN5 110:AN6 111:Reserved | ## ■ A/D Converter Control Register2 (ANCTR2:0x03FCD) | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|--------------|----------|---|---|---|---|---| | Flag | ANST | ANSTSEL<br>1 | Reserved | - | - | - | - | - | | Reset | 0 | 0 | 0 | - | - | - | - | - | | Access | R/W | R/W | R/W | - | - | - | - | - | | bp | Flag | Description | | | | |-----|--------------|-------------------------------------------------------------------------------------|--|--|--| | 7 | ANST | A/D conversion status 0:Finish, Hold 1:Start, Converting | | | | | 6 | ANSTSEL<br>1 | A/D conversion start factor selection 0:Set ANST flag to "1" 1:External interrupt 2 | | | | | 5 | Reserved | Set always to "0" | | | | | 4-0 | - | - | | | | ## 15.2.3 Data Buffers #### ■ A/D Conversion Data Storage Buffer0 (ANBUF0:0x03FCE) The lower 2 bits results from A/D conversion are stored to this register. | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---|---|---|---|---|---| | Flag | ANBUF07 | ANBUF06 | - | - | - | - | - | - | | Reset | Х | Х | - | - | - | - | - | - | | Access | R | R | - | - | - | - | - | - | ## ■ A/D Conversion Data Storage Buffer1 (ANBUF1:0x03FCF) The upper 8 bits results from A/D conversion are stored to this register. | bp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | Flag | ANBUF17 | ANBUF16 | ANBUF15 | ANBUF14 | ANBUF13 | ANBUF12 | ANBUF11 | ANBUF10 | | Reset | Х | Х | Х | Х | Х | Х | X | Х | | Access | R | R | R | R | R | R | R | R | # 15.3 Operation Description of A/D converter circuit setup procedure is as follows. 1. Set the analog pins. Set the analog input pin (set at the procedure 2) to "special function pin" by the port A input mode register (PAIMD). - \* Setup of the port A input mode register should be done before analog voltage is put to pins. - 2. Select the analog input pin. Select the analog input pin from AN6 to AN0 by the ANCHS2-0 flag of the A/D converter control register1 (ANCTR1). 3. Select the A/D converter clock. Select the A/D converter clock by the ANCK1, ANCK0 flag of the A/D converter control register 0 (ANCTR0). Converter clock (T<sub>AD</sub>) should not be less than 800 ns by any oscillator. 4. Set the sample hold time. Set the sample hold time by the ANSH1, ANSH0 flag of the A/D converter control register 0 (ANCTR0). The sample hold time should be based on analog input impedance. - \* Procedures (2) to (4) can be set in any order. (3) and (4) can be set at the same time. - 5. Set the A/D ladder resistance. Set the ANLADE flag of the A/D converter control register 0 (ANCTR0) to "1", and a current flow through the ladder resistance and A/D converter goes into the waiting. 6. Start A/D conversion. Set the ANST flag of the A/D converter control register 2 (ANCTR2) to "1" to start A/D converter. - \* Set the REDG0 flag of the external interrupt 2 control register (IRQ2ICR) and the EDGSEL flag of the edge interrupt control register (EDGDT) to specify the valid edge. - 7. A/D conversion After sampling by the sample hold time (set at the procedure 4), A/D conversion is decided in comparison with MSB in order. 8. Complete the A/D conversion. When A/D conversion is completed, the ANST flag is cleared to "0", and the result of the conversion is stored to the A/D buffer (ANBUF0,1). Then, the A/D complete interrupt request (ADIRQ) is generated. Set the ANLADE flag to "1" and wait 12 conversion clock to start A/D conversion. During A/D conversion, when the ANST flag is set to "0" to forcefully stop A/D conversion, more than (2 system clock) + (2 conversion clock) time is required to restart A/D conversion. When A/D conversion start factor is selected as "start by external interrupt" and ANST flag is set to "0" to forcefully stop A/D conversion, set always A/D conversion start factor to "0" before clearing the ANST flag to "0". Figure:15.3.1 Operation of A/D Conversion To read out the value of the A/D conversion, A/D conversion should be done several times to prevent noise error by confirming the match of level by program, or by using the average value. From A/D conversion start to the generation of A/D conversion complete interrupt is the A/D conversion period. Re-conversion is not executed if an external interrupt is generated between the instant when ANST flag is cleared and the instant when A/D conversion complete interrupt is generated. However, when ANST flag is set to "1" (software start up), reconversion is executed. ## 15.3.1 Setup #### ■ Input Pins of A/D Converter Setup Input pins for A/D converter is selected by the ANCH2-0 flag of the ANCTR1 register. #### ■ A/D Converter Clock Setup The A/D converter clock is set by the ANCK1 to ANCK0 flag of the ANCTR0 register. Set the A/D converter clock ( $T_{AD}$ ) more than 800 ns. Table:15.3.1 shows the machine clock (fosc, fx, fs) and the A/D converter clock ( $T_{AD}$ ). (calculated as fs = fosc/2, fx/4) Table:15.3.1 A/D Conversion Clock and A/D Conversion Cycle | | | A/D conversion clock | A/D conversion cycle (T <sub>AD</sub> ) | | | | | |---|---|----------------------|-----------------------------------------|--------------------------|-----------------|--|--| | | | CIUCK | at high speed oscillation | at low speed oscillation | | | | | | | | fosc=10 MHz | fosc=8.38 MHz | fosc=32.768 kHz | | | | 0 | 0 | fs/2 | 400 ns (no usable) | 477.33 ns (no usable) | 244.14 μs | | | | | 1 | fs/4 | 800 ns | 954.65 ns | 488.28 μs | | | | 1 | 0 | fs/8 | 1600 ns | 1.91 μs | 976.56 μs | | | | | 1 | fx*2 | 15.26 μs | 15.26 μs | 15.26 μs | | | For the system clock (fs), refer to [ Chapter 2 Clock Switching ]. #### ■ A/D Converter Sampling Time (Ts) Setup The sampling time of A/D converter is set by the ANSH1 to 0 flag of the ANCTR0 register. The sampling time of A/D converter depends on external circuit, so set the right value by analog input impedance. Table:15.3.2 Sampling Time of A/D Conversion and A/D Conversion Time | ANSH1 | ANSH0 | Sampling<br>time (Ts) | A/D conversion time[μs] | | | | | | | |-------|-------|-----------------------|----------------------------------------------|---------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|--|--| | | | | at high speed | at low speed | | | | | | | | | | at T <sub>AD</sub> =1600<br>ns<br>(fs=5 MHz) | at<br>T <sub>AD</sub> =954.65<br>ns<br>(fs=4.19<br>MHz) | at T <sub>AD</sub> =1.91<br>μs<br>(fs=4.19<br>MHz) | at<br>T <sub>AD</sub> =15.26<br>µs<br>(fx=32.768<br>kHz) | at<br>T <sub>AD</sub> =15.26<br>µs<br>(fx=32.768<br>kHz) | | | | 0 | 0 | T <sub>AD</sub> x 2 | 24.5 | 14.82 | 29.15 | 229.4 | 534.15 | | | | | 1 | T <sub>AD</sub> x 6 | 30.9 | 18.64 | 36.79 | 290.44 | 595.19 | | | | 1 | 0 | T <sub>AD</sub> x 18 | 50.1 | 30.09 | 59.71 | 473.56 | 778.31 | | | | | 1 | T <sub>AD</sub> x 18 | 50.1 | 30.09 | 59.71 | 473.56 | 778.31 | | | <sup>\*</sup> Calculated as fs=fosc/2,fx/4. The conversion time shown above does not include between the instant when A/D conversion start flag is enabled and the instant when the actual analog signal is sampled. The actual time is the conversion time plus 1 $T_{\rm AD}$ . [Calculus] Conversion Time = $T_S + 13T_{AD} + 2.5/fs$ A/D conversion time may be extended up to 0.5 system clock when $fx^*2$ is selected as the A/D conversion clock. #### ■ Built-in Ladder Register Control The ANLADE flag of the ANCTR0 register is set to "1" to send a current to the ladder resistance for A/D conversion. When A/D converter is stopped, the ANLADE flag of the ANCTR0 register is set to "0" to save the power consumption. #### ■ A/D Conversion Start Factor Selection A/D conversion start factor is set by the ANSTSEL1 flag of the ANCTR2 register. By setting the ANSTSEL1 flag of the ANCTR2 register, A/D conversion starts with the "external interrupt 2" factor. Also, A/D conversion starts when ANST flag of the ANCTR2 register is set to "1". When the "external interrupt 2" is selected as the A/D conversion start factor, specify the valid edge by the REDG0 flag of the external interrupt 2 control register (IRQ2ICR) or EDGSEL2 flag of the both edges interrupt control register (EDGDT). Specify the valid interrupt edge before selecting the interrupt factor by the A/D conversion start factor. When the "external interrupt 2" is selected as the A/D conversion start factor, specify the valid edge by the REDG0 flag of the external interrupt 2 control register (IRQ2ICR) or EDGSEL2 flag of the both edges interrupt control register (EDGDT). Specify the valid interrupt edge before selecting the interrupt factor by the A/D conversion start factor. #### A/D Conversion Start Setup A/D conversion start is set by the ANST flag of the ANCTR2 register. The ANST flag of the ANCTR2 register is set to "1" to start A/D conversion. When selecting "external interrupt 2" as the A/D conversion start factor, set the ANST flag of the ANCTR2 register to "1" after the external interrupt 2 is generated. Also, during A/D conversion, the ANST flag of the ANCTR2 register is set to "1" and cleared to "0" after the converted data is stored. ## 15.3.2 Setup Example #### ■ Example of A/D Converter Setup by Registers A/D conversion is started by setting registers. The analog input pins are set to AN0, the converter clock is set to fs/4, and the sampling hold time is set to $T_{AD}$ x 2. Then, A/D conversion complete interrupt is generated. An example setup procedure, with a description of each step is shown below. | Setup Procedure | Description | |--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Set the analog input pin. PAIMD(0x03F4E) bp0 :PAIMD0 =1 PAPLUD(0x03F4A) bp0 :PAPLU0 =0 | (1) Set the analog input pin (set at the procedure 2) as the special function pin by the port A input mode register (PAIMD). Also, disable pull-up resistor by the port A pull-up resistor control register (PAPLUD). | | (2) Select the analog input pin. ANCTR1(0x03FCC) bp2-0 :ANCHS2-0 =000 | (2) Select the analog input pin from AN6 to AN0 by the ANCH2-0 flag of the A/D converter control register1 (ANCTR1). | | (3) Select the A/D converter clock. ANCTR0(0x03FCB) bp5-4 :ANCK1-0 =01 | (3) Select the A/D converter clock by the ANCK1, ANCK0 flag of the A/D converter control register0 (ANCTR0). | | (4) Set the sample hold time. ANCTR0(0x03FCB) bp7-6 :ANSH1-0 =00 | (4) Set the sample hold time by the ANSH1, ANSH0 flag of the A/D converter control register0 (ANCTR0). | | (5) Set the interrupt level. ADICR(0x03FF4) bp7-6 :ADLV1-0 =00 | (5) Set the interrupt level by the ADLV1-0 flag of the A/D conversion complete interrupt control register (ADICR). If any interrupt request flag is already set, clear the flag. | | (6) Enable the interrupt. ADICR(0x03FF4) bp1 :ADIE =1 | (6) Set the ADIE flag the ADICR register to "1" to enable the interrupt. [Chapter 3 3.1.4 Interrupt Flag Setup] | | (7) Set the A/D ladder resistance. ANCTR0(0x03FCB) bp3 :ANLADE =1 | (7) Set the ANLADE flag of the A/D converter control register0 (ANCTR0) to "1" to send a current to the ladder resistance for the A/D conversion. | | (8) Start A/D conversion operation. ANCTR2(0x03FCD) bp7 :ANST =1 | (8) Set the ANST flag of the A/D converter control register2 (ANCTR2) to "1" to start the A/D conversion. | | (9) Complete A/D conversion operation. ANBUF0(0x03FCE) ANBUF1(0x03FCF) | (9) When A/D conversion is completed, the result is stored to the A/D buffer (ANBUF0,1) and the ANST flag of the A/D converter control register2 (ANCTR2) is cleared to "0". Then A/D conversion complete interrupt is generated. | <sup>\*</sup> The procedures (3) to (4) can be set at the same time. After A/D conversion is completed, when A/D conversion is re-started with a different setup, set the ANLADE of the A/D converter control register0 (ANCTR0) to "0" and confirm the analog stop before changing the setup. Operations of other procedures are not guaranteed. ## 15.3.3 Cautions A/D conversion can be damaged by noise easily. Therefore, anti-noise measures should be taken adequately. #### ■ Anti-noise measures For A/D input (analog input pin), add capacitor near the Vss pins of micro controller. Figure:15.3.2 A/D Converter Recommended Example 1 Figure:15.3.3 A/D Converter Recommended Example 2 For high precision of A/D conversion, the following cautions on A/D converter should be kept. 1. The input impedance R of A/D input pin should be under 500 k $\Omega$ , and the external capacitor C (more than 1000 pF, under 1 $\mu$ F) should be connected to it. 2. The A/D conversion frequency should be set in regard to R, C. 3.At the A/D conversion, if the input level of microcontroller is changed, or the peripheral added circuit is switched to ON/OFF, the A/D conversion could work wrongly, as the analog input pins and power pins cannot be fixed. At the setup checking, confirm the wave form of analog input pins. Figure:15.3.4 Recommended Circuit Chapter 15 A/D Converter # 16.1 Functions This LSI contains an internal LCD driver circuit with 12 segment pins and 4 common pins. The LCD driver contains of a segment output latch, LCD control registers, a prescaler, a timing control circuit, a multiplexer, segment drivers, common drivers and voltage divider resistors. ## 16.1.1 Functions Table:16.1.1 shows the functions of the LCD driver circuits. Table:16.1.1 LCD Functions | | LCD | |------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Duty | Static 1/2 duty 1/3 duty 1/4 duty | | Segment Output Pins | SEG0 to SEG11 | | Common Output Pins | COM0 to COM3 | | LCD Power Supply | V <sub>LC1</sub> to V <sub>LC3</sub> | | LCD Voltage Divider Resistor | V <sub>LC1</sub> input voltage can be divided into 2/3, 1/3. Selectable from high resistance or low resistance. | | Clock Source (LCDCLK) | fosc/2 <sup>11</sup> fosc/2 <sup>12</sup> fosc/2 <sup>13</sup> fosc/2 <sup>14</sup> fosc/2 <sup>15</sup> fosc/2 <sup>16</sup> fosc/2 <sup>17</sup> fosc/2 <sup>18</sup> fx/2 <sup>6</sup> fx/2 <sup>7</sup> fx/2 <sup>8</sup> fx/2 <sup>9</sup> | fosc: Machine clock (High speed oscillation) fx: Machine clock (Low speed oscillation) LCDCLK: LCD clock source (selected with LCDCK0 to LCDCK3) Use the LCD panel driver voltage $V_{LCD}$ as $V_{LCD} \pounds V_{DD} \pounds 3.6 v$ ## 16.1.2 LCD Operation in Standby Mode Certain LCD driver operation could be limited in standby mode. Table:16.1.2 shows the LCD operation capabilities in standby mode. Table:16.1.2 LCD Operation in Standby Mode | CPU Mode | | LCD Clock | | | |----------------|--------|-----------|----|--| | | | fosc | fx | | | Operation Mode | NORMAL | 0 | 0 | | | | SLOW | ¥ | 0 | | | Standby Mode | HALT0 | D | D | | | | HALT1 | ¥ | D | | | | STOP | ¥ | ¥ | | - O: LCD Operation is available. - D: Holding Display is available. - ¥: LCD Operation is not available. For transition to CPU mode in which LCD operation is not available, turn the LCD off and switch segment output to port in advance. For transition to the mode with low speed oscillation, set the bp0 of the XI dual function selection register (XSEL) to "1". #### 16.1.3 Maximum Pixels Table:16.1.3 shows the maximum pixels. Table:16.1.3 Maximum Pixels | Duty | Maximum Pixels<br>(Segment ¥ Common) | 8-Segment<br>LCD Panel | Common Pins | Segment Output Latch bits | |--------|--------------------------------------|------------------------|--------------|----------------------------| | Static | 12 (12 ¥ 1) | 1 figures | СОМО | bit0, bit4 | | 1/2 | 24 (12 ¥ 2) | 3 figures | COM0 to COM1 | bit0 to bit1, bit4 to bit5 | | 1/3 | 36 (12 ¥ 3) | 4 figures | COM0 to COM2 | bit0 to bit2, bit4 to bit6 | | 1/4 | 48 (12 ¥ 4) | 6 figures | COM0 to COM3 | bit0 to bit3, bit4 to bit7 | ## 16.1.4 Switching I/O ports and LCD segment pins Switching of general port and LCD segment pin is controlled by the LCD output control register 1, 2 (LCCTR1, LCCTR2). [Chapter 16 16.2 Control Registers] Port 7, 1 (SEG0 to SEG11) are switchable to I/O port in 1-bit unit. Port 3 (COM0 to COM3) is switchable to I/O port in 1-bit unit. ## 16.1.5 Switching I/O Ports and LCD Voltage¶ Switching of general ports, P34 to P36 and LCD voltage, $V_{LC3}$ to $V_{LC1}$ are controlled by the LCD control register3 (LCDMD3). [16.2 Control Registers] Only when the LCD functions are unused, general ports, P34 to P36 are available. When general ports, P34 to P36 are used, set the VLC3SL to VLC1SL flags of the LCD control register 3 (LCCTR3) to "0" and select P34 to P36. ## 16.1.6 Block Diagram Figure:16.1.1 LCD Driver Circuit Block Diagram # 16.2 Control Registers The LCD is controlled by LCD mode control register 1 (LCDMD1), LCD mode control register 2 (LCDMD2), LCD output control register 1 (LCCTR1), LCD output control register 2 (LCCTR2), and LCD output control register 3 (LCCTR3). The LCD display data is stored in the segment output latch. ## 16.2.1 Registers Table:16.2.1 shows the LCD control registers. Table:16.2.1 LCD Control Registers List | Register | Address | R/W | Function | Page | |----------|----------|-----|-------------------------------|--------| | LCDMD1 | X'03FC0' | R/W | LCD mode control register 1 | XVI-7 | | LCDMD2 | X'03FC1' | R/W | LCD mode control register 2 | XVI-8 | | LCCTR1 | X'03FC2' | R/W | LCD output control register 1 | XVI-9 | | LCCTR2 | X'03FC3' | R/W | LCD output control register 2 | XVI-10 | | LCCTR3 | X'03FC4' | R/W | LCD output control register 3 | XVI-11 | R/W: Readable/Writable [Chapter 16.2.7 Segment Output Latch] <sup>\*</sup> Address x'02E00' to x'02E05' are assigned to the segment output latch. ## 16.2.2 Mode Control Register 1 (LCDMD1) The LCD mode control register 1 (LCDMD1) is a 8-bit register that controls LCD clock, LCD display ON/OFF, and display duty. The address is assigned to X'3FC0' and read/write can be done by the instruction to RAM, I/O. The value of the LCDMD1 register is initialized at reset. Table:16.2.2 shows the LCD mode control register 1. ■ Mode Control Register 1 (LCDMD1: X'03FC0', R/W) Table:16.2.2 LCD Mode Control Register 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|----------|--------|--------|--------|--------|--------|--------| | Flag | LCDEN | Reserved | LCDTY1 | LCDTY0 | LCDCK3 | LCDCK2 | LCDCK1 | LCDCK0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | Flag | Description | |-----|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | LCDEN | LCD driver circuit start flag 0: Stop 1: Start | | 6 | Reserved | Set always to "0". | | 5-4 | LCDTY1<br>LCDTY0 | LCD display duty selection 00: 1/4 duty 01: 1/3 duty 10: 1/2 duty 11: Static | | 3-0 | LCDCK3<br>LCDCK2<br>LCDCK1<br>LCDCK0 | LCD clock source selection 0000: OSC1/2 <sup>11</sup> 0001: OSC1/2 <sup>12</sup> 0010: OSC1/2 <sup>13</sup> 0011: OSC1/2 <sup>14</sup> 0100: OSC1/2 <sup>15</sup> 0101: OSC1/2 <sup>16</sup> 0110: OSC1/2 <sup>17</sup> 0111: OSC1/2 <sup>18</sup> 1X00: XI/2 <sup>6</sup> 1X1: XI/2 <sup>7</sup> 1X10: XI/2 <sup>8</sup> 1X11: XI/2 <sup>9</sup> | For transition to the mode with low speed oscillation, set the bp0 of the XI dual function selection register (XSEL) to "1". ## 16.2.3 Mode Control Register 2 (LCDMD2) The LCD mode control register 2 (LCDMD2) is a 8-bit register that controls internal voltage dividing resistor ON/OFF, and internal voltage dividing resistor type. The address is assigned to X'3FC1' and read/write can be done by the instruction to RAM, I/O. The value of the LCDMD2 register is initialized at reset. Table:16.2.3 shows the LCD mode control register 1. ■ Mode Control Register 2 (LCDMD2: X'03CF1', R/W) Table:16.2.3 LCD Mode Control Register 2 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|----------|----------|-------|-------|-----|-----| | Flag | - | - | Reserved | Reserved | LCRHL | LCREN | - | - | | Reset | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | Flag | Description | |-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | - | - | | 5-4 | Reserved | Set always to "0". | | 3 | LCRHL | Internal voltage dividing resistor selection 0: Low resistance ( $V_{LC1}$ to $V_{LC2}$ , $V_{LC2}$ to $V_{LC3}$ , $V_{LC3}$ to $V_{SS}$ , about 10 kW) 1: High resistance ( $V_{LC1}$ to $V_{LC2}$ , $V_{LC2}$ to $V_{LC3}$ , $V_{LC3}$ to $V_{SS}$ , about 100 kW) | | 2 | LCREN | Internal voltage dividing circuit connect selection 0: Unconnected 1: Connected | | 1-0 | - | - | With the internal voltage dividing resistor, P34 ( $V_{LC3}$ ), P35 ( $V_{LC2}$ ), P36 ( $V_{LC1}$ ) can be used as ports. However, depending on the panel, if LCD display does not have enough brightness due to the lack of connection with a stabilizing capacitor, connect with a stabilizing capacitor or use an external voltage dividing resistor. ## 16.2.4 Output Control Register 1 (LCCTR1) The LCD output control register 1 (LCCTR1) switches port I/O (P30 to P33) and common output (COM0 to COM3), port I/O (P74 to P77) and segment output (SEG0 to SEG3). The address is assigned to X'3FC2'. At reset, these ports are set to the input port. ■ Output Control Register 1(LCCTR1:X'3FC2', R/W) Table:16.2.4 LCD Output Control Register 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | LC1SL3 | LC1SL2 | LC1SL1 | LC1SL0 | COMSL3 | COMSL2 | COMSL1 | COMSL0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | Flag | Description | |---|--------|-----------------------------------------| | 7 | LC1SL3 | SEG3/P74 selection 0: P74 1: SEG3 | | 6 | LC1SL2 | SEG2/P75 selection 0: P75 1: SEG2 | | 5 | LC1SL1 | SEG1/P76 selection 0: P76 1: SEG1 | | 4 | LC1SL0 | SEG0/P77 selection 0: P77 1: SEG0 | | 3 | COMSL3 | COM3/P33 selection 0: P33 1: COM3 | | 2 | COMSL2 | COM2/P32 selection 0: P32 1: COM2 | | 1 | COMSL1 | COM1/P31 selection 0: P31 1: COM1 | | 0 | COMSL0 | COM0/P30 selection<br>0: P30<br>1: COM0 | ## 16.2.5 Output Control Register 2 (LCCTR2) The LCD output control register 2 (LCCTR2) switches port I/O (P73 to P70), port I/O (P14 to P17) and segment output (SEG4 to SEG11). The address is assigned to X'3FC3'. At reset, these ports are set to the input port. ■ Output Control Register 2(LCCTR2:X'3FC3', R/W) Table:16.2.5 LCD Output Control Register 2 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | Flag | LC2SL7 | LC2SL6 | LC2SL5 | LC2SL4 | LC2SL3 | LC2SL2 | LC2SL1 | LC2SL0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | Flag | Description | |---|--------|-------------------------------------------| | 7 | LC2SL7 | SEG11/P14 selection<br>0: P14<br>1: SEG11 | | 6 | LC2SL6 | SEG10/P15 selection<br>0: P15<br>1: SEG10 | | 5 | LC2SL5 | SEG9/P16 selection 0: P16 1: SEG9 | | 4 | LC2SL4 | SEG8/P17 selection 0: P17 1: SEG8 | | 3 | LC2SL3 | SEG7/P70 selection<br>0: P70<br>1: SEG7 | | 2 | LC2SL2 | SEG6/P71 selection<br>0: P71<br>1: SEG6 | | 1 | LC2SL1 | SEG5/P72 selection 0: P72 1: SEG5 | | 0 | LC2SL0 | SEG4/P73 selection 0: P73 1: SEG4 | ## 16.2.6 Output Control Register 3 (LCCTR3) The LCD output control register 3 (LCCTR3) switches port I/O (P34 to P36) and $V_{LC1}$ to $V_{LC3}$ . The address is assigned to X'3FC4'. At reset, these ports are set to the input port. ■ Output Control Register 3 (LCCTR3:X'3FC4', R/W) Table:16.2.6 LCD Output Control Register 3 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|-----|-----|--------|--------|--------| | Flag | - | - | - | - | - | LC3SL2 | LC3SL1 | LC3SL0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Access | R/W | | Flag | Description | |-----|--------|-----------------------------------| | 7-3 | - | - | | 2 | LC3SL2 | VLC3/P34 selection 0: P34 1: VLC3 | | 1 | LC3SL1 | VLC2/P35 selection 0: P35 1: VLC2 | | 0 | LC3SL0 | VLC1/P36 selection 0: P36 1: VLC1 | With the internal voltage dividing resistor, P34 ( $V_{LC3}$ ), P35 ( $V_{LC2}$ ), P36 ( $V_{LC1}$ ) can be used as ports. However, depending on the panel, if LCD display does not have enough brightness due to the lack of connection with a stabilizing capacitor, connect with the stabilizing capacitor or use an external voltage dividing resistor. ### 16.2.7 Segment Output Latch A 4-bit latch is allocated per segment. Bit0 and bit4 are read out at the timing of COM0, bit1 and bit5 are read out at the timing of COM1, bit2 and bit6 are read out at the timing of COM2, and bit3and bit7 are read out at the timing of COM3. If a bit points "1", the segment pin outputs the "selected voltage", and if a bit points "0", the segment pin outputs "non-selected voltage". The assigned address are X'2E00' to X'2E05', and data reading/writing can be done as RAM. Segment output latch value is indefinite at reset. Figure:16.2.1 shows the matching of the segment output latch and the segment/common pins. Figure:16.2.1 Matching of the Segment Output Latch and the Segment/Common Pins # 16.3 Operation ### 16.3.1 Operation The LCD driver is capable of static display and dynamic display (1/2 duty 1/2 bias, 1/3 duty 1/3 bias, 1/4 duty 1/3 bias) through the segment output pins (SEG0 to SEG11) and the common output pins (COM0 to COM3). ■ The LCD driver circuit operation The LCD driver circuit generates the timing signals, which are necessary for controlling 1/2 duty, 1/3 duty, 1/4 duty and static, at the timing control circuit, based on the LCD clock divided by the prescaler, and supplies them to the common driver and the multiplexer. The common driver outputs the common signals which are necessary for the LCD display, based on the voltage from the LCD power supply. When the LCD is OFF, Vss is output and the potential difference between the LCD electrodes becomes 0 V. The multiplexer selects the segment output latched data in response to the signal from the timing control circuit and supplies it to the segment driver. The segment driver converts the content of the segment output latch into the signals, which is capable of driving the LCD, based on the voltage supplied to LCD power supply, then outputs the segment signal. When the LCD is OFF, Vss is output and the potential difference between the LCD electrodes becomes 0 V. At reset, common pins and segment pins become high impedance. Therefore, when reset input from external sources is long, there could be some adverse effects such as blinks of the LCD display. In STOP mode, supplies from the main clocks is stopped that the LCD drive cannot be operated. Set "0" to the enable flag of the LCD driver circuit before entering STOP mode. For transition to the mode with low speed oscillation, set the bp0 of the XI dual function selection register (XSEL) to "1". ### 16.3.2 Power Supply The driver power pins are $V_{LC1}$ , $V_{LC2}$ and $V_{LC3}$ . This LSI contains the internal voltage dividing resistor to divide voltage for LCD drive. There are two ways to supply voltage to the LCD driver; to supply voltage to the $V_{LC1}$ , $V_{LC2}$ and $V_{LC3}$ pins from external source (when external voltage dividing resistor is used), to supply voltage to $V_{LC1}$ pin from external source and use internal divider resistor. The power source for LCD drive and $V_{DD}$ power supply for the micro controller are separated so that the voltage $V_{DD}$ for LCD panel drive can be used at higher voltage than the $V_{DD}$ power supply (usable at $V_{LCD} \pounds V_{DD} \pounds 3.6$ V). The LCD driver voltage supplied through the LCD driver power pins ( $V_{LC1}$ , $V_{LC2}$ and $V_{LC3}$ ) is converted by the LCD clock signal and the timing control signal, and then supplied to the segment driver and the common driver. Table:16.3.1 Supplying LCD drive voltage (with 1/3 bias) | Supp | Supplying voltage | | Description | |------|-------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Supply the driving voltage directly | V <sub>LC1</sub><br>V <sub>LC2</sub><br>V <sub>LC3</sub> | Supply voltage to VLC1, VLC2, VLC3 pins externally. | | 2 | Use the external dividing resistor | V <sub>LC1</sub><br>V <sub>LC2</sub><br>V <sub>LC3</sub> | Supply the reference voltage to VLC1 pin externally and generate VLC2, VLC3 potentials at the external resistor divider, then supply the voltage to each pin. | | 3 | Use the internal dividing resistor | V <sub>LC1</sub> | Supply the reference voltage to VLC1 externally and generate VLC2, VLC3 potentials by using the internal resistor., | #### ■ Supplying voltage with the external voltage driving resistor Supply the voltage as shown in Table:16.3.2. Table:16.3.2 LCD Power Supply | | Static | 1/2 | 1/3 | |------------------|------------------------------------|---------------------------------------|---------------------------------------| | V <sub>LC1</sub> | V <sub>LCD</sub> + V <sub>SS</sub> | V <sub>LCD</sub> + V <sub>SS</sub> | V <sub>LCD</sub> + V <sub>SS</sub> | | V <sub>LC2</sub> | | 1/2V <sub>LCD</sub> + V <sub>SS</sub> | 2/3V <sub>LCD</sub> + V <sub>SS</sub> | | V <sub>LC3</sub> | V <sub>SS</sub> | | 1/3V <sub>LCD</sub> + V <sub>SS</sub> | V<sub>LCD</sub>: LCD panel driver voltage (Maximum voltage to the LCD panel) Use the LCD panel driver voltage $V_{LCD}$ at $V_{LCD} \pounds V_{DD} \pounds 3.6 V$ . $Figure: 16.3.1 \ shows \ example \ of \ the \ LCD \ power \ supply \ connection.$ #### (a) Static (VDD=VLCD) #### (b) 1/3duty 1/3bias, 1/4duty 1/3bias (VDD=VLCD) Figure:16.3.1 LCD Power Supply Connection (When using External Voltage Divider Resistors) 1.In Figure:16.3.1, current always flows through the voltage dividing resistors. The following connection is used to cut the current flowing through these dividing resistors. (at $V_{CL1} = V_{DD}$ ) Figure:16.3.2 LCD Power Supply Connection 2.The LCD power supply $V_{LC1}$ to $V_{LC3}$ is supplied as shown in the following Figure:16.3.3. $V_{LCD}$ value varies depending on the type of LCD. Refer to the specifications of LCD for the appropriate value. $$V_{LC1} = V_{LCD} + V_{SS}$$ $V_{LC2} = 2/3 V_{LCD} + V_{SS}$ $V_{LC3} = 1/3 V_{LCD} + V_{SS}$ Usually $V_{\mbox{\scriptsize DD}}$ - Vss are divided by resistors and supplied to the LCD. Standard resistance voltage ranges from tens to several hundreds kW. In Figure:16.3.3, a bypass capacitor C (0.01 mF to 0.1 mF) is used to lower the impedance of power supply. Figure:16.3.3 Supplying Voltage to V<sub>LC1</sub> to V<sub>LC3</sub> ■ Supplying voltage when using the internal voltage driving circuit Supply the voltage as shown in Table:16.3.3. Table:16.3.3 | | Static | 1/2 bias | 1/3 bias | |------------------|----------|--------------------------------------------------------------------------------|----------------------------------------| | V <sub>LC1</sub> | Disabled | V <sub>LCD</sub> | $V_{LCD}$ | | V <sub>LC2</sub> | | Connect V <sub>LC2</sub> to V <sub>LC3</sub> (1/2 V <sub>LCD</sub> is output.) | -<br>(2/3 V <sub>LCD</sub> is output.) | | V <sub>LC3</sub> | | | - (1/3 V <sub>LCD</sub> is output.) | When internal voltage dividing resistor is used, voltages of $V_{LC1}$ , $V_{LC2}$ and $V_{LC3}$ could be dropped depending on a used LCD panel and that may lower the brightness of LCD display. Use the external divider resistor when this happens. With the internal voltage dividing resistor, P34 ( $V_{LC3}$ ), P35 ( $V_{LC2}$ ), P36 ( $V_{LC1}$ ) can be used as ports. However, depending on the panel, if LCD display does not have enough brightness due to the lack of connection with a stabilizing capacitor, connect with the stabilizing capacitor or use an external voltage dividing resistor. The internal dividing resistor is formed of connecting between $V_{LC1}$ and $V_{LC2}$ , $V_{LC2}$ and $V_{LC3}$ , $V_{LC3}$ and $V_{SS}$ . In the selection of the internal dividing resistor type, when low resistor is selected, about 10 kW resistor is connected between $V_{LC1}$ and $V_{LC2}$ , $V_{LC2}$ and $V_{LC3}$ , $V_{LC3}$ and $V_{SS}$ . When high resistor is selected, about 100 kW resistor is connected to each pin. Figure:16.3.4 Forming of Internal Dividing Resistor and Resistor Value Figure:16.3.5 shows example of the LCD power supply connection. Stabilizing capacitor C for LCD power supply is recommended to be $C=0.1\ mF$ . Cv $\check{S}$ 0.1 mF should be connected as stabilization condenser Cv for $V_{DD}$ power supply. #### (a)1/2duty 1/2bias (VDD=VLCD) #### (b)1/3duty 1/3bias, 1/4duty 1/3bias (VDD=VLCD) Figure:16.3.5 LCD Power Supply Connection ## 16.3.3 Frame Cycle #### ■ Setup of the LCD frame cycle The clock fosc or fx is divided by the prescaler and supplied as the LCD clock. Set the LCD clock by the bit0 to bit3 of the LCDMD1 register, and set the LCD frame cycle by the bit4 to bit5 of the LCDMD1 register. Figure:16.3.6 shows reference input frequencies and the matching of the LCD clock and the LCD frame cycle. | | | | | | In | put freque | ncy | | | | | |-------------------------|---------------|----------|---------|----------|---------|------------|---------|----------|--------|-----------|--------| | Input cloci | duty | 10 MHz | | 8 MHz | | 4 MHz | | 2 MHz | | 32.76 | 8 kHz | | LCDCK3 to 0 | LCDTY1 to 0 | LCD dock | frame | LCD dock | frame | LCD dock | frame | LCD dock | frame | LCD ckock | frame | | | 00 (1/4 duty) | | 1221 Hz | | 977 Hz | | 488 Hz | | 244 Hz | | | | 0000 | 01 (1/3 duty) | 1 | 1628 Hz | | 1302 Hz | 1953 Hz | 651 Hz | 977 Hz | 326 Hz | | | | (OSC1/2 <sup>11</sup> ) | 10 (1/2 duty) | 4883 Hz | 2441 Hz | 3906Hz | 1953 Hz | | 977 Hz | | 488 Hz | | | | | 11 (static) | 1 | 4883 Hz | | 3906 Hz | | 1953 Hz | | 977 Hz | | | | | 00 (1/4 duty) | | 610 Hz | | 488 Hz | | 244 Hz | | 122 Hz | | | | 0001 | 01 (1/3 duty) | | 814 Hz | | 651 Hz | | 326 Hz | | 163 Hz | | | | (OSC1/2 <sup>12</sup> ) | 10 (1/2 duty) | 2441 Hz | 1221 Hz | 1953 Hz | 977 Hz | 977 Hz | 488 Hz | 488 Hz | 244 Hz | | | | | 11 (static) | 1 | 2441 Hz | | 1953 Hz | | 977 Hz | | 488 Hz | | | | | 00 (1/4 duty) | | 305 Hz | | 244 Hz | | 122 Hz | | 61 Hz | | | | 0010 | 01 (1/3 duty) | 1 | 407 Hz | | 326 Hz | | 163 Hz | | 81 Hz | | | | (OSC1/2 <sup>13</sup> ) | 10 (1/2 duty) | 1221 Hz | 610 Hz | 977 Hz | 488 Hz | 488 Hz | 244 Hz | 244 Hz | 122 Hz | | | | | 11 (static) | ] | 1221 Hz | | 977 Hz | | 488 Hz | | 244 Hz | | | | | 00 (1/4 duty) | | 153 Hz | | 122 Hz | | 61 Hz | | 31 Hz | | | | 0011 | 01 (1/3 duty) | 1 | 203 Hz | | 163 Hz | | 81 Hz | | 41 Hz | | | | (OSC1/2 <sup>14</sup> ) | 10 (1/2 duty) | 610 Hz | 305 Hz | 488 Hz | 244 Hz | 244 Hz | 122 Hz | 122 Hz | 61 Hz | | | | | 11 (static) | 1 | 610 Hz | | 488 Hz | | 244 Hz | | 122 Hz | | | | | 00 (1/4 duty) | | 76 Hz | | 61 Hz | | 31 Hz | | 15 Hz | | | | 0100 | 01 (1/3 duty) | | 102 Hz | 244 Hz | 81 Hz | 122 Hz | 41 Hz | 61 Hz | 20 Hz | | | | (OSC1/2 <sup>15</sup> ) | 10 (1/2 duty) | 305 Hz | 153 Hz | | 122 Hz | | 61 Hz | | 31 Hz | | | | | 11 (static) | | 305 Hz | | 244 Hz | | 122 Hz | | 61 Hz | | | | | 00 (1/4 duty) | | 38 Hz | | 31 Hz | | 15 Hz | | 8 Hz | | | | 0101 | 01 (1/3 duty) | | 51 Hz | 122 Hz | 41 Hz | 61 Hz | 20 Hz | 31 Hz | 10 Hz | | | | (OSC1/2 <sup>16</sup> ) | 10 (1/2 duty) | 153 Hz | 76 Hz | | 61 Hz | | 31 Hz | | 15 Hz | | | | | 11 (static) | | 153 Hz | | 122 Hz | | 61 Hz | | 31 Hz | | | | | 00 (1/4 duty) | | 19 Hz | | 15 Hz | 31 Hz | 8 Hz | 15 Hz | 4 Hz | | | | 0110 | 01 (1/3 duty) | | 25 Hz | 61 Hz | 20 Hz | | 10 Hz | | 5 Hz | | | | (OSC1/2 <sup>17</sup> ) | 10 (1/2 duty) | 76 Hz | 38 Hz | | 31 Hz | | 15 Hz | | 8 Hz | | | | | 11 (static) | | 76 Hz | | 61 Hz | | 31 Hz | | 15 Hz | | | | | 00 (1/4 duty) | | 10 Hz | | 8 Hz | | 4 Hz | 2 Hz | | | | | 0111 | 01 (1/3 duty) | 20.11- | 13 Hz | 24 11- | 10 Hz | 4511- | 5 Hz | 8 Hz | 3 Hz | | | | (OSC1/2 <sup>18</sup> ) | 10 (1/2 duty) | 38 Hz | 19 Hz | 31 Hz | 15 Hz | 15 Hz | 8 Hz | | 4 Hz | | | | | 11 (static) | | 38 Hz | | 31 Hz | | 15 Hz | | 8 Hz | | | | | 00 (1/4 duty) | | | | | | | | | | 128 Hz | | 1X00 | 01 (1/3 duty) | | | | / . | | / . | | 54011- | 171 Hz | | | (XI/2 <sup>6</sup> ) | 10 (1/2 duty) | | | | | | | | | 512 Hz | 256 Hz | | | 11 (static) | | | | | | | | | | 512 Hz | | | 00 (1/4 duty) | | | | | | | | | | 64 Hz | | 1X01 | 01 (1/3 duty) | | | | | , | | , | | 256 Hz | 85 Hz | | (XI/2 <sup>7</sup> ) | 10 (1/2 duty) | ] / | | | | / | | / | | 200 02 | 128 Hz | | | 11 (static) | $\angle$ | | | | | | | | | 256 Hz | | | 00 (1/4 duty) | 1 | | | | | | | | | 32 Hz | | 1X10 | 01 (1/3 duty) | | | | | ] . | | , | | 128 Hz | 43 Hz | | (XI/2 <sup>8</sup> ) | 10 (1/2 duty) | / | | | | / | | / | | 126 HZ | 64 Hz | | | 11 (static) | | | | | | | $\angle$ | | | 128 Hz | | | 00 (1/4 duty) | 1 | | | | | | | | | 16 Hz | | 1X11 | 01 (1/3 duty) | | | | | | | | | 64 Hz | 21 Hz | | (XI/2 <sup>9</sup> ) | 10 (1/2 duty) | / | | | | / | | | 32 Hz | | | | | 11 (static) | $\angle$ | | | | $\angle$ | | $\angle$ | | | 64 Hz | Figure:16.3.6 Input Frequency and the LCD Clock ## 16.3.4 Setup Example of the LCD Driver Circuit ■ Setup example of the internal voltage dividing resistor An example of setup procedure to display "23" on a 8 segment type LCD panel in 1/4 duty, 1/3 bias with both segment signals (SEG0 to SEG3) and common signals (COM0 to COM3), using internal voltage divider circuit is shown below. Refer to XIV-18. Figure:16.3.5 for the LCD power supply connection. Refer to XIV-22. LCD display for connection of LCD panel. | Setup Procedure | Description | |-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Select the internal voltage dividing resistor LCDMD2 (x'3FC1') bp3 : LCRHL = 1 | (1) Set the LCRHL flag of the LCD mode control register 2 (LCDMD2) to "1" to set up the internal voltage dividing resistor to high resistor. | | (2) Select the internal voltage dividing resistor connection LCDMD2 (x'3FC1') bp2 : LCREN = 1 | (2) Set the LCREN flag of the LCD mode control register 2 (LCDMD2) to "1" to connect the internal voltage dividing resistor between V <sub>LC1</sub> and V <sub>LC2</sub> , V <sub>LC2</sub> and V <sub>LC3</sub> , V <sub>LC3</sub> and Vss. | | (3) Set the pins | (3) Set COMSL3 to COMSL0 flags of the LCD output control register 1 (LCCTR1) to "1111" to set up the common pins 3 to 0. Set LC1LS1 to LC1LS0 flags of the LCD output control register 1 (LCCTR1) to "1" to set up the segment pins 3 to 0. | | (4) Select the LCD clock source<br>LCDMD1 (x'3FC0')<br>bp3-0 : LCDCK3-0 = 0111 | (4) Select OSC1/2 <sup>18</sup> as the LCD clock source by LCDCK3 to LCDCK0 flags of the LCD mode control register 1 (LCDMD1). | | (5) Select the LCD display duty LCDMD1 (x'3FC0') bp5-4 : LCDTY1-0 = 00 | (5) Set LCDTY1 to LCDTY0 flags of the LCD mode control register 1 (LCDMD1) to "00" to setup the display duty | | (6) Set the LCD panel display data<br>x'2E00' = x'5E'<br>x'2E01' = x'7C' | (6) Set the display data on the address X'2E00', X'2E01' of the segment output latch. [Refer to 16.4 LCD Display] | | (7) Start the LCD drive circuit<br>LCDMD1 (x'3FC0')<br>bp7 : LCDEN = 1 | (7) Set the LCDEN flag of the LCD mode control register 1 (LCDMD1) to "1" to start the LCD driver circuit. | If internal voltage booster circuit is used, voltage of $V_{LC1}$ , $V_{LC2}$ and $V_{LC3}$ could be dropped depending on the load of used LCD panel and that may lower the brightness of LCD display. In this case, set "0" to the internal voltage dividing resistor selection bit of the LCD mode control register 2 (LCDMD2) to select the low resistor. By selecting the low resistor, the current supply ability can be larger. # 16.4 Display Figure:16.4.1 to Figure:16.4.4 show example of connections, display and waveforms of the LCD panel in 1/2 duty, 1/3 duty, 1/4 duty and static. #### 16.4.1 Static #### ■ Static S:selected voltage N:non-selected voltage VLCD:LCD driver voltage On static COM(COM0) always outputs selected voltage. Figure:16.4.1 LCD Display in Static ## 16.4.2 Setup Example (Static) #### ■ Setup example of the LCD (static) An example of setup procedure to display "23" on a single-digit, 8 segment type LCD panel with both segment signals (SEG0 to SEG7) and common signals (COM0), using an external dividing resistor is shown below. [Chapter 16.4.1. LCD Display (static)] Clock source fosc = 4 MHz, LCD clock source fosc/ $2^{15}$ = 122 Hz, and flame cycle = 122 Hz are selected in this example. | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the LCD operation LCDMD1(X'3FC0') bp7 :LCDEN = 0 | (1) Set "0" to the LCDEN flag of the LCD mode control register (LCDMD1) to "1" to stop the LCD operation. | | (2) Set the display duty LCDMD1(X'3FC0') bp5-4:LCDDTY1-0= 11 | (2) Set the LCDTY1 to LCDTY0 flags of the LCD mode control register (LCDMD1) to "11" to enter the static driving mode. | | (3) Select the LCD clock source<br>LCDMD1(X'3FC0')<br>bp3-0:LCDCK3-0 = 0100 | (3) Select fosc/2 <sup>15</sup> as a LCD clock source by the LCDCK3 to LCDCK0 flags of the LCD mode control register (LCDMD). | | (4) Select the segment output/port pin Select the common output/port pin LCCTR1(X'3FC2') bp7-0:SC1SL3-0, COMSL3-0 = 11110001 LCCTR2(X'3FC3') bp3-0:SC2SL3-0 = 1111 | (4) Select SEG0 to SEG3 by the LCD output control register 1 (LCCTR1) and SEG4 to SEG7 by the COM0 and the LCD output control register 2 (LCCTR2). | | (5) Set the LCD panel display data Segment output latch SEG1-0 (X'2E00') = X'00' Segment output latch SEG3-2 (X'2E01') = X'11' Segment output latch SEG5-4 (X'2E02') = X'10' Segment output latch SEG7-6 (X'2E03') = X'11' | (5) Display "23" on the display panel by the address X'2E00' to X'2E03' of the segment output latch SEG0 to SEG7. [Chapter 16.4.1 Static] | | (6) Start the LCD operation<br>LCDMD1(X'3FC0')<br>bp7:LCDEN = 1 | (6) Set the LCDEN flag of the LCD mode control register (LCDMD1) to "1" to start the LCD operation. | ## 16.4.3 1/2duty #### ■ 1/2 duty S:selected voltage N:non-selected voltage VLCD:LCD driver voltage Figure:16.4.2 LCD Display (1/2 duty) ## 16.4.4 Setup Example (1/2 duty) #### ■ Setup example of the LCD (1/2 duty) An example of setup procedure to display "23" on a 2-digit, 8 segment type LCD panel with both segment signals (SEG0 to SEG7) and common signals (COM0), using an external dividing resistor is shown below. [Chapter 16.4.3. LCD Display (1/2 duty)] Clock source fosc = 4 MHz, a LCD clock source fosc/ $2^{15}$ = 122 Hz, and flame cycle = 61 Hz are selected in this example. | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the LCD operation LCDMD1(X'3FC0') bp7 :LCDEN = 0 | (1) Set the LCDEN flag of the LCD mode control register (LCDMD1) to "0" to stop the LCD operation. | | (2) Set the display duty LCDMD1(X'3FC0') bp5-4 :LCDDTY1-0= 10 | (2) Set the LCDTY1 to LCDTY0 flags of the LCD mode control register (LCDMD1) to "10" to enter 1/2 duty driving mode. | | (3) Select the LCD clock source<br>LCDMD1(X'3FC0')<br>bp3-0 :LCDCK3-0 = 0100 | (3) Select fosc/2 <sup>15</sup> as a LCD clock source by the LCDCK3 to LCDCK0 flags of the LCD mode control register 1 (LCDMD1). | | (4) Select the segment output/port pin Select the common output/port pin LCCTR1(X'3FC2') bp7-0:SC1SL3-0, COMSL3-0 = 11110011 LCCTR2(X'3FC3') bp3-0:SC2SL3-0 = 1111 | (4) Select the SEG3 to SEG0 and COM1 to COM0 by the LCD output control register 1(LCCTR1) and SEG7 to SEG4 by the LCD output control register 2 (LCCTR2). | | (5) Set the LCD panel display data Segment output latch SEG1-0 (X'2E00') = X'31' Segment output latch SEG3-2 (X'2E01') = X'22' Segment output latch SEG5-4 (X'2E02') = X'30' Segment output latch SEG7-6 (X'2E03') = X'32' | (5) Display "23" on the display panel by the address X'2E00' to X'2E03' of the segment output latch SEG7 to SEG0. [Chapter 16.4.3 1/2 duty] | | (6) Start the LCD operation LCDMD1(X'3FD0') bp7 :LCDEN = 1 | (6) Set the LCDEN flag of the LCD mode control register1 (LCDMD1) to "1" to start the LCD operation. | ## 16.4.5 1/3 duty #### ■ 1/3 duty S:selected voltage N:non-selected voltage VLCD:LCD driver voltage Figure:16.4.3 LCD Display (1/3 duty) ## 16.4.6 Setup Example (1/3 duty) #### ■ Setup example of the LCD (1/3 duty) An example of setup procedure to display "23" on a 2-digit, 8 segment type LCD panel with both segment signals (SEG0 to SEG7) and common signals (COM0), using an external dividing resistor is shown below. [Chapter 16.4.5. LCD Display (1/3 duty)] Clock source fosc = 4 MHz, a LCD clock source fosc/ $2^{15}$ = 122 Hz, and flame cycle = 41 Hz are selected in this example. | Setup Procedure | Description | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the LCD operation<br>LCDMD1(X'3FC0')<br>bp7 :LCDEN = 0 | (1) Set the LCDEN flag of the LCD mode control register1 (LCDMD1) to "1" to stop the LCD operation. | | (2) iSet the display duty LCDMD1(X'3FC0') bp5-4 :LCDDTY1-0= 01 | (2) Set the LCDTY1 to LCDTY0 flags of the LCD mode control register 1 (LCMD1) to "01" to enter 1/3 duty driving mode. | | (3) Select the LCD clock source<br>LCDMD1(X'3FC0')<br>bp3-0 :LCDCK3-0 = 0100 | (3) Select fosc/2 <sup>15</sup> as a LCD clock source by the LCDCK3 to LCDCK0 flags of the LCD mode control register 1 (LCDMD1). | | (4) Select the segment output/port pin Select the common output/port pin LCCTR1(X'3FC2') bp7-0:SC1SL3-0, COMSL3-0 = 11110111 LCCTR1(X'3FC3') bp3-0:LC1SL3-0 = 111 | (4) Select the SEG3 to SEG0 and COM2 to COM0 by the LCD output control register 1 (LCCTR1) and SEG7 to SEG4 by the LCD output control register 2 (LCCTR2). | | (5) Set the LCD panel display data Segment output latch SEG1-0 (X'2E00') = X'76' Segment output latch SEG3-2 (X'2E01') = X'40' Segment output latch SEG5-4 (X'2E02') = X'27' | (5) Display "23" on the display panel by the address X'2E00' to X'2E03' of the segment output latch SEG7 to SEG0. [Chapter 16.4.5 1/3 duty] | | (6) Start the LCD operation LCDMD1(X'3FC0') bp7 :LCDEN = 1 | (6) Set the LCDEN flag of the LCD mode control register 1 (LCMD1) to "1" to start the LCD operation. | ## 16.4.7 1/4 duty #### ■ 1/4 duty S:selected voltage N:non-selected voltage VLCD:LCD driver voltage Figure:16.4.4 LCD Display (1/4 duty) ## 16.4.8 Setup Example (1/4 duty) ### ■ Setup example of the LCD (1/4 duty) An example of setup procedure to display "23" on a 2-digit, 8 segment type LCD panel with both segment signals (SEG0 to SEG4)and common signals (COM0 to COM3) in 1/4 duty, 1/3 bias, using an external dividing resistor is shown below. [Chapter 16.4.7 LCD Display (1/4 duty)] Clock source fosc = 4 MHz, LCD clock source fosc/ $2^{15}$ = 122 Hz, and flame cycle = 31 Hz are selected in this example. | Setup Procedure | Description | |----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | (1) Stop the LCD operation<br>LCDMD1(X'3FC0')<br>bp7 :LCDEN = 0 | (1) Set the LCDEN flag of the LCD mode control register 1 (LCDMD1) to "0" to stop the LCD operation. | | (2) Set the display duty LCDMD1(X'3FC0') bp5-4 :LCDDTY1-0= 00 | (2) Set the LCDTY1 to LCDTY0 of the LCD mode control register 1 (LCDMD1) to "00" to enter 1/4 duty driving mode. | | (3) Select the LCD clock source<br>LCDMD1(X'3FC0')<br>bp3-0 :LCDCK3-0 = 0100 | (3) Select fosc/2 <sup>15</sup> as the LCD clock source by the LCDKC3 to LCDCK0 flags of the LCD mode control register 1 (LCMD1). | | (4) Select the segment output/port pin Select the common output/port pin LCCTR1(X'3FC2') bp3-0 :COMSL3-0 = 1111 bp7-4 :LC1SL3-0 = 1111 | (4) Select SEG7 to SEG0 and COM3 to COM0 by the output control register (LCCTR), (LCCTR2), (LCCTR3), (LCCTR4). | | (5) Set the LCD panel display data Segment output latch SEG1-0 (X'2E00') = X'5E' Segment output latch SEG3-2 (X'2E01') = X'7C' | (5) Display "23" on the display panel by the address X'2E00' to X'2E01' of the segment output latch SEG0 to SEG4. | | (6) Start the LCD operation<br>LCDMD1(X'3FC0')<br>bp7:LCDEN = 1 | (6) Set the LCDEN flag of the LCD mode control register 1 (LCMD1) to "1" to start the LCD operation. | ## 17.1 Flash EEPROM ### 17.1.1 Overview The MN101CF78A is equivalent to MN101C78A except its Mask ROM is substituted with 32 KB of flash EEPROM. The MN101CF78A is programmed in the following modes; - -PROM writer mode, which uses a dedicated PROM writer for a microcontroller's stand-alone programming. - -Onboard programming mode, which the CPU controls programming of a microcontroller on a target board. - -User program area (32 KB: 0x0000 to 0x7FFF) This area stores an user program. It is overwritten in both programming modes. Figure:17.1.1 Memory Map in Internal Flash EEPROM One cycle of "erase-write" process is counted as 1 programming in every block. When several blocks are programmed separately, programming count is added by just the number of programming cycle. (For instance, when block 1, 2 and 3 are programmed separately, 3 programming count is added.) Therefore, program several blocks together to reduce the programming count. Boot area stores the loader program for onboard serial programming. Boot area can be programmed by the PROM writer only. ## 17.2 PROM Writer Mode ### 17.2.1 Overview In PROM writer mode, the CPU is halted for the internal flash EEPROM to be programmed. The microcontroller is inserted into a dedicated adaptor socket, which connects to a PROM writer. When the microcontroller connects to the adaptor socket, it automatically enters PROM writer mode. The programming adaptor differs depending on the writer and the package type. Table:17.2.1 Programming Adaptor List | Programming Writer | Product Number | |----------------------------------------|-------------------------| | By Ando Electric Co., Ltd.<br>By Panax | TEF009-CF78A48 (48 pin) | Matching information of the dedicated writer is posted on our semiconductor website, which is listed on the last page of this manual. ■ Fixing a Device on the Adapter Socket and the Position of No.1 Pin Figure:17.2.1 Fixing a Device on the Adapter Socket and the Position of No.1 Pin ## 17.3 Onboard Serial Programming Mode ### 17.3.1 Overview The onboard serial programming mode is primarily used to program the flash EEPROM in devices that are already installed on a PCB board with internal serial interface. Use the dedicated serial writer for programming controlled by the load program. In this mode, load program is write/erase-protected in the hardware. Hardware and software requirements Hardware and software products required for onboard serial programming are as follows. Hardware requirements - -Onboard serial writer - -Flash programming connectors or pins for target board Software requirements -Load program installed in the internal flash EEPROM (Load program should be programmed with PROM writer in advance. The load program is attached to the serial writer.) - -Programming algorithm for operating onboard serial writer - Built-in hardware for onboard serial programming mode Use this LSI's serial interface 0 as a standard serial writer for programming the flash EEPROM in onboard serial programming mode. [ Refer to Chapter 11 Serial Interface 0 ] Serial interface I/O pins (SBT0B, SBI0B, P76), used for onboard serial programming should be reserved as dedicated pins to prevent other user circuits from communicating with the device. Alternatively, design your target board to be capable of normal communication with serial writer. Onboard serial programming writer The onboard serial programming writer supports the following model. Also, the load program can be downloaded on the following website; YDC AF220/B http://ydc.co.jp/micom/product/download\_impress.htm ## 17.3.2 Circuit Requirements for the Target Board Figure:17.3.1 Circuit Requirements for the Target Board ### Pins -V<sub>DD1</sub> (8.23 pin) 2.7V to 3.6V power supply -NRST (12 pin) Reset -SBT0B (40 pin) Serial interface clock supply pin -SBO0B (38 pin) Serial interface data input pin -GND (5 pin) Ground -P76 (39 pin) Busy signal output pin -MMOD (11 pin) MMOD pin (Low at user mode, High at on board programming) - $-V_{DD2}$ should be $2.7V \le V_{DD2} \le 3.6V$ . When $V_{DD}$ level (2.7V to 3.6V) is too low, serial writer generates error message. - -Connect pull-up resistors to NRST, MMOD, SBT0B and P76 pins on the target board. The pull-up resistor value should be 10 $k\Omega\pm1$ $k\Omega$ Design NRST and MMOD to be able to toggle by a switch between serial writer programming and normal operation. Alternatively, install a wired-OR connection. (For a wired-OR connection, disable NRST and MMOD from the target board during serial writer programming. - -NRST is output from the serial writer through an open-drain. - -To prevent the other user circuits on the target board from communicating, the circuit of the target board should be designed for SBT0O, SBO0B, and P76 pins to communicate with the serial writer. - -To prevent noise malfunction of Mask ROM, design the circuit of the target board carefully for the signal used for the serial writer. ### 17.3.3 Built-in Hardware for Onboard Programming ### 1. I/F The following built-in hardware is used as the I/F for serial programming of Flash EEPROM. One 8bit serial interface (Use serial 0) - -External clock for data transmission/reception - -LSB first transmission bit clock speed can be selected from 500 kbps, 250kbps, 125kbps, or 62.5kbps. - -Input/output is positive logic - -Two channels serial interface (SBT0B, SBO0B) Three I/O pins -SBT0B, SBO0B and P76 serve for both serial interface port and I/O port. ### 2. I/F Block Diagram Figure:17.3.2 I/F Block Diagram To prevent the other user circuits on the target board, shown on the Figure:17.3.2, from communicating, SBT0B, SBO0B and P76 pins should be reserved for serial programming, or the circuit of the target board should be designed for normal communication with serial writer. ## 17.3.4 MN101CF78A Clock on the Target Board -Use the existing clock on the target board for the clock supply to the MN101CF78A on the target board. Therefore, the clock frequency of the MN101CF78A differs depending on each user. -The guaranteed clock frequency for the MN101CF78A during serial programming is shown below. | Frequency | Operating voltage | |----------------------------|-------------------| | 10 MHz (internal 5MHz) | 2.7 V to 3.6 V | | 5.7 MHz (internal 5.7MHz) | 3.0 V to 3.6 V | | 4.6 MHz (internal 4.6 MHz) | 2.7 V to 3.6 V | # 17.4 Special Function Registers List | Address | Pogistor | Bit Symbol | | | | | | | | Page | |---------|----------|-------------------------------------|-----------------------------------------------------------------------------------------------|------------------------------|-------------------------|-------------------------------------------------|--------------------------------------------|--------------|-------------------------------|----------------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03F00 | CPUM | RESERV<br>ED | 0SCSEL<br>1 | 0SESEL<br>0 | 0SEDBL | STOP | HALT | OSC1 | 0SC0 | II-24<br>II-28 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Set always to "0". | Division rate setup Internal system mode clock Setup STOP HALT mode setup Oscillation control | | control | | | | | | | 0x03F01 | MEMCTR | IOW1 | IOW0 | IVBM | Reserve<br>d | Reserve<br>d | IRWE | Reserve<br>d | Reserve<br>d | II-20 | | | | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | | | | | IO wait set | nb | Interrupt<br>base<br>address | Set<br>always<br>to "0" | Set<br>always<br>to "1" | Interrupt<br>request<br>software<br>writes | Set always | s to "11" | | | 0x03F02 | WDCTR | - | - | Reserve<br>d | Reserve<br>d | Reserve<br>d | WDTS1 | WDTS0 | WDEN | IX-4 | | | | - | - | 0 | 0 | 0 | 1 | 1 | 0 | | | | | | | Set always | s to "0". | | Watchdog<br>detection p | | Watchdo<br>g timer<br>control | | | 0x03F03 | DLYCTR | BUZOE | BUZS2 | BUZS1 | BUZS0 | DLYS1 | DLYS0 | - | - | II-33 | | | | 0 | 0 | 0 | 0 | 0 | 0 | - | - | X-5 | | | | Buzzer<br>output<br>selection | Buzzer out | put frequenc | y selection | Oscillation stabilization wait period selection | | | | | | 0x03F11 | P1OUT | P1OUT7 | P1OUT6 | P1OUT5 | P1OUT4 | P1OUT3 | P1OUT2 | P1OUT1 | P1OUT0 | IV-7 | | | | х | x | x | x | x | х | х | х | | | | | Port 1 outp | ut data | | | | | | • | | | 0x03F12 | P2OUT | P2OUT7 | - | - | - | - | - | - | - | IV-22 | | | | 1 | - | - | - | - | - | - | - | | | | | Output<br>data<br>(Reset<br>output) | | | | | | | | | | 0x03F13 | P3OUT | P3OUT7 | P3OUT6 | P3OUT5 | P3OUT4 | P3OUT3 | P3OUT2 | P3OUT1 | P3OUT0 | IV-26 | | | | х | х | х | х | х | х | х | х | | | | | Port 3 outp | ut data | | | | | | | | | | | Bit Symbol | | | | | | | | | |---------|----------|---------------------------------------------|---------------------------------------------|---------------------------------------------|------------------------------------------------------------------|---------------------------------------------|-------------------------------------------|---------------------------------------------|----------------------------------|-------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03F15 | P5OUT | - | P5OUT6 | P5OUT5 | P5OUT4 | P5OUT3 | P5OUT2 | P5OUT1 | P5OUT0 | IV-41 | | | | - | х | х | х | х | х | х | х | | | | | Port 5 outp | ut data | | | | | | | | | 0x03F17 | P7OUT | P7OUT7 | P7OUT6 | P7OUT5 | P7OUT4 | P7OUT3 | P7OUT2 | P7OUT1 | P7OUT0 | IV-51 | | | | х | х | x | x | x | х | x | x | | | | | Port 7 outp | ut data | | | | | | | | | 0x03F19 | P9OUT | - | - | - | - | - | - | - | P9OUT0 | IV-67 | | | | - | - | - | - | - | - | - | x | | | | | | | | | | | | Port 9<br>output<br>data | | | 0x03F1A | PAOUT | - | PAOUT6 | PAOUT5 | PAOUT4 | PAOUT3 | PAOUT2 | PAOUT1 | PAOUT0 | IV-74 | | | | - | х | x | x | x | х | x | x | | | | - | Port A outp | out data | | | | | | | | | 0x03F1B | P1ODC | P17ODC | - | P15ODC | - | - | - | P11ODC | P100DC | IV-11 | | | | 0 | - | 0 | - | - | - | 0 | 0 | | | | | P17<br>open-<br>drain<br>control | | P15<br>open-<br>drain<br>control | | | | P11<br>open-<br>drain<br>control | P10<br>open-<br>drain<br>control | | | 0x03F1C | P1OMD | P1OMD7 | P1OMD<br>6 | P1OMD<br>5 | P1OMD<br>4 | P1OMD<br>3 | NBUZSE<br>L | P1OMD<br>2 | BUZSEL | IV-10 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | I/O port<br>Timer 2B<br>output<br>selection | I/O port<br>Timer 2B<br>output<br>selection | I/O port<br>Timer 0B<br>output<br>selection | I/O port,<br>Timer 0<br>remote<br>control<br>output<br>selection | I/O port,<br>Timer 7<br>output<br>selection | I/O port<br>NBUZZE<br>output<br>selection | I/O port,<br>Timer 8<br>output<br>selection | I/O port<br>BUZZER<br>selection | | | 0x03F1D | P7ODC | P77ODC | P76ODC | P75ODC | - | - | - | - | - | IV-54 | | | | 0 | 0 | 0 | - | - | - | - | - | | | | | P77<br>open-<br>drain<br>control | P76<br>open-<br>drain<br>control | P75<br>open-<br>drain<br>control | | | | | | | | Address | Pogistor | Bit Symbo | ol | | | | | | | Page | | | |--------------|------------|------------|-------------------|----------|----------------------------------|-----------------------------|---------------------------------------------------------------|---------------------------|-------|--------|--|--| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | - Page | | | | 0x03F1E | EDGDT | - | - | - | - | - | EDGSEL<br>1 | - | - | III-49 | | | | | | - | - | - | - | - | 0 | - | - | | | | | | | | | | | | IRQ2<br>both<br>edges<br>interrupt<br>opera-<br>tion<br>setup | | | | | | | 0x03F1F | CLKOUT | - | - | - | - | SCHMIT<br>T | PDOWN | CLKSEL | OUTEN | IV-13 | | | | | | - | - | - | - | 0 | 0 | 0 | 0 | | | | | | | | | | Switch<br>port<br>input<br>level | Clock<br>output<br>function | Clock<br>type<br>selection | Clock<br>output<br>enable | | | | | | 0x03F21 P1IN | P1IN | P1IN7 | P1IN6 | P1IN5 | P1IN4 | P1IN3 | P1IN2 | P1IN1 | P1IN0 | IV-8 | | | | | х | x | x | x | х | х | 1 | 1 | | | | | | | Port 1 inp | ut data | | | | | | | | | | | | 0x03F23 | P3IN | P3IN7 | P3IN6 | P3IN5 | P3IN4 | P3IN3 | P3IN2 | P3IN1 | P3IN0 | IV-27 | | | | | | 1 | х | x | x | х | x | x | х | | | | | | | Port 3 inp | Port 3 input data | | | | | | | | | | | 0x03F25 | P5IN | - | P5IN6 | P5IN5 | P5IN4 | P5IN3 | P5IN2 | P5IN1 | P5IN0 | IV-42 | | | | | | - | х | x | x | х | x | x | х | | | | | | | Port 5 inp | ut data | | | | | 1 | 1 | | | | | 0x03F27 | P7IN | P7IN7 | P7IN6 | P7IN5 | P7IN4 | P7IN3 | P7IN2 | P7IN1 | P7IN0 | IV-52 | | | | | | х | x | х | х | х | x | x | x | | | | | | | Port 7 inp | ut data | | | | | _ | | | | | | 0x03F29 P9IN | - | - | - | - | - | - | - | P9IN0 | IV-68 | | | | | | | - | - | - | - | - | - | - | 0 | | | | | | Port 9 inp | ut data | | <u> </u> | <b>.</b> | | | | | | | | | 0x03F2A | PAIN | - | PAIN6 | PAIN5 | PAIN4 | PAIN3 | PAIN2 | PAIN1 | PAIN0 | IV-75 | | | | | | - | 1 | 1 | 1 | х | x | x | x | | | | | | | Port A inp | out data | | | | | | | | | | | Address | Register | Bit Symbol | | | | | | | | Page | | | | |---------------|--------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------|----------------------------------------------|---------------------------------------------|----------------------------------------------|--------|--|--|--| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | raye | | | | | 0x03F2C | P5OMD | P5LED3 | P5LED2 | P5LED1 | P5LED0 | P5OMD<br>3 | P5OMD<br>2 | P5OMD<br>1 | P5OMD<br>0 | IV-44 | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | LED3<br>(large<br>current<br>output)<br>selection | LED2<br>(large<br>current<br>output)<br>selection | LED1<br>(large<br>current<br>output)<br>selection | LED0<br>(large<br>current<br>output)<br>selection | I/O port,<br>Timer 8<br>output<br>selection | I/O port,<br>Timer 2A<br>output<br>selection | I/O port,<br>Timer 7<br>output<br>selection | I/O port,<br>Timer 0A<br>output<br>selection | | | | | | 0x03F2D | PAODC | - | PA6ODC | PA5ODC | - | - | PA2ODC | - | PA0ODC | IV-77 | | | | | | | - | 0 | 0 | - | - | 0 | - | 0 | | | | | | | | | PA6<br>open-<br>drain<br>control | PA5<br>open-<br>drain<br>control | | | PA2<br>open-<br>drain<br>control | - | PA0<br>open-<br>drain<br>control | | | | | | 0x03F2E | NFCTR | P55IM | NF1SCK<br>1 | NF1SCK<br>0 | NF1EN | P54IM | NF0SCK<br>1 | NF0SCK<br>0 | NF0EN | III-48 | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | ACZ 1 enable | IRQ1/noise frequency | e sampling | IRQ1/<br>noise fil-<br>ter | ACZ0<br>enable | IRQ0/noise<br>frequency | e sampling | IRQ0/<br>noise fil-<br>ter | | | | | | | 0x03F31 P1DIR | P1DIR | P1DIR7 | P1DIR6 | P1DIR5 | P1DIR4 | P1DIR3 | P1DIR2 | P1DIR1 | P1DIR0 | IV-8 | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | Port 1 I/O | Port 1 I/O direction control | | | | | | | | | | | | 0x03F33 | P3DIR | P3DIR7 | P3DIR6 | P3DIR5 | P3DIR4 | P3DIR3 | P3DIR2 | P3DIR1 | P3DIR0 | IV-27 | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | Port 3 I/O | direction cont | rol | | | | | | | | | | | 0x03F35 | P5DIR | - | P5DIR6 | P5DIR5 | P5DIR4 | P5DIR3 | P5DIR2 | P5DIR1 | P5DIR0 | IV-42 | | | | | | | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | Port 5 I/O | direction cont | rol | | | | | | | | | | | 0x03F37 | P7DIR | P7DIR7 | P7DIR6 | P7DIR5 | P7DIR4 | P7DIR3 | P7DIR2 | P7DIR1 | P7DIR0 | IV-52 | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | Port 7 I/O | direction cont | rol | | | | | | | | | | | 0x03F39 | P9DIR | - | - | - | - | - | - | - | P9DIR0 | IV-68 | | | | | | | - | - | - | - | - | - | - | 0 | | | | | | | | Port 9 I/O | direction cont | rol | | | | | | | | | | | 0x03F3A | PADIR | - | PADIR6 | PADIR5 | PADIR4 | PADIR3 | PADIR2 | PADIR1 | PADIR0 | IV-75 | | | | | | | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | Port A I/O | direction cont | rol | | | | | | | | | | | A -1 -1 | Dominton | Bit Symbol | | | | | | | | Done | |--------------------|----------------|---------------------------------|----------------|----------------|----------------|-----------------------------------------|-----------------------------------------|--------------------------------------------|--------------------------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03F3B | P3ODC | - | - | - | - | P33ODC | P32ODC | - | - | IV-30 | | | | - | - | - | - | 0 | 0 | - | - | | | | | | | | | P33<br>open-<br>drain<br>control | P32<br>open-<br>drain<br>control | | | | | 0x03F3C | P7OMD | - | - | - | - | - | - | P7OMD<br>1 | P7OMD<br>0 | IV-53 | | | | - | - | - | - | - | - | 0 | 0 | | | | 0x03F3D P1CNT0 | | | | | | | I/O port<br>Timer 3<br>output<br>selection | I/O port<br>Timer 1<br>output<br>selection | | | 0x03F3D | P1CNT0 | - | - | P1CNT0<br>5 | P1CNT0<br>4 | P1CNT0<br>3 | P1CNT0<br>2 | P1CNT0<br>1 | P1CNT0<br>0 | IV-12 | | | | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | P16 real tir | me control | P14 real tir | me control | P12 real ti | me control | | | 0x03F3E KEYT3_1IMD | KEYT3S<br>EL | - | - | - | KEYT3_<br>1EN3 | KEYT3_<br>1EN2 | KEYT3_<br>1EN1 | KEYT3_<br>1EN0 | III-50 | | | | | 0 | - | - | - | 0 | 0 | 0 | 0 | | | | | Key inter-<br>rupt con-<br>trol | | | | KEY3<br>key inter-<br>rupt<br>selection | KEY2<br>key inter-<br>rupt<br>selection | KEY1<br>key inter-<br>rupt<br>selection | KEY0<br>key inter-<br>rupt<br>selection | | | 0x03F3F | KEYT3_2IMD | - | - | - | - | KEYT3_<br>2EN3 | KEYT3_<br>2EN2 | KEYT3_<br>2EN1 | KEYT3_<br>2EN0 | III-51 | | | | - | - | - | - | 0 | 0 | 0 | 0 | | | | | | | | | KEY7<br>key inter-<br>rupt<br>selection | KEY6<br>key inter-<br>rupt<br>selection | KEY5<br>key inter-<br>rupt<br>selection | KEY4<br>key inter-<br>rupt<br>selection | | | 0x03F41 | P1PLUD | P1PLUD<br>7 | P1PLUD<br>6 | P1PLUD<br>5 | P1PLUD<br>4 | P1PLUD<br>3 | P1PLUD<br>2 | P1PLUD<br>1 | P1PLUD<br>0 | IV-9 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | | | | Port 1 pull- | up/pull-down | resistor | | | | | | | | 0x03F43 | P3PLUD | P3PLUD<br>7 | P3PLUD<br>6 | P3PLUD<br>5 | P3PLUD<br>4 | P3PLUD<br>3 | P3PLUD<br>2 | P3PLUD<br>1 | P3PLUD<br>0 | IV-28 | | | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | up resistor/pu | ıll-down resis | stor | | | | | | | 0x03F45 | P5PLU | - | P5PLU6 | P5PLU5 | P5PLU4 | P5PLU3 | P5PLU2 | P5PLU1 | P5PLU0 | IV-43 | | | | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Port 5 pull- | up resistor | • | • | • | • | • | • | 1 | | A alaba | Deminter | Bit Symbol | | | | | | | | Danie | |---------|--------------|--------------|------------------|-------------|---------------------|---------------------|---------------------|------------------------------------------------------|------------------------------------|-------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03F47 | P7PLUD | P7PLUD<br>7 | P7PLUD<br>6 | P7PLUD<br>5 | P7PLUD<br>4 | P7PLUD<br>3 | P7PLUD<br>2 | P7PLUD<br>1 | P7PLUD<br>0 | IV-53 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Port 7 pull- | up/pull-down | resistor | | | | | | | | 0x03F49 | P9PLU | - | - | - | - | - | - | - | P9PLUD<br>0 | IV-69 | | | | - | - | - | - | - | - | - | 1 | | | | | Port 9 pull- | up/pull-down | resistor | | | | | | | | 0x03F4A | PAPLUD | - | PAPLUD<br>6 | PAPLUD<br>5 | PAPLUD<br>4 | PAPLUD<br>3 | PAPLUD<br>2 | PAPLU1<br>D | PAPLUD<br>0 | IV-76 | | | | - | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | | | | Port A pull- | -up/pull-down | resistor | | | | | | | | 0x03F4B | SELUD | - | - | - | PADWN | P3DWN | P9DWN | P7DWN | P1DWN | IV-77 | | | | - | - | - | 1 | 1 | 1 | 0 | 0 | | | | | | | | PA pull-<br>up/down | P3 pull-<br>up/down | P9 pull-<br>up/down | P7 pull-<br>up/down | P1 pull-<br>up/down | | | 0x03F4C | 0x03F4C XSEL | - | - | - | - | - | - | - | XSEL | IV-70 | | | | - | - | - | - | - | - | - | 0 | | | | | | | | | | | | P91, XI<br>selection | | | 0x03F4E | PAIMD | PAIMD7 | PAIMD6 | PAIMD5 | PAIMD4 | PAIMD3 | PAIMD2 | PAIMD1 | PAIMD0 | IV-76 | | | | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Analog inp | ut pin selection | on | | | | | | | | 0x03F50 | TM0BC | TM0BC7 | TM0BC6 | TM0BC5 | TM0BC4 | TM0BC3 | TM0BC2 | TM0BC1 | TM0BC0 | V-13 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Timer 0 bin | ary counter | | | | | | | | | 0x03F51 | TM1BC | TM1BC7 | TM1BC6 | TM1BC5 | TM1BC4 | TM1BC3 | TM1BC2 | TM1BC1 | TM1BC0 | V-13 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Timer 1 bin | ary counter | | | | | | | | | 0x03F52 | TM0OC | TM0OC7 | TM0OC6 | TM0OC5 | TM0OC4 | TM0OC3 | TM0OC2 | TM0OC1 | TM0OC0 | V-12 | | | | х | х | x | х | х | х | x | х | | | | | Timer 0 cor | mpare registe | er | | | | | | | | 0x03F64 | TM6BEN | - | - | - | - | - | - | TBEN | TM6EN | VII-7 | | | | - | - | - | - | - | - | 0 | 0 | | | | | - | - | - | - | - | - | Time<br>base<br>timer<br>opera-<br>tion con-<br>trol | TM6<br>opera-<br>tion con-<br>trol | | | Address | Register | Bit Symbol | | | | | | | | Page | |---------|----------|--------------|----------------|--------------------------|---------------------------------------|-------------------------------------------------|--------------------------|---------------------------------|-----------------------------------------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | rage | | 0x03F6C | RMCTR | - | - | Reserve<br>d | TMORM | RM0EN | RMDTY<br>1 | RMDTY<br>0 | RMBTM<br>S | VIII-5 | | | | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | Set<br>always<br>to "0". | P14 special function output selection | Remote<br>control<br>career<br>output<br>enable | Remote co<br>career duty | | Remote<br>control<br>career<br>base<br>timer<br>selection | | | 0x03F6D | PSCMD | - | - | - | - | - | - | - | PSCEN | III-47 | | | | - | - | - | - | - | - | - | 0 | | | | | - | - | - | - | - | - | - | Prescale<br>r count<br>control | | | 0x03F6E | TM7MD4 | - | - | - | T7ONES<br>HOT | T7NODE<br>D | - | T7ICT2 | T7CAPC<br>LR | VI-19 | | | | - | - | - | -0 | 0 | - | 0 | 0 | | | | | - | - | - | 1 shot<br>pulse<br>selection | Dead<br>time<br>selection | - | Capture<br>trigger<br>selection | BC clear<br>control<br>at cap-<br>ture | | | 0x03F6F | TM8MD4 | - | - | - | - | - | - | T8ICT2 | T8CAPC<br>LR | VI-23 | | | | - | - | - | - | - | - | 0 | 0 | | | | | - | - | - | - | - | - | Capture<br>trigger<br>selection | BC clear<br>control<br>at cap-<br>ture | | | 0x03F70 | TM7BCL | TM7BCL<br>7 | TM7BCL<br>6 | TM7BCL<br>5 | TM7BCL<br>4 | TM7BCL | TM7BCL<br>2 | TM7BCL<br>1 | TM7BCL<br>0 | VI-11 | | | | х | x | х | x | x | х | x | х | | | | | Timer 7 bin | ary counter le | ower 8 bits | | | | | | | | 0x03F71 | ТМ7ВСН | TM7BCH<br>7 | TM7BC<br>H6 | TM7BC<br>H5 | TM7BC<br>H4 | TM7BC<br>H3 | TM7BC<br>H2 | TM7BC<br>H1 | TM7BC<br>H0 | VI-11 | | | | х | x | x | x | х | x | x | x | | | | | Timer 7 bin | ary counter ι | upper 8 bits | | | | | | | | 0x03F72 | TM7OC1L | TM7OC1<br>L7 | TM7OC1<br>L6 | TM7OC1<br>L5 | TM7OC1<br>L4 | TM7OC1<br>L3 | TM7OC1<br>L2 | TM7OC1<br>L1 | TM7OC1<br>L0 | VI-9 | | | | х | х | х | х | х | х | х | x | | | | | Timer 7 cor | mpare registe | er 1 lower 8 b | its | | | | | | | 0x03F73 | TM7OC1H | TM7OC1<br>H7 | TM7OC1<br>H6 | TM7OC1<br>H5 | TM7OC1<br>H4 | TM7OC1<br>H3 | TM7OC1<br>H2 | TM7OC1<br>H1 | TM7OC1<br>H0 | VI-9 | | | | х | x | x | x | x | x | x | х | | | | | Timer 7 cor | mpare registe | er 1 upper 8 b | oits | | | | | | | A dduc c c | Desistes | Bit Symbol | | | | | | | | Dane | |------------|----------|---------------------------------------------|--------------------------|----------------------------------------------|-----------------------------------------------|---------------------------------------------|----------------------------------------------|--------------------|--------------|-------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03F74 | TM7PR1L | TM7PR1<br>L7 | TM7PR1<br>L6 | TM7PR1<br>L5 | TM7PR1<br>L4 | TM7PR1<br>L3 | TM7PR1<br>L2 | TM7PR1<br>L1 | TM7PR1<br>L0 | VI-10 | | | | х | x | x | x | х | x | х | x | | | | | Timer 7 pre | set register 1 | lower 8 bits | | | | | | | | 0x03F75 | TM7PR1H | TM7PR1<br>H7 | TM7PR1<br>H6 | TM7PR1<br>H5 | TM7PR1<br>H4 | TM7PR1<br>H3 | TM7PR1<br>H2 | TM7PR1<br>H1 | TM7PR1<br>H0 | VI-10 | | | | х | x | x | x | x | x | x | x | | | | | Timer 7 pre | set register 1 | upper 8 bits | ; | | | | | | | 0x03F76 | TM7ICL | TM7ICL7 | TM7ICL<br>6 | TM7ICL<br>5 | TM7ICL<br>4 | TM7ICL<br>3 | TM7ICL<br>2 | TM7ICL<br>1 | TM7ICL<br>0 | VI-11 | | | | х | х | х | х | х | х | х | х | | | | | Timer 7 inp | ut capture re | gister lower 8 | 3 bits | | | | | | | 0x03F77 | TM7ICH | TM7ICH7 | TM7ICH<br>6 | TM7ICH<br>5 | TM7ICH<br>4 | TM7ICH<br>3 | TM7ICH<br>2 | TM7ICH<br>1 | TM7ICH<br>0 | VI-11 | | | | х | x | х | x | x | x | x | x | | | | | Timer 7 input capture register upper 8 bits | | | | | | | | | | 0x03F78 | TM7MD1 | Reserved | T7ICED<br>G1 | TM7CL | TM7EN | TM7PS1 | TM7PS0 | TM7CK1 | TM7CK0 | VI-16 | | | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | | | Set<br>always to<br>"0" | Capture<br>trigger | Timer<br>output<br>reset<br>signal | Timer<br>count<br>control | Count cloc | k selection | Clock sour<br>tion | ce selec- | | | 0x03F79 | TM7MD2 | T7ICED<br>G0 | TM7PW<br>MSL | TM7BC<br>R | TM7PW<br>M | TM7IRS<br>1 | T7ICEN | T7ICT1 | T7ICT0 | VI-17 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Capture<br>trigger<br>edge<br>selection | PWM<br>mode<br>selection | TM7<br>count<br>clear<br>factor<br>selection | Timer<br>output<br>wave-<br>form<br>selection | Timer 7<br>interrupt<br>factor<br>selection | Input<br>capture<br>opera-<br>tion<br>enable | Capture tri | gger | | | 0x03F7A | TM7OC2L | TM7OC2<br>L7 | TM7OC2<br>L6 | TM7OC2<br>L5 | TM7OC2<br>L4 | TM7OC2<br>L3 | TM7OC2<br>L2 | TM7OC2<br>L1 | TM7OC2<br>L0 | VI-9 | | | | х | х | х | х | х | х | х | х | | | | | | · · · · · | er 2 lower 8 b | 1 | i | i | i | i | | | 0x03F7B | TM7OC2H | TM7OC2<br>H7 | TM7OC2<br>H6 | TM7OC2<br>H5 | TM7OC2<br>H4 | TM7OC2<br>H3 | TM7OC2<br>H2 | TM7OC2<br>H1 | TM7OC2<br>H0 | VI-9 | | | | х | x | х | x | x | x | x | x | | | | | Timer 7 cor | npare registe | er 2 upper 8 b | oits | | | | | | | Address | Register | Bit Symbol | | | | | | | | Page | | | | |---------|----------|--------------|---------------------------|----------------|--------------|--------------|--------------|--------------|--------------|-------|--|--|--| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | rage | | | | | 0x03F7C | TM7PR2L | TM7PR2<br>L7 | TM7PR2<br>L6 | TM7PR2<br>L5 | TM7PR2<br>L4 | TM7PR2<br>L3 | TM7PR2<br>L2 | TM7PR2<br>L1 | TM7PR2<br>L0 | VI-10 | | | | | | | х | х | х | х | х | х | х | х | | | | | | | | Timer 7 pre | set register 2 | 2 lower 8 bits | | | | | | | | | | | 0x03F7D | TM7PR2H | TM7PR2<br>H7 | TM7PR1<br>H6 | TM7PR2<br>H5 | TM7PR2<br>H4 | TM7PR2<br>H3 | TM7PR2<br>H2 | TM7PR2<br>H1 | TM7PR2<br>H0 | VI-10 | | | | | | | х | х | х | х | х | х | х | х | | | | | | | | Timer 7 pre | set register 2 | 2 upper 8 bits | | | | | | | | | | | 0x03F7E | TM7DPR1 | TM7DPR<br>17 | TM7DP<br>R16 | TM7DP<br>R15 | TM7DP<br>R14 | TM7DP<br>R13 | TM7DP<br>R12 | TM7DP<br>R11 | TM7DP<br>R10 | VI-12 | | | | | | | х | х | x | х | x | х | х | х | | | | | | | | Timer 7 pre | set register 1 | | • | | | | | | | | | | 0x03F7F | TM7DPR2 | TM7DPR<br>27 | TM7DP<br>R26 | TM7DP<br>R25 | TM7DP<br>R24 | TM7DP<br>R23 | TM7DP<br>R22 | TM7DP<br>R21 | TM7DP<br>R20 | VI-12 | | | | | | | х | x | x | x | x | x | х | x | - | | | | | | | Timer 7 pre | Timer 7 preset register 2 | | | | | | | | | | | | 0x03F80 | TM8BCL | TM8BCL<br>7 | TM8BCL<br>6 | TM8BCL<br>5 | TM8BCL<br>4 | TM8BCL<br>3 | TM8BCL<br>2 | TM8BCL<br>1 | TM8BCL<br>0 | VI-15 | | | | | | | х | х | х | х | х | х | х | х | | | | | | | | Timer 8 bin | ary counter lo | ower 8 bits | | | | | | | | | | | 0x03F81 | TM8BCH | TM8BCH<br>7 | TM8BC<br>H6 | TM8BC<br>H5 | TM8BC<br>H4 | TM8BC<br>H3 | TM8BC<br>H2 | TM8BC<br>H1 | TM8BC<br>H0 | VI-15 | | | | | | | х | x | x | x | x | x | x | x | | | | | | | | Timer 8 bin | ary counter u | ipper 8 bits | | | | | | | | | | | 0x03F82 | TM8OC1L | TM8OC1<br>L7 | TM8OC1<br>L6 | TM8OC1<br>L5 | TM8OC1<br>L4 | TM8OC1<br>L3 | TM8OC1<br>L2 | TM8OC1<br>L1 | TM8OC1<br>L0 | VI-13 | | | | | | | х | x | x | x | x | x | x | x | | | | | | | | Timer 8 cor | mpare registe | er 1 lower 8 b | its | | | | | | | | | | 0x03F83 | TM8OC1H | TM8OC1<br>H7 | TM8OC1<br>H6 | TM8OC1<br>H5 | TM8OC1<br>H4 | TM8OC1<br>H3 | TM8OC1<br>H2 | TM8OC1<br>H1 | TM8OC1<br>H0 | VI-13 | | | | | | | х | x | x | x | x | x | x | x | | | | | | | | Timer 8 cor | mpare registe | er 1 upper 8 b | oits | | | | | | | | | | 0x03F84 | TM8PR1L | TM8PR1<br>L7 | TM8PR1<br>L6 | TM8PR1<br>L5 | TM8PR1<br>L4 | TM8PR1<br>L3 | TM8PR1<br>L2 | TM8PR1<br>L1 | TM8PR1<br>L0 | VI-14 | | | | | | | х | x | x | x | x | x | x | x | | | | | | | | Timer 8 pre | set register 1 | l lower 8 bits | | | | | | | | | | | 0x03F85 | TM8PR1H | TM8PR1<br>H7 | TM8PR1<br>H6 | TM8PR1<br>H5 | TM8PR1<br>H4 | TM8PR1<br>H3 | TM8PR1<br>H2 | TM8PR1<br>H1 | TM8PR1<br>H0 | VI-14 | | | | | | | х | x | x | x | x | x | x | x | | | | | | | | Timer 8 pre | set register 1 | Upper 8 bits | S | | | | | ] | | | | | | | Bit Symbol | | | | | | | | _ | |---------|----------|-----------------------------------------|--------------------------|----------------------------------------------------|-----------------------------------------------|---------------------------------------------|----------------------------------------------|--------------------|--------------|-------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03F86 | TM8ICL | TM8ICL7 | TM8ICL<br>6 | TM8ICL<br>5 | TM8ICL<br>4 | TM8ICL<br>3 | TM8ICL<br>2 | TM8ICL<br>1 | TM8ICL<br>0 | VI-15 | | | | х | х | х | х | х | х | х | х | | | | | Timer 8 inp | ut capture re | gister 1 lowe | r 8 bits | | | | | | | 0x03F87 | TM8ICH | TM8ICH7 | TM8ICH<br>6 | TM8ICH<br>5 | TM8ICH<br>4 | TM8ICH<br>3 | TM8ICH<br>2 | TM8ICH<br>1 | TM8ICH<br>0 | VI-15 | | | | х | x | x | x | x | x | x | x | | | | | Timer 8 inp | ut capture re | gister 1 uppe | r 8 bits | | | | | | | 0x03F88 | TM8MD1 | Reserved | T8ICED<br>G1 | TM8CL | TM8EN | TM8PS1 | TM8PS0 | TM8CK1 | TM8CK0 | VI-20 | | | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | | | Set<br>always to<br>"0". | Capture<br>trigger | Timer<br>output<br>reset<br>signal | Timer 8<br>count<br>control | Count cloc | k selection | Clock sour<br>tion | ce selec- | | | 0x03F89 | TM8MD2 | T8ICED<br>G1 | TM8PW<br>MSL | TM8BC<br>R | TM8PW<br>M | TM8IRS<br>1 | T8ICEN | T8ICT1 | T8ICT0 | VI-21 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Capture<br>trigger<br>edge<br>selection | PWM<br>mode<br>selection | Timer 8<br>count<br>clear fac-<br>tor<br>selection | Timer<br>output<br>wave-<br>form<br>selection | Timer 8<br>interrupt<br>factor<br>selection | Input<br>capture<br>opera-<br>tion<br>enable | Capture tri | gger | | | 0x03F8A | TM8OC2L | TM8OC2<br>L7 | TM8OC2<br>L6 | TM8OC2<br>L5 | TM8OC2<br>L4 | TM8OC2<br>L3 | TM8OC2<br>L2 | TM8OC2<br>L1 | TM8OC2<br>L0 | VI-13 | | | | х | х | х | х | х | х | х | х | | | | | Timer 8 cor | npare registe | r 2 lower 8 b | its | | | | | | | 0x03F8B | TM8OC2H | TM8OC2<br>H7 | TM8OC2<br>H6 | TM8OC2<br>H5 | TM8OC2<br>H4 | TM8OC2<br>H3 | TM8OC2<br>H2 | TM8OC2<br>H1 | TM8OC2<br>H0 | VI-13 | | | | х | х | х | х | х | х | х | х | | | | | Timer 8 cor | npare registe | r 2 upper 8 b | its | | | | | | | 0x03F8C | TM8PR2L | TM8PR2<br>L7 | TM8PR2<br>L6 | TM8PR2<br>L5 | TM8PR2<br>L4 | TM8PR2<br>L3 | TM8PR2<br>L2 | TM8PR2<br>L1 | TM8PR2<br>L0 | VI-14 | | | | x | х | х | х | х | х | х | х | | | | | | set register 2 | 1 | 1 | i | 1 | 1 | i | | | 0x03F8D | TM8PR2H | TM8PR2<br>H7 | TM8PR2<br>H6 | TM8PR2<br>H5 | TM8PR2<br>H4 | TM8PR2<br>H3 | TM8PR2<br>H2 | TM8PR2<br>H1 | TM8PR2<br>H0 | VI-14 | | | | х | х | х | х | х | х | х | x | | | | | Timer 8 pre | set register 2 | 2 upper 8 bits | | | | | | | | | 5 | Bit Symbol | | | | | | | | _ | |---------|----------|--------------------------------------------------------|------------------------------|-----------------------------------------|---------------------------------------|--------------------------------------------|------------------------------------------------|-----------------------------------------------|-------------------------------------------------|-------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03F8E | TM7MD3 | TM7CKS<br>MP | Reserve<br>d | TM7CKE<br>DG | T7IGBT<br>TR | T7IGBT<br>DT | T7IGBT<br>EN | T7IGBT1 | T7IGBT0 | VI-18 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Capture sampling | Set<br>always<br>to "0". | TM7IO<br>count<br>edge<br>selection | IGBT<br>trigger<br>level<br>selection | IGBT<br>dead<br>time<br>insert<br>timing | IGBT<br>opera-<br>tion<br>enable | IGBT/Time<br>selection | r trigger | | | 0x03F8F | TM8MD3 | TM8CKS<br>MP | - | - | TM8CKE<br>DG | TM8SEL | TM8PW<br>MF | TM8PW<br>MO | TM8CAS | VI-22 | | | | 0 | - | - | 0 | 0 | 0 | 0 | 0 | | | | | Capture sampling | | | TM8IO<br>count<br>edge<br>selection | Timer 8<br>output<br>selection | PWM<br>output<br>control<br>at timer<br>8 halt | Timer 8 PWM output polarity selection | Cascade selection | | | 0x03F90 | SCSEL | TMPSC1 | TMPSC1 | TMPSC<br>O2 | TMPSC<br>O1 | SC4SL | - | SC1SL | SCOSL | XI-12 | | | | 0 | 0 | 0 | 0 | 0 | - | 0 | 0 | | | | | Serial 1 Tim<br>dividing sel | • | Serial 0 tim<br>dividing se | ner 2 output<br>lection | Serial 4<br>I/O pin<br>switch-<br>ing | | Serial 1<br>I/O pin<br>switch-<br>ing | Serial 1<br>I/O pin<br>switch-<br>ing | | | 0x03F91 | SC0MD0 | SC0CE1 | - | - | SC0DIR | SCOSTE | SC0LNG<br>2 | SC0LNG<br>1 | SC0LNG<br>0 | XI-7 | | | | 0 | - | - | 0 | 0 | 1 | 1 | 1 | | | | | Transmis<br>sion /<br>Recep-<br>tion edge<br>selection | | | Transfer<br>bit speci-<br>fication | Start<br>condi-<br>tion<br>selection | Synchrono<br>selection | us serial trar | sfer bit | | | 0x03F92 | SC0MD1 | SCOIOM | SC0SBT<br>S | SC0SBI<br>S | SC0SBO<br>S | SC0CK<br>M | SCOMST | SC0DIIV | SC0CM<br>D | XI-8 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Serial<br>data<br>input<br>selection | SBT<br>function<br>selection | Serial<br>input<br>control<br>selection | SBO0<br>function<br>selection | Transfer<br>clock<br>dividing<br>selection | Clock<br>master/<br>slave<br>selection | Transfer clock dividing selection (1/8, 1/16) | Synchro<br>nous/<br>URT | | | 0x03F93 | SC0MD2 | SC0FM1 | SC0FM0 | SC0PM1 | SC0PM0 | SC0NPE | - | SC0BRK<br>F | SC0BRK<br>E | XI-9 | | | | 0 | 0 | 0 | 0 | 0 | - | 0 | 0 | | | | | Frame mod cation | de specifi- | Added bit s<br>tion | specifica- | Parity<br>enable | | Bread<br>status<br>recep-<br>tion<br>monitor | Break<br>status<br>trans-<br>mission<br>control | | | A.1.1 | <b>D</b> | Bit Symbol | | | | | | | | _ | |---------|----------|-----------------------------------------|------------------------------|-----------------------------------------|------------------------------------|--------------------------------------------|----------------------------------------|-----------------------------------------------|-------------------------------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | - Page | | 0x03F94 | SC0MD3 | SC0FDC<br>1 | SC0FDC<br>0 | - | - | SC0PSC<br>E | SC0PSC<br>2 | SC0PSC<br>1 | SCOPSC<br>0 | XI-10 | | | | 0 | 0 | - | - | 0 | 0 | 0 | 0 | | | | | Output sele<br>SBO0 final<br>mit | ection after<br>data trans- | - | - | Prescale<br>r count<br>control | Selection of | clock | | | | 0x03F95 | SCOSTR | SC0TBS<br>Y | SCORBS<br>Y | SC0TEM<br>P | SC0RE<br>MP | SC0FEF | SC0PEK | SC0OR<br>E | SC0ERE | XI-11 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Serial bus | status | Transfer<br>buffer<br>empty | Receive<br>buffer<br>empty | Framing error detection | Parity<br>error<br>detection | Overrun<br>error<br>detection | Error<br>monitor<br>flag | | | 0x03F96 | RXBUF0 | RXBUF0<br>7 | RXBUF0<br>6 | RXBUF0<br>5 | RXBUF0<br>4 | RXBUF0<br>3 | RXBUF0<br>2 | RXBUF0<br>1 | RXBUF0<br>0 | XI-6 | | | | х | x | х | x | x | x | x | x | | | | | Serial interf | face 0 recept | ion data buffe | er | 1 | 1 | | 1 | | | 0x03F97 | TXBUF0 | TXBUF0<br>7 | TXBUF0<br>6 | TXBUF0<br>5 | TXBUF0<br>4 | TXBUF0 | TXBUF0<br>2 | TXBUF0<br>1 | TXBUF0<br>0 | XI-6 | | | | х | х | х | х | х | х | х | х | | | | | Serial interf | face 0 transm | nission data b | uffer | | | | | | | 0x03F99 | SC1MD0 | SC1CE1 | - | - | SC1DIR | SC1STE | SC1LNG<br>2 | SC1LNG<br>1 | SC1LNG<br>0 | XII-7 | | | | 0 | - | - | 0 | 0 | 1 | 1 | 1 | | | | | transmiss ion/ reception edge selection | - | - | Transfer<br>bit speci-<br>fication | Start<br>condi-<br>tion<br>selection | Synchrono<br>tion | us transfer b | it specifica- | | | 0x03F9A | SC1MD1 | SC1IOM | SC1SBT<br>S | SC1SBI<br>S | SC1SBO<br>S | SC1CK<br>M | SC1MST | SC1DIV | SC0CM<br>D | XII-8 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Serial<br>data<br>input | SBT<br>function<br>selection | Serial<br>input<br>control<br>selection | SBO<br>function<br>selection | Transfer<br>clock<br>dividing<br>selection | Clock<br>master/<br>slave<br>selection | Transfer clock dividing selection (1/8, 1/16) | Synchro<br>nous/<br>UART | | | 0x03F9B | SC1MD2 | SC1FM1 | SC1FM0 | SC1PM1 | SC1PM0 | SC1NPE | - | SC1BRK<br>F | SC1BRK<br>E | XII-9 | | | | 0 | 0 | 0 | 0 | 0 | - | 0 | 0 | | | | | Frame mod cation | de specifi- | Added bit s<br>tion | specifica- | Parity<br>enable | - | Break<br>status<br>recep-<br>tion<br>monitor | Break<br>status<br>trans-<br>mission<br>control | | | Address | Register | Bit Symbol | | | | | | | | Page | |---------|----------|------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------|------------------------------------|--------------------------------------|------------------------------|-------------------------------|--------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | rage | | 0x03F9C | SC1MD3 | SC1FDC<br>1 | SC1FDC<br>0 | - | - | SC1PSC<br>E | SC1PSC<br>2 | SC1PSC<br>1 | SC1PSC<br>0 | XII-10 | | | | 0 | 0 | - | - | 0 | 0 | 0 | 0 | | | | | Output sele<br>SBO final d<br>mit | | | | Prescale<br>r count<br>control | Selection of | lock | | | | 0x03F9D | SC1STR | SC1TBS<br>Y | SC1RBS<br>Y | SC1TEM<br>P | SC1RE<br>MP | SC1FEF | SC1PEK | SC1OR<br>E | SC1ERE | XII-11 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Serial bus s | status | Transmis<br>sion<br>buffer<br>empty | Receptio<br>n buffer<br>empty | Frame<br>error<br>detection | Parity<br>error<br>detection | Overrun<br>error<br>detection | Error<br>monitor<br>flag | | | 0x03F9E | RXBUF1 | RXBUF1<br>7 | RXBUF1<br>6 | RXBUF1<br>5 | RXBUF1<br>4 | RXBUF1<br>3 | RXBUF1<br>2 | RXBUF1<br>1 | RXBUF1<br>0 | XII-6 | | | | х | x | x | x | x | x | х | x | | | | | Serial inter | ace 1 recept | ion data buffe | er | l . | l . | | | | | 0x03F9F | TXBUF1 | TXBUF1 | TXBUF1<br>6 | TXBUF1<br>5 | TXBUF1<br>4 | TXBUF1 | TXBUF1<br>2 | TXBUF1<br>1 | TXBUF1<br>0 | XII-6 | | | | х | x | x | x | x | x | x | x | | | | | Serial inter | ace 1 transm | nission data b | uffer | | | | | | | 0x03FA0 | SC3MD0 | SC3BSY | SC3CE1 | - | SC3DIR | SC3STE | SC3LNG<br>2 | SC3LNG<br>1 | SC3LNG<br>0 | XIII-6 | | | | 0 | 0 | - | 0 | 0 | 1 | 1 | 1 | | | | | Clock<br>synchro-<br>nous<br>transmis-<br>sion<br>serial bus<br>status | Transmis<br>sion/<br>Recep-<br>tion<br>edge<br>selection | - | Transfer<br>bit speci-<br>fication | Start<br>condi-<br>tion<br>selection | Synchrono<br>tion | us transfer b | it specifica- | | | 0x03FA1 | SC3MD1 | SC3IOM | SC3SBT<br>S | SC3SBI<br>S | SC3SBO<br>S | - | SC3MST | - | - | XIII-7 | | | | 0 | 0 | 0 | 0 | - | 0 | - | - | | | | | Serial<br>data<br>input<br>selection | SBT3<br>function<br>selection | Serial<br>input<br>control<br>selection | SBO3<br>function<br>selection | | Clock<br>master/<br>Slave | | | | | 0x03FA2 | SC3MD3 | SC3FDC<br>1 | SC3FDC<br>0 | - | - | SC3PSC<br>E | SC3PSC<br>2 | SC3PSC<br>1 | SC3PSC<br>0 | XIII-8 | | | | 0 | 0 | - | - | 0 | 0 | 0 | 0 | | | | | Output sele<br>SBO final d | | | | Prescale<br>r count<br>control | Selection of | lock | | | | Address | Register | Bit Symbol | | | | | | | | Page | |---------|----------|---------------------------|--------------------------------------|-------------------------------------|---------------------------|----------------------------------------------------------|------------------------------|----------------------------|---------------|---------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | raye | | 0x03FA3 | SC3STR | - | - | SC3TEM<br>P | - | - | - | - | - | XIII-9 | | | | - | - | 0 | - | - | - | - | - | | | | | | | Transfer<br>buffer<br>empty<br>flag | | | | | | | | 0x03FA4 | TXBUF3 | TXBUF3 | TXBUF3<br>6 | TXBUF3<br>5 | TXBUF3<br>4 | TXBUF3 | TXBUF3<br>2 | TXBUF3<br>1 | TXBUF3<br>0 | XIII-5 | | | | х | х | х | х | х | х | х | х | | | | | Serial inter | face 3 transm | nission data b | uffer | | | | | | | 0x03FA5 | SC3TRB | SC3TRB<br>7 | SC3TRB<br>6 | SC3TRB<br>5 | SC3TRB<br>4 | SC3TRB<br>3 | SC3TRB<br>2 | SC3TRB<br>1 | SC3TRB<br>0 | XIII-5 | | | | х | х | х | х | х | х | х | х | | | | | Serial inter | face 3 recept | ion data buffe | er | | | | | | | 0x03FA6 | SC3CTR | IIC3BSY | IIC3STC | IIC3STP<br>C | IIC3TMD | IIC3REX | SC3CM<br>D | SC3ACK<br>S | SC3ACK<br>O | XIII-10 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Serial<br>bus sta-<br>tus | Start<br>condi-<br>tion<br>selection | Stop<br>condi-<br>tion<br>selection | Commun<br>ication<br>mode | Transmis<br>sion/<br>Recep-<br>tion<br>mode<br>selection | Synchro<br>nous/ IIC | ACK<br>enable | ACK bit level | | | 0x03FA7 | SC4AD0 | I2CAD7 | I2CAD5 | I2CAD6 | I2CAD4 | I2CAD3 | I2CAD2 | I2CAD1 | I2CAD0 | XIV-6 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Serial inter | face 4 addres | s setup | | | | | | | | 0x03FA8 | SC4AD1 | SELI2C | I2CMON | - | - | I2CGEM | I2CADM | I2CAD9 | I2CAD8 | XIV-6 | | | | 0 | 0 | - | - | 0 | 0 | 0 | 0 | | | | | Reset<br>control | Pin mon-<br>itor | | | Commun ication mode selection | Address<br>mode<br>selection | Serial inter<br>address se | | | | 0x03FA9 | SC4RXB | I2CRXB7 | I2CRXB<br>6 | I2CRXB<br>5 | I2CRXB<br>4 | I2CRXB<br>3 | I2CRXB<br>2 | I2CRXB<br>1 | I2CRXB<br>0 | XIV-5 | | | | х | х | х | х | х | х | х | х | | | | | Serial inter | face 4 recept | ion data buffe | er | • | • | | • | | | 0x03FAA | SC4TXB | I2CTXB7 | I2CTXB6 | I2CTXB5 | I2CTXB4 | I2CTXB3 | I2CTXB2 | I2CTXB1 | I2CTXB0 | XIV-5 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Serial inter | face 4 transm | nission data b | uffer | • | | | | | | A dduc c c | Dogistor | Bit Symbol | | | | | | | | Dane | |------------|----------|-------------------------------------------------------------|----------------------------------|--------------------------------------|-----------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------|---------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03FAB | SC4STR | WRS | I2CINT | STRT | RSTRT | I2CBSY | SLVBSY | ACKVAL<br>ID | - | XIV-7 | | | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | - | | | | | Data<br>transfer<br>direction<br>determi-<br>nation<br>flag | Interrupt<br>detec-<br>tion flag | Start<br>condi-<br>tion<br>detection | Re-start<br>condi-<br>tion<br>detection | Bus<br>busy flag | Slave<br>busy flag | ACK<br>detec-<br>tion flag | | | | 0x03FC0 | LCDMD1 | LCDEN | Reserve<br>d | LCDTY1 | LCDTY0 | LCDCK3 | LCDCK2 | LCDCK1 | LCDCK0 | XVI-7 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | LCD start | Set<br>always<br>to "0". | LCD displa | ay duty | Source clo | ck | | | | | 0x03FC1 | LCDMD2 | | | Reserve<br>d | Reserve<br>d | LCRHL | LCREN | Reserve<br>d | Reserve<br>d | XVI-8 | | | | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | Set always | s to "0". | Internal<br>voltage<br>dividing<br>resistor<br>value<br>selection | Dividing<br>voltage<br>resistor<br>connec-<br>tion<br>selection | Set always | s to "00" | | | 0x03FC2 | LCCTR1 | LC1SL3 | LC1SL2 | LC1SL1 | LC1SL0 | COMSL<br>3 | COMSL<br>2 | COMSL<br>1 | COMSL<br>0 | XVI-9 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | P74/<br>SEG3<br>selection | P75/<br>SEG2<br>selection | P76/<br>SEG1<br>selection | P77/<br>SEG0<br>selection | P33/<br>COM3<br>selection | P32/<br>COM2<br>selection | P31/<br>COM1<br>selection | P30/<br>COM0<br>selection | | | 0x03FC3 | LCCTR2 | LC2SL7 | LC2SL6 | LC2SL5 | LC2SL4 | LC2SL3 | LC2SL2 | LC2SL1 | LC2SL0 | XVI-10 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | P14/<br>SEG11<br>selection | P15/<br>SEG10<br>selection | P16/<br>SEG9<br>selection | P17/<br>SEG8<br>selection | P70/<br>SEG7<br>selection | P71/<br>SEG6<br>selection | P72/<br>SEG5<br>selection | P73/<br>SEG4<br>selection | | | 0x03FC4 | LCCTR3 | - | - | - | - | - | LC3SL2 | LC3SL1 | LC3SL0 | XVI-11 | | | | - | - | - | - | - | 0 | 0 | 0 | | | | | | | | | | P34/<br>VLC3<br>selection | P35/<br>VLC2<br>selection | P36/<br>VLC1<br>selection | | | 0x03FC | ANCTR0 | ANSH1 | ANSH0 | ANCK1 | ANCK0 | ANLADE | - | - | - | XV-5 | | В | | 0 | 0 | 0 | 0 | 0 | - | - | - | | | | | Sample an | d hold time | A/D conve | rsion clock | A/D lad-<br>der<br>resis-<br>tance<br>control | | | | | | | | Bit Symbol | | | | | | | | _ | |-------------|----------|--------------------------|---------------------------------------------------|----------------------------------------------------------|-------------|--------|---------------------------|--------------------------------------|------------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03FC | ANCTR1 | - | - | - | - | - | ANSHS2 | ANSHS1 | ANSHS0 | XV-6 | | С | | - | - | - | - | - | 0 | 0 | 0 | | | | | | | | | | Analog inp | ut channel | | | | 0x03FC<br>D | ANCTR2 | ANST | ANSTSE<br>L1 | Reserve<br>d | - | - | - | - | - | XV-6 | | | | 0 | 0 | 0 | - | - | - | - | - | | | | | A/D conversion status | A/D conversion<br>starting<br>factor<br>selection | Set<br>always<br>to "0". | | | | | | | | 0x03FC<br>E | ANBUF0 | ANBUF0<br>7 | ANBUF0<br>6 | - | - | - | - | - | - | XV-7 | | | | х | х | - | - | - | - | - | - | | | | | A/D conver | sion data sto | rage buffer 0 | | | | | | | | 0x03FC<br>F | ANBUF1 | ANBUF1<br>7 | ANBUF1<br>6 | ANBUF1<br>5 | ANBUF1<br>4 | ANBUF1 | ANBUF1<br>2 | ANBUF1<br>1 | ANBUF1<br>0 | XV-7 | | | | х | x | x | х | х | х | x | x | | | | | A/D conver | sion data sto | rage buffer 1 | | _ | | | | | | 0x03FE1 | NMICR | - | - | - | - | - | IRQNPG | IRQNW<br>DG | Reserve<br>d | III-19 | | | | - | - | - | - | - | 0 | 0 | 0 | | | | | | | | | | Program interrupt request | Watch<br>dog<br>interrupt<br>request | Set<br>always<br>to "0". | | | 0x03FE2 | IRQ0ICR | IRQ0LV1 | IRQ0LV0 | REDG0 | - | - | - | IRQ0IE | IRQ0IR | III-20 | | | | 0 | 0 | 0 | - | - | - | 0 | 0 | | | | | Interrupt le cation flag | vel specifi- | Interrupt<br>valid<br>edge<br>specifi-<br>cation<br>flag | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE3 | IRQ1ICR | IRQ1LV1 | IRQ1LV0 | REDG0 | - | - | - | IRQ1IE | IRQ1IR | III-21 | | | | 0 | 0 | 0 | - | - | - | 0 | 0 | | | | | Interrupt le cation flag | vel specifi- | Interrupt<br>valid<br>edge<br>specifi-<br>cation<br>flag | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | Address | Dogistor | Bit Symbol | | | | | | | | Dogo | |-----------|----------|-----------------------------|--------------|----------------------------------------------------------|-------|-------|-------|-----------------------------|------------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | - Page | | 0x03FE4 | IRQ2ICR | IRQ2LV1 | IRQ2LV0 | REDG1 | - | - | - | IRQ2IE | IRQ2IR | III-22 | | | | 0 | 0 | 0 | - | - | - | 0 | 0 | | | | | Interrupt le<br>cation flag | vel specifi- | Interrupt<br>valid<br>edge<br>specifi-<br>cation<br>flag | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE6 | IRQ4ICR | IRQ4LV1 | IRQ4LV0 | - | - | - | - | IRQ4IE | IRQ4IR | III-23 | | | | 0 | 0 | 0 | - | - | - | 0 | 0 | | | 0x03FE7 T | | Interrupt le<br>cation flag | vel specifi- | Interrupt<br>valid<br>edge<br>specifi-<br>cation<br>flag | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE7 | TM0ICR | TM0LV1 | TM0LV0 | - | - | - | - | TM0IE | TM0IR | III-24 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | DV03EE9 3 | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE8 | TM1ICR | TM1LV1 | TM1LV0 | - | - | - | - | TM1IE | TM1IR | III-25 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE9 | TM2ICR | TM2LV1 | TM2LV0 | - | - | - | - | TM2IE | TM2IR | III-26 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE | TM3ICR | TM3LV1 | TM3LV0 | - | - | - | - | ТМЗІЕ | TM3IR | III-27 | | Α | | 0 | 0 | - | - | - | - | 0 | 0 | 1 | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE | TM6ICR | TM6LV1 | TM6LV0 | - | - | - | - | TM6IE | TM6IR | III-28 | | В | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | A ddroop | Dogistor | Bit Symbol | | | | | | | | Dogo | |-------------|----------|--------------|--------------|-------|-------|-------|-------|-----------------------------|------------------------------|--------| | Address | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | - Page | | 0x03FE<br>C | TBICR | TBLV1 | TBLV0 | - | - | - | - | TBIE | TBIR | III-29 | | C | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE<br>D | TM7ICR | TM7LV1 | TM7LV0 | - | - | - | - | TMOIE | TM0IR | III-30 | | D | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FE<br>E | T7OC2ICR | T7OC2L<br>V1 | T7OC2L<br>V0 | - | - | - | - | T7OC2I<br>E | T7OC2I<br>R | III-31 | | | | 0 | 0 | - | - | - | - | 0 | 0 | - | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FEF | SC0RICR | SC0RLV<br>1 | SCORLV<br>0 | - | - | - | - | SC0RIE | SC0RIR | III-32 | | | | 0 | 0 | - | - | - | - | 0 | 0 | 1 | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FF0 | SC0TICR | SC0TLV1 | SC0TLV<br>0 | - | - | - | - | SC0TIE | SC0TIR | III-33 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FF1 | SC1RICR | SC1RLV<br>1 | SC1RLV<br>0 | - | - | - | - | SC0RIE | SC0RIR | III-34 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FF2 | SC1TICR | SC1TLV1 | SC1TLV<br>0 | - | - | - | - | SC1TIE | SC1TIR | III-35 | | | | 0 | 0 | - | - | - | - | 0 | 0 | 1 | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FF3 | SC3ICR | SC3LV1 | SC3LV0 | - | - | - | - | SC3IE | SC3IR | III-36 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | Addroop | Register | Bit Symbol | | | | | | | | Page | |------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------|--------------|-------|-------|-------|-------|-----------------------------|------------------------------|--------| | 0x03FF4 AD 0x03FF5 SC 0x03FF6 TM | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Page | | 0x03FF4 | ADICR ADLV1 0 Interrupt level SC4ICR SC4LV1 0 Interrupt level TM8ICR TM8LV1 0 Interrupt level T8OC2ICR T8OC2L V1 | | ADLV0 | - | - | - | - | ADIE | ADIR | III-37 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FF5 | SC4ICR | SC4LV1 | SC4LV0 | - | - | - | - | SC4IE | SC4IR | III-38 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FF6 | TM8ICR | TM8LV1 | TM8LV0 | - | - | - | - | TM8IE | TM8IR | III-39 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | | 0x03FF7 | T8OC2ICR | | T8OC2L<br>V0 | - | - | - | - | T8OC2I<br>E | T8OC2I<br>R | III-40 | | | | 0 | 0 | - | - | - | - | 0 | 0 | | | | | Interrupt le | vel flag | | | | | Interrupt<br>enable<br>flag | Interrupt<br>request<br>flag | | # 17.5 Instruction Set | Group | Mnemonic | Operation | | FI | | | Code | Cycle | Re- | | | | | | | | e Code | | | | 1 | |---------|-------------------|----------------------|----------|----|----|----------|------|--------|------|------|------|---------|--------------------------------------------------------------------------------------------------------------|----|------|------|--------|---|---|----|---------------| | | | | VF | NF | CF | ZF | Size | | peat | Ext. | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | | ta Move | Instructions | Dr. Dr. | Т | | | | 2 | 1 | | | 1010 | D., D., | | | | | | | | | — | | OV | MOV Dn,Dm | Dn→Dm | | | | | | | | | | DnDm | - 40 | | | | | | | | | | | MOV Imm8,Dm | imm8→Dm | | | | | 4 | 3 | | 0040 | | OMDm | 1 <#8. | > | | | | | | | $\rightarrow$ | | | MOV Dn,PSW | Dn→PSW | • | • | • | • | 3 | 2 | | 0010 | | | | | | | | | | | $\dashv$ | | | MOV PSW,Dm | PSW→Dm | | | | - | 2 | 2 | | 0010 | | | | | | | | | | | $\dashv$ | | | MOV (An),Dm | mem8(An)→Dm | | | | | 4 | 2 | | | 0100 | | .40 | | | | | | | | $\rightarrow$ | | | MOV (d8,An),Dm | mem8(d8+An)→Dm | | | | | | | | | | 1ADm | | > | | | | | | | | | | MOV (d16,An),Dm | mem8(d16+An)→Dm | | | | | 7 | 4 | | | | | <d16< td=""><td></td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></d16<> | | | > | | | | | | | | MOV (d4,SP),Dm | mem8(d4+SP)→Dm | | | | | 3 | 2 | | | | 01Dm | | | | | | | | | $\rightarrow$ | | | MOV (d8,SP),Dm | mem8(d8+SP)→Dm | | | | | 5 | 3 | | 0010 | | | | > | | | | | | | - | | | MOV (d16,SP),Dm | mem8(d16+SP)→Dm | | | | | 7 | 4 | | 0010 | | | | | | > | | | | | - | | | MOV (io8),Dm | mem8(IOTOP+io8)→Dm | | | | | 4 | 2 | | | | 00Dm | | > | | | | | | | _ | | | MOV (abs8),Dm | mem8(abs8)→Dm | | | | | 4 | 2 | | | 0100 | 01Dm | <abs< td=""><td>8&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td>_</td></abs<> | 8> | | | | | | | _ | | | MOV (abs12),Dm | mem8(abs12)→Dm | | | | | 5 | 2 | | | | | <abs< td=""><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | | > | | | | | | | | | MOV (abs16),Dm | mem8(abs16)→Dm | | | | | 7 | 4 | | 0010 | 1100 | 00Dm | <abs< td=""><td>16</td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></abs<> | 16 | | > | | | | | | | | MOV Dn,(Am) | Dn→mem8(Am) | | | | | 2 | 2 | | | 0101 | 1aDn | | | | | | | | | | | | MOV Dn,(d8,Am) | Dn→mem8(d8+Am) | | | | | 4 | 2 | | | 0111 | 1aDn | <d8.< td=""><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d8.<> | > | | | | | | | | | | MOV Dn,(d16,Am) | Dn→mem8(d16+Am) | | | | | 7 | 4 | | 0010 | 0111 | 1aDn | <d16< td=""><td></td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></d16<> | | | > | | | | | | | | MOV Dn,(d4,SP) | Dn→mem8(d4+SP) | | | | | 3 | 2 | | | 0111 | 01Dn | <d4></d4> | | | | | | | | | | | MOV Dn,(d8,SP) | Dn→mem8(d8+SP) | | | | | 5 | 3 | | 0010 | 0111 | 01Dn | <d8.< td=""><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d8.<> | > | | | | | | | | | | MOV Dn,(d16,SP) | Dn→mem8(d16+SP) | | | | | 7 | 4 | | 0010 | 0111 | 00Dn | <d16< td=""><td></td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></d16<> | | | > | | | | | | | | MOV Dn,(io8) | Dn→mem8(IOTOP+io8) | | | | | 4 | 2 | | | 0111 | 00Dn | <i08< td=""><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></i08<> | > | | | | | | | | | | MOV Dn,(abs8) | Dn→mem8(abs8) | | | | | 4 | 2 | | | 0101 | 01Dn | <abs< td=""><td>8&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 8> | | | | | | | | | | MOV Dn,(abs12) | Dn→mem8(abs12) | | | | | 5 | 2 | | | 0101 | 00Dn | <abs< td=""><td>12</td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 12 | > | | | | | | | | | MOV Dn,(abs16) | Dn→mem8(abs16) | | | | | 7 | 4 | | 0010 | 1101 | 00Dn | <abs< td=""><td>16</td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></abs<> | 16 | | > | | | | | | | | MOV imm8,(io8) | imm8→mem8(IOTOP+io8) | | | | | 6 | 3 | | | 0000 | 0010 | <i08< td=""><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></i08<> | > | <#8. | > | | | | | | | | MOV imm8,(abs8) | imm8→mem8(abs8) | | | | | 6 | 3 | | | 0001 | 0100 | <abs< td=""><td>8&gt;</td><td>&lt;#8.</td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></abs<> | 8> | <#8. | > | | | | | | | | MOV imm8,(abs12) | imm8→mem8(abs12) | | | | | 7 | 3 | | | 0001 | 0101 | <abs< td=""><td>12</td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td></td><td></td><td></td><td></td></abs<> | 12 | > | <#8. | > | | | | | | | MOV imm8,(abs16) | imm8→mem8(abs16) | | | | | 9 | 5 | | 0011 | 1101 | 1001 | <abs< td=""><td>16</td><td></td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td></td><td></td><td></td></abs<> | 16 | | > | <#8. | > | | | | | | MOV Dn,(HA) | Dn→mem8(HA) | | | | | 2 | 2 | | | 1101 | | | | | | | | | | | | OVW | MOVW (An),DWm | mem16(An)→DWm | | | | | 2 | 3 | | | 1110 | | | | | | | | | | | | | MOVW (An),Am | mem16(An)→Am | | | | | 3 | 4 | | 0010 | | | | | | | | | | | | | | MOVW (d4,SP),DWm | mem16(d4+SP)→DWm | | | | | 3 | 3 | | | | 011d | <d4></d4> | | | | | | | | | | | MOVW (d4,SP),Am | mem16(d4+SP)→Am | | | | | 3 | 3 | | | | 010a | | | | | | | | | | | | MOVW (d8,SP),DWm | mem16(d8+SP)→DWm | | | | | 5 | 4 | | 0010 | | | | > | | | | | | | | | | MOVW (d8,SP),Am | mem16(d8+SP)→Am | <b>.</b> | | | | 5 | 4 | | 0010 | | | | > | | | | | | | | | | MOVW (d16,SP),DWm | mem16(d16+SP)→DWm | 1 | | | - | 7 | 5 | | 0010 | | | | | | | | | | | | | | MOVW (d16,SP),Am | mem16(d16+SP)→Am | | | | | 7 | 5 | | 0010 | | | | | | > | | | | | | | | MOVW (abs8),DWm | mem16(abs8)→DWm | | | | - | 4 | 3 | | 0010 | | | | | | / | | | | | | | | MOVW (abs8),Am | | | | | - | 4 | 3 | | | | | <abs< td=""><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | | | | | | | | | | | | mem16(abs8)→Am | | | | | 7 | 5 | | | | | | | | | | | | | | | | MOVW (abs16),DWm | mem16(abs16)→DWm | | | | | | - | | 0010 | | | | 16 | | > | | | | | | | | MOVW (abs16),Am | mem16(abs16)→Am | | | | | 7 | 5<br>3 | | | | | <abs< td=""><td>16</td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></abs<> | 16 | | > | | | | | | | | MOVW DWn,(Am) | DWn→mem16(Am) | | | | | | | | | 1111 | | | | | | | | | | | | | MOVW An,(Am) | An→mem16(Am) | | | | | 3 | 4 | | 0010 | | | | | | | | | | | | | | MOVW DWn,(d4,SP) | DWn→mem16(d4+SP) | | | | | 3 | 3 | | | | 011D | | | | | | | | | | | | MOVW An,(d4,SP) | An→mem16(d4+SP) | | | | | 3 | 3 | | | | 010A | | | | | | | | | | | | MOVW DWn,(d8,SP) | DWn→mem16(d8+SP) | | | | | 5 | 4 | | 0010 | | | | > | | | | | | | | | | MOVW An,(d8,SP) | An→mem16(d8+SP) | | | | | 5 | 4 | | 0010 | | | | > | | | | | | | | | | MOVW DWn,(d16,SP) | DWn→mem16(d16+SP) | | | | | 7 | 5 | | 0010 | 1111 | 001D | <d16< td=""><td></td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></d16<> | | | > | | | | | | | | MOVW An,(d16,SP) | An→mem16(d16+SP) | | | | | 7 | 5 | | 0010 | 1111 | 000A | <d16< td=""><td></td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></d16<> | | | > | | | | | | | | MOVW DWn,(abs8) | DWn→mem16(abs8) | | | | | 4 | 3 | | | 1101 | 011D | <abs< td=""><td>8&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 8> | | | | | | | | | | MOVW An,(abs8) | An→mem16(abs8) | | | | | 4 | 3 | | | 1101 | 010A | <abs< td=""><td>8&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 8> | | | | | | | | | | MOVW DWn,(abs16) | DWn→mem16(abs16) | <u></u> | | | <u> </u> | 7 | 5 | _ | 0010 | 1101 | 011D | <abs< td=""><td>16</td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td></abs<> | 16 | | > | | | | | | | | MOVW An,(abs16) | An→mem16(abs16) | | | | | 7 | 5 | | 0010 | 1101 | 010A | <abs< td=""><td>16</td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td>_</td></abs<> | 16 | | > | | | | | _ | | | MOVW DWn,(HA) | DWn→mem16(HA) | | | | | 2 | 3 | | | 1001 | 010D | | | | | | | | _ | | | | MOVW An,(HA) | An→mem16(HA) | | | | | 2 | 3 | | | 1001 | 011A | | | | | | | | | | | | MOVW imm8,DWm | sign(imm8)→DWm | | | | | 4 | 2 | | | | 110d | <#8. | > | | | | | | | | | | MOVW imm8,Am | zero(imm8)→Am | | | | | 4 | 2 | | | | 111a | | > | | | | | | | | | | , | , ., | 1 | 1 | | _ | | | - | | | | | | | | | | | | | <sup>\*1</sup> d8 sign-extension \*4 A=An, a=Am \*5 #8 sign-extension \*6 #8 zero-extension \*6 #8 zero-extension | Group | Mnemonic | Operation | | | ag | 7- | | | | exten- | 1 | 2 | 3 | 4 | ا<br>5 | Machin<br>6 | ie Cod | | 9 | 10 | 11 | N | |-----------|---------------------------|--------------------------------------------------|----|-----|----|----|------|----|----------|---------------|--------|------|------------------------------------------------------------------------------------------------------------------------|----|--------|-------------|--------|---|------|-----|-------|-----| | | | | ۷F | INF | CF | ZF | Size | | peat | sion | | | <u> </u> | | | - | | - | 3 | 10 | - ' ' | _ | | | MOVW imm16,Am | imm16→Am | T | | | | 6 | 3 | | | 1101 | 111a | <#16 | | | > | | | | | | Т | | | MOVW SP,Am | SP→Am | | | | | 3 | 3 | | 0010 | 0000 | | | | | | | | | | | + | | | MOVW An,SP | An→SP | | | | | 3 | 3 | | | 0000 | | | | | | | | | | | † | | | MOVW DWn,DWm | DWn→DWm | | | | | 3 | 3 | | _ | 1000 | | | | | | | | | | | + | | | MOVW DWn,Am | DWn→Am | +- | - | - | _ | 3 | 3 | | | 0100 | | | | | | | | | | | + | | | MOVW An,DWm | An→DWm | +- | - | | | 3 | 3 | | _ | 1100 | | | | | | | | | | | + | | | MOVW An,Am | An→Am | + | | | - | 3 | 3 | | _ | 0000 | | | | | | | | | | | + | | PUSH | PUSH Dn | SP-1→SP,Dn→mem8(SP) | + | | | - | 2 | 3 | | 0010 | | | | | | | | | | | | - | | FUSH | | SP-2→SP,An→mem16(SP) | + | - | | | 2 | 5 | | | 0001 | 10Dn | | | | | | | | | | + | | DOD | PUSH An<br>POP Dn | | + | | | | 2 | 3 | | | | | | | | | | | | | | + | | POP | | mem8(SP)→Dn,SP+1→SP | | | | - | _ | | | | | 10Dn | | | | | | | | | | + | | | POP An | mem16(SP)→An,SP+2→SP | | | | | 2 | 4 | | | 0000 | | | | | | | | | | | 4 | | EXT | EXT Dn,DWm | sign(Dn)→DWm | | | | | 3 | 3 | | 0010 | 1001 | 000d | | | | | | | | | | | | | manupulation instruction: | | _ | | | | _ | _ | | | | | | | | | | | | | | _ | | ADD | ADD Dn,Dm | Dm+Dn→Dm | • | • | • | • | 3 | 2 | | 0011 | | DnDm | | | | | | | | | | 4 | | | ADD imm4,Dm | Dm+sign(imm4)→Dm | • | • | • | • | 3 | 2 | | | 1000 | 00Dm | <#4> | | | | | | | | | 4 | | | ADD imm8,Dm | Dm+imm8→Dm | • | • | • | • | 4 | 2 | | | 0000 | 10Dm | <#8. | > | | | | | | | | 4 | | ADDC | ADDC Dn,Dm | Dm+Dn+CF→Dm | • | • | • | • | 3 | 2 | 0 | 0011 | 1011 | DnDm | | | | | | | | | | _ | | ADDW | ADDW DWn,DWm | DWm+DWn→DWm | • | • | • | • | 3 | 3 | 0 | 0010 | 0101 | 00Dd | | | | | | | | | | | | | ADDW DWn,Am | Am+DWn→Am | • | • | • | • | 3 | 3 | 0 | 0010 | 0101 | 10Da | | | | | | | | | | J | | | ADDW imm4,Am | Am+sign(imm4)→Am | • | • | • | • | 3 | 2 | | | 1110 | 110a | <#4> | | | | | | | | | 7 | | | ADDW imm8,Am | Am+sign(imm8)→Am | • | • | • | • | 5 | 3 | | 0010 | 1110 | 110a | <#8. | > | | | | | | | | | | | ADDW imm16,Am | Am+imm16→Am | • | • | • | • | 7 | 4 | | 0010 | 0101 | 011a | <#16 | | | > | | | | | | ٦ | | | ADDW imm4.SP | SP+sign(imm4)→SP | | | | | 3 | 2 | | | | 1101 | | | | | | | | | | ٦ | | | ADDW imm8.SP | SP+sign(imm8)→SP | + | | | | 4 | 2 | | | | 1100 | | > | | | | | | | | _ | | | ADDW imm16,SP | SP+imm16→SP | +- | | | _ | 7 | 4 | | 0010 | | 1100 | | | | _ | | | | | | + | | | ADDW imm16,DWm | DWm+imm16→DWm | • | • | • | • | 7 | 4 | | | | 010d | _ | | | > | | | | | | + | | ADDUW | ADDUW Dn,Am | | • | • | • | • | 3 | 3 | 0 | | | | <# 10 | | | > | | | | | | + | | | | Am+zero(Dn)→Am | Ť | - | - | - | 3 | | _ | | 1000 | | | | | | | | | | | 4 | | ADDSW | ADDSW Dn,Am | Am+sign(Dn)→Am | • | • | • | • | _ | 3 | 0 | | 1001 | | | | | | | | | | | 4 | | SUB | SUB Dn,Dm( when Dn≠Dm) | Dm-Dn→Dm | • | • | • | • | 3 | 2 | 0 | 0010 | | DnDm | | | | | | | | | | 4 | | | SUB Dn,Dn | Dn-Dn→Dn | 0 | 0 | 0 | 1 | 2 | 1 | | | 1000 | | | | | | | | | | | 4 | | | SUB imm8,Dm | Dm-imm8→Dm | • | • | • | • | 5 | 3 | | 0010 | 10101 | DmDm | <#8. | > | | | | | | | | | | SUBC | SUBC Dn,Dm | Dm-Dn-CF→Dm | • | • | • | • | 3 | 2 | 0 | 0010 | 1011 | DnDm | | | | | | | | | | | | SUBW | SUBW DWn,DWm | DWm-DWn→DWm | • | • | • | • | 3 | 3 | | 0010 | 0100 | 00Dd | | | | | | | | | | | | | SUBW DWn,Am | Am-DWn→Am | • | • | • | • | 3 | 3 | | 0010 | 0100 | 10Da | | | | | | | | | | | | | SUBW imm16,DWm | DWm-imm16→DWm | • | • | • | • | 7 | 4 | | 0010 | 0100 | 010d | <#16 | | | > | | | | | | | | | SUBW imm16,Am | Am-imm16→Am | • | • | • | • | 7 | 4 | | 0010 | 0100 | 011a | <#16 | | | > | | | | | | | | MULU | MULU Dn,Dm | Dm*Dn→DWk | 0 | • | • | • | 3 | 8 | | 0010 | 1111 | 111D | | | | | | | | | | | | DIVU | DIVU Dn,DWm | DWm/Dn→DWm-IDWm-h | • | • | • | • | 3 | 9 | | 0010 | 1110 | 111d | | | | | | | | | | _ | | CMP | CMP Dn,Dm | Dm-DnPSW | • | • | • | • | 3 | 2 | | 0011 | 0010 | DnDm | | | | | | | | | | 7 | | | CMP imm8.Dm | Dm-imm8PSW | • | • | • | • | 4 | 2 | | | | 00Dm | <#R | > | | | | | | | | + | | | CMP imm8,(abs8) | mem8(abs8)-imm8PSW | • | • | • | • | 6 | 3 | | | | 0100 | | | <#8. | > | | | | | | - | | | CMP imm8,(abs12) | mem8(abs12)-imm8PSW | • | • | • | • | 7 | 3 | | | | | | | | | | | | | | - | | | - ' ' | <del> </del> | +- | 1 | - | • | 9 | | | 0011 | 0000 | | <abs< td=""><td>12</td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td></td><td></td><td></td><td></td><td>-</td></abs<> | 12 | > | <#8. | > | | | | | - | | ON ADVA | CMP imm8,(abs16) | mem8(abs16)-imm8PSW | • | • | • | - | _ | 5 | | | | 1000 | <abs< td=""><td>16</td><td></td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td></td><td></td><td></td><td>_</td></abs<> | 16 | | > | <#8. | > | | | | _ | | CMPW | CMPW DWn,DWm | DWm-DWnPSW | • | • | • | • | 3 | 3 | | _ | 1000 | | | | | | | | | | | _ | | | CMPW DWn,Am | Am-DWnPSW | • | • | - | | 3 | 3 | | | 0101 | | | | | | | | | | | _ | | | CMPW An,Am | Am-AnPSW | • | • | • | • | 3 | 3 | | 0010 | 0000 | | | | | | | | | | | _ | | | CMPW imm16,DWm | DWm-imm16PSW | • | • | • | • | 6 | 3 | | | 1100 | 110d | <#16 | | | > | | | | | | | | | CMPW imm16,Am | Am-imm16PSW | • | • | • | • | 6 | 3 | | | 1101 | 110a | <#16 | | | > | | | | | | _ ' | | ogical ma | nipulation instructions | | | | | _ | | | | | | | | | | | | | | | | _ | | AND | AND Dn,Dm | Dm&Dn→Dm | 0 | • | 0 | • | 3 | 2 | | 0011 | 0111 | DnDm | | | | | | | | | | | | | AND imm8,Dm | Dm&imm8→Dm | 0 | • | 0 | • | 4 | 2 | | | 0001 | 11Dm | <#8. | > | | | | | | | | | | | AND imm8,PSW | PSW&imm8→PSW | • | • | • | • | 5 | 3 | | 0010 | 1001 | 0010 | <#8. | > | | | | | | | | Ī | | OR . | OR Dn,Dm | DmlDn→Dm | 0 | • | 0 | • | 3 | 2 | | 0011 | 0110 | DnDm | | | | | | | | | | _ | | | OR imm8,Dm | Dmlimm8→Dm | 0 | • | 0 | • | 4 | 2 | | | 0001 | 10Dm | <#8. | > | | | | | | | | _ | | | OR imm8,PSW | PSWlimm8→PSW | • | • | • | • | 5 | 3 | | 0010 | | 0011 | | > | | | | | | | | - | | XOR | XOR Dn,Dm | Dm^Dn→Dm | 0 | • | 0 | • | 3 | 2 | | | | DnDm | | | | | | | | | | - | | | XOR imm8,Dm | Dm^imm8→Dm | 0 | - | 0 | • | 5 | 3 | | | | DmDm | <b>-</b> #Ω | _ | | | | | | | | - | | | ACK IIIIIIO,DIII | DIII IIIIIIIO—DIIII | 10 | | U | • | | | <u> </u> | | | | | > | | | | | | | | - | | | | | | | | | | ** | 1 [ | D=DW | /n. d= | -DWm | n | *5 | D=D | Wm | | | *9 r | m≠n | | | | | | | | | | | | | | | | | | | | | | | ٠. | , | | | | | | | | | | | | ** | 2 / | A=An,<br>d=DW | a=Aı | | | *6 | #4 s | ign-e: | | | ٠. | , | | | Instruction Set XVII - 29 | Group | Mnemonic | Operation | | FI | ag | | Code | Cycle | Re- | Exten | | | | | ı | 1achin | e Code | e | | | | N | |-----------|-----------------------|---------------------------------------|----------|----------|----------|----------|------|-------|------|-------|------|-------|----------------------------------------------------------------------------------------------------------------|-----|------|--------|--------|---|---|----|----|---| | Gloup | Willemonic | Operation | VF | | | ZF | Size | | peat | | 1 | 2 | 3 | 4 | 5 " | 6 | 7 | 8 | 9 | 10 | 11 | | | | | | | | | | | | | 0.011 | | | | | | | | | | | | | | IOT | NOT Dn | <sup>−</sup> Dn→Dn= | 0 | • | 0 | • | 3 | 2 | | 0010 | 0010 | 10Dn | | | | | | | | | | T | | ASR | ASR Dn | Dn.msb→temp,Dn.lsb→CF | 0 | <b> </b> | • | • | 3 | 2 | 0 | _ | 0011 | | | | | | | | | | | † | | | | Dn>>1→Dn,temp→Dn.msb | | | | - | | | | | | | | | | | | | | | | | | SR | LSR Dn | Dn.lsb→CF,Dn>>1→Dn | 0 | 0 | • | • | 3 | 2 | 0 | 0010 | 0011 | 11Dn | | | | | | | | | | + | | _31 | LOK DII | | ١ | ١٠ | _ | ▮ | ٦ | _ | _ | 0010 | 0011 | ПОП | | | | | | | | | | | | | | 0→Dn.msb | | - | | _ | | | | | | | | | | | | | | | | 4 | | ROR | ROR Dn | Dn.lsb→temp,Dn>>1→Dn | 0 | • | • | • | 3 | 2 | 0 | 0010 | 0010 | 11Dn | | | | | | | | | | | | | | CF→Dn.msb,temp→CF | | | | | | | | | | | | | | | | | | | | | | Bit manip | oulation instructions | | | | | | | | | | | | | | | | | | | | | | | BSET | BSET (io8)bp | mem8(IOTOP+io8)&bpdataPSW | 0 | • | 0 | • | 5 | 5 | | 0011 | 1000 | 0bp. | <i08< td=""><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></i08<> | > | | | | | | | | | | | | 1→mem8(IOTOP+io8)bp | | | | | | | | | | | | | | | | | | | | | | | BSET (abs8)bp | mem8(abs8)&bpdataPSW | 0 | • | 0 | • | 4 | 4 | | | 1011 | 0bp. | ∠ahs | 8 5 | | | | | | | | T | | | DOET (db30)bp | | ľ | | ľ | _ | ľ | ' | | | 1011 | obp. | \ab3 | 0 | | | | | | | | | | | | 1→mem8(abs8)bp | _ | - | - | _ | _ | | | | 4400 | - | | | | | | | | | | _ | | | BSET (abs16)bp | mem8(abs16)&bpdataPSW | 0 | • | 0 | • | 7 | 6 | | 0011 | 1100 | 0bp. | <abs< td=""><td>16</td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 16 | | > | | | | | | | | | | 1→mem8(abs16)bp | | _ | | _ | | | | | | | | | | | | | | | | | | BCLR | BCLR (io8)bp | mem8(IOTOP+io8)&bpdataPSW | 0 | • | 0 | • | 5 | 5 | | 0011 | 1000 | 1bp. | <i08< td=""><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></i08<> | > | | | | | | | | | | | | 0→mem8(IOTOP+io8)bp | | | | | | | | | | | | | | | | | | | | | | | BCLR (abs8)bp | mem8(abs8)&bpdataPSW | 0 | • | 0 | • | 4 | 4 | | | 1011 | 1bp. | <abs< td=""><td>8&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 8> | | | | | | | | | | | ' ' ' | 0→mem8(abs8)bp | | ľ | | - | | | | | | • | | | | | | | | | | | | | PCLP (obc16)bp | | | • | 0 | • | 7 | 6 | | 0011 | 1100 | 1hn | -oho | 16 | | | | | | | | | | | BCLR (abs16)bp | mem8(abs16)&bpdataPSW | 0 | • | 0 | ╹ | l ′ | 0 | | 0011 | 1100 | 1bp. | <abs< td=""><td>16</td><td>••••</td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 16 | •••• | > | | | | | | | | | | 0→mem8(abs16)bp | | _ | | | | | | | | | | | | | | | | | | | | BTST | BTST imm8,Dm | Dm&imm8PSW | 0 | • | 0 | • | 5 | 3 | | 0010 | 0000 | 11Dm | <#8. | > | | | | | | | | | | | BTST (abs16)bp | mem8(abs16)&bpdataPSW | 0 | • | 0 | • | 7 | 5 | | 0011 | 1101 | 0bp. | <abs< td=""><td>16</td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td></abs<> | 16 | | > | | | | | | | | ranch ins | structions | • | | | | | | | | | | | | | | | | | | | | | | Всс | BEQ label | if(ZF=1), PC+3+d4(label)+H→PC | <br> | T | l | l | 3 | 2/3 | | | 1001 | 000H | -d4> | | | | | | | | | | | 500 | DEQ IADOI | | | | | | ľ | | | | 1001 | 00011 | \u 12 | | | | | | | | | | | | | if(ZF=0), PC+3→PC | ⊢ | $\vdash$ | $\vdash$ | $\vdash$ | - | 0.00 | | | | | | | | | | | | | | _ | | | BEQ label | if(ZF=1), PC+4+d7(label)+H→PC | | | | | 4 | 2/3 | | | 1000 | 1010 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d7.<> | Н | | | | | | | | | | | | if(ZF=0), PC+4→PC | | | | | | | | | | | | | | | | | | | | | | | BEQ label | if(ZF=1), PC+5+d11(label)+H→PC | | | | | 5 | 2/3 | | | 1001 | 1010 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d11<> | | Н | | | | | | | | | | | if(ZF=0), PC+5→PC | | | | | | | | | | | | | | | | | | | | | | | BNE label | if(ZF=0), PC+3+d4(label)+H→PC | | 1 | | | 3 | 2/3 | | | 1001 | 001H | <d4></d4> | | | | | | | | | _ | | | | if(ZF=1), PC+3→PC | | | | | | | | | | | | | | | | | | | | | | | DAIE L. L. | | $\vdash$ | + | | | _ | 0/0 | | | 4000 | | | | | | | | | | | _ | | | BNE label | if(ZF=0), PC+4+d7(label)+H→PC | | | | | 4 | 2/3 | | | 1000 | 1011 | <a <="" td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></a> | Н | | | | | | | | | | | | if(ZF=1), PC+4→PC | | _ | | | | | | | | | | | | | | | | | | | | | BNE label | if(ZF=0), PC+5+d11(label)+H→PC | | | | | 5 | 2/3 | | | 1001 | 1011 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d11<> | | Н | | | | | | | | | | | if(ZF=1), PC+5→PC | | | | | | | | | | | | | | | | | | | | | | | BGE label | if((VF^NF)=0),PC+4+d7(label)+H→PC | | | | | 4 | 2/3 | | | 1000 | 1000 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d7.<> | Н | | | | | | | | | | | | if((VF^NF)=1),PC+4→PC | | | | | | | | | | | | | | | | | | | | | | | BGE label | | | | | | _ | 2/3 | | | 4004 | 4000 | 14.4 | | | | | | | | | | | | BGE label | if((VF^NF)=0),PC+5+d11(label)+H→PC | | | | | 5 | 2/3 | | | 1001 | 1000 | <011 | | Н | | | | | | | | | | | if((VF^NF)=1),PC+5→PC | _ | | | | | | | | | | | | | | | | | | | | | | BCC label | if(CF=0),PC+4+d7(label)+H→PC | | | | | 4 | 2/3 | | | 1000 | 1100 | <d7.< td=""><td>H</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d7.<> | H | | | | | | | | | | | | if(CF=1), PC+4→PC | | | | | | | | | | | | | | | | | | | | | | | BCC label | if(CF=0), PC+5+d11(label)+H→PC | | | | | 5 | 2/3 | | | 1001 | 1100 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d11<> | | Н | | | | | | | | | | | if(CF=1), PC+5→PC | | | | | | | | | | | | | | | | | | | | | | | DCC lobel | if(CF=1),PC+4+d7(label)+H→PC | $\vdash$ | $\vdash$ | | | 4 | 2/3 | | | 4000 | 4404 | | | | | | | | | | - | | | BCS label | | | | | | 4 | 2/3 | | | 1000 | 1101 | <u <="" td=""><td>П</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></u> | П | | | | | | | | | | | | if(CF=0), PC+4→PC | _ | _ | | | | | | | | | | | | | | | | | | | | | BCS label | if(CF=1), PC+5+d11(label)+H→PC | | | | | 5 | 2/3 | | | 1001 | 1101 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d11<> | | Н | | | | | | | | | | | if(CF=0), PC+5→PC | | | L | L | | L | | | | | | | | | | | | | | | | | BLT label | if((VF^NF)=1),PC+4+d7(label)+H→PC | | | | | 4 | 2/3 | | | 1000 | 1110 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d7.<> | Н | | | | | | | | | | | | if((VF^NF)=0),PC+4→PC | | | | | | | | | | | | | | | | | | | | | | | DI TILLI | | $\vdash$ | + | | $\vdash$ | - | 0.5 | | | 40- | | | | | | | | | | | _ | | | BLT label | if((VF^NF)=1),PC+5+d11(label)+H→PC | | | | | 5 | 2/3 | | | 1001 | 1110 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d11<> | | Н | | | | | | | | | | | if((VF^NF)=0),PC+5→PC | | | | | | | | | | | | | | | | | | | | | | | BLE label | if((VF^NF) ZF=1),PC+4+d7(label)+H→PC | | | | | 4 | 2/3 | | | 1000 | 1111 | <d7.< td=""><td>Н</td><td>_</td><td></td><td>_</td><td></td><td></td><td>_</td><td>_</td><td></td></d7.<> | Н | _ | | _ | | | _ | _ | | | | | if((VF^NF) ZF=0),PC+4→PC | | | | | | | | | | | | | | | | | | | | | | | BLE label | if((VF^NF) ZF=1),PC+5+d11(label)+H→PC | | | | | 5 | 2/3 | | | 1001 | 1111 | <d11< td=""><td></td><td>н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>_</td></d11<> | | н | | | | | | | _ | | | | if((VF^NF) ZF=0),PC+5→PC | ] _ | - | - | - | | _, | | | 1001 | | -uii | | | | | | | | | | | | | III(VF′1NF)I∠F=U).PU+5→PU | 1 | | | | | _ | | | | | | | | | | | | | | | | | | | | | 1 | | l – | | | | | | | | | | | | | | | | | | BGT label | if((VF^NF) ZF=0),PC+5+d7(label)+H→PC | | | | | 5 | 3/4 | | 0010 | 0010 | 0001 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></d7.<> | Н | | | | | | | | | <sup>\*1</sup> d4 sign-extension \*2 d7 sign-extension \*3 d11 sign-extension ### MN101C SERIES INSTRUCTION SET | Group | Mnemonic | Operation | VF | | ag<br>CF | ZF | Code<br>Size | Cycle | Re-<br>peat | Exten-<br>sion | 1 | 2 | 3 | 4 | 5 | /achir | ne Cod<br>7 | de<br>8 | ę | 9 | 10 1 | N<br>11 | Vote | |-------|------------------------------|-------------------------------------------------------------------------|----------|----------|----------|----|--------------|-------|-------------|----------------|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------|---------|----------------------------------------------------------------|-----|------|---------|------| | | | | | | | | | | | | | | | | | | | | | | | | | | Bcc | BGT label | if((VF^NF) ZF=0),PC+6+d11(label)+H→PC | | | | | 6 | 3/4 | | 0010 | 0011 | 0001 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | | | if((VF^NF) ZF=1),PC+6→PC | <u> </u> | <u> </u> | Ш | | | | | | | | | | | | | | | | | _ | _ | | | BHI label | if(CFIZF=0),PC+5+d7(label)+H→PC | | | | | 5 | 3/4 | | 0010 | 0010 | 0010 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | Н | | | | | | | | * | *2 | | | | if(CFIZF=1), PC+5→PC | <u> </u> | ╙ | Ш | | | | | | | | | | | | | | | | | _ | _ | | | BHI label | if(CFIZF=0),PC+6+d11(label)+H→PC | | | | | 6 | 3/4 | | 0010 | 0011 | 0010 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | | | if(CFIZF=1), PC+6→PC | <u> </u> | L | Ш | | | | | | | | | | | | | | | | | _ | _ | | ı | BLS label | if(CFIZF=1),PC+5+d7(label)+H→PC | | | | | 5 | 3/4 | | 0010 | 0010 | 0011 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td> *</td><td>*2</td></d7.<> | Н | | | | | | | | * | *2 | | 1 | | if(CFIZF=0), PC+5→PC | <u> </u> | L | Ш | | | | | | | | | | | | | | | | | | | | | BLS label | if(CFIZF=1),PC+6+d11(label)+H→PC | | | | | 6 | 3/4 | | 0010 | 0011 | 0011 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | | | if(CFIZF=0), PC+6→PC | L | L | Ш | | | | | | | | | | | | | | | | | | | | | BNC label | if(NF=0),PC+5+d7(label)+H→PC | | | | | 5 | 3/4 | | 0010 | 0010 | 0100 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td> *</td><td>*2</td></d7.<> | Н | | | | | | | | * | *2 | | ı | | if(NF=1),PC+5→PC | | | | | | | | | | | | | | | | | | | | | | | | BNC label | if(NF=0),PC+6+d11(label)+H→PC | | | | | 6 | 3/4 | | 0010 | 0011 | 0100 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | | | if(NF=1),PC+6→PC | L | L | | | | | | | | | | | | | | | | | | | _ | | | BNS label | if(NF=1),PC+5+d7(label)+H→PC | | | | | 5 | 3/4 | | 0010 | 0010 | 0101 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | Н | | | | | | | | * | *2 | | | | if(NF=0),PC+5→PC | L | L | Ш | | | | | | | | | | | | | | | | | | | | | BNS label | if(NF=1),PC+6+d11(label)+H→PC | | | | | 6 | 3/4 | | 0010 | 0011 | 0101 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td> *</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | | | if(NF=0),PC+6→PC | | | | | | | | | | | | | | | | | | | | | | | | BVC label | if(VF=0),PC+5+d7(label)+H→PC | | | | | 5 | 3/4 | | 0010 | 0010 | 0110 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | Н | | | | | | | | * | *2 | | | | if(VF=1),PC+5→PC | | | | | | | | | | | | | | | | | | | | | | | | BVC label | if(VF=0),PC+6+d11(label)+H→PC | | | | | 6 | 3/4 | | 0010 | 0011 | 0110 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | | | if(VF=1),PC+6→PC | | | | | | | | | | | | | | | | | | | | | | | | BVS label | if(VF=1),PC+5+d7(label)+H→PC | | | | | 5 | 3/4 | | 0010 | 0010 | 0111 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | Н | | | | | | | | * | *2 | | ı | | if(VF=0),PC+5→PC | | | | | | | | | | | | | | | | | | | | | | | ı | BVS label | if(VF=1),PC+6+d11(label)+H→PC | | | | | 6 | 3/4 | | 0010 | 0011 | 0111 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | | | if(VF=0),PC+6→PC | | | | | | | | | | | | | | | | | | | | | | | | BRA label | PC+3+d4(label)+H→PC | | | | | 3 | 3 | | | 1110 | 111H | <d4></d4> | | | | | | | | | * | *1 | | | BRA label | PC+4+d7(label)+H→PC | | | | | 4 | 3 | | | 1000 | 1001 | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | Н | | | | | | | | * | *2 | | | BRA label | PC+5+d11(label)+H→PC | | | | | 5 | 3 | | | 1001 | 1001 | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | | | * | *3 | | CBEQ | CBEQ imm8,Dm,label | if(Dm=imm8),PC+6+d7(label)+H→PC | • | • | • | • | 6 | 3/4 | | | 1100 | 10Dm | <#8. | > | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | Н | | | | | | * | *2 | | | | if(Dm≠imm8),PC+6→PC | | | | | | | | | | | | | | | | | | | | | | | | CBEQ imm8,Dm,label | if(Dm=imm8),PC+8+d11(label)+H→PC | • | • | • | • | 8 | 4/5 | | 0010 | 1100 | 10Dm | <#8. | > | <d11< td=""><td></td><td>Н</td><td>-</td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | - | | | | * | *3 | | | | if(Dm≠imm8),PC+8→PC | | _ | | | | | | | | | | | | | | | | | | | | | | CBEQ imm8,(abs8),label | if(mem8(abs8)=imm8),PC+9+d7(label)+H→PC | • | • | • | • | 9 | 6/7 | | 0010 | 1101 | 1100 | <abs< td=""><td>8&gt;</td><td>&lt;#8.</td><td>&gt;</td><td><d7.< td=""><td>Н</td><td> </td><td></td><td></td><td>*</td><td>*2</td></d7.<></td></abs<> | 8> | <#8. | > | <d7.< td=""><td>Н</td><td> </td><td></td><td></td><td>*</td><td>*2</td></d7.<> | Н | | | | * | *2 | | | | if(mem8(abs8)≠imm8),PC+9→PC | ľ | | | | | | | | | | | | | | | | | | | | | | | CBEQ imm8,(abs8),label | if(mem8(abs8)=imm8),PC+10+d11(label)+H→PC | • | • | • | • | 10 | 6/7 | | 0010 | 1101 | 1101 | <abs< td=""><td>8&gt;</td><td>&lt;#8.</td><td>&gt;</td><td><d11< td=""><td></td><td></td><td>Н</td><td></td><td>*</td><td>*3</td></d11<></td></abs<> | 8> | <#8. | > | <d11< td=""><td></td><td></td><td>Н</td><td></td><td>*</td><td>*3</td></d11<> | | | Н | | * | *3 | | | | if(mem8(abs8)≠imm8),PC+10→PC | | ľ | | | | | | | | | | | | | | | | | | | | | | CBEQ imm8,(abs16),label | if(mem8(abs16)=imm8),PC+11+d7(label)+H→PC | | • | • | • | 11 | 7/8 | | 0011 | 1101 | 1100 | <abs< td=""><td>16</td><td></td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td>· &lt;0</td><td>17.</td><td>H</td><td>*</td><td>*2</td></abs<> | 16 | | > | <#8. | > | · <0 | 17. | H | * | *2 | | | | if(mem8(abs16)≠imm8),PC+11→PC | _ | | | | | | | | | | | | | | | | | | | | | | | CBEQ imm8,(abs16),label | if(mem8(abs16)=imm8),PC+12+d11(label)+H→PC | • | • | • | • | 12 | 7/8 | | 0011 | 1101 | 1101 | <abs< td=""><td>16</td><td></td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td>- <d< td=""><td>111</td><td></td><td>.H *</td><td>*3</td></d<></td></abs<> | 16 | | > | <#8. | > | - <d< td=""><td>111</td><td></td><td>.H *</td><td>*3</td></d<> | 111 | | .H * | *3 | | | ,(,), | if(mem8(abs16)≠imm8),PC+12→PC | | ľ | | | | | | | | | | | | | | | | | | | | | CBNE | CBNE imm8,Dm,label | if(Dm≠imm8),PC+6+d7(label)+H→PC | | • | • | • | 6 | 3/4 | | | 1101 | 10Dm | <#8 | > | <d7.< td=""><td>H&gt;</td><td></td><td></td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | H> | | | | | | * | *2 | | | | if(Dm=imm8),PC+6→PC | _ | | | • | | | | | | | 4 | | ٠ | | | | | | | | | | | CBNE imm8,Dm,label | if(Dm≠imm8),PC+8+d11(label)+H→PC | • | • | • | • | 8 | 4/5 | | 0010 | 1101 | 10Dm | <#8. | | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>*</td><td>*3</td></d11<> | | Н | | | | | * | *3 | | | OBITE IIIIIO,BIII,IABOI | if(Dm=imm8),PC+8→PC | _ | _ | | • | 1 | | | 0010 | | IODIII | \iii0. | | <b>~</b> 0111 | | | | | | | | Ŭ | | | CBNE imm8,(abs8),label | if(mem8(abs8)≠imm8),PC+9+d7(label)+H→PC | | • | • | • | 9 | 6/7 | | 0010 | 1101 | 1110 | <abs< td=""><td>8 &gt;</td><td>~#R</td><td>_</td><td><d7.< td=""><td>H</td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<></td></abs<> | 8 > | ~#R | _ | <d7.< td=""><td>H</td><td></td><td></td><td></td><td>*</td><td>*2</td></d7.<> | H | | | | * | *2 | | | | if(mem8(abs8)=imm8),PC+9→PC | | _ | | • | 1 | | | 0010 | | 1110 | ~abo | 0 | \//O. | | -ar. | | | | | | - | | | CBNE imm8,(abs8),label | if(mem8(abs8)≠imm8),PC+10+d11(label)+H→PC | | • | • | • | 10 | 6/7 | | 0010 | 1101 | 1111 | <abs< td=""><td>Ω \</td><td>_#8</td><td>_</td><td>-d11</td><td>_</td><td></td><td>н</td><td></td><td>*</td><td>*3</td></abs<> | Ω \ | _#8 | _ | -d11 | _ | | н | | * | *3 | | | CDIVE IIIIIIO,(abso),iabei | if(mem8(abs8)=imm8),PC+10→PC | _ | • | | | | 0,1 | | 0010 | 1101 | | \ab3 | 0 | \no. | | \u11 | | ••• | | | | J | | | CBNE imm8,(abs16),label | | | • | • | • | 11 | 7/8 | | 0011 | 1101 | 1110 | <abs< td=""><td>16</td><td></td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td></td><td>17.</td><td>н</td><td>*</td><td>*2</td></abs<> | 16 | | > | <#8. | > | | 17. | н | * | *2 | | | ODINE IIIIIIO,(aus ro),iabei | if(mem8(abs16)=imm8),PC+11→PC | 1- | _ | | | l | ,,, | | 0011 | 1101 | 1110 | <aus< td=""><td>10</td><td>••••</td><td>&gt;</td><td>&lt;#O.</td><td>&gt;</td><td>&lt;0</td><td></td><td>! 1</td><td></td><td>2</td></aus<> | 10 | •••• | > | <#O. | > | <0 | | ! 1 | | 2 | | | CRNE imm8 (abo16) label | if(mem8(abs16)≠mm8),PC+12+d11(label)+H→PC | +- | • | • | • | 12 | 7/8 | | 0011 | 1101 | 1111 | -aha | 16 | | | <#8. | | ابر | 111 | | .H * | *3 | | | ODINE IIIIIIO,(aus ro),iabei | if(mem8(abs16)=imm8),PC+12→PC | 1 | | | • | 12 | 1,3 | | JUII | 1101 | 1111 | <abs< td=""><td>10</td><td>••••</td><td>&gt;</td><td>&lt;#8.</td><td>&gt;</td><td>· <d< td=""><td>111</td><td></td><td>7</td><td>J</td></d<></td></abs<> | 10 | •••• | > | <#8. | > | · <d< td=""><td>111</td><td></td><td>7</td><td>J</td></d<> | 111 | | 7 | J | | TBZ | TR7 (ahe8)ho lahal | if(mem8(abs16)=Imm8),PC+12→PC<br>if(mem8(abs8)bp=0),PC+7+d7(label)+H→PC | - | | | • | 7 | 6/7 | | 0011 | 0000 | Ohn | -aha | 0 - | 7617 | ы | | | | | | + | *2 | | I DZ | TBZ (abs8)bp,label | | 0 | • | 0 | | l ′ | 0// | | 0011 | UUUU | upp. | <abs< td=""><td>ŏ&gt;</td><td><a <="" td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td> 1</td><td>2</td></a></td></abs<> | ŏ> | <a <="" td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td> 1</td><td>2</td></a> | Н | | | | | | 1 | 2 | | | | if(mem8(abs8)bp=1),PC+7→PC | 1 | <u></u> | | | | | | | | | | | | | | | | | | _ | _ | | | TBZ (abs8)bp,label | if(mem8(abs8)bp=0),PC+8+d11(label)+H→PC | _ | • | 0 | • | 8 | 6/7 | | 0044 | 0000 | 1hn | <abs< td=""><td>0 -</td><td>1111</td><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>1 -</td><td>*3</td></abs<> | 0 - | 1111 | | Н | | | | | 1 - | *3 | <sup>\*1</sup> d4 sign-extension\*2 d7 sign-extension\*3 d11 sign-extension | Group | | I SET | | ū | 20 | | o | h . | | Evton | | | | | | 4 | | _ | | | | W . | |-------|-----------------------------------------|-----------------------------------------------------------|----|---|----------|----------|--------------|-------|-------------|----------------|------|------|----------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------------------------------------------------------|-------------|---------------------------------------------------------------------|--------|---|----|----|------| | J.54p | Mnemonic | Operation | VF | | ag<br>CF | ZF | Code<br>Size | Cycle | Re-<br>peat | Exten-<br>sion | 1 | 2 | 3 | 4 | 5 | √achir<br>6 | ne Code<br>7 | e<br>8 | 9 | 10 | 11 | Note | | | | | 1 | | | <u> </u> | | | r | Joiott | | | | | | | | | | | | | | TBZ | TBZ (io8)bp,label | if(mem8(IOTOP+io8)bp=0),PC+7+d7(label)+H→PC | 0 | • | 0 | • | 7 | 6/7 | | 0011 | 0100 | Obp. | <i08< td=""><td>&gt;</td><td><d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td>*1</td></d7.<></td></i08<> | > | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td>*1</td></d7.<> | Н | | | | | | *1 | | | (***,****** | if(mem8(IOTOP+io8)bp=1),PC+7→PC | | | - | | | | | | | | | | | | | | | | | | | | TBZ (io8)bp,label | if(mem8(IOTOP+io8)bp=0),PC+8+d11(label)+H→PC | 0 | • | 0 | • | 8 | 6/7 | | 0011 | 0100 | 1bp. | <i08< td=""><td>&gt;</td><td><d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>*2</td></d11<></td></i08<> | > | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>*2</td></d11<> | | Н | | | | | *2 | | | (************************************** | if(mem8(IOTOP+io8)bp=1),PC+8→PC | | | | | | | | | | | | | | | | | | | | | | | TBZ (abs16)bp,label | if(mem8(abs16)bp=0),PC+9+d7(label)+H→PC | | • | 0 | • | 9 | 7/8 | | 0011 | 1110 | 0bp. | <abs< td=""><td>16</td><td></td><td>&gt;</td><td><d7.< td=""><td>Н</td><td></td><td></td><td></td><td>*1</td></d7.<></td></abs<> | 16 | | > | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td>*1</td></d7.<> | Н | | | | *1 | | | | if(mem8(abs16)bp=1),PC+9→PC | | | | | | | | | | | | | | | | | | | | | | | TBZ (abs16)bp,label | if(mem8(abs16)bp=0),PC+10+d11(label)+H→PC | 0 | • | 0 | • | 10 | 7/8 | | 0011 | 1110 | 1bp. | <abs< td=""><td>16</td><td></td><td>&gt;</td><td><d11< td=""><td></td><td>Н</td><td></td><td></td><td>*2</td></d11<></td></abs<> | 16 | | > | <d11< td=""><td></td><td>Н</td><td></td><td></td><td>*2</td></d11<> | | Н | | | *2 | | | | if(mem8(abs16)bp=1),PC+10→PC | | | | | | | | | | | | | | | | | | | | | | TBNZ | TBNZ (abs8)bp,label | if(mem8(abs8)bp=1),PC+7+d7(label)+H→PC | 0 | • | 0 | • | 7 | 6/7 | | 0011 | 0001 | 0bp. | <abs< td=""><td>8&gt;</td><td><d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td>*1</td></d7.<></td></abs<> | 8> | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td>*1</td></d7.<> | Н | | | | | | *1 | | | | if(mem8(abs8)bp=0),PC+7→PC | | | | | | | | | | | | | | | | | | | | | | | TBNZ (abs8)bp,label | if(mem8(abs8)bp=1),PC+8+d11(label)+H→PC | 0 | • | 0 | • | 8 | 6/7 | | 0011 | 0001 | 1bp. | <abs< td=""><td>8&gt;</td><td><d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>*2</td></d11<></td></abs<> | 8> | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>*2</td></d11<> | | Н | | | | | *2 | | | | if(mem8(abs8)bp=0),PC+8→PC | | | | | | | | | | | | | | | | | | | | | | | TBNZ (io8)bp,label | if(mem8(io)bp=1),PC+7+d7(label)+H→PC | 0 | • | 0 | • | 7 | 6/7 | | 0011 | 0101 | 0bp. | <i08< td=""><td>&gt;</td><td><d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td>*1</td></d7.<></td></i08<> | > | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td></td><td></td><td>*1</td></d7.<> | Н | | | | | | *1 | | | | if(mem8(io)bp=0),PC+7→PC | | | | | | | | | | | | | | | | | | | | | | | TBNZ (io8)bp,label | if(mem8(io)bp=1),PC+8+d11(label)+H→PC | 0 | • | 0 | • | 8 | 6/7 | | 0011 | 0101 | 1bp. | <i08< td=""><td>&gt;</td><td><d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>*2</td></d11<></td></i08<> | > | <d11< td=""><td></td><td>Н</td><td></td><td></td><td></td><td></td><td>*2</td></d11<> | | Н | | | | | *2 | | | | if(mem8(io)bp=0),PC+8→PC | | | | | | | | | | | | | | | | | | | | | | | TBNZ (abs16)bp,label | if(mem8(abs16)bp=1),PC+9+d7(label)+H→PC | 0 | • | 0 | • | 9 | 7/8 | | 0011 | 1111 | 0bp. | <abs< td=""><td>16</td><td></td><td>&gt;</td><td><d7.< td=""><td>Н</td><td></td><td></td><td></td><td>*1</td></d7.<></td></abs<> | 16 | | > | <d7.< td=""><td>Н</td><td></td><td></td><td></td><td>*1</td></d7.<> | Н | | | | *1 | | | | if(mem8(abs16)bp=0),PC+9→PC | | | | | | | | | | | | | | | | | | | | | | | TBNZ (abs16)bp,label | if(mem8(abs16)bp=1),PC+10+d11(label)+H→PC | 0 | • | 0 | • | 10 | 7/8 | | 0011 | 1111 | 1bp. | <abs< td=""><td>16</td><td></td><td>&gt;</td><td><d11< td=""><td></td><td>Н</td><td></td><td></td><td>*2</td></d11<></td></abs<> | 16 | | > | <d11< td=""><td></td><td>Н</td><td></td><td></td><td>*2</td></d11<> | | Н | | | *2 | | | | if(mem8(abs16)bp=0),PC+10→PC | | | | | | | | | | | | | | | | | | | | | | JMP | JMP (An) | 0→PC.17-16,An→PC.15-0,0→PC.H | | | | | 3 | 4 | | 0010 | 0001 | 00A0 | | | | | | | | | | | | | JMP label | abs18(label)+H→PC | | | | | 7 | 5 | | 0011 | 1001 | 0aaH | <abs< td=""><td>18.b</td><td>p15~</td><td>0&gt;</td><td></td><td></td><td></td><td></td><td></td><td>*5</td></abs<> | 18.b | p15~ | 0> | | | | | | *5 | | JSR | JSR (An) | SP-3→SP,(PC+3).bp7-0→mem8(SP) | | | | | 3 | 7 | | 0010 | 0001 | 00A1 | | | | | | | | | | | | | | (PC+3).bp15-8→mem8(SP+1) | | | | | | | | | | | | | | | | | | | | | | | | (PC+3).H→mem8(SP+2).bp7, | | | | | | | | | | | | | | | | | | | | | | | | 0→mem8(SP+2).bp6-2,<br>(PC+3).bp17-16→mem8(SP+2).bp1-0 | | | | | | | | | | | | | | | | | | | | | | | | 0→PC.bp17-16 | | | | | | | | | | | | | | | | | | | | | | | | An→PC.bp15-0,0→PC.H | | | | | | | | | | | | | | | | | | | | | | | JSR label | SP-3→SP,(PC+5).bp7-0→mem8(SP) | | | | | 5 | 6 | | | 0001 | 000H | <d12< td=""><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td>*3</td></d12<> | | > | | | | | | | *3 | | | | (PC+5).bp15-8→mem8(SP+1) | | | | | | | | | | | | | | | | | | | | | | | | (PC+5).H→mem8(SP+2).bp7, | | | | | | | | | | | | | | | | | | | | | | | | 0→mem8(SP+2).bp6-2, | | | | | | | | | | | | | | | | | | | | | | | | (PC+5).bp17-16→mem8(SP+2).bp1-0 | | | | | | | | | | | | | | | | | | | | | | | | PC+5+d12(label)+H→PC | | | | | | | | | | | | | | | | | | | | | | | JSR label | SP-3→SP,(PC+6).bp7-0→mem8(SP) | | | | | 6 | 7 | | | 0001 | 001H | <d16< td=""><td></td><td></td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td>*4</td></d16<> | | | > | | | | | | *4 | | | | (PC+6).bp15-8→mem8(SP+1) | | | | | | | | | | | | | | | | | | | | | | | | (PC+6).H→mem8(SP+2).bp7, | | | | | | | | | | | | | | | | | | | | | | | | 0→mem8(SP+2).bp6-2, | | | | | | | | | | | | | | | | | | | | | | | | (PC+6).bp17-16→mem8(SP+2).bp1-0 | | | | | | | | | | | | | | | | | | | | | | | | PC+6+d16(label)+H→PC | | L | | | | | | | | | | | | | | | | | | | | | JSR label | SP-3→SP,(PC+7).bp7-0→mem8(SP) | | | | | 7 | 8 | | 0011 | 1001 | 1aaH | <abs< td=""><td>18.b</td><td>p15~</td><td>0&gt;</td><td></td><td></td><td></td><td></td><td></td><td>*5</td></abs<> | 18.b | p15~ | 0> | | | | | | *5 | | | | (PC+7).bp15-8→mem8(SP+1) | | | | | | | | | | | | | | | | | | | | | | | | (PC+7).H→mem8(SP+2).bp7, | | | | | | | | | | | | | | | | | | | | | | | | 0→mem8(SP+2).bp6-2, | | | | | | | | | | | | | | | | | | | | | | | | (PC+7).bp17-16→mem8(SP+2).bp1-0 | | | | | | | | | | | | | | | | | | | | | | | | abs18(label)+H→PC | L | | | | | | | | | | | | | | | | | | | | | | JSRV (tbl4) | SP-3 $\rightarrow$ SP,(PC+3).bp7-0 $\rightarrow$ mem8(SP) | | | | | 3 | 9 | | | 1111 | 1110 | <t4></t4> | | | | | | | | | | | | | (PC+3).bp15-8→mem8(SP+1) | | | | | | | | | | | | | | | | | | | | | | | | (PC+3).H→mem8(SP+2).bp7 | | | | | | | | | | | | | | | | | | | | | | | | 0→mem8(SP+2).bp6-2, | | | | | | | | | | | | | | | | | | | | | | | | (PC+3).bp17-16→mem8(SP+2).bp1-0 | | | | | | | | | | | | | | | | | | | | | | | | mem8(x'004080+tbl4<<2)->PC.bp7-0 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | 1 | | 1 | | | | 1 | | | | | | | | | | | | | | | | mem8(x'004080+thl4~2+1)_PC hn15-8 | | | | | l | | | | | | | | | | | | | | | | | | | mem8(x'004080+tbl4<<2+1) -> PC.bp15-8 | | | | | | | | | | | | | | | | | | | | | | | | mem8(x'004080+tbl4<<2+2).bp7->PC.H | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <sup>\*1</sup> d7 sign-extension \*2 d11 sign-extension \*3 d12 sign-extension \*4 d16 sign-extension \*5 aa=abs18.17 - 16 | Group | Mnemonic | Operation | | | ag | | Code | Cycle | e Re- | Exten- | | | | | 1 | Machin | e Code | | | | | Note | |------------|------------|-------------------------------|----|----|----|----|------|-------|-------|--------|------|------|---|---|---|--------|--------|---|---|----|----|------| | <u> </u> | | · · | VF | NF | CF | ZF | Size | Ĺ | peat | sion | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | | | | | | _ | _ | _ | _ | _ | _ | | | | | | | | | | | | | | | | RTS | RTS | mem8(SP)→(PC).bp7-0 | | | | | 2 | 7 | | ( | 0000 | 0001 | | | | | | | | | | | | | | mem8(SP+1)→(PC).bp15-8 | | | | | | | | | | | | | | | | | | | | | | | | mem8(SP+2).bp7→(PC).H | | | | | | | | | | | | | | | | | | | | | | | | mem8(SP+2).bp1-0→(PC).bp17-16 | | | | | | | | | | | | | | | | | | | | | | | | SP+3→SP | | | | | | | | | | | | | | | | | | | | | | RTI | RTI | mem8(SP)→PSW | • | • | • | • | 2 | 11 | | ( | 0000 | 0011 | | | | | | | | | | | | | | mem8(SP+1)→(PC).bp7-0 | | | | | | | | | | | | | | | | | | | | | | | | mem8(SP+2)→(PC).bp15-8 | | | | | | | | | | | | | | | | | | | | | | | | mem8(SP+3).bp7→(PC).H | | | | | | | | | | | | | | | | | | | | | | | | mem8(SP+3).bp1-0→(PC).bp17-16 | | | | | | | | | | | | | | | | | | | | | | | | mem8(SP+4)→HA-I | | | | | | | | | | | | | | | | | | | | | | | | mem8(SP+5)→HA-h | | | | | | | | | | | | | | | | | | | | | | | | SP+6→SP | | | | | | | | | | | | | | | | | | | | | | Contorl in | structions | ' | | | | | | | | | | | | | | | | | | | | | | REP | REP imm3 | imm3-1→RPC | | | | | 3 | 2 | | 0010 | 0001 | 1rep | | | | | | | | | | *1 | \*1 no repeat whn imm3=0, (rep: imm3-1) Other than the instruction of MN101C Series,the assembler of this Series has the following instructions as macro instructions. The assembler will interpret the macro instructions below as the assembler instructions. | macro in | structions | replaced | instructions | remarks | |----------|------------|----------|--------------|---------| | INC | Dn | ADD | 1,Dn | | | DEC | Dn | ADD | -1,Dn | | | INC | An | ADDW | 1,An | | | DEC | An | ADDW | -1,An | | | INC2 | An | ADDW | 2,An | | | DEC2 | An | ADDW | -2,An | | | CLR | Dn | SUB | Dn,Dm | n=m | | ASL | Dn | ADD | Dn,Dm | n=m | | LSL | Dn | ADD | Dn,Dm | n=m | | ROL | Dn | ADDC | Dn,Dm | n=m | | NEG | Dn | NOT | Dn | | | | | ADD | 1,Dn | | | NOPL | | MOVW | DWn,DWm | n=m | | MOV | (SP),Dn | MOV | (0,SP),Dn | | | MOV | Dn,(SP) | MOV | Dn,(0,SP) | | | MOVW | (SP),DWn | MOVW | (0,SP),DWn | | | MOVW | DWn,(SP) | MOVW | DWn,(0,SP) | | | MOVW | (SP),An | MOVW | (0,SP),An | | | MOVW | An,(SP) | MOVW | An,(0,SP) | | Ver3.2(2002.01.31) # 17.6 Instruction Map | MN10 | 1C S | ERIE | SIN | STRU | ICTIC | N MA | ŀΡ | |------------|-----------|------|-----|------|-------|------|----| | 1st nibble | 2nd nibbl | е | | | | | | | | | | | | | | | | Ist nibbl | e\2nd nibb | | | | | _ | | _ | | | | | _ | | _ | _ | |-----------|------------|----------|--------------|-----------|-------------|-------------|----------|------------|---------|----------|---------|---------|------------|------------|-------------|---------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | | 0 | NOP | RTS | MOV #8,(io8) | RTI | CMP #8,(abs | 8)/(abs12) | POP Ar | n | ADD #8 | ,Dm | | | MOVW | #8,DWm | MOVW | #8,Am | | 1 | JSR d1 | 2(label) | JSR d1 | 6(label) | MOV #8,(ab | s8)/(abs12) | PUSH / | An | OR #8,[ | Om | | | AND #8 | 3,Dm | | | | 2 | When th | ne exens | sion code | e is b'oo | 10' | | | | | | | | | | | | | 3 | When th | ne exten | sion cod | e is b'00 | )11' | | | | | | | | | | | | | 4 | MOV (a | bs12),D | m | | MOV (al | bs8),Dm | า | | MOV (A | n),Dm | | | | | | | | 5 | MOV D | n,(abs12 | 2) | | MOV Dr | n,(abs8) | | | MOV Di | n,(Am) | | | | | | | | 6 | MOV (id | 08),Dm | | | MOV (d | 4,SP),D | m | | MOV (d | 8,An),Dr | m | | | | | | | 7 | MOV D | n,(io8) | | | MOV Dr | n,(d4,SF | P) | | MOV Di | n,(d8,Am | n) | | | | | | | 8 | ADD #4 | ,Dm | | | SUB Dn | ,Dn | | | BGE d7 | BRA d7 | BEQ d7 | BNE d7 | BCC d7 | BCS d7 | BLT d7 | BLE d7 | | 9 | BEQ d4 | ļ | BNE d4 | | MOVW D | Wn,(HA) | MOVW | An,(HA) | BGE d11 | BRA d11 | BEQ d11 | BNE d11 | BCC d11 | BCS d11 | BLT d11 | BLE d11 | | Α | MOV D | n,Dm / N | /OV #8,I | Om | | | | | | | | | | | | | | В | BSET (a | abs8)bp | | | | | | | BCLR (a | abs8)bp | | | | | | | | С | CMP #8 | 3,Dm | | | MOVW (a | abs8),Am | MOVW (a | bs8),DWm | CBEQ # | 8,Dm,d | 7 | | CMPW # | ‡16,DWm | MOVW # | 16,DWm | | D | MOV D | n,(HA) | | | MOVW A | n,(abs8) | MOVW D | Wn,(abs8) | CBNE # | 8,Dm,d | 7 | | CMPW | #16,Am | MOVW | #16,Am | | Е | MOVW | (An),DV | Vm | | MOVW (d | 4,SP),Am | MOVW (d4 | 4,SP),DWm | POP Dr | 1 | | | ADDW | #4,Am | BRA d4 | | | F | MOVW | DWn,(A | .m) | | MOVW Ar | n,(d4,SP) | MOVW DV | Vn,(d4,SP) | PUSH [ | n | | | ADDW #8,SP | ADDW #4,SP | JSRV (tbl4) | | | Extension code: b'0010' | | |-------------------------|--| | 2nd nible\3rd nibble | | | nd nible | 3rd nibble<br>0 | ;<br>1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | |----------|-----------------|-----------|------------|-------------|---------|-----------|----------|------------|--------|----------|------|-------|-------------|-------------|--------------|------------| | 0 | MOVW | An,Am | | | CMPW | An,Am | | | MOVW | SP,Am | MOVW | An,SP | BTST# | 8,Dm | | | | 1 | JMP (A0) | JSR (A0) | JMP (A1) | JSR (A1) | MOV P | SW,Dm | | | REP #3 | | | | | | | | | 2 | | BGT d7 | BHI d7 | BLS d7 | BNC d7 | BNS d7 | BVC d7 | BVS d7 | NOT Dn | l | | | ROR D | n | | | | 3 | | BGT d11 | BHI d11 | BLS d11 | BNC d11 | BNS d11 | BVC d11 | BVS d11 | ASR Dn | | | | LSR Dn | 1 | | | | 4 | SUBW I | DWn,DV | Vm | | SUBW # | 16,DWm | SUBW | #16,Am | SUBW [ | DWn,An | n | | MOVW | DWn,Ar | n | | | 5 | ADDW I | DWn,DV | Vm | | ADDW # | f16,DWm | ADDW | #16,Am | ADDW I | DWn,An | n | | CMPW | DWn,An | n | | | 6 | MOV (d | 16,SP),[ | Om | | MOV (d | 18,SP),D | m | | MOV (d | 16,An),[ | Om | | | | | | | 7 | MOV Dr | n,(d16,S | P) | | MOV D | n,(d8,SF | ') | | MOV Dr | n,(d16,A | ım) | | | | | | | 8 | MOVW E | )Wn,DWi | m (NOPL | @n=m) | CMPW | DWn,D\ | ٧m | | ADDUW | / Dn,Am | 1 | | | | | | | 9 | EXT Dn | ,DWm | AND #8,PSW | OR #8,PSW | MOV D | n,PSW | | | ADDSW | / Dn,Am | ı | | | | | | | Α | SUB Dn | ,Dm / S | UB #8,D | m | | | | | | | | | | | | | | В | SUBC E | n,Dm | | | | | | | | | | | | | | | | С | MOV (a | bs16),D | m | | MOVW (a | abs16),Am | MOVW (al | os16),DWm | CBEQ# | 8,Dm,d | 12 | | MOVW | An,DWn | n | | | D | MOV Dr | n,(abs16 | 5) | | MOVW A | n,(abs16) | MOVW D | Wn,(abs16) | CBNE # | 8,Dm,d | 12 | | CBEQ #8,(a | bs8),d7/d11 | CBNE #8,(abs | :8),d7/d11 | | Ε | MOVW (d1 | 16,SP),Am | MOVW (d1 | 6,SP),DWm | MOVW (d | d8,SP),Am | MOVW (da | B,SP),DWm | MOVW | (An),Am | 1 | | ADDW | #8,Am | DIVU | | | F | MOVW An | ,(d16,SP) | MOVW DW | /n,(d16,SP) | MOVW A | n,(d8,SP) | MOVW D | Wn,(d8,SP) | MOVW | An,(Am | ) | | ADDW #16,SP | | MULU | | Extension code: b'0011' 2nd nibble\ 3rd nibble | i nibbi | e\ 3rd nibbl | e<br>1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | |---------|--------------|------------|--------|----|---|---|---|---|----------------|----------------|------|---|--------------|------------|--------------|-----------| | 0 | TBZ (abs | 8)bp,d7 | | | | | | | TBZ (al | os8)bp,d1 | 1 | | | | | | | 1 | TBNZ (ab | s8)bp,d | 7 | | | | | | TBNZ ( | abs8)bp,d | 111 | | | | | | | 2 | CMP Dn, | Dm | | | | | | | | | | | | | | | | 3 | ADD Dn,l | Om | | | | | | | | | | | | | | | | 4 | TBZ (io8) | bp,d7 | | | | | | | TBZ (io | 8)bp,d11 | | | | | | | | 5 | TBNZ (io | B)bp,d7 | | | | | | | TBNZ ( | io8)bp,d1 | 1 | | | | | | | 6 | OR Dn,D | m | | | | | | | • | | | | | | | | | 7 | AND Dn,I | Om | | | | | | | | | | | | | | | | 8 | BSET (io | B)bp | | | | | | | BCLR ( | io8)bp | | | | | | | | 9 | JMP abs1 | l 8(label) | | | | | | | JSR ab | s18(label | ) | | | | | | | Α | XOR Dn,l | Dm / XO | R #8,D | )m | | | | | | | | | | | | | | В | ADDC Dr | n,Dm | | | | | | | | | | | | | | | | С | BSET (ab | s16)bp | | | | | | | BCLR ( | abs16)bp | ) | | | | | | | D | BTST (ab | s16)bp | | | | | | | cmp #8,(abs16) | mov #8,(abs16) | | | CBEQ #8,(abs | s16),d7/11 | CBNE #8,(abs | 16),d7/11 | | Е | TBZ (abs | 16)bp,d7 | 7 | | | | | | TBZ (al | os16)bp,d | 111 | | _ | | | | | F | TBNZ (ab | s16)bp, | d7 | | | | | | TBNZ ( | abs16)bp | ,d11 | | | | | | | | | | | | | | | | | | | | | | | | Ver2.1(2001.03.26) # **Record of Changes** The following shows the changes in the publication of "MN101C78A/F78A LSI User's Manual" (Edition: 1.2 to 1.3) | Page | Line | Definition | Former Edition (1.2) | New Edition (1.3) | |-------|------|------------|-----------------------------|----------------------------------| | Cover | - | Add | MN101C78A LSI User's Manual | MN101C78A/F78A LSI User's Manual | ## MN101C78A/F78A LSI User's Manual March, 2004 1st Edition 3rd Printing Issued by Matsushita Electric Industrial Co., Ltd. © Matsushita Electric Industrial Co., Ltd. ## **SALES OFFICES** ### □NORTH AMERICA U.S.A. Sales Office: Panasonic Industrial Company [PIC] • New Jersey Office: 2 Panasonic Way Secaucus, New Jersey 07094, U.S.A. Tel:1-201-348-5257 Fax:1-201-392-4652 • Chicago Office: 1707 N. Randall Road Elgin, Illinois 60123-7847, U.S.A. Tel:1-847-468-5720 Fax:1-847-468-5725 • San Jose Office: 2033 Gateway Place, Suite 200, San Jose, California 95110, U.S.A Tel:1-408-487-9510 Fax:1-408-436-8037 • Atlanta Office: 1225 Northbrook Parkway Suite 1-151 Suwanee, Georgia 30024, U.S.A. Tel:1-770-338-6953 Fax:1-770-338-6849 • San Diego Office: 9444 Balboa Avenue, Suite 185, San Diego, California 92123, U.S.A. Tel:1-858-503-2910 Fax:1-858-715-5545 Canada Sales Office: Panasonic Canada Inc. ☐ [PCI] 5770 Ambler Drive 27 Mississauga, Ontario L4W 2T3, Canada Tel:1-905-238-2243 Fax:1-905-238-2414 #### **LATIN AMERICA** Mexico Sales Office: Panasonic de Mexico, S.A. de C.V.□ [PANAMEX] Amores 1120 Col. Del Valle Delegacion Benito Juarez C.P. 03100 Mexico, D.F. Mexico Tel:52-5-488-1000 Fax:52-5-488-1073 • Guadalajara Office: Sucursal Guadarajara Av. Lazaro Cardenas 2305 Local G-102 Plaza Comercial Abastos; Col. Las Torres Guadalajara, Jal. 44920, Mexico Tel:52-3-671-1205 Fax:52-3-671-1256 Brazil Sales Office: Panasonic do Brasil Ltda. [PANABRAS] Caixa Postal 1641, Sao Jose dos Campos, Estado de Sao Paulo, Brasil Tel:55-12-3935-9000 Fax:55-12-3931-3789 ### **EUROPE** • Europe Sales Office: Panasonic Industrial Europe $\mathsf{GmbH}\square$ [PIE] • Germany Sales Office: Hans-Pinsel-Strasse 2 85540 Haar, Germany Tel:49-89-46159-119 Fax:49-89-46159-195 #### **DASIA** Singapore Sales Office: Panasonic Semiconductor of South Asia [PSSA] 300 Beach Road, #16-01, the Concourse, Singapore 199555, the Republic of Singapore Tel:65-6390-3688 Fax:65-6390-3689 Malaysia Sales Office: Panasonic Industrial Company (M) Sdn. Bhd. ☐ [PICM] • Head Office: 15th Floor, Menara IGB, Mid Valley City, Lingkaran Syed Putra, 59200 Kuala Lumpur, Malaysia Tel:60-3-2297-6888 Fax:60-6-2284-6898 Penang Office: Suite 20-07,20th Floor, MWE Plaza, No.8, Lebuh Farquhar,10200 Penang, Malaysia Tel: 60-4-201-5113 Fax:60-4-261-9989 • Johore Sales Office: Menara Pelangi, Suite8.3A, Level8, No.2, Jalan Kuning, Taman Pelangi, 80400 Johor Bahru, Johor, Malaysia Tel:60-7-331-3822 Fax:60-7-355-3996 Thailand Sales Office: Panasonic Industrial (Thailand) Ltd. ☐ [PICT] 252-133 Muang Thai-Phatra Complex Building, 31st Floor Rachadaphisek Road, Huaykwang, Bangkok 10320, Thailand Tel:66-2-693-3400 to 3421 Fax:66-2-693-3422 to 3427 Philippines Sales Office: Panasonic Industrial Sales Philippines ☐ [PISP 102 Laguna Boulevard,Bo.Don Jose Laguna Technopark, Santa. Rosa, Laguna 4026, the Philippines Tel:63-2-520-8615 Fax:63-2-520-8629 China Sales Office: Panasonic Industrial (Shanghai) Co., Ltd. ☐ [PI(SH)] Floor 12, China Insurance Building, 166 East Road Lujiazui, Pudong New District, Shanghai 200120, China Tel:86-21-6841-9642 Fax:86-21-6841-9631 Panasonic Industrial (Tianjin) Co., Ltd. [PI(TJ)] Room No.1001, Tianjin International Building 75, Nanjin Road, Tianjin 300050, China Tel:86-22-2313-9771 Fax:86-22-2313-9770 Panasonic SH Industrial Sales (Shenzhen) Co., Ltd. □[PSI(SZ)] • Shum Yip Centre Office: 25F, Shum Yip Centre, #5045, East Shennan Road, Shenzhen, China Tel:86-755-8211-0888 Fax:86-755-8211-0970 Panasonic Shun Hing Industrial Sales (Hong Kong) Co., Ltd.□ [PSI(HK)] 11th Floor, Great Eagle Center 23 Harbour Road, Wanchai, Hong Kong Tel:852-2529-7322 Fax:852-2865-3697 Taiwan Sales Office: Panasonic Industrial Sales (Taiwan) Co.,Ltd. ☐ [PIST] Head Office: 6F, 550, Sec. 4, Chung Hsiao E. RD. Taipei 110, Taiwan Tel:886-2-2757-1900 Fax:886-2-2757-1906 • Kaohsiung Office: 6th Floor, Hsin Kong Bldg. No.251, Chi Hsien 1st Road, Kaohsiung 800, Taiwan Tel:886-7-346-3815 Fax:886-7-236-8362 • Korea Sales Office: Panasonic Industrial Korea Co., Ltd. ☐ [PIKL] Kukje Center Bldg. 11th Floor, 191 Hangangro 2ga, Youngsan-ku, Seoul 140-702, Korea Tel:82-2-795-9600 Fax:82-2-795-1542 ## Semiconductor Company, Matsushita Electric Industrial Co., Ltd. Nagaokakyo, Kyoto 617-8520, Japan Tel:075-951-8151 http://panasonic.co.jp/semicon/e-index.html 050204 □ Printed in Japan